mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-03 08:11:08 +00:00
Fix fnmatch towlower namespace (bug 18469).
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.
This commit is contained in:
parent
6cfae52edf
commit
bb4acb522c
12
ChangeLog
12
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>
|
2015-06-02 Roland McGrath <roland@hack.frob.com>
|
||||||
|
|
||||||
* stdlib/setenv.c [__GNUC__,__GNUC_MINOR__ < 4,7]: Use
|
* stdlib/setenv.c [__GNUC__,__GNUC_MINOR__ < 4,7]: Use
|
||||||
|
2
NEWS
2
NEWS
@ -19,7 +19,7 @@ Version 2.22
|
|||||||
18047, 18049, 18068, 18080, 18093, 18100, 18104, 18110, 18111, 18116,
|
18047, 18049, 18068, 18080, 18093, 18100, 18104, 18110, 18111, 18116,
|
||||||
18125, 18128, 18138, 18185, 18196, 18197, 18206, 18210, 18211, 18217,
|
18125, 18128, 18138, 18185, 18196, 18197, 18206, 18210, 18211, 18217,
|
||||||
18220, 18221, 18234, 18244, 18247, 18287, 18319, 18333, 18346, 18397,
|
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
|
* Cache information can be queried via sysconf() function on s390 e.g. with
|
||||||
_SC_LEVEL1_ICACHE_SIZE as argument.
|
_SC_LEVEL1_ICACHE_SIZE as argument.
|
||||||
|
@ -60,6 +60,8 @@ extern __typeof (iswupper_l) __iswupper_l;
|
|||||||
extern __typeof (iswxdigit_l) __iswxdigit_l;
|
extern __typeof (iswxdigit_l) __iswxdigit_l;
|
||||||
extern __typeof (towlower_l) __towlower_l;
|
extern __typeof (towlower_l) __towlower_l;
|
||||||
extern __typeof (towupper_l) __towupper_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 (__towctrans)
|
||||||
libc_hidden_proto (__iswctype)
|
libc_hidden_proto (__iswctype)
|
||||||
@ -77,6 +79,8 @@ libc_hidden_proto (__iswupper_l)
|
|||||||
libc_hidden_proto (__iswxdigit_l)
|
libc_hidden_proto (__iswxdigit_l)
|
||||||
libc_hidden_proto (__towlower_l)
|
libc_hidden_proto (__towlower_l)
|
||||||
libc_hidden_proto (__towupper_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
|
/* The spec says that isdigit must only match the decimal digits. We
|
||||||
can check this without a memory access. */
|
can check this without a memory access. */
|
||||||
|
@ -229,7 +229,7 @@ __wcschrnul (s, c)
|
|||||||
# if HANDLE_MULTIBYTE
|
# if HANDLE_MULTIBYTE
|
||||||
/* Note that this evaluates C many times. */
|
/* Note that this evaluates C many times. */
|
||||||
# ifdef _LIBC
|
# ifdef _LIBC
|
||||||
# define FOLD(c) ((flags & FNM_CASEFOLD) ? towlower (c) : (c))
|
# define FOLD(c) ((flags & FNM_CASEFOLD) ? __towlower (c) : (c))
|
||||||
# else
|
# else
|
||||||
# define FOLD(c) ((flags & FNM_CASEFOLD) && ISUPPER (c) ? towlower (c) : (c))
|
# define FOLD(c) ((flags & FNM_CASEFOLD) && ISUPPER (c) ? towlower (c) : (c))
|
||||||
# endif
|
# endif
|
||||||
|
@ -69,22 +69,26 @@ libc_hidden_weak (iswxdigit)
|
|||||||
|
|
||||||
#undef towlower
|
#undef towlower
|
||||||
wint_t
|
wint_t
|
||||||
towlower (wc)
|
__towlower (wc)
|
||||||
wint_t wc;
|
wint_t wc;
|
||||||
{
|
{
|
||||||
size_t i = _NL_CURRENT_WORD (LC_CTYPE, _NL_CTYPE_MAP_OFFSET) + __TOW_tolower;
|
size_t i = _NL_CURRENT_WORD (LC_CTYPE, _NL_CTYPE_MAP_OFFSET) + __TOW_tolower;
|
||||||
const char *desc = _NL_CURRENT (LC_CTYPE, i);
|
const char *desc = _NL_CURRENT (LC_CTYPE, i);
|
||||||
return wctrans_table_lookup (desc, wc);
|
return wctrans_table_lookup (desc, wc);
|
||||||
}
|
}
|
||||||
libc_hidden_def (towlower)
|
libc_hidden_def (__towlower)
|
||||||
|
weak_alias (__towlower, towlower)
|
||||||
|
libc_hidden_weak (towlower)
|
||||||
|
|
||||||
#undef towupper
|
#undef towupper
|
||||||
wint_t
|
wint_t
|
||||||
towupper (wc)
|
__towupper (wc)
|
||||||
wint_t wc;
|
wint_t wc;
|
||||||
{
|
{
|
||||||
size_t i = _NL_CURRENT_WORD (LC_CTYPE, _NL_CTYPE_MAP_OFFSET) + __TOW_toupper;
|
size_t i = _NL_CURRENT_WORD (LC_CTYPE, _NL_CTYPE_MAP_OFFSET) + __TOW_toupper;
|
||||||
const char *desc = _NL_CURRENT (LC_CTYPE, i);
|
const char *desc = _NL_CURRENT (LC_CTYPE, i);
|
||||||
return wctrans_table_lookup (desc, wc);
|
return wctrans_table_lookup (desc, wc);
|
||||||
}
|
}
|
||||||
libc_hidden_def (towupper)
|
libc_hidden_def (__towupper)
|
||||||
|
weak_alias (__towupper, towupper)
|
||||||
|
libc_hidden_weak (towupper)
|
||||||
|
Loading…
Reference in New Issue
Block a user