[msan] Interceptors for pipe2 and socketpair.
llvm-svn: 179022
This commit is contained in:
parent
d66c414619
commit
b4eac2f810
|
@ -540,6 +540,22 @@ INTERCEPTOR(int, pipe, int pipefd[2]) {
|
|||
return res;
|
||||
}
|
||||
|
||||
INTERCEPTOR(int, pipe2, int pipefd[2], int flags) {
|
||||
ENSURE_MSAN_INITED();
|
||||
int res = REAL(pipe2)(pipefd, flags);
|
||||
if (!res)
|
||||
__msan_unpoison(pipefd, sizeof(int[2]));
|
||||
return res;
|
||||
}
|
||||
|
||||
INTERCEPTOR(int, socketpair, int domain, int type, int protocol, int sv[2]) {
|
||||
ENSURE_MSAN_INITED();
|
||||
int res = REAL(socketpair)(domain, type, protocol, sv);
|
||||
if (!res)
|
||||
__msan_unpoison(sv, sizeof(int[2]));
|
||||
return res;
|
||||
}
|
||||
|
||||
INTERCEPTOR(int, wait, int *status) {
|
||||
ENSURE_MSAN_INITED();
|
||||
int res = REAL(wait)(status);
|
||||
|
@ -1109,6 +1125,8 @@ void InitializeInterceptors() {
|
|||
INTERCEPT_FUNCTION(__xstat64);
|
||||
INTERCEPT_FUNCTION(__lxstat64);
|
||||
INTERCEPT_FUNCTION(pipe);
|
||||
INTERCEPT_FUNCTION(pipe2);
|
||||
INTERCEPT_FUNCTION(socketpair);
|
||||
INTERCEPT_FUNCTION(wait);
|
||||
INTERCEPT_FUNCTION(waitpid);
|
||||
INTERCEPT_FUNCTION(fgets);
|
||||
|
|
|
@ -41,6 +41,7 @@
|
|||
#include <sys/types.h>
|
||||
#include <dirent.h>
|
||||
#include <pwd.h>
|
||||
#include <sys/socket.h>
|
||||
|
||||
#if defined(__i386__) || defined(__x86_64__)
|
||||
# include <emmintrin.h>
|
||||
|
@ -605,6 +606,26 @@ TEST(MemorySanitizer, pipe) {
|
|||
close(pipefd[1]);
|
||||
}
|
||||
|
||||
TEST(MemorySanitizer, pipe2) {
|
||||
int* pipefd = new int[2];
|
||||
int res = pipe2(pipefd, O_NONBLOCK);
|
||||
assert(!res);
|
||||
EXPECT_NOT_POISONED(pipefd[0]);
|
||||
EXPECT_NOT_POISONED(pipefd[1]);
|
||||
close(pipefd[0]);
|
||||
close(pipefd[1]);
|
||||
}
|
||||
|
||||
TEST(MemorySanitizer, socketpair) {
|
||||
int sv[2];
|
||||
int res = socketpair(AF_UNIX, SOCK_STREAM, 0, sv);
|
||||
assert(!res);
|
||||
EXPECT_NOT_POISONED(sv[0]);
|
||||
EXPECT_NOT_POISONED(sv[1]);
|
||||
close(sv[0]);
|
||||
close(sv[1]);
|
||||
}
|
||||
|
||||
TEST(MemorySanitizer, getcwd) {
|
||||
char path[PATH_MAX + 1];
|
||||
char* res = getcwd(path, sizeof(path));
|
||||
|
|
Loading…
Reference in New Issue