public inbox for glibc-cvs@sourceware.org
help / color / mirror / Atom feed
* [glibc] Fix elf: Do not duplicate the GLIBC_TUNABLES string
@ 2023-12-19 21:34 H.J. Lu
  0 siblings, 0 replies; 2+ messages in thread
From: H.J. Lu @ 2023-12-19 21:34 UTC (permalink / raw)
  To: glibc-cvs

https://sourceware.org/git/gitweb.cgi?p=glibc.git;h=cad5703e4f80841b7f7e3fe57127bd0df7ddb86e

commit cad5703e4f80841b7f7e3fe57127bd0df7ddb86e
Author: H.J. Lu <hjl.tools@gmail.com>
Date:   Tue Dec 19 13:21:06 2023 -0800

    Fix elf: Do not duplicate the GLIBC_TUNABLES string
    
    Fix issues in sysdeps/x86/tst-hwcap-tunables.c added by
    
    Author: Adhemerval Zanella <adhemerval.zanella@linaro.org>
    Date:   Wed Dec 6 10:24:01 2023 -0300
    
        elf: Do not duplicate the GLIBC_TUNABLES string
    
    1. -AVX,-AVX2,-AVX512F should be used to disable AVX, AVX2 and AVX512.
    2. AVX512 IFUNC functions check AVX512VL.  -AVX512VL should be added
    to disable these functions.
    
    This fixed:
    
    FAIL: elf/tst-hwcap-tunables
    ...
    [0] Spawned test for -Prefer_ERMS,-Prefer_FSRM,-AVX,-AVX2,-AVX_Usable,-AVX2_Usable,-AVX512F_Usable,-SSE4_1,-SSE4_2,-SSSE3,-Fast_Unaligned_Load,-ERMS,-AVX_Fast_Unaligned_Load
    error: subprocess failed: tst-tunables
    error:   unexpected output from subprocess
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    
    [1] Spawned test for ,-,-Prefer_ERMS,-Prefer_FSRM,-AVX,-AVX2,-AVX_Usable,-AVX2_Usable,-AVX512F_Usable,-SSE4_1,-SSE4_2,,-SSSE3,-Fast_Unaligned_Load,,-,-ERMS,-AVX_Fast_Unaligned_Load,-,
    error: subprocess failed: tst-tunables
    error:   unexpected output from subprocess
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    ../sysdeps/x86/tst-hwcap-tunables.c:91: numeric comparison failure
       left: 1 (0x1); from: impls[i].usable
      right: 0 (0x0); from: false
    
    error: 2 test failures
    
    on Intel Tiger Lake.

Diff:
---
 sysdeps/x86/tst-hwcap-tunables.c | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)

diff --git a/sysdeps/x86/tst-hwcap-tunables.c b/sysdeps/x86/tst-hwcap-tunables.c
index 01a9377f7e..4e36aa077d 100644
--- a/sysdeps/x86/tst-hwcap-tunables.c
+++ b/sysdeps/x86/tst-hwcap-tunables.c
@@ -58,17 +58,17 @@ static const struct test_t
 {
   {
     /* Disable everything.  */
-    "-Prefer_ERMS,-Prefer_FSRM,-AVX,-AVX2,-AVX_Usable,-AVX2_Usable,"
-    "-AVX512F_Usable,-SSE4_1,-SSE4_2,-SSSE3,-Fast_Unaligned_Load,-ERMS,"
+    "-Prefer_ERMS,-Prefer_FSRM,-AVX,-AVX2,-AVX512F,-AVX512VL,"
+    "-SSE4_1,-SSE4_2,-SSSE3,-Fast_Unaligned_Load,-ERMS,"
     "-AVX_Fast_Unaligned_Load",
     test_1,
     array_length (test_1)
   },
   {
     /* Same as before, but with some empty suboptions.  */
-    ",-,-Prefer_ERMS,-Prefer_FSRM,-AVX,-AVX2,-AVX_Usable,-AVX2_Usable,"
-    "-AVX512F_Usable,-SSE4_1,-SSE4_2,,-SSSE3,-Fast_Unaligned_Load,,-,-ERMS,"
-    "-AVX_Fast_Unaligned_Load,-,",
+    ",-,-Prefer_ERMS,-Prefer_FSRM,-AVX,-AVX2,-AVX512F,-AVX512VL,"
+    "-SSE4_1,-SSE4_2,-SSSE3,-Fast_Unaligned_Load,,-,"
+    "-ERMS,-AVX_Fast_Unaligned_Load,-,",
     test_1,
     array_length (test_1)
   }

^ permalink raw reply	[flat|nested] 2+ messages in thread

* [glibc] Fix elf: Do not duplicate the GLIBC_TUNABLES string
@ 2023-12-20  0:32 H.J. Lu
  0 siblings, 0 replies; 2+ messages in thread
From: H.J. Lu @ 2023-12-20  0:32 UTC (permalink / raw)
  To: glibc-cvs

https://sourceware.org/git/gitweb.cgi?p=glibc.git;h=50bef9bd63e7fb94f1d2cc8b7809256ffc73b2ef

commit 50bef9bd63e7fb94f1d2cc8b7809256ffc73b2ef
Author: H.J. Lu <hjl.tools@gmail.com>
Date:   Tue Dec 19 16:01:33 2023 -0800

    Fix elf: Do not duplicate the GLIBC_TUNABLES string
    
    commit 2a969b53c0b02fed7e43473a92f219d737fd217a
    Author: Adhemerval Zanella <adhemerval.zanella@linaro.org>
    Date:   Wed Dec 6 10:24:01 2023 -0300
    
        elf: Do not duplicate the GLIBC_TUNABLES string
    
    has
    
    @@ -38,7 +39,7 @@
        which isn't available.  */
     #define CHECK_GLIBC_IFUNC_PREFERRED_OFF(f, cpu_features, name, len) \
       _Static_assert (sizeof (#name) - 1 == len, #name " != " #len); \
    -  if (memcmp (f, #name, len) == 0)             \
    +  if (tunable_str_comma_strcmp_cte (&f, #name) == 0)       \
         {                           \
           cpu_features->preferred[index_arch_##name]        \
       &= ~bit_arch_##name;                \
    @@ -46,12 +47,11 @@
    
    Fix it by removing "== 0" after tunable_str_comma_strcmp_cte.

Diff:
---
 sysdeps/x86/cpu-tunables.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/sysdeps/x86/cpu-tunables.c b/sysdeps/x86/cpu-tunables.c
index ef96148d30..142c6b9240 100644
--- a/sysdeps/x86/cpu-tunables.c
+++ b/sysdeps/x86/cpu-tunables.c
@@ -39,7 +39,7 @@
    which isn't available.  */
 #define CHECK_GLIBC_IFUNC_PREFERRED_OFF(f, cpu_features, name, len)	\
   _Static_assert (sizeof (#name) - 1 == len, #name " != " #len);	\
-  if (tunable_str_comma_strcmp_cte (&f, #name) == 0)			\
+  if (tunable_str_comma_strcmp_cte (&f, #name))				\
     {									\
       cpu_features->preferred[index_arch_##name]			\
 	&= ~bit_arch_##name;						\

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2023-12-20  0:32 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-12-19 21:34 [glibc] Fix elf: Do not duplicate the GLIBC_TUNABLES string H.J. Lu
2023-12-20  0:32 H.J. Lu

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).