diff options
4 files changed, 1146 insertions, 4 deletions
diff --git a/main/fortify-headers/0001-Fix-usage-of-__USER_LABEL_PREFIX__.patch b/main/fortify-headers/0001-Fix-usage-of-__USER_LABEL_PREFIX__.patch new file mode 100644 index 0000000000..1c9eed5b25 --- /dev/null +++ b/main/fortify-headers/0001-Fix-usage-of-__USER_LABEL_PREFIX__.patch @@ -0,0 +1,29 @@ +From a9ee1d2743acb0b2903db87c0a241c0a569cfc4e Mon Sep 17 00:00:00 2001 +From: Trutz Behn <me@trutz.be> +Date: Tue, 2 Jun 2015 21:33:39 +0200 +Subject: [PATCH 1/3] Fix usage of __USER_LABEL_PREFIX__ + +The predefined __USER_LABEL_PREFIX__ macro if it is non-empty contains +an identifier, not a string literal, thus it needs to be stringified. +--- + include/fortify-headers.h | 4 +++- + 1 file changed, 3 insertions(+), 1 deletion(-) + +diff --git a/include/fortify-headers.h b/include/fortify-headers.h +index 72b99ec..fcb862d 100644 +--- a/include/fortify-headers.h ++++ b/include/fortify-headers.h +@@ -16,7 +16,9 @@ + #ifndef _FORTIFY_HEADERS_H + #define _FORTIFY_HEADERS_H + +-#define fortify_fn(fn) __typeof__(fn) __orig_##fn __asm__(__USER_LABEL_PREFIX__ #fn); \ ++#define _FORTIFY_STR(s) #s ++#define _FORTIFY_ORIG(p,fn) __typeof__(fn) __orig_##fn __asm__(_FORTIFY_STR(p) #fn) ++#define fortify_fn(fn) _FORTIFY_ORIG(__USER_LABEL_PREFIX__,fn); \ + extern __inline __attribute__((__always_inline__,__gnu_inline__,__artificial__)) + + #endif +-- +2.4.2 + diff --git a/main/fortify-headers/0002-Use-namespace-safe-macro-param-and-variable-names.patch b/main/fortify-headers/0002-Use-namespace-safe-macro-param-and-variable-names.patch new file mode 100644 index 0000000000..6ae2bd8a8b --- /dev/null +++ b/main/fortify-headers/0002-Use-namespace-safe-macro-param-and-variable-names.patch @@ -0,0 +1,1032 @@ +From 1cd5461a5375207602f2cbdfd9a50a9b751cb7c8 Mon Sep 17 00:00:00 2001 +From: Trutz Behn <me@trutz.be> +Date: Wed, 3 Jun 2015 19:27:01 +0200 +Subject: [PATCH 2/3] Use namespace-safe macro, param and variable names + +--- + include/fortify-headers.h | 2 +- + include/poll.h | 18 ++--- + include/stdio.h | 78 ++++++++++---------- + include/stdlib.h | 12 +-- + include/string.h | 124 +++++++++++++++---------------- + include/strings.h | 18 ++--- + include/sys/select.h | 16 ++-- + include/sys/socket.h | 36 ++++----- + include/unistd.h | 96 ++++++++++++------------ + include/wchar.h | 182 +++++++++++++++++++++++----------------------- + 10 files changed, 291 insertions(+), 291 deletions(-) + +diff --git a/include/fortify-headers.h b/include/fortify-headers.h +index fcb862d..288a973 100644 +--- a/include/fortify-headers.h ++++ b/include/fortify-headers.h +@@ -18,7 +18,7 @@ + + #define _FORTIFY_STR(s) #s + #define _FORTIFY_ORIG(p,fn) __typeof__(fn) __orig_##fn __asm__(_FORTIFY_STR(p) #fn) +-#define fortify_fn(fn) _FORTIFY_ORIG(__USER_LABEL_PREFIX__,fn); \ ++#define _FORTIFY_FN(fn) _FORTIFY_ORIG(__USER_LABEL_PREFIX__,fn); \ + extern __inline __attribute__((__always_inline__,__gnu_inline__,__artificial__)) + + #endif +diff --git a/include/poll.h b/include/poll.h +index 6ca08a7..d9b602c 100644 +--- a/include/poll.h ++++ b/include/poll.h +@@ -27,25 +27,25 @@ extern "C" { + + #undef poll + +-fortify_fn(poll) int poll(struct pollfd *fds, nfds_t nfds, int timeout) ++_FORTIFY_FN(poll) int poll(struct pollfd *__f, nfds_t __n, int __s) + { +- __typeof__(sizeof 0) bos = __builtin_object_size(fds, 0); ++ __typeof__(sizeof 0) __b = __builtin_object_size(__f, 0); + +- if (nfds > bos / sizeof(struct pollfd)) ++ if (__n > __b / sizeof(struct pollfd)) + __builtin_trap(); +- return __orig_poll(fds, nfds, timeout); ++ return __orig_poll(__f, __n, __s); + } + + #ifdef _GNU_SOURCE + #undef ppoll +-fortify_fn(ppoll) int ppoll(struct pollfd *fds, nfds_t nfds, const struct timespec *timeout, +- const sigset_t *mask) ++_FORTIFY_FN(ppoll) int ppoll(struct pollfd *__f, nfds_t __n, const struct timespec *__s, ++ const sigset_t *__m) + { +- __typeof__(sizeof 0) bos = __builtin_object_size(fds, 0); ++ __typeof__(sizeof 0) __b = __builtin_object_size(__f, 0); + +- if (nfds > bos / sizeof(struct pollfd)) ++ if (__n > __b / sizeof(struct pollfd)) + __builtin_trap(); +- return __orig_ppoll(fds, nfds, timeout, mask); ++ return __orig_ppoll(__f, __n, __s, __m); + } + #endif + +diff --git a/include/stdio.h b/include/stdio.h +index 6689519..996c661 100644 +--- a/include/stdio.h ++++ b/include/stdio.h +@@ -33,84 +33,84 @@ extern "C" { + #undef snprintf + #undef sprintf + +-fortify_fn(fgets) char *fgets(char *s, int n, FILE *fp) ++_FORTIFY_FN(fgets) char *fgets(char *__s, int __n, FILE *__f) + { +- size_t bos = __builtin_object_size(s, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if ((size_t)n > bos) ++ if ((size_t)__n > __b) + __builtin_trap(); +- return __orig_fgets(s, n, fp); ++ return __orig_fgets(__s, __n, __f); + } + +-fortify_fn(fread) size_t fread(void *dst, size_t n, size_t nmemb, FILE *fp) ++_FORTIFY_FN(fread) size_t fread(void *__d, size_t __n, size_t __m, FILE *__f) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n != 0 && (n * nmemb) / n != nmemb) ++ if (__n != 0 && (__n * __m) / __n != __m) + __builtin_trap(); +- if (n * nmemb > bos) ++ if (__n * __m > __b) + __builtin_trap(); +- return __orig_fread(dst, n, nmemb, fp); ++ return __orig_fread(__d, __n, __m, __f); + } + +-fortify_fn(fwrite) size_t fwrite(const void *dst, size_t n, size_t nmemb, FILE *fp) ++_FORTIFY_FN(fwrite) size_t fwrite(const void *__d, size_t __n, size_t __m, FILE *__f) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n != 0 && (n * nmemb) / n != nmemb) ++ if (__n != 0 && (__n * __m) / __n != __m) + __builtin_trap(); +- if (n * nmemb > bos) ++ if (__n * __m > __b) + __builtin_trap(); +- return __orig_fwrite(dst, n, nmemb, fp); ++ return __orig_fwrite(__d, __n, __m, __f); + } + +-fortify_fn(vsnprintf) int vsnprintf(char *s, size_t n, const char *fmt, +- __builtin_va_list ap) ++_FORTIFY_FN(vsnprintf) int vsnprintf(char *__s, size_t __n, const char *__f, ++ __builtin_va_list __v) + { +- size_t bos = __builtin_object_size(s, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_vsnprintf(s, n, fmt, ap); ++ return __orig_vsnprintf(__s, __n, __f, __v); + } + +-fortify_fn(vsprintf) int vsprintf(char *s, const char *fmt, __builtin_va_list ap) ++_FORTIFY_FN(vsprintf) int vsprintf(char *__s, const char *__f, __builtin_va_list __v) + { +- size_t bos = __builtin_object_size(s, 0); +- int r; ++ size_t __b = __builtin_object_size(__s, 0); ++ int __r; + +- if (bos != (size_t)-1) { +- r = __orig_vsnprintf(s, bos, fmt, ap); +- if (r != -1 && (size_t)r >= bos) ++ if (__b != (size_t)-1) { ++ __r = __orig_vsnprintf(__s, __b, __f, __v); ++ if (__r != -1 && (size_t)__r >= __b) + __builtin_trap(); + } else { +- r = __orig_vsprintf(s, fmt, ap); ++ __r = __orig_vsprintf(__s, __f, __v); + } +- return r; ++ return __r; + } + +-fortify_fn(snprintf) int snprintf(char *s, size_t n, const char *fmt, ...) ++_FORTIFY_FN(snprintf) int snprintf(char *__s, size_t __n, const char *__f, ...) + { +- size_t bos = __builtin_object_size(s, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_snprintf(s, n, fmt, __builtin_va_arg_pack()); ++ return __orig_snprintf(__s, __n, __f, __builtin_va_arg_pack()); + } + +-fortify_fn(sprintf) int sprintf(char *s, const char *fmt, ...) ++_FORTIFY_FN(sprintf) int sprintf(char *__s, const char *__f, ...) + { +- size_t bos = __builtin_object_size(s, 0); +- int r; ++ size_t __b = __builtin_object_size(__s, 0); ++ int __r; + +- if (bos != (size_t)-1) { +- r = __orig_snprintf(s, bos, fmt, __builtin_va_arg_pack()); +- if (r != -1 && (size_t)r >= bos) ++ if (__b != (size_t)-1) { ++ __r = __orig_snprintf(__s, __b, __f, __builtin_va_arg_pack()); ++ if (__r != -1 && (size_t)__r >= __b) + __builtin_trap(); + } else { +- r = __orig_sprintf(s, fmt, __builtin_va_arg_pack()); ++ __r = __orig_sprintf(__s, __f, __builtin_va_arg_pack()); + } +- return r; ++ return __r; + } + + #ifdef __cplusplus +diff --git a/include/stdlib.h b/include/stdlib.h +index 5566ab4..2b67235 100644 +--- a/include/stdlib.h ++++ b/include/stdlib.h +@@ -31,20 +31,20 @@ extern "C" { + + #if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE) + #undef realpath +-fortify_fn(realpath) char *realpath(const char *path, char *resolved) ++_FORTIFY_FN(realpath) char *realpath(const char *__p, char *__r) + { +- size_t bos; ++ size_t __b; + +- if (resolved) { ++ if (__r) { + #ifndef PATH_MAX + #error PATH_MAX unset. A fortified realpath will not work. + #else +- bos = __builtin_object_size(resolved, 0); +- if (PATH_MAX > bos) ++ __b = __builtin_object_size(__r, 0); ++ if (PATH_MAX > __b) + __builtin_trap(); + #endif + } +- return __orig_realpath(path, resolved); ++ return __orig_realpath(__p, __r); + } + #endif + +diff --git a/include/string.h b/include/string.h +index 5db7ac9..98bfea1 100644 +--- a/include/string.h ++++ b/include/string.h +@@ -33,141 +33,141 @@ extern "C" { + #undef strncat + #undef strncpy + +-fortify_fn(memcpy) void *memcpy(void *dst, const void *src, size_t n) ++_FORTIFY_FN(memcpy) void *memcpy(void *__od, const void *__os, size_t __n) + { +- size_t bos_dst = __builtin_object_size(dst, 0); +- size_t bos_src = __builtin_object_size(src, 0); +- char *d = (char *)dst; +- const char *s = (const char *)src; ++ size_t __bd = __builtin_object_size(__od, 0); ++ size_t __bs = __builtin_object_size(__os, 0); ++ char *__d = (char *)__od; ++ const char *__s = (const char *)__os; + + /* trap if pointers are overlapping but not if dst == src. + * gcc seems to like to generate code that relies on dst == src */ +- if ((d < s && d + n > s) || +- (s < d && s + n > d)) ++ if ((__d < __s && __d + __n > __s) || ++ (__s < __d && __s + __n > __d)) + __builtin_trap(); +- if (n > bos_dst || n > bos_src) ++ if (__n > __bd || __n > __bs) + __builtin_trap(); +- return __orig_memcpy(dst, src, n); ++ return __orig_memcpy(__od, __os, __n); + } + +-fortify_fn(memmove) void *memmove(void *dst, const void *src, size_t n) ++_FORTIFY_FN(memmove) void *memmove(void *__d, const void *__s, size_t __n) + { +- size_t bos_dst = __builtin_object_size(dst, 0); +- size_t bos_src = __builtin_object_size(src, 0); ++ size_t __bd = __builtin_object_size(__d, 0); ++ size_t __bs = __builtin_object_size(__s, 0); + +- if (n > bos_dst || n > bos_src) ++ if (__n > __bd || __n > __bs) + __builtin_trap(); +- return __orig_memmove(dst, src, n); ++ return __orig_memmove(__d, __s, __n); + } + +-fortify_fn(memset) void *memset(void *dst, int c, size_t n) ++_FORTIFY_FN(memset) void *memset(void *__d, int __c, size_t __n) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_memset(dst, c, n); ++ return __orig_memset(__d, __c, __n); + } + + #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \ + || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \ + || defined(_BSD_SOURCE) + #undef stpcpy +-fortify_fn(stpcpy) char *stpcpy(char *dst, const char *src) ++_FORTIFY_FN(stpcpy) char *stpcpy(char *__d, const char *__s) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (strlen(src) + 1 > bos) ++ if (strlen(__s) + 1 > __b) + __builtin_trap(); +- return __orig_stpcpy(dst, src); ++ return __orig_stpcpy(__d, __s); + } + + #undef stpncpy +-fortify_fn(stpncpy) char *stpncpy(char *dst, const char *src, size_t n) ++_FORTIFY_FN(stpncpy) char *stpncpy(char *__d, const char *__s, size_t __n) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_stpncpy(dst, src, n); ++ return __orig_stpncpy(__d, __s, __n); + } + #endif + +-fortify_fn(strcat) char *strcat(char *dst, const char *src) ++_FORTIFY_FN(strcat) char *strcat(char *__d, const char *__s) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (strlen(src) + strlen(dst) + 1 > bos) ++ if (strlen(__s) + strlen(__d) + 1 > __b) + __builtin_trap(); +- return __orig_strcat(dst, src); ++ return __orig_strcat(__d, __s); + } + +-fortify_fn(strcpy) char *strcpy(char *dst, const char *src) ++_FORTIFY_FN(strcpy) char *strcpy(char *__d, const char *__s) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (strlen(src) + 1 > bos) ++ if (strlen(__s) + 1 > __b) + __builtin_trap(); +- return __orig_strcpy(dst, src); ++ return __orig_strcpy(__d, __s); + } + +-fortify_fn(strncat) char *strncat(char *dst, const char *src, size_t n) ++_FORTIFY_FN(strncat) char *strncat(char *__d, const char *__s, size_t __n) + { +- size_t bos = __builtin_object_size(dst, 0); +- size_t slen, dlen; +- +- if (n > bos) { +- slen = strlen(src); +- dlen = strlen(dst); +- if (slen > n) +- slen = n; +- if (slen + dlen + 1 > bos) ++ size_t __b = __builtin_object_size(__d, 0); ++ size_t __sl, __dl; ++ ++ if (__n > __b) { ++ __sl = strlen(__s); ++ __dl = strlen(__d); ++ if (__sl > __n) ++ __sl = __n; ++ if (__sl + __dl + 1 > __b) + __builtin_trap(); + } +- return __orig_strncat(dst, src, n); ++ return __orig_strncat(__d, __s, __n); + } + +-fortify_fn(strncpy) char *strncpy(char *dst, const char *src, size_t n) ++_FORTIFY_FN(strncpy) char *strncpy(char *__d, const char *__s, size_t __n) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_strncpy(dst, src, n); ++ return __orig_strncpy(__d, __s, __n); + } + + #ifdef _GNU_SOURCE + #undef mempcpy +-fortify_fn(mempcpy) void *mempcpy(void *dst, const void *src, size_t n) ++_FORTIFY_FN(mempcpy) void *mempcpy(void *__d, const void *__s, size_t __n) + { +- size_t bos_dst = __builtin_object_size(dst, 0); +- size_t bos_src = __builtin_object_size(src, 0); ++ size_t __bd = __builtin_object_size(__d, 0); ++ size_t __bs = __builtin_object_size(__s, 0); + +- if (n > bos_dst || n > bos_src) ++ if (__n > __bd || __n > __bs) + __builtin_trap(); +- return __orig_mempcpy(dst, src, n); ++ return __orig_mempcpy(__d, __s, __n); + } + #endif + + #if defined(_GNU_SOURCE) || defined(_BSD_SOURCE) + #undef strlcat + #undef strlcpy +-fortify_fn(strlcat) size_t strlcat(char *dst, const char *src, size_t n) ++_FORTIFY_FN(strlcat) size_t strlcat(char *__d, const char *__s, size_t __n) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_strlcat(dst, src, n); ++ return __orig_strlcat(__d, __s, __n); + } + +-fortify_fn(strlcpy) size_t strlcpy(char *dst, const char *src, size_t n) ++_FORTIFY_FN(strlcpy) size_t strlcpy(char *__d, const char *__s, size_t __n) + { +- size_t bos = __builtin_object_size(dst, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_strlcpy(dst, src, n); ++ return __orig_strlcpy(__d, __s, __n); + } + #endif + +diff --git a/include/strings.h b/include/strings.h +index ed8efdb..4eb5486 100644 +--- a/include/strings.h ++++ b/include/strings.h +@@ -30,23 +30,23 @@ extern "C" { + || (defined(_XOPEN_SOURCE) && _XOPEN_SOURCE+0 < 700) + #undef bcopy + #undef bzero +-fortify_fn(bcopy) void bcopy(const void *src, void *dst, size_t n) ++_FORTIFY_FN(bcopy) void bcopy(const void *__s, void *__d, size_t __n) + { +- size_t bos_dst = __builtin_object_size(dst, 0); +- size_t bos_src = __builtin_object_size(src, 0); ++ size_t __bd = __builtin_object_size(__d, 0); ++ size_t __bs = __builtin_object_size(__s, 0); + +- if (n > bos_dst || n > bos_src) ++ if (__n > __bd || __n > __bs) + __builtin_trap(); +- return __orig_bcopy(src, dst, n); ++ return __orig_bcopy(__s, __d, __n); + } + +-fortify_fn(bzero) void bzero(void *src, size_t n) ++_FORTIFY_FN(bzero) void bzero(void *__s, size_t __n) + { +- size_t bos = __builtin_object_size(src, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_bzero(src, n); ++ return __orig_bzero(__s, __n); + } + #endif + +diff --git a/include/sys/select.h b/include/sys/select.h +index 0f1e1df..4623071 100644 +--- a/include/sys/select.h ++++ b/include/sys/select.h +@@ -25,23 +25,23 @@ extern "C" { + #endif + + static __inline __attribute__((__always_inline__,__gnu_inline__,__artificial__)) +-void __fortify_FD_CLR(int fd, fd_set *set) ++void __fortify_FD_CLR(int __f, fd_set *__s) + { +- size_t bos = __builtin_object_size(set, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (fd < 0 || fd >= FD_SETSIZE || bos < sizeof(fd_set)) ++ if (__f < 0 || __f >= FD_SETSIZE || __b < sizeof(fd_set)) + __builtin_trap(); +- FD_CLR(fd, set); ++ FD_CLR(__f, __s); + } + + static __inline __attribute__((__always_inline__,__gnu_inline__,__artificial__)) +-void __fortify_FD_SET(int fd, fd_set *set) ++void __fortify_FD_SET(int __f, fd_set *__s) + { +- size_t bos = __builtin_object_size(set, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (fd < 0 || fd >= FD_SETSIZE || bos < sizeof(fd_set)) ++ if (__f < 0 || __f >= FD_SETSIZE || __b < sizeof(fd_set)) + __builtin_trap(); +- FD_SET(fd, set); ++ FD_SET(__f, __s); + } + + #undef FD_CLR +diff --git a/include/sys/socket.h b/include/sys/socket.h +index c6e4c35..e68e21c 100644 +--- a/include/sys/socket.h ++++ b/include/sys/socket.h +@@ -30,42 +30,42 @@ extern "C" { + #undef send + #undef sendto + +-fortify_fn(recv) ssize_t recv(int sockfd, void *buf, size_t n, int flags) ++_FORTIFY_FN(recv) ssize_t recv(int __f, void *__s, size_t __n, int __fl) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_recv(sockfd, buf, n, flags); ++ return __orig_recv(__f, __s, __n, __fl); + } + +-fortify_fn(recvfrom) ssize_t recvfrom(int sockfd, void *buf, size_t n, int flags, +- struct sockaddr *sa, socklen_t *salen) ++_FORTIFY_FN(recvfrom) ssize_t recvfrom(int __f, void *__s, size_t __n, int __fl, ++ struct sockaddr *__a, socklen_t *__l) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_recvfrom(sockfd, buf, n, flags, sa, salen); ++ return __orig_recvfrom(__f, __s, __n, __fl, __a, __l); + } + +-fortify_fn(send) ssize_t send(int sockfd, const void *buf, size_t n, int flags) ++_FORTIFY_FN(send) ssize_t send(int __f, const void *__s, size_t __n, int __fl) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_send(sockfd, buf, n, flags); ++ return __orig_send(__f, __s, __n, __fl); + } + +-fortify_fn(sendto) ssize_t sendto(int sockfd, const void *buf, size_t n, int flags, +- const struct sockaddr *sa, socklen_t salen) ++_FORTIFY_FN(sendto) ssize_t sendto(int __f, const void *__s, size_t __n, int __fl, ++ const struct sockaddr *__a, socklen_t __l) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_sendto(sockfd, buf, n, flags, sa, salen); ++ return __orig_sendto(__f, __s, __n, __fl, __a, __l); + } + + #ifdef __cplusplus +diff --git a/include/unistd.h b/include/unistd.h +index 7986e52..45304e1 100644 +--- a/include/unistd.h ++++ b/include/unistd.h +@@ -37,115 +37,115 @@ extern "C" { + #undef ttyname_r + #undef write + +-fortify_fn(confstr) size_t confstr(int name, char *buf, size_t len) ++_FORTIFY_FN(confstr) size_t confstr(int __n, char *__s, size_t __l) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (len > bos) ++ if (__l > __b) + __builtin_trap(); +- return __orig_confstr(name, buf, len); ++ return __orig_confstr(__n, __s, __l); + } + +-fortify_fn(getcwd) char *getcwd(char *buf, size_t len) ++_FORTIFY_FN(getcwd) char *getcwd(char *__s, size_t __l) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (len > bos) ++ if (__l > __b) + __builtin_trap(); +- return __orig_getcwd(buf, len); ++ return __orig_getcwd(__s, __l); + } + + #if defined(_GNU_SOURCE) || defined(_BSD_SOURCE) + #undef getdomainname +-fortify_fn(getdomainname) int getdomainname(char *name, size_t len) ++_FORTIFY_FN(getdomainname) int getdomainname(char *__s, size_t __l) + { +- size_t bos = __builtin_object_size(name, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (len > bos) ++ if (__l > __b) + __builtin_trap(); +- return __orig_getdomainname(name, len); ++ return __orig_getdomainname(__s, __l); + } + #endif + +-fortify_fn(getgroups) int getgroups(int len, gid_t *set) ++_FORTIFY_FN(getgroups) int getgroups(int __l, gid_t *__s) + { +- size_t bos = __builtin_object_size(set, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (len > bos / sizeof(gid_t)) ++ if (__l > __b / sizeof(gid_t)) + __builtin_trap(); +- return __orig_getgroups(len, set); ++ return __orig_getgroups(__l, __s); + } + +-fortify_fn(gethostname) int gethostname(char *name, size_t len) ++_FORTIFY_FN(gethostname) int gethostname(char *__s, size_t __l) + { +- size_t bos = __builtin_object_size(name, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (len > bos) ++ if (__l > __b) + __builtin_trap(); +- return __orig_gethostname(name, len); ++ return __orig_gethostname(__s, __l); + } + +-fortify_fn(getlogin_r) int getlogin_r(char *name, size_t len) ++_FORTIFY_FN(getlogin_r) int getlogin_r(char *__s, size_t __l) + { +- size_t bos = __builtin_object_size(name, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (len > bos) ++ if (__l > __b) + __builtin_trap(); +- return __orig_getlogin_r(name, len); ++ return __orig_getlogin_r(__s, __l); + } + +-fortify_fn(pread) ssize_t pread(int fd, void *buf, size_t n, off_t offset) ++_FORTIFY_FN(pread) ssize_t pread(int __f, void *__s, size_t __n, off_t __o) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_pread(fd, buf, n, offset); ++ return __orig_pread(__f, __s, __n, __o); + } + +-fortify_fn(read) ssize_t read(int fd, void *buf, size_t n) ++_FORTIFY_FN(read) ssize_t read(int __f, void *__s, size_t __n) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_read(fd, buf, n); ++ return __orig_read(__f, __s, __n); + } + +-fortify_fn(readlink) ssize_t readlink(const char *path, char *buf, size_t n) ++_FORTIFY_FN(readlink) ssize_t readlink(const char *__p, char *__s, size_t __n) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_readlink(path, buf, n); ++ return __orig_readlink(__p, __s, __n); + } + +-fortify_fn(readlinkat) ssize_t readlinkat(int fd, const char *path, char *buf, size_t n) ++_FORTIFY_FN(readlinkat) ssize_t readlinkat(int __f, const char *__p, char *__s, size_t __n) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_readlinkat(fd, path, buf, n); ++ return __orig_readlinkat(__f, __p, __s, __n); + } + +-fortify_fn(ttyname_r) int ttyname_r(int fd, char *name, size_t n) ++_FORTIFY_FN(ttyname_r) int ttyname_r(int __f, char *__s, size_t __n) + { +- size_t bos = __builtin_object_size(name, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_ttyname_r(fd, name, n); ++ return __orig_ttyname_r(__f, __s, __n); + } + +-fortify_fn(write) ssize_t write(int fd, const void *buf, size_t n) ++_FORTIFY_FN(write) ssize_t write(int __f, const void *__s, size_t __n) + { +- size_t bos = __builtin_object_size(buf, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos) ++ if (__n > __b) + __builtin_trap(); +- return __orig_write(fd, buf, n); ++ return __orig_write(__f, __s, __n); + } + + #ifdef __cplusplus +diff --git a/include/wchar.h b/include/wchar.h +index 64618f1..6fa86f2 100644 +--- a/include/wchar.h ++++ b/include/wchar.h +@@ -41,190 +41,190 @@ extern "C" { + #undef wmemmove + #undef wmemset + +-fortify_fn(fgetws) wchar_t *fgetws(wchar_t *s, int n, FILE *fp) ++_FORTIFY_FN(fgetws) wchar_t *fgetws(wchar_t *__s, int __n, FILE *__f) + { +- size_t bos = __builtin_object_size(s, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if ((size_t)n > bos / sizeof(wchar_t)) ++ if ((size_t)__n > __b / sizeof(wchar_t)) + __builtin_trap(); +- return __orig_fgetws(s, n, fp); ++ return __orig_fgetws(__s, __n, __f); + } + + #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \ + || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE) + #undef mbsnrtowcs +-fortify_fn(mbsnrtowcs) size_t mbsnrtowcs(wchar_t *d, const char **s, size_t n, +- size_t wn, mbstate_t *st) ++_FORTIFY_FN(mbsnrtowcs) size_t mbsnrtowcs(wchar_t *__d, const char **__s, size_t __n, ++ size_t __wn, mbstate_t *__st) + { +- size_t bos = __builtin_object_size(d, 0); +- size_t r; ++ size_t __b = __builtin_object_size(__d, 0); ++ size_t __r; + +- if (wn > n / sizeof(wchar_t)) { +- bos /= sizeof(wchar_t); +- r = __orig_mbsnrtowcs(d, s, n, wn > bos ? bos : wn, st); +- if (bos < wn && d && *s && r != (size_t)-1) ++ if (__wn > __n / sizeof(wchar_t)) { ++ __b /= sizeof(wchar_t); ++ __r = __orig_mbsnrtowcs(__d, __s, __n, __wn > __b ? __b : __wn, __st); ++ if (__b < __wn && __d && *__s && __r != (size_t)-1) + __builtin_trap(); + } else { +- r = __orig_mbsnrtowcs(d, s, n > bos ? bos : n, wn, st); +- if (bos < n && d && *s && r != (size_t)-1) ++ __r = __orig_mbsnrtowcs(__d, __s, __n > __b ? __b : __n, __wn, __st); ++ if (__b < __n && __d && *__s && __r != (size_t)-1) + __builtin_trap(); + } +- return r; ++ return __r; + } + #endif + +-fortify_fn(mbsrtowcs) size_t mbsrtowcs(wchar_t *d, const char **s, size_t wn, +- mbstate_t *st) ++_FORTIFY_FN(mbsrtowcs) size_t mbsrtowcs(wchar_t *__d, const char **__s, size_t __wn, ++ mbstate_t *__st) + { +- size_t bos = __builtin_object_size(d, 0); +- size_t r; ++ size_t __b = __builtin_object_size(__d, 0); ++ size_t __r; + +- bos /= sizeof(wchar_t); +- r = __orig_mbsrtowcs(d, s, wn > bos ? bos : wn, st); +- if (bos < wn && d && *s && r != (size_t)-1) ++ __b /= sizeof(wchar_t); ++ __r = __orig_mbsrtowcs(__d, __s, __wn > __b ? __b : __wn, __st); ++ if (__b < __wn && __d && *__s && __r != (size_t)-1) + __builtin_trap(); +- return r; ++ return __r; + } + +-fortify_fn(mbstowcs) size_t mbstowcs(wchar_t *ws, const char *s, size_t wn) ++_FORTIFY_FN(mbstowcs) size_t mbstowcs(wchar_t *__ws, const char *__s, size_t __wn) + { +- size_t bos = __builtin_object_size(ws, 0); ++ size_t __b = __builtin_object_size(__ws, 0); + +- if (ws && wn > bos / sizeof(wchar_t)) ++ if (__ws && __wn > __b / sizeof(wchar_t)) + __builtin_trap(); +- return __orig_mbstowcs(ws, s, wn); ++ return __orig_mbstowcs(__ws, __s, __wn); + } + +-fortify_fn(wcrtomb) size_t wcrtomb(char *s, wchar_t wc, mbstate_t *st) ++_FORTIFY_FN(wcrtomb) size_t wcrtomb(char *__s, wchar_t __w, mbstate_t *__st) + { +- size_t bos = __builtin_object_size(s, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (s && MB_CUR_MAX > bos) ++ if (__s && MB_CUR_MAX > __b) + __builtin_trap(); +- return __orig_wcrtomb(s, wc, st); ++ return __orig_wcrtomb(__s, __w, __st); + } + +-fortify_fn(wcscat) wchar_t *wcscat(wchar_t *d, const wchar_t *s) ++_FORTIFY_FN(wcscat) wchar_t *wcscat(wchar_t *__d, const wchar_t *__s) + { +- size_t bos = __builtin_object_size(d, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (wcslen(s) + wcslen(d) + 1 > bos / sizeof(wchar_t)) ++ if (wcslen(__s) + wcslen(__d) + 1 > __b / sizeof(wchar_t)) + __builtin_trap(); +- return __orig_wcscat(d, s); ++ return __orig_wcscat(__d, __s); + } + +-fortify_fn(wcscpy) wchar_t *wcscpy(wchar_t *d, const wchar_t *s) ++_FORTIFY_FN(wcscpy) wchar_t *wcscpy(wchar_t *__d, const wchar_t *__s) + { +- size_t bos = __builtin_object_size(d, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (wcslen(s) + 1 > bos / sizeof(wchar_t)) ++ if (wcslen(__s) + 1 > __b / sizeof(wchar_t)) + __builtin_trap(); +- return __orig_wcscpy(d, s); ++ return __orig_wcscpy(__d, __s); + } + +-fortify_fn(wcsncat) wchar_t *wcsncat(wchar_t *d, const wchar_t *s, size_t n) ++_FORTIFY_FN(wcsncat) wchar_t *wcsncat(wchar_t *__d, const wchar_t *__s, size_t __n) + { +- size_t bos = __builtin_object_size(d, 0); +- size_t slen, dlen; ++ size_t __b = __builtin_object_size(__d, 0); ++ size_t __sl, __dl; + +- if (n > bos / sizeof(wchar_t)) { +- slen = wcslen(s); +- dlen = wcslen(d); +- if (slen > n) +- slen = n; +- if (slen + dlen + 1 > bos / sizeof(wchar_t)) ++ if (__n > __b / sizeof(wchar_t)) { ++ __sl = wcslen(__s); ++ __dl = wcslen(__d); ++ if (__sl > __n) ++ __sl = __n; ++ if (__sl + __dl + 1 > __b / sizeof(wchar_t)) + __builtin_trap(); + } +- return __orig_wcsncat(d, s, n); ++ return __orig_wcsncat(__d, __s, __n); + } + +-fortify_fn(wcsncpy) wchar_t *wcsncpy(wchar_t *d, const wchar_t *s, size_t n) ++_FORTIFY_FN(wcsncpy) wchar_t *wcsncpy(wchar_t *__d, const wchar_t *__s, size_t __n) + { +- size_t bos = __builtin_object_size(d, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n > bos / sizeof(wchar_t)) ++ if (__n > __b / sizeof(wchar_t)) + __builtin_trap(); +- return __orig_wcsncpy(d, s, n); ++ return __orig_wcsncpy(__d, __s, __n); + } + + #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \ + || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE) + #undef wcsnrtombs +-fortify_fn(wcsnrtombs) size_t wcsnrtombs(char *d, const wchar_t **s, size_t wn, +- size_t n, mbstate_t *st) ++_FORTIFY_FN(wcsnrtombs) size_t wcsnrtombs(char *__d, const wchar_t **__s, size_t __wn, ++ size_t __n, mbstate_t *__st) + { +- size_t bos = __builtin_object_size(d, 0); +- size_t r; ++ size_t __b = __builtin_object_size(__d, 0); ++ size_t __r; + +- if (wn > n / sizeof(wchar_t)) { +- bos /= sizeof(wchar_t); +- r = __orig_wcsnrtombs(d, s, wn > bos ? bos : wn, n, st); +- if (bos < wn && d && *s && r != (size_t)-1) ++ if (__wn > __n / sizeof(wchar_t)) { ++ __b /= sizeof(wchar_t); ++ __r = __orig_wcsnrtombs(__d, __s, __wn > __b ? __b : __wn, __n, __st); ++ if (__b < __wn && __d && *__s && __r != (size_t)-1) + __builtin_trap(); + } else { +- r = __orig_wcsnrtombs(d, s, wn, n > bos ? bos : n, st); +- if (bos < n && d && *s && r != (size_t)-1) ++ __r = __orig_wcsnrtombs(__d, __s, __wn, __n > __b ? __b : __n, __st); ++ if (__b < __n && __d && *__s && __r != (size_t)-1) + __builtin_trap(); + } +- return r; ++ return __r; + } + #endif + +-fortify_fn(wcsrtombs) size_t wcsrtombs(char *d, const wchar_t **s, size_t n, +- mbstate_t *st) ++_FORTIFY_FN(wcsrtombs) size_t wcsrtombs(char *__d, const wchar_t **__s, size_t __n, ++ mbstate_t *__st) + { +- size_t bos = __builtin_object_size(d, 0); +- size_t r; ++ size_t __b = __builtin_object_size(__d, 0); ++ size_t __r; + +- r = __orig_wcsrtombs(d, s, n > bos ? bos : n, st); +- if (bos < n && d && *s && r != (size_t)-1) ++ __r = __orig_wcsrtombs(__d, __s, __n > __b ? __b : __n, __st); ++ if (__b < __n && __d && *__s && __r != (size_t)-1) + __builtin_trap(); +- return r; ++ return __r; + } + +-fortify_fn(wcstombs) size_t wcstombs(char *s, const wchar_t *ws, size_t n) ++_FORTIFY_FN(wcstombs) size_t wcstombs(char *__s, const wchar_t *__ws, size_t __n) + { +- size_t bos = __builtin_object_size(s, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (s && n > bos) ++ if (__s && __n > __b) + __builtin_trap(); +- return __orig_wcstombs(s, ws, n); ++ return __orig_wcstombs(__s, __ws, __n); + } + +-fortify_fn(wctomb) int wctomb(char *s, wchar_t wc) ++_FORTIFY_FN(wctomb) int wctomb(char *__s, wchar_t __w) + { +- size_t bos = __builtin_object_size(s, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (s && MB_CUR_MAX > bos) ++ if (__s && MB_CUR_MAX > __b) + __builtin_trap(); +- return __orig_wctomb(s, wc); ++ return __orig_wctomb(__s, __w); + } + +-fortify_fn(wmemcpy) wchar_t *wmemcpy(wchar_t *d, const wchar_t *s, size_t n) ++_FORTIFY_FN(wmemcpy) wchar_t *wmemcpy(wchar_t *__d, const wchar_t *__s, size_t __n) + { +- size_t bos = __builtin_object_size(d, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n > bos / sizeof(wchar_t)) ++ if (__n > __b / sizeof(wchar_t)) + __builtin_trap(); +- return __orig_wmemcpy(d, s, n); ++ return __orig_wmemcpy(__d, __s, __n); + } + +-fortify_fn(wmemmove) wchar_t *wmemmove(wchar_t *d, const wchar_t *s, size_t n) ++_FORTIFY_FN(wmemmove) wchar_t *wmemmove(wchar_t *__d, const wchar_t *__s, size_t __n) + { +- size_t bos = __builtin_object_size(d, 0); ++ size_t __b = __builtin_object_size(__d, 0); + +- if (n > bos / sizeof(wchar_t)) ++ if (__n > __b / sizeof(wchar_t)) + __builtin_trap(); +- return __orig_wmemmove(d, s, n); ++ return __orig_wmemmove(__d, __s, __n); + } + +-fortify_fn(wmemset) wchar_t *wmemset(wchar_t *s, wchar_t c, size_t n) ++_FORTIFY_FN(wmemset) wchar_t *wmemset(wchar_t *__s, wchar_t __c, size_t __n) + { +- size_t bos = __builtin_object_size(s, 0); ++ size_t __b = __builtin_object_size(__s, 0); + +- if (n > bos / sizeof(wchar_t)) ++ if (__n > __b / sizeof(wchar_t)) + __builtin_trap(); +- return __orig_wmemset(s, c, n); ++ return __orig_wmemset(__s, __c, __n); + } + + #ifdef __cplusplus +-- +2.4.2 + diff --git a/main/fortify-headers/0003-Use-the-__inline__-keyword-instead-of-__inline-to-av.patch b/main/fortify-headers/0003-Use-the-__inline__-keyword-instead-of-__inline-to-av.patch new file mode 100644 index 0000000000..17f6a3ab3a --- /dev/null +++ b/main/fortify-headers/0003-Use-the-__inline__-keyword-instead-of-__inline-to-av.patch @@ -0,0 +1,69 @@ +From 4cdac9cbdaa01f884e0e8b3f947b7f0cb1170729 Mon Sep 17 00:00:00 2001 +From: Trutz Behn <me@trutz.be> +Date: Thu, 4 Jun 2015 15:01:37 +0200 +Subject: [PATCH 3/3] Use the __inline__ keyword instead of __inline to avoid + breakage + +Newer compilers default to GNU11, a C11 dialect. Some software however +is unprepared for this or has wrong compatibility checks. What happens +is that some software will for compatibility with C89 + + #define inline + +before inclusion of a standard header, which is undefined behaviour in +C99 and above (C99/C11 7.1.2/4), as inline is a keyword. + +If any libc headers that are then included via #include_next provide an +__inline macro definition (current musl does this if C++ or C99 and +above is detected) like the following + + #define __inline inline + +this results in any __inline token to be preprocessed away. + +This breaks use of __builtin_va_arg_pack() in our stdio.h at +compile-time as it can only be used in always inlined functions. The +function attributes __always_inline__ and __gnu_inline__ themselves +require an inline specifier on the function to be applied. +--- + include/fortify-headers.h | 2 +- + include/sys/select.h | 4 ++-- + 2 files changed, 3 insertions(+), 3 deletions(-) + +diff --git a/include/fortify-headers.h b/include/fortify-headers.h +index 288a973..c4e6495 100644 +--- a/include/fortify-headers.h ++++ b/include/fortify-headers.h +@@ -19,6 +19,6 @@ + #define _FORTIFY_STR(s) #s + #define _FORTIFY_ORIG(p,fn) __typeof__(fn) __orig_##fn __asm__(_FORTIFY_STR(p) #fn) + #define _FORTIFY_FN(fn) _FORTIFY_ORIG(__USER_LABEL_PREFIX__,fn); \ +- extern __inline __attribute__((__always_inline__,__gnu_inline__,__artificial__)) ++ extern __inline__ __attribute__((__always_inline__,__gnu_inline__,__artificial__)) + + #endif +diff --git a/include/sys/select.h b/include/sys/select.h +index 4623071..db6135d 100644 +--- a/include/sys/select.h ++++ b/include/sys/select.h +@@ -24,7 +24,7 @@ + extern "C" { + #endif + +-static __inline __attribute__((__always_inline__,__gnu_inline__,__artificial__)) ++static __inline__ __attribute__((__always_inline__,__gnu_inline__,__artificial__)) + void __fortify_FD_CLR(int __f, fd_set *__s) + { + size_t __b = __builtin_object_size(__s, 0); +@@ -34,7 +34,7 @@ void __fortify_FD_CLR(int __f, fd_set *__s) + FD_CLR(__f, __s); + } + +-static __inline __attribute__((__always_inline__,__gnu_inline__,__artificial__)) ++static __inline__ __attribute__((__always_inline__,__gnu_inline__,__artificial__)) + void __fortify_FD_SET(int __f, fd_set *__s) + { + size_t __b = __builtin_object_size(__s, 0); +-- +2.4.2 + diff --git a/main/fortify-headers/APKBUILD b/main/fortify-headers/APKBUILD index a2bbd52aac..8ea50b4118 100644 --- a/main/fortify-headers/APKBUILD +++ b/main/fortify-headers/APKBUILD @@ -2,7 +2,7 @@ # Maintainer: Timo Teräs <timo.teras@iki.fi> pkgname=fortify-headers pkgver=0.5 -pkgrel=0 +pkgrel=1 pkgdesc="standalone fortify source implementation" url="http://git.2f30.org/fortify-headers/" arch="noarch" @@ -13,6 +13,9 @@ makedepends="$depends_dev" install="" subpackages="" source="http://dl.2f30.org/releases/$pkgname-$pkgver.tar.gz + 0001-Fix-usage-of-__USER_LABEL_PREFIX__.patch + 0002-Use-namespace-safe-macro-param-and-variable-names.patch + 0003-Use-the-__inline__-keyword-instead-of-__inline-to-av.patch " _builddir="$srcdir"/$pkgname-$pkgver @@ -36,6 +39,15 @@ package() { rm -f "$pkgdir"/usr/lib/*.la } -md5sums="56487ae93e3f45ffc0736afd3ebce549 fortify-headers-0.5.tar.gz" -sha256sums="4564f0ee9cb7c789b5a827d21a0d3b6da9df61fcb7ba31b711999f638e9e913a fortify-headers-0.5.tar.gz" -sha512sums="951e3a5771c3cf9b2fe248e62badfc6699f0a05b8967f3982d279de8473501c66a6d1c17d7b42c90ef8bd303c06a642d7bdfea334caef892c90a15c45d4bb1c4 fortify-headers-0.5.tar.gz" +md5sums="56487ae93e3f45ffc0736afd3ebce549 fortify-headers-0.5.tar.gz +714b730430421676f4f4522068d383a8 0001-Fix-usage-of-__USER_LABEL_PREFIX__.patch +a187cf4e7357b91d2df939494e8fc238 0002-Use-namespace-safe-macro-param-and-variable-names.patch +d541c38e645b34d15b178b4f4204d3a9 0003-Use-the-__inline__-keyword-instead-of-__inline-to-av.patch" +sha256sums="4564f0ee9cb7c789b5a827d21a0d3b6da9df61fcb7ba31b711999f638e9e913a fortify-headers-0.5.tar.gz +d2a33f6689039f33e5ead42fe27e1be65580beb2c3e748efe7437f24a6366e20 0001-Fix-usage-of-__USER_LABEL_PREFIX__.patch +d6e4e8d75d0543feca2e5966bb9586ec6e9113e66c80a8a47d5b45ad9d3141eb 0002-Use-namespace-safe-macro-param-and-variable-names.patch +004c8f2332a5f4b258d7a685425c285fd90b55f0d93f11de8095db2a44f86194 0003-Use-the-__inline__-keyword-instead-of-__inline-to-av.patch" +sha512sums="951e3a5771c3cf9b2fe248e62badfc6699f0a05b8967f3982d279de8473501c66a6d1c17d7b42c90ef8bd303c06a642d7bdfea334caef892c90a15c45d4bb1c4 fortify-headers-0.5.tar.gz +060a2e8b4a5f441368df57447528e7c29491c3f4c03fc095cefaa9ed79858601f74496b1734be8604534696b74b40cd47fa7b8ba384e143ff21db75cf09d8ae8 0001-Fix-usage-of-__USER_LABEL_PREFIX__.patch +8a4b76dfcbe9c50a1a1cd2ba2757a1936a296532bc63227e0783c5b9e881f96363c421b6470456fe901a4a51a0ff1e0ca2f3b084dda4b82e0878991f3caa8854 0002-Use-namespace-safe-macro-param-and-variable-names.patch +538830d2f69c8b628e0b65ac37b02ff78a6af4a10b46aa8b00c3e7830d7f52a55475ba78793f84ad1ca3614f0eebebd1932101dca869af5ce92044682365eadf 0003-Use-the-__inline__-keyword-instead-of-__inline-to-av.patch" |