Merge __foo_chk() into __fortify_foo()

Este commit está contenido en:
sin 2015-01-28 15:36:44 +00:00
padre b258495eba
commit 6bb34c15b4

Ver fichero

@ -5,15 +5,6 @@
#if defined(_FORTIFY_SOURCE) && _FORTIFY_SOURCE > 0 && defined(__OPTIMIZE__) && __OPTIMIZE__ > 0
static inline __attribute__ ((always_inline))
void *__memcpy_chk(void *__restrict dest, const void *__restrict src, size_t ssize,
size_t dsize)
{
if (ssize > dsize)
__builtin_trap();
return memcpy(dest, src, ssize);
}
static inline __attribute__ ((always_inline))
void *__fortify_memcpy(void *__restrict dest, const void *__restrict src, size_t n)
{
@ -21,24 +12,14 @@ void *__fortify_memcpy(void *__restrict dest, const void *__restrict src, size_t
if (bos == (size_t)-1)
return memcpy(dest, src, n);
if (__builtin_constant_p(n))
if (n <= bos)
return memcpy(dest, src, n);
return __memcpy_chk(dest, src, n, bos);
if (__builtin_constant_p(n) && n > bos)
__builtin_trap();
return memcpy(dest, src, n);
}
#undef memcpy
#define memcpy(dest, src, n) __fortify_memcpy(dest, src, n)
static inline __attribute__ ((always_inline))
void *__memmove_chk(void *__restrict dest, const void *__restrict src, size_t ssize,
size_t dsize)
{
if (ssize > dsize)
__builtin_trap();
return memmove(dest, src, ssize);
}
static inline __attribute__ ((always_inline))
void *__fortify_memmove(void *__restrict dest, const void *__restrict src, size_t n)
{
@ -46,23 +27,14 @@ void *__fortify_memmove(void *__restrict dest, const void *__restrict src, size_
if (bos == (size_t)-1)
return memmove(dest, src, n);
if (__builtin_constant_p(n))
if (n <= bos)
return memmove(dest, src, n);
return __memmove_chk(dest, src, n, bos);
if (__builtin_constant_p(n) && n > bos)
__builtin_trap();
return memmove(dest, src, n);
}
#undef memmove
#define memmove(dest, src, n) __fortify_memmove(dest, src, n)
static inline __attribute__ ((always_inline))
void *__memset_chk(void *dest, int c, size_t n, size_t dsize)
{
if (n > dsize)
__builtin_trap();
return memset(dest, c, n);
}
static inline __attribute__ ((always_inline))
void *__fortify_memset(void *dest, int c, size_t n)
{
@ -70,26 +42,14 @@ void *__fortify_memset(void *dest, int c, size_t n)
if (bos == (size_t)-1)
return memset(dest, c, n);
if (__builtin_constant_p(n))
if (n <= bos)
return memset(dest, c, n);
return __memset_chk(dest, c, n, bos);
if (__builtin_constant_p(n) && n > bos)
__builtin_trap();
return memset(dest, c, n);
}
#undef memset
#define memset(dest, src, n) __fortify_memset(dest, src, n)
static inline __attribute__ ((always_inline))
char *__strcat_chk(char *__restrict dest, const char *__restrict src, size_t n)
{
size_t slen = strlen(src);
size_t dlen = strlen(dest);
if (slen + dlen + 1 > n)
__builtin_trap();
return strcat(dest, src);
}
static inline __attribute__ ((always_inline))
char *__fortify_strcat(char *__restrict dest, const char *__restrict src)
{
@ -97,22 +57,14 @@ char *__fortify_strcat(char *__restrict dest, const char *__restrict src)
if (bos == (size_t)-1)
return strcat(dest, src);
return __strcat_chk(dest, src, bos);
if (strlen(src) + strlen(dest) + 1 > bos)
__builtin_trap();
return strcat(dest, src);
}
#undef strcat
#define strcat(dest, src) __fortify_strcat(dest, src)
static inline __attribute__ ((always_inline))
char *__strcpy_chk(char *__restrict dest, const char *__restrict src, size_t n)
{
size_t slen = strlen(src);
if (slen + 1 > n)
__builtin_trap();
return strcpy(dest, src);
}
static inline __attribute__ ((always_inline))
char *__fortify_strcpy(char *__restrict dest, const char *__restrict src)
{
@ -120,50 +72,36 @@ char *__fortify_strcpy(char *__restrict dest, const char *__restrict src)
if (bos == (size_t)-1)
return strcpy(dest, src);
return __strcpy_chk(dest, src, bos);
if (strlen(src) + 1 > bos)
__builtin_trap();
return strcpy(dest, src);
}
#undef strcpy
#define strcpy(dest, src) __fortify_strcpy(dest, src)
static inline __attribute__ ((always_inline))
char *__strncat_chk(char *__restrict dest, const char *__restrict src, size_t n,
size_t dsize)
{
size_t slen = strlen(src);
size_t dlen = strlen(dest);
if (slen > n) slen = n;
if (slen + dlen + 1 > dsize)
__builtin_trap();
return strncat(dest, src, n);
}
static inline __attribute__ ((always_inline))
char *__fortify_strncat(char *__restrict dest, const char *__restrict src, size_t n)
{
size_t bos = __builtin_object_size(dest, 0);
size_t slen, dlen;
if (bos == (size_t)-1)
return strncat(dest, src, n);
if (__builtin_constant_p(n))
if (n <= bos)
return strncat(dest, src, n);
return __strncat_chk(dest, src, n, bos);
if (__builtin_constant_p(n) && n > bos) {
slen = strlen(src);
dlen = strlen(dest);
if (slen > n)
slen = n;
if (slen + dlen + 1 > bos)
__builtin_trap();
}
return strncat(dest, src, n);
}
#undef strncat
#define strncat(dest, src, n) __fortify_strcat(dest, src, n)
static inline __attribute__ ((always_inline))
char *__strncpy_chk(char *__restrict dest, const char *__restrict src, size_t n,
size_t dsize)
{
if (n > dsize)
__builtin_trap();
return strncpy(dest, src, n);
}
static inline __attribute__ ((always_inline))
char *__fortify_strncpy(char *__restrict dest, const char *__restrict src, size_t n)
{
@ -171,25 +109,15 @@ char *__fortify_strncpy(char *__restrict dest, const char *__restrict src, size_
if (bos == (size_t)-1)
return strncpy(dest, src, n);
if (__builtin_constant_p(n))
if (n <= bos)
return strncpy(dest, src, n);
return __strncpy_chk(dest, src, n, bos);
if (__builtin_constant_p(n) && n > bos)
__builtin_trap();
return strncpy(dest, src, n);
}
#undef strncpy
#define strncpy(dest, src, n) __fortify_strcpy(dest, src, n)
#if defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
static inline __attribute__ ((always_inline))
size_t __strlcat_chk(char *__restrict dest, const char *__restrict src, size_t n,
size_t dsize)
{
if (n > dsize)
__builtin_trap();
return strlcat(dest, src, n);
}
static inline __attribute__ ((always_inline))
size_t __fortify_strlcat(char *__restrict dest, const char *__restrict src, size_t n)
{
@ -197,25 +125,14 @@ size_t __fortify_strlcat(char *__restrict dest, const char *__restrict src, size
if (bos == (size_t)-1)
return strlcat(dest, src, n);
if (__builtin_constant_p(n)) {
if (n <= bos)
return strlcat(dest, src, n);
}
return __strlcat_chk(dest, src, n, bos);
if (__builtin_constant_p(n) && n > bos)
__builtin_trap();
return strlcat(dest, src, n);
}
#undef strlcat
#define strlcat(dest, src, n) __fortify_strlcat(dest, src, n)
static inline __attribute__ ((always_inline))
size_t __strlcpy_chk(char *__restrict dest, const char *__restrict src, size_t n,
size_t dsize)
{
if (n > dsize)
__builtin_trap();
return strlcpy(dest, src, n);
}
static inline __attribute__ ((always_inline))
size_t __fortify_strlcpy(char *__restrict dest, const char *__restrict src, size_t n)
{
@ -223,11 +140,9 @@ size_t __fortify_strlcpy(char *__restrict dest, const char *__restrict src, size
if (bos == (size_t)-1)
return strlcpy(dest, src, n);
if (__builtin_constant_p(n)) {
if (n <= bos)
return strlcpy(dest, src, n);
}
return __strlcpy_chk(dest, src, n, bos);
if (__builtin_constant_p(n) && n > bos)
__builtin_trap();
return strlcpy(dest, src, n);
}
#undef strlcpy