]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
powerpc: refactor strchr, strchrnul, and strrchr IFUNC.
authorWainer dos Santos Moschetta <wainersm@linux.vnet.ibm.com>
Tue, 11 Apr 2017 17:18:35 +0000 (14:18 -0300)
committerTulio Magno Quites Machado Filho <tuliom@linux.vnet.ibm.com>
Tue, 11 Apr 2017 20:13:54 +0000 (17:13 -0300)
Clean up the IFUNC implementations for powerpc in order to remove
unneeded macro definitions.

Tested on ppc64le with and without --disable-multi-arch flag.

* sysdeps/powerpc/powerpc64/multiarch/strchr-power7.S: Define the
implementation-specific function name and remove unneeded macros
definition.
* sysdeps/powerpc/powerpc64/multiarch/strchr-power8.S: Likewise.
* sysdeps/powerpc/powerpc64/multiarch/strchr-ppc64.S: Likewise.
* sysdeps/powerpc/powerpc64/multiarch/strchrnul-power7.S: Likewise.
* sysdeps/powerpc/powerpc64/multiarch/strchrnul-power8.S: Likewise.
* sysdeps/powerpc/powerpc64/multiarch/strrchr-power7.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strchr.S: Set a default
function name if not defined and pass as parameter to macros
accordingly.
* sysdeps/powerpc/powerpc64/power7/strchrnul.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strrchr.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strchr.S: Likewise.
* sysdeps/powerpc/powerpc64/strchr.S: Likewise.

12 files changed:
ChangeLog
sysdeps/powerpc/powerpc64/multiarch/strchr-power7.S
sysdeps/powerpc/powerpc64/multiarch/strchr-power8.S
sysdeps/powerpc/powerpc64/multiarch/strchr-ppc64.S
sysdeps/powerpc/powerpc64/multiarch/strchrnul-power7.S
sysdeps/powerpc/powerpc64/multiarch/strchrnul-power8.S
sysdeps/powerpc/powerpc64/multiarch/strrchr-power7.S
sysdeps/powerpc/powerpc64/power7/strchr.S
sysdeps/powerpc/powerpc64/power7/strchrnul.S
sysdeps/powerpc/powerpc64/power7/strrchr.S
sysdeps/powerpc/powerpc64/power8/strchr.S
sysdeps/powerpc/powerpc64/strchr.S

index 004d6a80657903f4305a9243b5079242de5fef2d..a02f848c5aff65045cd4ed066f382aa7f562183f 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,21 @@
 2017-04-11  Wainer dos Santos Moschetta  <wainersm@linux.vnet.ibm.com>
 
+       * sysdeps/powerpc/powerpc64/multiarch/strchr-power7.S: Define the
+       implementation-specific function name and remove unneeded macros
+       definition.
+       * sysdeps/powerpc/powerpc64/multiarch/strchr-power8.S: Likewise.
+       * sysdeps/powerpc/powerpc64/multiarch/strchr-ppc64.S: Likewise.
+       * sysdeps/powerpc/powerpc64/multiarch/strchrnul-power7.S: Likewise.
+       * sysdeps/powerpc/powerpc64/multiarch/strchrnul-power8.S: Likewise.
+       * sysdeps/powerpc/powerpc64/multiarch/strrchr-power7.S: Likewise.
+       * sysdeps/powerpc/powerpc64/power7/strchr.S: Set a default
+       function name if not defined and pass as parameter to macros
+       accordingly.
+       * sysdeps/powerpc/powerpc64/power7/strchrnul.S: Likewise.
+       * sysdeps/powerpc/powerpc64/power7/strrchr.S: Likewise.
+       * sysdeps/powerpc/powerpc64/power8/strchr.S: Likewise.
+       * sysdeps/powerpc/powerpc64/strchr.S: Likewise.
+
        * sysdeps/powerpc/powerpc64/multiarch/strlen-power7.S: Define
        the strlen implementation name and remove unneeded macros definition.
        * sysdeps/powerpc/powerpc64/multiarch/strlen-power8.S: Likewise.
index c0228dc650a8fb591bdacc55046428b81d5da9ae..e64c0b7c820c7fa4c097395982b9982e694a6a46 100644 (file)
 
 #include <sysdep.h>
 
-#undef ENTRY
-#define ENTRY(name)                                            \
-  .section ".text";                                            \
-  ENTRY_2(__strchr_power7)                                     \
-  .align ALIGNARG(2);                                          \
-  BODY_LABEL(__strchr_power7):                                 \
-  cfi_startproc;                                               \
-  LOCALENTRY(__strchr_power7)
-
-#undef END
-#define END(name)                                              \
-  cfi_endproc;                                                 \
-  TRACEBACK(__strchr_power7)                                   \
-  END_2(__strchr_power7)
+#define STRCHR __strchr_power7
 
 #undef libc_hidden_builtin_def
 #define libc_hidden_builtin_def(name)
index 461b8a9e13fd975427b346ee2edf2943f48e82fc..bbda7b0505e465fa76ad94b398be79e77cd440b1 100644 (file)
 
 #include <sysdep.h>
 
-#undef ENTRY
-#define ENTRY(name)                                            \
-  .section ".text";                                            \
-  ENTRY_2(__strchr_power8)                                     \
-  .align ALIGNARG(2);                                          \
-  BODY_LABEL(__strchr_power8):                                 \
-  cfi_startproc;                                               \
-  LOCALENTRY(__strchr_power8)
-
-#undef END
-#define END(name)                                              \
-  cfi_endproc;                                                 \
-  TRACEBACK(__strchr_power8)                                   \
-  END_2(__strchr_power8)
+#define STRCHR __strchr_power8
 
 #undef libc_hidden_builtin_def
 #define libc_hidden_builtin_def(name)
index 9354239294757faddfb95148ac1c06f2e05cb59e..769f9f07d402029845b60bcd8bae389b2d2645f9 100644 (file)
 #include <sysdep.h>
 
 #ifdef SHARED
-# undef ENTRY
-# define ENTRY(name)                                           \
-  .section ".text";                                            \
-  ENTRY_2(__strchr_ppc)                                                \
-  .align ALIGNARG(2);                                          \
-  BODY_LABEL(__strchr_ppc):                                    \
-  cfi_startproc;                                               \
-  LOCALENTRY(__strchr_ppc)
-
-# undef END
-# define END(name)                                             \
-  cfi_endproc;                                                 \
-  TRACEBACK(__strchr_ppc)                                      \
-  END_2(__strchr_ppc)
+# define STRCHR __strchr_ppc
 
 # undef libc_hidden_builtin_def
 # define libc_hidden_builtin_def(name)                         \
index 57186f24e526fac184be3560bc633b24e6bc6a73..c8e28721fd179298d8dc8bfe562a5cd5847c0627 100644 (file)
 
 #include <sysdep.h>
 
-#undef ENTRY
-#define ENTRY(name)                                            \
-  .section ".text";                                            \
-  ENTRY_2(__strchrnul_power7)                                  \
-  .align ALIGNARG(2);                                          \
-  BODY_LABEL(__strchrnul_power7):                              \
-  cfi_startproc;                                               \
-  LOCALENTRY(__strchrnul_power7)
-
-#undef END
-#define END(name)                                              \
-  cfi_endproc;                                                 \
-  TRACEBACK(__strchrnul_power7)                                        \
-  END_2(__strchrnul_power7)
+#define STRCHRNUL __strchrnul_power7
 
 #undef libc_hidden_builtin_def
 #define libc_hidden_builtin_def(name)
index 5a701c7d885cb38f4bac60d36129034c9e4202ea..1cd39fc1b339587e06fc0a3095dbe993c3ba3d45 100644 (file)
 
 #include <sysdep.h>
 
-#undef ENTRY
-#define ENTRY(name)                                            \
-  .section ".text";                                            \
-  ENTRY_2(__strchrnul_power8)                                  \
-  .align ALIGNARG(2);                                          \
-  BODY_LABEL(__strchrnul_power8):                              \
-  cfi_startproc;                                               \
-  LOCALENTRY(__strchrnul_power8)
-
-#undef END
-#define END(name)                                              \
-  cfi_endproc;                                                 \
-  TRACEBACK(__strchrnul_power8)                                        \
-  END_2(__strchrnul_power8)
+#define STRCHRNUL __strchrnul_power8
 
 #undef libc_hidden_builtin_def
 #define libc_hidden_builtin_def(name)
index 841b933288991ee2e65661a231121a836e039484..10bab2ec54dc338d15a15d75f88c646b4b045688 100644 (file)
 
 #include <sysdep.h>
 
-#undef ENTRY
-#define ENTRY(name)                                            \
-  .section ".text";                                            \
-  ENTRY_2(__strrchr_power7)                                    \
-  .align ALIGNARG(2);                                          \
-  BODY_LABEL(__strrchr_power7):                                        \
-  cfi_startproc;                                               \
-  LOCALENTRY(__strrchr_power7)
-
-#undef END
-#define END(name)                                              \
-  cfi_endproc;                                                 \
-  TRACEBACK(__strrchr_power7)                                  \
-  END_2(__strrchr_power7)
+#define STRRCHR __strrchr_power7
 
 #undef libc_hidden_builtin_def
 #define libc_hidden_builtin_def(name)
index 9a210c9d4c50c839887223397231cae15f733b5f..a18e2e101c8b6a0a9ed4ad5ebdea3274c112f942 100644 (file)
 
 #include <sysdep.h>
 
+#ifndef STRCHR
+# define STRCHR strchr
+#endif
+
 /* int [r3] strchr (char *s [r3], int c [r4])  */
        .machine  power7
-ENTRY (strchr)
+ENTRY (STRCHR)
        CALL_MCOUNT 2
        dcbt    0,r3
        clrrdi  r8,r3,3       /* Align the address to doubleword boundary.  */
@@ -221,6 +225,6 @@ L(done_null):
        srdi    r0,r0,3       /* Convert leading zeros to bytes.  */
        add     r3,r8,r0      /* Return address of the matching null byte.  */
        blr
-END (strchr)
+END (STRCHR)
 weak_alias (strchr, index)
 libc_hidden_builtin_def (strchr)
index 99aa1576ffe6bf5f7cd48ad06cb1107133684c18..27bc1f0682a09f016457b9f2cf24290ee1fb0f56 100644 (file)
 
 #include <sysdep.h>
 
+#ifndef STRCHRNUL
+# define STRCHRNUL __strchrnul
+#endif
 /* int [r3] strchrnul (char *s [r3], int c [r4])  */
        .machine  power7
-ENTRY (__strchrnul)
+ENTRY (STRCHRNUL)
        CALL_MCOUNT 2
        dcbt    0,r3
        clrrdi  r8,r3,3       /* Align the address to doubleword boundary.  */
@@ -123,6 +126,6 @@ L(done):
        srdi    r0,r0,3       /* Convert leading zeros to bytes.  */
        add     r3,r8,r0      /* Return address of matching c/null byte.  */
        blr
-END (__strchrnul)
-weak_alias (__strchrnul,strchrnul)
-libc_hidden_builtin_def (__strchrnul)
+END (STRCHRNUL)
+weak_alias (STRCHRNUL, strchrnul)
+libc_hidden_builtin_def (STRCHRNUL)
index ee201223a6b5170c2268efbf85edc7ead11a0b31..c22393deb5f9ddb61b24b038a2ed2b005aa7caf7 100644 (file)
 #include <sysdep.h>
 
 /* int [r3] strrchr (char *s [r3], int c [r4])  */
+
+#ifndef STRRCHR
+# define STRRCHR strrchr
+#endif
+
        .machine  power7
-ENTRY (strrchr)
+ENTRY (STRRCHR)
        CALL_MCOUNT 2
        dcbt    0,r3
        clrrdi  r8,r3,3       /* Align the address to doubleword boundary.  */
@@ -250,6 +255,6 @@ L(done_null):
        srdi    r0,r0,3       /* Convert trailing zeros to bytes.  */
        add     r3,r8,r0      /* Return address of the matching null byte.  */
        blr
-END (strrchr)
+END (STRRCHR)
 weak_alias (strrchr, rindex)
 libc_hidden_builtin_def (strrchr)
index 5d6fa5d46e95d3f963d799e0a9edc70b33ebbaf3..e0c185c1624225cd7b972f31c30bcebe1b150910 100644 (file)
 #include <sysdep.h>
 
 #ifdef USE_AS_STRCHRNUL
-# define FUNC_NAME __strchrnul
+# ifndef STRCHRNUL
+#   define FUNC_NAME __strchrnul
+# else
+#   define FUNC_NAME STRCHRNUL
+# endif
 #else
-# define FUNC_NAME strchr
-#endif
+# ifndef STRCHR
+#  define FUNC_NAME strchr
+# else
+#  define FUNC_NAME STRCHR
+# endif
+#endif  /* !USE_AS_STRCHRNUL  */
+
 /* int [r3] strchr (char *s [r3], int c [r4])  */
 /* TODO: change these to the actual instructions when the minimum required
    binutils allows it.  */
index dc5ddb103c21318632d0b06ee92e61f743351cc1..cbfcc14cfecff5ab058955fbf1cac5e9def58df3 100644 (file)
 
 /* char * [r3] strchr (const char *s [r3] , int c [r4] )  */
 
-ENTRY (strchr)
+#ifndef STRCHR
+# define STRCHR strchr
+#endif
+
+ENTRY (STRCHR)
        CALL_MCOUNT 2
 
 #define rTMP1  r0
@@ -145,7 +149,7 @@ L(foundit):
 #endif
        add     rRTN, rSTR, rCLZB
        blr
-END (strchr)
+END (STRCHR)
 
 weak_alias (strchr, index)
 libc_hidden_builtin_def (strchr)