AddressSanitizer: revert r150683 - we can't get rid of headers that easily

llvm-svn: 150699
This commit is contained in:
Alexey Samsonov 2012-02-16 17:00:45 +00:00
parent 3fc6e4a7cd
commit fbb50f19ad
2 changed files with 12 additions and 12 deletions

View File

@ -34,11 +34,11 @@
#if defined(__APPLE__)
// FIXME(samsonov): Gradually replace system headers with declarations of
// intercepted functions. We need these declarations on Mac to get addresses of
// the functions to intercept.
// intercepted functions.
#include <pthread.h>
#include <signal.h>
#include <string.h>
#include <strings.h>
#endif // __APPLE__
namespace __asan {
@ -218,10 +218,8 @@ static void *asan_thread_start(void *arg) {
}
#ifndef _WIN32
extern "C"
int pthread_create(void *thread, const void *attr,
void *(*start_routine)(void*), void *arg);
INTERCEPTOR(int, pthread_create, void *thread, const void *attr,
INTERCEPTOR(int, pthread_create, pthread_t *thread,
const pthread_attr_t *attr,
void *(*start_routine)(void*), void *arg) {
GET_STACK_TRACE_HERE(kStackTraceMax);
int current_tid = asanThreadRegistry().GetCurrentTidOrMinusOne();
@ -239,9 +237,8 @@ INTERCEPTOR(void*, signal, int signum, void *handler) {
return NULL;
}
extern "C"
int sigaction(int signum, const void *act, void *oldact);
INTERCEPTOR(int, sigaction, int signum, const void *act, void *oldact) {
INTERCEPTOR(int, sigaction, int signum, const struct sigaction *act,
struct sigaction *oldact) {
if (!AsanInterceptsSignal(signum)) {
return REAL(sigaction)(signum, act, oldact);
}
@ -396,7 +393,8 @@ DEFINE_REAL(char*, index, const char *string, int c);
#endif
#ifdef ANDROID
DEFINE_REAL(int, sigaction, int signum, const void *act, void *oldact);
DEFINE_REAL(int, sigaction, int signum, const struct sigaction *act,
struct sigaction *oldact);
#endif
INTERCEPTOR(int, strcasecmp, const char *s1, const char *s2) {

View File

@ -24,7 +24,9 @@ DECLARE_REAL(char*, strchr, const char *str, int c);
DECLARE_REAL(size_t, strlen, const char *s);
DECLARE_REAL(char*, strncpy, char *to, const char *from, size_t size);
DECLARE_REAL(size_t, strnlen, const char *s, size_t maxlen);
DECLARE_REAL(int, sigaction, int signum, const void *act, void *oldact);
struct sigaction;
DECLARE_REAL(int, sigaction, int signum, const struct sigaction *act,
struct sigaction *oldact);
namespace __asan {