jocke@1737: Original patch from Gentoo. jocke@1737: jocke@1737: -= BEGIN original header =- jocke@1737: ARMV5 can use STRD and LDRD access instructions but these accesses need to be jocke@1737: 8 byte aligned. The dynamic linker's malloc needs to match this so structures jocke@1737: become 8 byte aligned to void unaligned accesses. jocke@1737: jocke@1737: RP - 14/02/2008 jocke@1737: jocke@1737: -= END original header =- jocke@1737: jocke@1737: Modified slightly for uClibc-0.9.30.2 by Joachim Nilsson jocke@1737: jocke@1737: diff -durN uClibc-0.9.30.orig/ldso/ldso/arm/dl-sysdep.h uClibc-0.9.30/ldso/ldso/arm/dl-sysdep.h jocke@1737: --- uClibc-0.9.30.orig/ldso/ldso/arm/dl-sysdep.h 2008-09-25 10:35:20.000000000 +0200 jocke@1737: +++ uClibc-0.9.30/ldso/ldso/arm/dl-sysdep.h 2009-02-07 09:57:59.000000000 +0100 jocke@1737: @@ -15,6 +15,8 @@ jocke@1737: GOT_BASE[1] = (unsigned long) MODULE; \ jocke@1737: } jocke@1737: jocke@1737: +#define DL_MALLOC_ALIGN 8 /* EABI needs 8 byte alignment for STRD LDRD*/ jocke@1737: + jocke@1737: static __always_inline unsigned long arm_modulus(unsigned long m, unsigned long p) jocke@1737: { jocke@1737: unsigned long i,t,inc;