]> sourceware.org Git - glibc.git/commitdiff
Fix fnmatch towlower namespace (bug 18469).
authorJoseph Myers <joseph@codesourcery.com>
Tue, 2 Jun 2015 20:23:09 +0000 (20:23 +0000)
committerJoseph Myers <joseph@codesourcery.com>
Tue, 2 Jun 2015 20:23:09 +0000 (20:23 +0000)
fnmatch brings in references to towlower (and thereby towupper), which
isn't in all the standards that contain fnmatch, resulting in
linknamespace test failures.  (This is contrary to glibc conventions,
rather than a standards conformance issue, because of the to*
reservation.)  This patch fixes this in the usual way, making those
functions into weak aliases.

Tested for x86_64 and x86 (testsuite, and that disassembly of
installed shared libraries is unchanged by the patch).  This is on top
of <https://sourceware.org/ml/libc-alpha/2015-06/msg00019.html>, but
the two patches should be independent.

(The __attribute_pure__ on the declarations in include/wctype.h comes
from GCC's built-in attributes for towlower and towupper, and is
needed to get the same code generation for fnmatch before and after
the patch.  It seems likely there are cases where the declaration of
__foo in the internal headers is missing attributes from foo in the
public headers, built-in to GCC or both, but I don't know a good way
to detect such missing attributes.)

[BZ #18469]
* wctype/wcfuncs.c (towlower): Rename to __towlower and define as
weak alias of __towlower.  Use libc_hidden_weak.
(towupper): Rename to __towupper and define as weak alias of
__towupper.  Use libc_hidden_weak.
* include/wctype.h (__towlower): Declare.  Use libc_hidden_proto.
(__towupper): Likewise.
* posix/fnmatch.c [HANDLE_MULTIBYTE && _LIBC] (FOLD): Use
__towlower instead of towlower.

ChangeLog
NEWS
include/wctype.h
posix/fnmatch.c
wctype/wcfuncs.c

index 33636ba1fdb57709ff3a31087f0701b85bd764a9..9182ed9adae5a0f8667e051848bb1d9d891e9c08 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,15 @@
+2015-06-02  Joseph Myers  <joseph@codesourcery.com>
+
+       [BZ #18469]
+       * wctype/wcfuncs.c (towlower): Rename to __towlower and define as
+       weak alias of __towlower.  Use libc_hidden_weak.
+       (towupper): Rename to __towupper and define as weak alias of
+       __towupper.  Use libc_hidden_weak.
+       * include/wctype.h (__towlower): Declare.  Use libc_hidden_proto.
+       (__towupper): Likewise.
+       * posix/fnmatch.c [HANDLE_MULTIBYTE && _LIBC] (FOLD): Use
+       __towlower instead of towlower.
+
 2015-06-02  Roland McGrath  <roland@hack.frob.com>
 
        * stdlib/setenv.c [__GNUC__,__GNUC_MINOR__ < 4,7]: Use
diff --git a/NEWS b/NEWS
index e1a1a244c43314ea0d2bd717e4950504e6980eda..ed02de066a581e7366b7a932148291f3b9348979 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -19,7 +19,7 @@ Version 2.22
   18047, 18049, 18068, 18080, 18093, 18100, 18104, 18110, 18111, 18116,
   18125, 18128, 18138, 18185, 18196, 18197, 18206, 18210, 18211, 18217,
   18220, 18221, 18234, 18244, 18247, 18287, 18319, 18333, 18346, 18397,
-  18409, 18410, 18412, 18418, 18422, 18434, 18444.
+  18409, 18410, 18412, 18418, 18422, 18434, 18444, 18469.
 
 * Cache information can be queried via sysconf() function on s390 e.g. with
   _SC_LEVEL1_ICACHE_SIZE as argument.
index b29e82484bffbbcc7420140d87864d5aaa072cc2..88c78e62a02db4ef015443aaf84b8b58e1f71db6 100644 (file)
@@ -60,6 +60,8 @@ extern __typeof (iswupper_l) __iswupper_l;
 extern __typeof (iswxdigit_l) __iswxdigit_l;
 extern __typeof (towlower_l) __towlower_l;
 extern __typeof (towupper_l) __towupper_l;
+extern __typeof (towlower) __towlower __THROW __attribute_pure__;
+extern __typeof (towupper) __towupper __THROW __attribute_pure__;
 
 libc_hidden_proto (__towctrans)
 libc_hidden_proto (__iswctype)
@@ -77,6 +79,8 @@ libc_hidden_proto (__iswupper_l)
 libc_hidden_proto (__iswxdigit_l)
 libc_hidden_proto (__towlower_l)
 libc_hidden_proto (__towupper_l)
+libc_hidden_proto (__towlower)
+libc_hidden_proto (__towupper)
 
 /* The spec says that isdigit must only match the decimal digits.  We
    can check this without a memory access.  */
index a707847dccd5945a1266bff6942b18f2fb9144bf..7480ec7f00b342936033cf53bc85f9f1aa7256dd 100644 (file)
@@ -229,7 +229,7 @@ __wcschrnul (s, c)
 # if HANDLE_MULTIBYTE
 /* Note that this evaluates C many times.  */
 #  ifdef _LIBC
-#   define FOLD(c) ((flags & FNM_CASEFOLD) ? towlower (c) : (c))
+#   define FOLD(c) ((flags & FNM_CASEFOLD) ? __towlower (c) : (c))
 #  else
 #   define FOLD(c) ((flags & FNM_CASEFOLD) && ISUPPER (c) ? towlower (c) : (c))
 #  endif
index 87bdcc5311804689a8a5d62201c5832de9d17b96..788fed9a6ac7f706af2a5b43f83e5e5f997d9a84 100644 (file)
@@ -69,22 +69,26 @@ libc_hidden_weak (iswxdigit)
 
 #undef towlower
 wint_t
-towlower (wc)
+__towlower (wc)
      wint_t wc;
 {
   size_t i = _NL_CURRENT_WORD (LC_CTYPE, _NL_CTYPE_MAP_OFFSET) + __TOW_tolower;
   const char *desc = _NL_CURRENT (LC_CTYPE, i);
   return wctrans_table_lookup (desc, wc);
 }
-libc_hidden_def (towlower)
+libc_hidden_def (__towlower)
+weak_alias (__towlower, towlower)
+libc_hidden_weak (towlower)
 
 #undef towupper
 wint_t
-towupper (wc)
+__towupper (wc)
      wint_t wc;
 {
   size_t i = _NL_CURRENT_WORD (LC_CTYPE, _NL_CTYPE_MAP_OFFSET) + __TOW_toupper;
   const char *desc = _NL_CURRENT (LC_CTYPE, i);
   return wctrans_table_lookup (desc, wc);
 }
-libc_hidden_def (towupper)
+libc_hidden_def (__towupper)
+weak_alias (__towupper, towupper)
+libc_hidden_weak (towupper)
This page took 0.132433 seconds and 5 git commands to generate.