OSDN Git Service

macro out the /10 operation so arches can have their own versions ... and create...
authorMike Frysinger <vapier@gentoo.org>
Wed, 8 Mar 2006 03:58:13 +0000 (03:58 -0000)
committerMike Frysinger <vapier@gentoo.org>
Wed, 8 Mar 2006 03:58:13 +0000 (03:58 -0000)
ldso/include/dl-string.h
ldso/ldso/arm/dl-sysdep.h
ldso/ldso/cris/dl-sysdep.h
ldso/ldso/frv/dl-sysdep.h
ldso/ldso/i386/dl-sysdep.h
ldso/ldso/m68k/dl-sysdep.h
ldso/ldso/mips/dl-sysdep.h
ldso/ldso/powerpc/dl-sysdep.h
ldso/ldso/sh64/dl-sysdep.h
ldso/ldso/x86_64/dl-sysdep.h

index ec098d2..a50cfd6 100644 (file)
 #include <dl-sysdep.h> /* for do_rem */
 #include <features.h>
 
+/* provide some sane defaults */
+#ifndef do_rem
+# define do_rem(result, n, base) ((result) = (n) % (base))
+#endif
+#ifndef do_div_10
+# define do_div_10(result, remain) ((result) /= 10)
+#endif
+
 static size_t _dl_strlen(const char * str);
 static char *_dl_strcat(char *dst, const char *src);
 static char * _dl_strcpy(char * dst,const char *src);
@@ -234,7 +242,7 @@ static __always_inline char * _dl_simple_ltoa(char * local, unsigned long i)
                char temp;
                do_rem(temp, i, 10);
                *--p = '0' + temp;
-               i /= 10;
+               do_div_10(i, temp);
        } while (i > 0);
        return p;
 }
@@ -324,7 +332,7 @@ static __always_inline char * _dl_simple_ltoahex(char * local, unsigned long i)
        do { \
                do_rem(v, (X), 10); \
                *--tmp2 = '0' + v; \
-               (X) /= 10; \
+               do_div_10((X), v); \
        } while ((X) > 0); \
        _dl_write(2, tmp2, tmp1 - tmp2 + sizeof(tmp) - 1); \
 }
index 194fd2e..839e927 100644 (file)
@@ -43,6 +43,7 @@ static inline unsigned long arm_modulus(unsigned long m, unsigned long p)
        return m;
 }
 #define do_rem(result, n, base) ((result) = arm_modulus(n, base))
+#define do_div_10(result, remain) ((result) = (((result) - (remain)) / 2) * -(-1ul / 5ul))
 
 /* Here we define the magic numbers that this dynamic loader should accept */
 #define MAGIC1 EM_ARM
index b5fa890..b84dcad 100644 (file)
@@ -18,8 +18,6 @@
 struct elf_resolve;
 extern unsigned long _dl_linux_resolver(struct elf_resolve *tpnt, int reloc_entry);
 
-#define do_rem(result, n, base) ((result) = (n) % (base))
-
 /* 8192 bytes alignment */
 #define PAGE_ALIGN 0xffffe000
 #define ADDR_ALIGN 0x1fff
index 158f6af..131eb5f 100644 (file)
@@ -65,8 +65,6 @@ struct funcdesc_value
 
 extern int _dl_linux_resolve(void) __attribute__((__visibility__("hidden")));
 
-#define do_rem(result, n, base) ((result) = (n) % (base))
-
 /* 16KiB page alignment.  Should perhaps be made dynamic using
    getpagesize(), based on AT_PAGESZ from auxvt?  */
 #define PAGE_ALIGN 0xffffc000
index 2ef94c9..6d6039c 100644 (file)
@@ -25,8 +25,6 @@ do {                                                                                                          \
 struct elf_resolve;
 extern unsigned long _dl_linux_resolver(struct elf_resolve * tpnt, int reloc_entry);
 
-#define do_rem(result, n, base) ((result) = (n) % (base))
-
 /* 4096 bytes alignment */
 #define PAGE_ALIGN 0xfffff000
 #define ADDR_ALIGN 0xfff
index c11d2fb..4e5e090 100644 (file)
@@ -25,10 +25,6 @@ do { \
 struct elf_resolve;
 extern unsigned int _dl_linux_resolver (struct elf_resolve *, int);
 
-/* Define this because we do not want to call .udiv in the library.
-   Not needed for m68k.  */
-#define do_rem(result, n, base)  ((result) = (n) % (base))
-
 /* 4096 bytes alignment */
 #define PAGE_ALIGN 0xfffff000
 #define ADDR_ALIGN 0xfff
index 63119aa..77edcd9 100644 (file)
@@ -63,8 +63,6 @@ unsigned long __dl_runtime_resolve(unsigned long sym_index,
 struct elf_resolve;
 void _dl_perform_mips_global_got_relocations(struct elf_resolve *tpnt, int lazy);
 
-#define do_rem(result, n, base) ((result) = (n) % (base))
-
 /* 4096 bytes alignment */
 #define PAGE_ALIGN 0xfffff000
 #define ADDR_ALIGN 0xfff
index 6f7bde1..a06aa8a 100644 (file)
@@ -67,9 +67,6 @@ struct elf_resolve;
 extern unsigned long _dl_linux_resolver(struct elf_resolve * tpnt, int reloc_entry);
 void _dl_init_got(unsigned long *lpnt,struct elf_resolve *tpnt);
 
-
-#define do_rem(result, n, base) ((result) = (n) % (base))
-
 /* 4096 bytes alignment */
 #define PAGE_ALIGN 0xfffff000
 #define ADDR_ALIGN 0xfff
index 506e9ec..f16885b 100644 (file)
@@ -25,8 +25,6 @@
 struct elf_resolve;
 extern unsigned long _dl_linux_resolver(struct elf_resolve * tpnt, int reloc_entry);
 
-#define do_rem(result, n, base) ((result) = (n) % (base))
-
 /* 4096 bytes alignment */
 #define PAGE_ALIGN 0xfffff000
 #define ADDR_ALIGN 0xfff
index 9e2aff1..202eab1 100644 (file)
@@ -41,8 +41,6 @@ do {                                                                                                          \
 struct elf_resolve;
 extern unsigned long _dl_linux_resolver(struct elf_resolve * tpnt, int reloc_entry);
 
-#define do_rem(result, n, base) ((result) = (n) % (base))
-
 /* 4096 bytes alignment */
 #define PAGE_ALIGN 0xfffff000
 #define ADDR_ALIGN 0xfff