mirror of
git://sourceware.org/git/glibc.git
synced 2025-04-12 14:21:18 +08:00
* include/features.h (__USE_FORTIFY_LEVEL): Also set for Red Hat
GCC 3.4.x-RH >= 3.4.2-8. * libio/bits/features.h (printf, fprintf, vprintf, vfprintf): For GCC 3.4.x-RH use __builtin___{,v}{,f}printf_chk instead of __{,v}{,f}printf_chk. * debug/tst-chk1.c (do_test): Deal with GCC 3.4.x-RH not being able to recognize subobjects.
This commit is contained in:
parent
bb21d92c36
commit
5acf2e2cb4
10
ChangeLog
10
ChangeLog
@ -1,3 +1,13 @@
|
||||
2004-11-02 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* include/features.h (__USE_FORTIFY_LEVEL): Also set for Red Hat
|
||||
GCC 3.4.x-RH >= 3.4.2-8.
|
||||
* libio/bits/features.h (printf, fprintf, vprintf, vfprintf): For
|
||||
GCC 3.4.x-RH use __builtin___{,v}{,f}printf_chk instead of
|
||||
__{,v}{,f}printf_chk.
|
||||
* debug/tst-chk1.c (do_test): Deal with GCC 3.4.x-RH not
|
||||
being able to recognize subobjects.
|
||||
|
||||
2004-11-01 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* sysdeps/unix/sysv/linux/x86_64/sys/procfs.h [__WORDSIZE == 32]
|
||||
|
@ -201,7 +201,7 @@ do_test (void)
|
||||
if (memcmp (a.buf1, "aabcdabcjj", 10))
|
||||
FAIL ();
|
||||
|
||||
#if __USE_FORTIFY_LEVEL < 2
|
||||
#if __USE_FORTIFY_LEVEL < 2 || !__GNUC_PREREQ (4, 0)
|
||||
/* The following tests are supposed to crash with -D_FORTIFY_SOURCE=2
|
||||
and sufficient GCC support, as the string operations overflow
|
||||
from a.buf1 into a.buf2. */
|
||||
@ -300,7 +300,7 @@ do_test (void)
|
||||
memset (a.buf1 + 9, 'j', l0 + 2);
|
||||
CHK_FAIL_END
|
||||
|
||||
#if __USE_FORTIFY_LEVEL >= 2
|
||||
#if __USE_FORTIFY_LEVEL >= 2 && __GNUC_PREREQ (4, 0)
|
||||
# define O 0
|
||||
#else
|
||||
# define O 1
|
||||
|
@ -264,7 +264,11 @@
|
||||
|
||||
#if _FORTIFY_SOURCE > 0 && __OPTIMIZE__ > 0 \
|
||||
&& (__GNUC_PREREQ (4, 1) \
|
||||
|| (defined __GNUC_RH_RELEASE__ && __GNUC_PREREQ (4, 0)))
|
||||
|| (defined __GNUC_RH_RELEASE__ && __GNUC_PREREQ (4, 0)) \
|
||||
|| (defined __GNUC_RH_RELEASE__ && __GNUC_PREREQ (3, 4) \
|
||||
&& __GNUC_MINOR__ == 4 \
|
||||
&& (__GNUC_PATCHLEVEL__ > 2 \
|
||||
|| (__GNUC_PATCHLEVEL__ == 2 && __GNUC_RH_RELEASE__ >= 8))))
|
||||
# if _FORTIFY_SOURCE == 1
|
||||
# define __USE_FORTIFY_LEVEL 1
|
||||
# elif _FORTIFY_SOURCE > 1
|
||||
|
@ -61,14 +61,25 @@ extern int __vfprintf_chk (FILE *__restrict __stream, int __flag,
|
||||
extern int __vprintf_chk (int __flag, __const char *__restrict __format,
|
||||
_G_va_list __ap);
|
||||
|
||||
# define printf(...) \
|
||||
# if __GNUC_PREREQ (4, 0)
|
||||
# define printf(...) \
|
||||
__printf_chk (__USE_FORTIFY_LEVEL - 1, __VA_ARGS__)
|
||||
# define fprintf(stream, ...) \
|
||||
# define fprintf(stream, ...) \
|
||||
__fprintf_chk (stream, __USE_FORTIFY_LEVEL - 1, __VA_ARGS__)
|
||||
# define vprintf(format, ap) \
|
||||
# define vprintf(format, ap) \
|
||||
__vprintf_chk (__USE_FORTIFY_LEVEL - 1, format, ap)
|
||||
# define vfprintf(stream, format, ap) \
|
||||
# define vfprintf(stream, format, ap) \
|
||||
__vfprintf_chk (stream, __USE_FORTIFY_LEVEL - 1, format, ap)
|
||||
# else
|
||||
# define printf(...) \
|
||||
__builtin___printf_chk (__USE_FORTIFY_LEVEL - 1, __VA_ARGS__)
|
||||
# define fprintf(stream, ...) \
|
||||
__builtin___fprintf_chk (stream, __USE_FORTIFY_LEVEL - 1, __VA_ARGS__)
|
||||
# define vprintf(format, ap) \
|
||||
__builtin___vprintf_chk (__USE_FORTIFY_LEVEL - 1, format, ap)
|
||||
# define vfprintf(stream, format, ap) \
|
||||
__builtin___vfprintf_chk (stream, __USE_FORTIFY_LEVEL - 1, format, ap)
|
||||
# endif
|
||||
|
||||
#endif
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user