summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJason Wever <weeve@gentoo.org>2004-05-25 13:12:32 +0000
committerJason Wever <weeve@gentoo.org>2004-05-25 13:12:32 +0000
commit4847e8967ab1404ebf53e368678b8a28fad274f8 (patch)
tree88a9a8e5579c23084c5b2ae4c341b6adf8276a65 /app-office
parentMarked stable on hppa. (Manifest recommit) (diff)
downloadgentoo-2-4847e8967ab1404ebf53e368678b8a28fad274f8.tar.gz
gentoo-2-4847e8967ab1404ebf53e368678b8a28fad274f8.tar.bz2
gentoo-2-4847e8967ab1404ebf53e368678b8a28fad274f8.zip
Added patches to fix bug #46089 and added ~sparc keyword to openoffice-1.1.1-r1
Diffstat (limited to 'app-office')
-rw-r--r--app-office/openoffice/ChangeLog6
-rw-r--r--app-office/openoffice/files/1.1.1/linux-sparc.patch449
-rw-r--r--app-office/openoffice/openoffice-1.1.1-r1.ebuild9
3 files changed, 458 insertions, 6 deletions
diff --git a/app-office/openoffice/ChangeLog b/app-office/openoffice/ChangeLog
index 036fbb939824..afeffe5a603f 100644
--- a/app-office/openoffice/ChangeLog
+++ b/app-office/openoffice/ChangeLog
@@ -1,6 +1,10 @@
# ChangeLog for app-office/openoffice
# Copyright 2002-2004 Gentoo Technologies, Inc.; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/app-office/openoffice/ChangeLog,v 1.73 2004/05/12 11:17:05 pappy Exp $
+# $Header: /var/cvsroot/gentoo-x86/app-office/openoffice/ChangeLog,v 1.74 2004/05/25 13:12:32 weeve Exp $
+
+ 25 May 2004; Jason Wever <weeve@gentoo.org> +files/1.1.1/linux-sparc.patch,
+ openoffice-1.1.1-r1.ebuild:
+ Added patches to fix bug #46089 and added ~sparc keyword to openoffice-1.1.1-r1
12 May 2004; Alexander Gabert <pappy@gentoo.org> openoffice-1.0.3-r2.ebuild:
removed hardened-gcc check and CC variable modification
diff --git a/app-office/openoffice/files/1.1.1/linux-sparc.patch b/app-office/openoffice/files/1.1.1/linux-sparc.patch
new file mode 100644
index 000000000000..9325e23117b7
--- /dev/null
+++ b/app-office/openoffice/files/1.1.1/linux-sparc.patch
@@ -0,0 +1,449 @@
+Index: boost/boost_1_27_0.patch
+===================================================================
+RCS file: /cvs/external/boost/boost_1_27_0.patch,v
+retrieving revision 1.4.10.1
+diff -u -u -r1.4.10.1 boost_1_27_0.patch
+--- boost/boost_1_27_0.patch 15 Aug 2003 11:47:26 -0000 1.4.10.1
++++ boost/boost_1_27_0.patch 10 Mar 2004 05:42:33 -0000
+@@ -31,7 +31,26 @@
+ + #if defined(BOOST_OOO_NO_NEW_EXCEPTIONS) && !defined(BOOST_NO_EXCEPTIONS)
+ + #define BOOST_NO_EXCEPTIONS
+ + #endif
+-+
+++
++*** misc/boost_1_27_0/boost/detail/atomic_count.hpp Fri Feb 8 02:26:13 2002
++--- misc/build/boost_1_27_0/boost/detail/atomic_count.hpp Fri Dec 19 01:00:46 2003
++***************
++*** 93,99 ****
++
++ #include <boost/detail/atomic_count_win32.hpp>
++
++! #elif defined(linux) || defined(__linux) || defined(__linux__)
++
++ #include <boost/detail/atomic_count_linux.hpp>
++
++--- 93,99 ----
++
++ #include <boost/detail/atomic_count_win32.hpp>
++
++! #elif (defined(linux) || defined(__linux) || defined(__linux__)) && !(defined(SPARC) || defined(sparc) || defined(sparc64))
++
++ #include <boost/detail/atomic_count_linux.hpp>
++
+ *** misc/boost_1_27_0/boost/detail/atomic_count_linux.hpp Thu Feb 7 10:26:13 2002
+ --- misc/build/boost_1_27_0/boost/detail/atomic_count_linux.hpp Wed May 7 11:28:19 2003
+ ***************
+@@ -157,7 +176,7 @@
+ --- misc/build/boost_1_27_0/boost/detail/linux_atomic.h Wed May 7 11:32:48 2003
+ ***************
+ *** 0 ****
+---- 1,181 ----
++--- 1,118 ----
+ + #ifndef _LINUX_ATOMIC_H_
+ + #define _LINUX_ATOMIC_H_
+ +
+@@ -268,70 +287,7 @@
+ + __CS_LOOP(old_val, new_val, v, 1, "sr");
+ + return new_val;
+ +}
+-+#elif defined ( SPARC )
+-+
+-+
+-+#define atomic_set(v, i) (((v)->aVal) = ((i) << 8))
+-+
+-+static __inline__ int __atomic_add(int i, atomic_t *v)
+-+{
+-+ register volatile int *ptr asm("g1");
+-+ register int increment asm("g2");
+-+
+-+ ptr = &v->aVal;
+-+ increment = i;
+-+
+-+ __asm__ __volatile__(
+-+ "mov %%o7, %%g4\n\t"
+-+ "call ___atomic_add\n\t"
+-+ " add %%o7, 8, %%o7\n"
+-+ : "=&r" (increment)
+-+ : "0" (increment), "r" (ptr)
+-+ : "g3", "g4", "g7", "memory", "cc");
+-+
+-+ return increment;
+-+}
+ +
+-+static __inline__ int __atomic_sub(int i, atomic_t *v)
+-+{
+-+ register volatile int *ptr asm("g1");
+-+ register int increment asm("g2");
+-+
+-+ ptr = &v->aVal;
+-+ increment = i;
+-+
+-+ __asm__ __volatile__(
+-+ "mov %%o7, %%g4\n\t"
+-+ "call ___atomic_sub\n\t"
+-+ " add %%o7, 8, %%o7\n"
+-+ : "=&r" (increment)
+-+ : "0" (increment), "r" (ptr)
+-+ : "g3", "g4", "g7", "memory", "cc");
+-+
+-+ return increment;
+-+}
+-+
+-+#define atomic_add(i, v) ((void)__atomic_add((i), (v)))
+-+#define atomic_sub(i, v) ((void)__atomic_sub((i), (v)))
+-+
+-+#define atomic_dec_return(v) __atomic_sub(1, (v))
+-+#define atomic_inc_return(v) __atomic_add(1, (v))
+-+
+-+#define atomic_sub_and_test(i, v) (__atomic_sub((i), (v)) == 0)
+-+#define atomic_dec_and_test(v) (__atomic_sub(1, (v)) == 0)
+-+
+-+#define atomic_inc(v) ((void)__atomic_add(1, (v)))
+-+#define atomic_dec(v) ((void)__atomic_sub(1, (v)))
+-+
+-+#define atomic_add_negative(i, v) (__atomic_add((i), (v)) < 0)
+-+
+-+/* Atomic operations are already serializing */
+-+#define smp_mb__before_atomic_dec() barrier()
+-+#define smp_mb__after_atomic_dec() barrier()
+-+#define smp_mb__before_atomic_inc() barrier()
+-+#define smp_mb__after_atomic_inc() barrier()
+-+
+-+#endif
+ + #else
+ +
+ + #error - need to define your processors atomic inc and dec here
+Index: boost/makefile.mk
+===================================================================
+RCS file: /cvs/external/boost/makefile.mk,v
+retrieving revision 1.4
+diff -u -u -r1.4 makefile.mk
+--- boost/makefile.mk 2 Jul 2003 15:23:23 -0000 1.4
++++ boost/makefile.mk 10 Mar 2004 05:42:33 -0000
+@@ -76,7 +76,7 @@
+
+ PATCH_FILE_NAME=boost_1_27_0.patch
+
+-#ADDITIONAL_FILES=
++ADDITIONAL_FILES=boost$/detail$/linux_atomic.h
+
+ CONFIGURE_DIR=
+ CONFIGURE_ACTION=
+Index: bridges/source/cpp_uno/gcc3_linux_sparc/cpp2uno.cxx
+===================================================================
+RCS file: /cvs/udk/bridges/source/cpp_uno/gcc3_linux_sparc/cpp2uno.cxx,v
+retrieving revision 1.2
+diff -u -u -r1.2 cpp2uno.cxx
+--- bridges/source/cpp_uno/gcc3_linux_sparc/cpp2uno.cxx 28 Apr 2003 16:28:42 -0000 1.2
++++ bridges/source/cpp_uno/gcc3_linux_sparc/cpp2uno.cxx 10 Mar 2004 05:42:33 -0000
+@@ -163,8 +163,21 @@
+ {
+ case typelib_TypeClass_HYPER:
+ case typelib_TypeClass_UNSIGNED_HYPER:
+- case typelib_TypeClass_DOUBLE:
+- pCppStack += sizeof(sal_Int32); // extra long
++ case typelib_TypeClass_DOUBLE:
++ {
++ if ((reinterpret_cast< long >(pCppStack) & 7) != 0)
++ {
++ OSL_ASSERT( sizeof (double) == sizeof (sal_Int64) );
++ void * pDest = alloca( sizeof (sal_Int64) );
++ *reinterpret_cast< sal_Int32 * >(pDest) =
++ *reinterpret_cast< sal_Int32 const * >(pCppStack);
++ *(reinterpret_cast< sal_Int32 * >(pDest) + 1) =
++ *(reinterpret_cast< sal_Int32 const * >(pCppStack) + 1);
++ pCppArgs[nPos] = pUnoArgs[nPos] = pDest;
++ }
++ pCppStack += sizeof (sal_Int32); // extra long
++ break;
++ }
+ }
+ // no longer needed
+ TYPELIB_DANGER_RELEASE( pParamTypeDescr );
+@@ -488,7 +501,7 @@
+ sal_Bool bComplex = nTableEntry & 0x80000000 ? sal_True : sal_False;
+
+ typelib_TypeClass aType =
+- cpp_mediate( nTableEntry, pCallStack+17, &nRegReturn );
++ cpp_mediate( nTableEntry, pCallStack+17, (sal_Int64*)&nRegReturn );
+
+ switch( aType )
+ {
+Index: bridges/source/cpp_uno/gcc3_linux_sparc/uno2cpp.cxx
+===================================================================
+RCS file: /cvs/udk/bridges/source/cpp_uno/gcc3_linux_sparc/uno2cpp.cxx,v
+retrieving revision 1.2.34.1
+diff -u -u -r1.2.34.1 uno2cpp.cxx
+--- bridges/source/cpp_uno/gcc3_linux_sparc/uno2cpp.cxx 15 Aug 2003 11:59:42 -0000 1.2.34.1
++++ bridges/source/cpp_uno/gcc3_linux_sparc/uno2cpp.cxx 10 Mar 2004 05:42:39 -0000
+@@ -359,16 +359,24 @@
+ if (!rParam.bOut && cppu_isSimpleType( pParamTypeDescr ))
+ {
+ pCppArgs[ nPos ] = adjustPointer( pCppStack, pParamTypeDescr );
+- uno_copyAndConvertData( pCppArgs[nPos], pUnoArgs[nPos], pParamTypeDescr,
+- &pThis->pBridge->aUno2Cpp );
+-
+ switch (pParamTypeDescr->eTypeClass)
+ {
+ case typelib_TypeClass_HYPER:
+ case typelib_TypeClass_UNSIGNED_HYPER:
+ case typelib_TypeClass_DOUBLE:
+- pCppStack += sizeof(sal_Int32); // extra long
+- }
++ OSL_ASSERT( sizeof (double) == sizeof (sal_Int64) );
++ *reinterpret_cast< sal_Int32 * >(pCppStack) =
++ *reinterpret_cast< sal_Int32 const * >(pUnoArgs[ nPos ]);
++ pCppStack += sizeof (sal_Int32);
++ *reinterpret_cast< sal_Int32 * >(pCppStack) =
++ *(reinterpret_cast< sal_Int32 const * >(pUnoArgs[ nPos ] ) + 1);
++ break;
++ default:
++ uno_copyAndConvertData(
++ pCppArgs[nPos], pUnoArgs[nPos], pParamTypeDescr,
++ &pThis->pBridge->aUno2Cpp );
++ break;
++ }
+ // no longer needed
+ TYPELIB_DANGER_RELEASE( pParamTypeDescr );
+ }
+@@ -407,11 +415,15 @@
+
+ try
+ {
++ int nStackLongs = (pCppStack - pCppStackStart)/sizeof(sal_Int32);
+ OSL_ENSURE( !( (pCppStack - pCppStackStart ) & 3), "UNALIGNED STACK !!! (Please DO panic" );
+ callVirtualMethod(
+- pThis->pCppI, nVtableCall,
+- pCppReturn, pReturnTypeDescr->eTypeClass,
+- (sal_Int32 *)pCppStackStart, (pCppStack - pCppStackStart) / sizeof(sal_Int32) );
++ pThis->pCppI,
++ nVtableCall,
++ pCppReturn,
++ pReturnTypeDescr->eTypeClass,
++ (sal_Int32 *)pCppStackStart,
++ nStackLongs);
+ // NO exception occured...
+ *ppUnoExc = 0;
+
+Index: cppu/source/uno/copy.hxx
+===================================================================
+RCS file: /cvs/udk/cppu/source/uno/copy.hxx,v
+retrieving revision 1.10
+diff -u -u -r1.10 copy.hxx
+--- cppu/source/uno/copy.hxx 20 Mar 2003 12:28:50 -0000 1.10
++++ cppu/source/uno/copy.hxx 10 Mar 2004 05:42:40 -0000
+@@ -752,12 +752,7 @@
+ break;
+ case typelib_TypeClass_HYPER:
+ case typelib_TypeClass_UNSIGNED_HYPER:
+-#if defined(GCC) && defined(SPARC)
+- *(sal_Int32 *)pDest = *(sal_Int32 *)pSource;
+- *(((sal_Int32 *)pDest) +1) = *(((sal_Int32 *)pSource) +1);
+-#else
+ *(sal_Int64 *)pDest = *(sal_Int64 *)pSource;
+-#endif
+ break;
+ case typelib_TypeClass_FLOAT:
+ *(float *)pDest = *(float *)pSource;
+Index: scp/source/office/files.scp
+===================================================================
+RCS file: /cvs/installation/scp/source/office/Attic/files.scp,v
+retrieving revision 1.369.16.9
+diff -u -u -r1.369.16.9 files.scp
+--- scp/source/office/files.scp 10 Feb 2004 20:05:45 -0000 1.369.16.9
++++ scp/source/office/files.scp 10 Mar 2004 05:44:58 -0000
+@@ -3301,6 +3301,26 @@
+
+ #endif
+
++
++#if defined (FAT_PRODUCT) && defined(LINUX) && defined(SPARC)
++
++Custom GID_CUSTOM_JVM
++ FileName = LIBNAME(jvm);
++ Styles = (EXEC_INST_BEFORE,STANDALONE,WORKSTATION,NETWORK,REPAIRABLE);
++ Code = {
++ [Install]
++ InstallationPath=.
++ RequiredVersion=1.4.1_01
++ ExcludeVersion=
++ AdditionalClasspath=<OFFICE_CLASSDIR>/classes.jar:<OFFICE_CLASSDIR>/sandbox.jar:<OFFICE_CLASSDIR>/ridl.jar:<OFFICE_CLASSDIR>/unoil.jar:<OFFICE_CLASSDIR>/jurt.jar:<OFFICE_CLASSDIR>/juh.jar:<OFFICE_CLASSDIR>/java_uno.jar:<OFFICE_CLASSDIR>/xt.jar:<OFFICE_CLASSDIR>/jaxp.jar:<OFFICE_CLASSDIR>/java_uno_accessbridge.jar:<OFFICE_CLASSDIR>/aportisdoc.jar:<OFFICE_CLASSDIR>/htmlsoff.jar:<OFFICE_CLASSDIR>/jmc.jar:<OFFICE_CLASSDIR>/minicalc.jar:<OFFICE_CLASSDIR>/pexcel.jar:<OFFICE_CLASSDIR>/pocketword.jar:<OFFICE_CLASSDIR>/XFlatXml.jar:<OFFICE_CLASSDIR>/xmerge.jar:<OFFICE_CLASSDIR>/XMergeBridge.jar:
++ AdditionalJars=javaplugin.jar;plugin.jar
++ CPLD=0
++ };
++End
++
++#endif
++
++
+ #endif
+ // of #ifdef SOLAR_JAVA
+
+? a.out
+? solar.c.stripped
+? test.c
+? x
+Index: solar.c
+===================================================================
+RCS file: /cvs/util/tools/source/solar/solar.c,v
+retrieving revision 1.2
+diff -u -r1.2 solar.c
+--- solar.c 15 Apr 2003 17:55:43 -0000 1.2
++++ tools/source/solar/solar.c 22 Oct 2003 13:08:21 -0000
+@@ -58,17 +58,22 @@
+ *
+ *
+ ************************************************************************/
+-#include <stdio.h>
+
+-#ifdef UNX
++/* POSIX defines that a program is undefined after a SIG_SEGV. The
++ * code stopped working on Linux Kernel 2.6 so I have moved this back to
++ * use FORK.
++ * If at a later time the signals work correctly with the Linux Kernel 2.6
++ * then this change may be reverted although not strictly posix safe. */
++#define USE_FORK_TO_CHECK 1
++
++#include <stdio.h>
++#include <stdlib.h>
++#include <errno.h>
++#include <string.h>
+
+ #include <unistd.h>
+ #include <sys/types.h>
+
+-#ifdef HPUX
+-#include <stdlib.h>
+-#endif
+-
+ #define I_STDARG
+ #ifdef I_STDARG
+ #include <stdarg.h>
+@@ -84,9 +89,6 @@
+ #include <setjmp.h>
+ #endif
+
+-#else
+-#endif
+-
+ #define printTypeSize(Type,Name) printf( "sizeof(%s)\t= %d\n", Name, sizeof (Type) )
+
+ #define isSignedType(Type) (((Type)-1) < 0)
+@@ -133,7 +135,7 @@
+
+ /*************************************************************************
+ |*
+-|* IsStackGrowingDown()
++|* GetStackAlignment()
+ |*
+ |* Beschreibung Alignment von char Parametern, die (hoffentlich)
+ |* ueber den Stack uebergeben werden
+@@ -176,8 +178,6 @@
+ typedef int (*TestFunc)( Type, void* );
+
+
+-#ifdef UNX
+-
+ /*************************************************************************
+ |*
+ |* PrintArgs()
+@@ -230,11 +230,11 @@
+ void SignalHdl( int sig )
+ {
+ bSignal = 1;
+- /*
++
+ fprintf( stderr, "Signal %d caught\n", sig );
+- signal( sig, SignalHdl );
+- /**/
+- longjmp( check_env, sig );
++ signal( SIGSEGV, SIG_DFL );
++ signal( SIGBUS, SIG_DFL );
++ siglongjmp( check_env, sig );
+ }
+ #endif
+
+@@ -270,7 +270,7 @@
+
+ bSignal = 0;
+
+- if ( !setjmp( check_env ) )
++ if ( !sigsetjmp( check_env, 0 ) )
+ {
+ signal( SIGSEGV, SignalHdl );
+ signal( SIGBUS, SignalHdl );
+@@ -286,9 +286,6 @@
+ #endif
+ }
+
+-#endif
+-
+-
+ /*************************************************************************
+ |*
+ |* GetAtAddress()
+@@ -373,6 +370,7 @@
+ int CheckSetAccess( Type eT, void* p )
+ {
+ int b;
++
+ b = -1 != check( (TestFunc)SetAtAddress, eT, p );
+ #if OSL_DEBUG_LEVEL > 1
+ fprintf( stderr,
+@@ -437,7 +435,7 @@
+ |* Letzte Aenderung
+ |*
+ *************************************************************************/
+-Description_Ctor( struct Description* pThis )
++void Description_Ctor( struct Description* pThis )
+ {
+ pThis->bBigEndian = IsBigEndian();
+ pThis->bStackGrowsDown = IsStackGrowingDown();
+@@ -468,16 +466,21 @@
+ |* Letzte Aenderung
+ |*
+ *************************************************************************/
+-Description_Print( struct Description* pThis, char* name )
++void Description_Print( struct Description* pThis, char* name )
+ {
+ int i;
+ FILE* f = fopen( name, "w" );
++ if( ! f ) {
++ fprintf( stderr, "Unable to open file %s: %s\n", name, strerror( errno ) );
++ exit( 99 );
++ }
+ fprintf( f, "#define __%s\n",
+ pThis->bBigEndian ? "BIGENDIAN" : "LITTLEENDIAN" );
+ for ( i = 0; i < 3; i++ )
+ fprintf( f, "#define __ALIGNMENT%d\t%d\n",
+- 1 << i+1, pThis->nAlignment[i] );
+- fprintf( f, "#define __STACKALIGNMENT wird nicht benutzt\t%d\n", pThis->nStackAlignment );
++ 1 << (i+1), pThis->nAlignment[i] );
++ fprintf( f, "/* Stack alignment is not used... */\n" );
++ fprintf( f, "#define __STACKALIGNMENT\t%d\n", pThis->nStackAlignment );
+ fprintf( f, "#define __STACKDIRECTION\t%d\n",
+ pThis->bStackGrowsDown ? -1 : 1 );
+ fprintf( f, "#define __SIZEOFCHAR\t%d\n", sizeof( char ) );
+@@ -538,8 +541,12 @@
+ printf( ( CheckGetAccess( eT, (long*)&a[i] ) ? "OK\n" : "ERROR\n" ) );
+ }
+ }
+-
+-main( int argc, char* argv[] )
++/************************************************************************
++ *
++ * Use C code to determine the characteristics of the building platform.
++ *
++ ************************************************************************/
++int main( int argc, char* argv[] )
+ {
+ printTypeSign( char, "char" );
+ printTypeSign( short, "short" );
+@@ -574,7 +581,6 @@
+ Description_Ctor( &description );
+ Description_Print( &description, argv[1] );
+ }
+-
+ {
+ char* p = NULL;
+ InfoMemoryAccess( p );
diff --git a/app-office/openoffice/openoffice-1.1.1-r1.ebuild b/app-office/openoffice/openoffice-1.1.1-r1.ebuild
index d3af721ea529..fb17ea5f424d 100644
--- a/app-office/openoffice/openoffice-1.1.1-r1.ebuild
+++ b/app-office/openoffice/openoffice-1.1.1-r1.ebuild
@@ -1,6 +1,6 @@
# Copyright 1999-2004 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/app-office/openoffice/openoffice-1.1.1-r1.ebuild,v 1.4 2004/05/07 14:40:14 suka Exp $
+# $Header: /var/cvsroot/gentoo-x86/app-office/openoffice/openoffice-1.1.1-r1.ebuild,v 1.5 2004/05/25 13:12:32 weeve Exp $
# IMPORTANT: This is extremely alpha!!!
@@ -47,7 +47,7 @@ HOMEPAGE="http://www.openoffice.org/"
LICENSE="LGPL-2 | SISSL-1.1"
SLOT="0"
-KEYWORDS="x86"
+KEYWORDS="x86 ~sparc"
IUSE="gnome kde"
RDEPEND=">=sys-libs/glibc-2.1
@@ -259,9 +259,8 @@ src_unpack() {
#Work around recent portage sandbox troubles
epatch ${FILESDIR}/${PV}/build.patch
-# if [ ${ARCH} = "sparc" ]; then
-# epatch ${FILESDIR}/${PV}/openoffice-1.1.0-sparc64-fix.patch
-# fi
+ # Linux/SPARC fixes
+ [ `use sparc` ] && epatch ${FILESDIR}/${PV}/linux-sparc.patch
#Security fix
epatch ${FILESDIR}/${PV}/neon.patch