mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-18 12:16:13 +08:00
Fix crypt snprintf namespace (bug 20829).
Extending linknamespace tests to cover libcrypt showed that crypt brings in references to snprintf, but is in XPG3 and XPG4 which don't have snprintf. This patch fixes it to use __snprintf instead, exporting __snprintf from libc.so at version GLIBC_PRIVATE and adding libc_hidden_proto / libc_hidden_def accordingly. Tested for x86_64 and x86, in conjunction with the testsuite changes to enable linknamespace testing for libdl and libcrypt. Also tested (compilation only) for powerpc to make sure there were no problem interactions with the optional-long-double handling for snprintf. [BZ #20829] * stdio-common/Versions (__snprintf): Add to version GLIBC_PRIVATE. * include/stdio.h (__snprintf): Use libc_hidden_proto. * stdio-common/snprintf.c (__snprintf): Use libc_hidden_def. * crypt/sha256-crypt.c (__sha256_crypt_r): Use __snprintf instead of snprintf. * crypt/sha512-crypt.c (__sha512_crypt_r): Likewise.
This commit is contained in:
parent
7773556dfb
commit
61158ffa9a
11
ChangeLog
11
ChangeLog
@ -1,3 +1,14 @@
|
||||
2016-11-16 Joseph Myers <joseph@codesourcery.com>
|
||||
|
||||
[BZ #20829]
|
||||
* stdio-common/Versions (__snprintf): Add to version
|
||||
GLIBC_PRIVATE.
|
||||
* include/stdio.h (__snprintf): Use libc_hidden_proto.
|
||||
* stdio-common/snprintf.c (__snprintf): Use libc_hidden_def.
|
||||
* crypt/sha256-crypt.c (__sha256_crypt_r): Use __snprintf instead
|
||||
of snprintf.
|
||||
* crypt/sha512-crypt.c (__sha512_crypt_r): Likewise.
|
||||
|
||||
2016-11-16 Zack Weinberg <zackw@panix.com>
|
||||
|
||||
* string/string.h: Remove obsolete comment stating that
|
||||
|
@ -319,8 +319,8 @@ __sha256_crypt_r (const char *key, const char *salt, char *buffer, int buflen)
|
||||
|
||||
if (rounds_custom)
|
||||
{
|
||||
int n = snprintf (cp, MAX (0, buflen), "%s%zu$",
|
||||
sha256_rounds_prefix, rounds);
|
||||
int n = __snprintf (cp, MAX (0, buflen), "%s%zu$",
|
||||
sha256_rounds_prefix, rounds);
|
||||
cp += n;
|
||||
buflen -= n;
|
||||
}
|
||||
|
@ -318,8 +318,8 @@ __sha512_crypt_r (const char *key, const char *salt, char *buffer, int buflen)
|
||||
|
||||
if (rounds_custom)
|
||||
{
|
||||
int n = snprintf (cp, MAX (0, buflen), "%s%zu$",
|
||||
sha512_rounds_prefix, rounds);
|
||||
int n = __snprintf (cp, MAX (0, buflen), "%s%zu$",
|
||||
sha512_rounds_prefix, rounds);
|
||||
cp += n;
|
||||
buflen -= n;
|
||||
}
|
||||
|
@ -11,6 +11,7 @@ extern int __fcloseall (void);
|
||||
extern int __snprintf (char *__restrict __s, size_t __maxlen,
|
||||
const char *__restrict __format, ...)
|
||||
__attribute__ ((__format__ (__printf__, 3, 4)));
|
||||
libc_hidden_proto (__snprintf)
|
||||
extern int __vsnprintf (char *__restrict __s, size_t __maxlen,
|
||||
const char *__restrict __format, _G_va_list __arg)
|
||||
__attribute__ ((__format__ (__printf__, 3, 0)));
|
||||
|
@ -60,5 +60,7 @@ libc {
|
||||
GLIBC_PRIVATE {
|
||||
# global variables
|
||||
_itoa_lower_digits;
|
||||
# Used in libcrypt.
|
||||
__snprintf;
|
||||
}
|
||||
}
|
||||
|
@ -35,4 +35,5 @@ __snprintf (char *s, size_t maxlen, const char *format, ...)
|
||||
|
||||
return done;
|
||||
}
|
||||
libc_hidden_def (__snprintf)
|
||||
ldbl_weak_alias (__snprintf, snprintf)
|
||||
|
Loading…
Reference in New Issue
Block a user