forked from OSchip/llvm-project
[asan] i686-linux-android support.
Large part of this change is required due to https://code.google.com/p/android/issues/detail?id=61799 dlsym() crashes when symbol resolution fails, which means we have to limit the interceptor list instead of relying on runtime detection. There are minor differencies in system headers, too. llvm-svn: 212273
This commit is contained in:
parent
7c2d32bf87
commit
4af9c0ea80
|
@ -68,7 +68,9 @@
|
|||
# define ASAN_INTERCEPT_SIGLONGJMP 0
|
||||
#endif
|
||||
|
||||
#if ASAN_HAS_EXCEPTIONS && !SANITIZER_WINDOWS
|
||||
// Android bug: https://code.google.com/p/android/issues/detail?id=61799
|
||||
#if ASAN_HAS_EXCEPTIONS && !SANITIZER_WINDOWS && \
|
||||
!(SANITIZER_ANDROID && defined(__i386))
|
||||
# define ASAN_INTERCEPT___CXA_THROW 1
|
||||
#else
|
||||
# define ASAN_INTERCEPT___CXA_THROW 0
|
||||
|
|
|
@ -1834,6 +1834,30 @@ INTERCEPTOR(struct __sanitizer_hostent *, gethostbyname2, char *name, int af) {
|
|||
#endif
|
||||
|
||||
#if SANITIZER_INTERCEPT_GETHOSTBYNAME_R
|
||||
INTERCEPTOR(int, gethostbyname_r, char *name, struct __sanitizer_hostent *ret,
|
||||
char *buf, SIZE_T buflen, __sanitizer_hostent **result,
|
||||
int *h_errnop) {
|
||||
void *ctx;
|
||||
COMMON_INTERCEPTOR_ENTER(ctx, gethostbyname_r, name, ret, buf, buflen, result,
|
||||
h_errnop);
|
||||
// FIXME: under ASan the call below may write to freed memory and corrupt
|
||||
// its metadata. See
|
||||
// https://code.google.com/p/address-sanitizer/issues/detail?id=321.
|
||||
int res = REAL(gethostbyname_r)(name, ret, buf, buflen, result, h_errnop);
|
||||
if (result) {
|
||||
COMMON_INTERCEPTOR_WRITE_RANGE(ctx, result, sizeof(*result));
|
||||
if (res == 0 && *result) write_hostent(ctx, *result);
|
||||
}
|
||||
if (h_errnop)
|
||||
COMMON_INTERCEPTOR_WRITE_RANGE(ctx, h_errnop, sizeof(*h_errnop));
|
||||
return res;
|
||||
}
|
||||
#define INIT_GETHOSTBYNAME_R COMMON_INTERCEPT_FUNCTION(gethostbyname_r);
|
||||
#else
|
||||
#define INIT_GETHOSTBYNAME_R
|
||||
#endif
|
||||
|
||||
#if SANITIZER_INTERCEPT_GETHOSTENT_R
|
||||
INTERCEPTOR(int, gethostent_r, struct __sanitizer_hostent *ret, char *buf,
|
||||
SIZE_T buflen, __sanitizer_hostent **result, int *h_errnop) {
|
||||
void *ctx;
|
||||
|
@ -1851,7 +1875,13 @@ INTERCEPTOR(int, gethostent_r, struct __sanitizer_hostent *ret, char *buf,
|
|||
COMMON_INTERCEPTOR_WRITE_RANGE(ctx, h_errnop, sizeof(*h_errnop));
|
||||
return res;
|
||||
}
|
||||
#define INIT_GETHOSTENT_R \
|
||||
COMMON_INTERCEPT_FUNCTION(gethostent_r);
|
||||
#else
|
||||
#define INIT_GETHOSTENT_R
|
||||
#endif
|
||||
|
||||
#if SANITIZER_INTERCEPT_GETHOSTBYADDR_R
|
||||
INTERCEPTOR(int, gethostbyaddr_r, void *addr, int len, int type,
|
||||
struct __sanitizer_hostent *ret, char *buf, SIZE_T buflen,
|
||||
__sanitizer_hostent **result, int *h_errnop) {
|
||||
|
@ -1872,26 +1902,13 @@ INTERCEPTOR(int, gethostbyaddr_r, void *addr, int len, int type,
|
|||
COMMON_INTERCEPTOR_WRITE_RANGE(ctx, h_errnop, sizeof(*h_errnop));
|
||||
return res;
|
||||
}
|
||||
#define INIT_GETHOSTBYADDR_R \
|
||||
COMMON_INTERCEPT_FUNCTION(gethostbyaddr_r);
|
||||
#else
|
||||
#define INIT_GETHOSTBYADDR_R
|
||||
#endif
|
||||
|
||||
INTERCEPTOR(int, gethostbyname_r, char *name, struct __sanitizer_hostent *ret,
|
||||
char *buf, SIZE_T buflen, __sanitizer_hostent **result,
|
||||
int *h_errnop) {
|
||||
void *ctx;
|
||||
COMMON_INTERCEPTOR_ENTER(ctx, gethostbyname_r, name, ret, buf, buflen, result,
|
||||
h_errnop);
|
||||
// FIXME: under ASan the call below may write to freed memory and corrupt
|
||||
// its metadata. See
|
||||
// https://code.google.com/p/address-sanitizer/issues/detail?id=321.
|
||||
int res = REAL(gethostbyname_r)(name, ret, buf, buflen, result, h_errnop);
|
||||
if (result) {
|
||||
COMMON_INTERCEPTOR_WRITE_RANGE(ctx, result, sizeof(*result));
|
||||
if (res == 0 && *result) write_hostent(ctx, *result);
|
||||
}
|
||||
if (h_errnop)
|
||||
COMMON_INTERCEPTOR_WRITE_RANGE(ctx, h_errnop, sizeof(*h_errnop));
|
||||
return res;
|
||||
}
|
||||
|
||||
#if SANITIZER_INTERCEPT_GETHOSTBYNAME2_R
|
||||
INTERCEPTOR(int, gethostbyname2_r, char *name, int af,
|
||||
struct __sanitizer_hostent *ret, char *buf, SIZE_T buflen,
|
||||
__sanitizer_hostent **result, int *h_errnop) {
|
||||
|
@ -1911,13 +1928,10 @@ INTERCEPTOR(int, gethostbyname2_r, char *name, int af,
|
|||
COMMON_INTERCEPTOR_WRITE_RANGE(ctx, h_errnop, sizeof(*h_errnop));
|
||||
return res;
|
||||
}
|
||||
#define INIT_GETHOSTBYNAME_R \
|
||||
COMMON_INTERCEPT_FUNCTION(gethostent_r); \
|
||||
COMMON_INTERCEPT_FUNCTION(gethostbyaddr_r); \
|
||||
COMMON_INTERCEPT_FUNCTION(gethostbyname_r); \
|
||||
#define INIT_GETHOSTBYNAME2_R \
|
||||
COMMON_INTERCEPT_FUNCTION(gethostbyname2_r);
|
||||
#else
|
||||
#define INIT_GETHOSTBYNAME_R
|
||||
#define INIT_GETHOSTBYNAME2_R
|
||||
#endif
|
||||
|
||||
#if SANITIZER_INTERCEPT_GETSOCKOPT
|
||||
|
@ -3151,7 +3165,7 @@ INTERCEPTOR(int, initgroups, char *user, u32 group) {
|
|||
#define INIT_INITGROUPS
|
||||
#endif
|
||||
|
||||
#if SANITIZER_INTERCEPT_ETHER
|
||||
#if SANITIZER_INTERCEPT_ETHER_NTOA_ATON
|
||||
INTERCEPTOR(char *, ether_ntoa, __sanitizer_ether_addr *addr) {
|
||||
void *ctx;
|
||||
COMMON_INTERCEPTOR_ENTER(ctx, ether_ntoa, addr);
|
||||
|
@ -3168,6 +3182,14 @@ INTERCEPTOR(__sanitizer_ether_addr *, ether_aton, char *buf) {
|
|||
if (res) COMMON_INTERCEPTOR_INITIALIZE_RANGE(res, sizeof(*res));
|
||||
return res;
|
||||
}
|
||||
#define INIT_ETHER_NTOA_ATON \
|
||||
COMMON_INTERCEPT_FUNCTION(ether_ntoa); \
|
||||
COMMON_INTERCEPT_FUNCTION(ether_aton);
|
||||
#else
|
||||
#define INIT_ETHER_NTOA_ATON
|
||||
#endif
|
||||
|
||||
#if SANITIZER_INTERCEPT_ETHER_HOST
|
||||
INTERCEPTOR(int, ether_ntohost, char *hostname, __sanitizer_ether_addr *addr) {
|
||||
void *ctx;
|
||||
COMMON_INTERCEPTOR_ENTER(ctx, ether_ntohost, hostname, addr);
|
||||
|
@ -3208,14 +3230,12 @@ INTERCEPTOR(int, ether_line, char *line, __sanitizer_ether_addr *addr,
|
|||
}
|
||||
return res;
|
||||
}
|
||||
#define INIT_ETHER \
|
||||
COMMON_INTERCEPT_FUNCTION(ether_ntoa); \
|
||||
COMMON_INTERCEPT_FUNCTION(ether_aton); \
|
||||
#define INIT_ETHER_HOST \
|
||||
COMMON_INTERCEPT_FUNCTION(ether_ntohost); \
|
||||
COMMON_INTERCEPT_FUNCTION(ether_hostton); \
|
||||
COMMON_INTERCEPT_FUNCTION(ether_line);
|
||||
#else
|
||||
#define INIT_ETHER
|
||||
#define INIT_ETHER_HOST
|
||||
#endif
|
||||
|
||||
#if SANITIZER_INTERCEPT_ETHER_R
|
||||
|
@ -3676,6 +3696,14 @@ INTERCEPTOR(float, lgammaf_r, float x, int *signp) {
|
|||
if (signp) COMMON_INTERCEPTOR_WRITE_RANGE(ctx, signp, sizeof(*signp));
|
||||
return res;
|
||||
}
|
||||
#define INIT_LGAMMA_R \
|
||||
COMMON_INTERCEPT_FUNCTION(lgamma_r); \
|
||||
COMMON_INTERCEPT_FUNCTION(lgammaf_r);
|
||||
#else
|
||||
#define INIT_LGAMMA_R
|
||||
#endif
|
||||
|
||||
#if SANITIZER_INTERCEPT_LGAMMAL_R
|
||||
INTERCEPTOR(long double, lgammal_r, long double x, int *signp) {
|
||||
void *ctx;
|
||||
COMMON_INTERCEPTOR_ENTER(ctx, lgammal_r, x, signp);
|
||||
|
@ -3686,12 +3714,9 @@ INTERCEPTOR(long double, lgammal_r, long double x, int *signp) {
|
|||
if (signp) COMMON_INTERCEPTOR_WRITE_RANGE(ctx, signp, sizeof(*signp));
|
||||
return res;
|
||||
}
|
||||
#define INIT_LGAMMA_R \
|
||||
COMMON_INTERCEPT_FUNCTION(lgamma_r); \
|
||||
COMMON_INTERCEPT_FUNCTION(lgammaf_r); \
|
||||
COMMON_INTERCEPT_FUNCTION(lgammal_r);
|
||||
#define INIT_LGAMMAL_R COMMON_INTERCEPT_FUNCTION(lgammal_r);
|
||||
#else
|
||||
#define INIT_LGAMMA_R
|
||||
#define INIT_LGAMMAL_R
|
||||
#endif
|
||||
|
||||
#if SANITIZER_INTERCEPT_DRAND48_R
|
||||
|
@ -4654,6 +4679,9 @@ static void InitializeCommonInterceptors() {
|
|||
INIT_GETSOCKNAME;
|
||||
INIT_GETHOSTBYNAME;
|
||||
INIT_GETHOSTBYNAME_R;
|
||||
INIT_GETHOSTBYNAME2_R;
|
||||
INIT_GETHOSTBYADDR_R;
|
||||
INIT_GETHOSTENT_R;
|
||||
INIT_GETSOCKOPT;
|
||||
INIT_ACCEPT;
|
||||
INIT_ACCEPT4;
|
||||
|
@ -4705,7 +4733,8 @@ static void InitializeCommonInterceptors() {
|
|||
INIT_STATVFS;
|
||||
INIT_STATVFS64;
|
||||
INIT_INITGROUPS;
|
||||
INIT_ETHER;
|
||||
INIT_ETHER_NTOA_ATON;
|
||||
INIT_ETHER_HOST;
|
||||
INIT_ETHER_R;
|
||||
INIT_SHMCTL;
|
||||
INIT_RANDOM_R;
|
||||
|
@ -4731,6 +4760,7 @@ static void InitializeCommonInterceptors() {
|
|||
INIT_REMQUO;
|
||||
INIT_LGAMMA;
|
||||
INIT_LGAMMA_R;
|
||||
INIT_LGAMMAL_R;
|
||||
INIT_DRAND48_R;
|
||||
INIT_RAND_R;
|
||||
INIT_GETLINE;
|
||||
|
|
|
@ -831,6 +831,7 @@ POST_SYSCALL(stat)(long res, const void *filename, void *statbuf) {
|
|||
}
|
||||
}
|
||||
|
||||
#if !SANITIZER_ANDROID
|
||||
PRE_SYSCALL(statfs)(const void *path, void *buf) {
|
||||
if (path)
|
||||
PRE_READ(path, __sanitizer::internal_strlen((const char *)path) + 1);
|
||||
|
@ -868,6 +869,7 @@ POST_SYSCALL(fstatfs64)(long res, long fd, long sz, void *buf) {
|
|||
if (buf) POST_WRITE(buf, struct_statfs64_sz);
|
||||
}
|
||||
}
|
||||
#endif // !SANITIZER_ANDROID
|
||||
|
||||
PRE_SYSCALL(lstat)(const void *filename, void *statbuf) {
|
||||
if (filename)
|
||||
|
@ -2295,7 +2297,7 @@ PRE_SYSCALL(ni_syscall)() {}
|
|||
POST_SYSCALL(ni_syscall)(long res) {}
|
||||
|
||||
PRE_SYSCALL(ptrace)(long request, long pid, long addr, long data) {
|
||||
#if defined(__i386) || defined (__x86_64)
|
||||
#if !SANITIZER_ANDROID && (defined(__i386) || defined (__x86_64))
|
||||
if (data) {
|
||||
if (request == ptrace_setregs) {
|
||||
PRE_READ((void *)data, struct_user_regs_struct_sz);
|
||||
|
@ -2314,7 +2316,7 @@ PRE_SYSCALL(ptrace)(long request, long pid, long addr, long data) {
|
|||
}
|
||||
|
||||
POST_SYSCALL(ptrace)(long res, long request, long pid, long addr, long data) {
|
||||
#if defined(__i386) || defined (__x86_64)
|
||||
#if !SANITIZER_ANDROID && (defined(__i386) || defined (__x86_64))
|
||||
if (res >= 0 && data) {
|
||||
// Note that this is different from the interceptor in
|
||||
// sanitizer_common_interceptors.inc.
|
||||
|
|
|
@ -75,11 +75,11 @@
|
|||
#define SANITIZER_INTERCEPT_STRPTIME SI_NOT_WINDOWS
|
||||
|
||||
#define SANITIZER_INTERCEPT_SCANF SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_ISOC99_SCANF SI_LINUX
|
||||
#define SANITIZER_INTERCEPT_ISOC99_SCANF SI_LINUX_NOT_ANDROID
|
||||
|
||||
#ifndef SANITIZER_INTERCEPT_PRINTF
|
||||
# define SANITIZER_INTERCEPT_PRINTF SI_NOT_WINDOWS
|
||||
# define SANITIZER_INTERCEPT_ISOC99_PRINTF SI_LINUX
|
||||
# define SANITIZER_INTERCEPT_ISOC99_PRINTF SI_LINUX_NOT_ANDROID
|
||||
#endif
|
||||
|
||||
#define SANITIZER_INTERCEPT_FREXP 1
|
||||
|
@ -88,10 +88,10 @@
|
|||
#define SANITIZER_INTERCEPT_GETPWNAM_AND_FRIENDS SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_GETPWNAM_R_AND_FRIENDS \
|
||||
SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_GETPWENT SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_GETPWENT SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_FGETPWENT SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_GETPWENT_R SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_SETPWENT SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_SETPWENT SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_CLOCK_GETTIME SI_LINUX
|
||||
#define SANITIZER_INTERCEPT_GETITIMER SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_TIME SI_NOT_WINDOWS
|
||||
|
@ -104,9 +104,12 @@
|
|||
#define SANITIZER_INTERCEPT_GETSOCKNAME SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_GETHOSTBYNAME SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_GETHOSTBYNAME_R SI_LINUX
|
||||
#define SANITIZER_INTERCEPT_GETHOSTBYNAME2_R SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_GETHOSTBYADDR_R SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_GETHOSTENT_R SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_GETSOCKOPT SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_ACCEPT SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_ACCEPT4 SI_LINUX
|
||||
#define SANITIZER_INTERCEPT_ACCEPT4 SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_MODF SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_RECVMSG SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_GETPEERNAME SI_NOT_WINDOWS
|
||||
|
@ -119,13 +122,13 @@
|
|||
(defined(__i386) || defined (__x86_64)) // NOLINT
|
||||
#define SANITIZER_INTERCEPT_SETLOCALE SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_GETCWD SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_GET_CURRENT_DIR_NAME SI_LINUX
|
||||
#define SANITIZER_INTERCEPT_GET_CURRENT_DIR_NAME SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_STRTOIMAX SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_MBSTOWCS SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_MBSNRTOWCS SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_WCSTOMBS SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_WCSNRTOMBS SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_TCGETATTR SI_LINUX
|
||||
#define SANITIZER_INTERCEPT_TCGETATTR SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_REALPATH SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_CANONICALIZE_FILE_NAME SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_CONFSTR SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
|
@ -142,19 +145,20 @@
|
|||
#define SANITIZER_INTERCEPT_SIGWAIT SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_SIGWAITINFO SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_SIGTIMEDWAIT SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_SIGSETOPS SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_SIGSETOPS SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_SIGPENDING SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_SIGPROCMASK SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_BACKTRACE SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_GETMNTENT SI_LINUX
|
||||
#define SANITIZER_INTERCEPT_GETMNTENT_R SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_STATFS SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_STATFS SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_STATFS64 \
|
||||
(SI_MAC && !SI_IOS) || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_STATVFS SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_STATVFS64 SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_INITGROUPS SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_ETHER SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_ETHER_NTOA_ATON SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_ETHER_HOST SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_ETHER_R SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_SHMCTL \
|
||||
(SI_LINUX_NOT_ANDROID && SANITIZER_WORDSIZE == 64)
|
||||
|
@ -183,6 +187,7 @@
|
|||
#define SANITIZER_INTERCEPT_REMQUO SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_LGAMMA SI_NOT_WINDOWS
|
||||
#define SANITIZER_INTERCEPT_LGAMMA_R SI_LINUX
|
||||
#define SANITIZER_INTERCEPT_LGAMMAL_R SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_DRAND48_R SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_RAND_R SI_MAC || SI_LINUX_NOT_ANDROID
|
||||
#define SANITIZER_INTERCEPT_ICONV SI_LINUX_NOT_ANDROID
|
||||
|
|
|
@ -50,18 +50,15 @@
|
|||
|
||||
#include <linux/aio_abi.h>
|
||||
|
||||
#if SANITIZER_ANDROID
|
||||
#include <asm/statfs.h>
|
||||
#else
|
||||
#include <sys/statfs.h>
|
||||
#endif
|
||||
|
||||
#if !SANITIZER_ANDROID
|
||||
#include <sys/statfs.h>
|
||||
#include <linux/perf_event.h>
|
||||
#endif
|
||||
|
||||
namespace __sanitizer {
|
||||
#if !SANITIZER_ANDROID
|
||||
unsigned struct_statfs64_sz = sizeof(struct statfs64);
|
||||
#endif
|
||||
} // namespace __sanitizer
|
||||
|
||||
#if !defined(__powerpc64__) && !defined(__x86_64__) && !defined(__aarch64__)\
|
||||
|
|
|
@ -191,13 +191,14 @@ namespace __sanitizer {
|
|||
unsigned struct_tms_sz = sizeof(struct tms);
|
||||
unsigned struct_sigevent_sz = sizeof(struct sigevent);
|
||||
unsigned struct_sched_param_sz = sizeof(struct sched_param);
|
||||
unsigned struct_statfs_sz = sizeof(struct statfs);
|
||||
|
||||
|
||||
#if SANITIZER_MAC && !SANITIZER_IOS
|
||||
unsigned struct_statfs64_sz = sizeof(struct statfs64);
|
||||
#endif // SANITIZER_MAC && !SANITIZER_IOS
|
||||
|
||||
#if !SANITIZER_ANDROID
|
||||
unsigned struct_statfs_sz = sizeof(struct statfs);
|
||||
unsigned struct_sockaddr_sz = sizeof(struct sockaddr);
|
||||
unsigned ucontext_t_sz = sizeof(ucontext_t);
|
||||
#endif // !SANITIZER_ANDROID
|
||||
|
|
|
@ -39,11 +39,11 @@ namespace __sanitizer {
|
|||
extern unsigned struct_itimerspec_sz;
|
||||
extern unsigned struct_sigevent_sz;
|
||||
extern unsigned struct_sched_param_sz;
|
||||
extern unsigned struct_statfs_sz;
|
||||
extern unsigned struct_statfs64_sz;
|
||||
extern unsigned struct_sockaddr_sz;
|
||||
|
||||
#if !SANITIZER_ANDROID
|
||||
extern unsigned struct_statfs_sz;
|
||||
extern unsigned struct_sockaddr_sz;
|
||||
extern unsigned ucontext_t_sz;
|
||||
#endif // !SANITIZER_ANDROID
|
||||
|
||||
|
|
Loading…
Reference in New Issue