2019-08-01 20:41:23 +08:00
|
|
|
//===-- dfsan_interceptors.cpp --------------------------------------------===//
|
2013-08-16 05:18:53 +08:00
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2013-08-16 05:18:53 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file is a part of DataFlowSanitizer.
|
|
|
|
//
|
|
|
|
// Interceptors for standard library functions.
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2020-08-20 06:07:17 +08:00
|
|
|
#include <sys/syscall.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
2013-11-17 17:41:47 +08:00
|
|
|
#include "dfsan/dfsan.h"
|
2013-08-16 05:18:53 +08:00
|
|
|
#include "interception/interception.h"
|
|
|
|
#include "sanitizer_common/sanitizer_common.h"
|
|
|
|
|
2016-09-16 05:02:18 +08:00
|
|
|
using namespace __sanitizer;
|
|
|
|
|
2020-10-06 00:56:50 +08:00
|
|
|
namespace {
|
|
|
|
|
|
|
|
bool interceptors_initialized;
|
|
|
|
|
|
|
|
} // namespace
|
2020-08-20 06:07:17 +08:00
|
|
|
|
2013-08-16 05:18:53 +08:00
|
|
|
INTERCEPTOR(void *, mmap, void *addr, SIZE_T length, int prot, int flags,
|
|
|
|
int fd, OFF_T offset) {
|
2020-08-20 06:07:17 +08:00
|
|
|
void *res;
|
|
|
|
|
|
|
|
// interceptors_initialized is set to true during preinit_array, when we're
|
|
|
|
// single-threaded. So we don't need to worry about accessing it atomically.
|
|
|
|
if (!interceptors_initialized)
|
|
|
|
res = (void *)syscall(__NR_mmap, addr, length, prot, flags, fd, offset);
|
|
|
|
else
|
|
|
|
res = REAL(mmap)(addr, length, prot, flags, fd, offset);
|
|
|
|
|
|
|
|
if (res != (void *)-1)
|
2020-10-11 09:26:47 +08:00
|
|
|
dfsan_set_label(0, res, RoundUpTo(length, GetPageSizeCached()));
|
2013-08-16 05:18:53 +08:00
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
INTERCEPTOR(void *, mmap64, void *addr, SIZE_T length, int prot, int flags,
|
|
|
|
int fd, OFF64_T offset) {
|
|
|
|
void *res = REAL(mmap64)(addr, length, prot, flags, fd, offset);
|
2020-08-20 06:07:17 +08:00
|
|
|
if (res != (void *)-1)
|
2020-10-11 09:26:47 +08:00
|
|
|
dfsan_set_label(0, res, RoundUpTo(length, GetPageSizeCached()));
|
2013-08-16 05:18:53 +08:00
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2020-10-02 02:05:34 +08:00
|
|
|
INTERCEPTOR(int, munmap, void *addr, SIZE_T length) {
|
|
|
|
int res = REAL(munmap)(addr, length);
|
2020-10-11 09:26:47 +08:00
|
|
|
if (res != -1)
|
|
|
|
dfsan_set_label(0, addr, RoundUpTo(length, GetPageSizeCached()));
|
2020-10-02 02:05:34 +08:00
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2013-08-16 05:18:53 +08:00
|
|
|
namespace __dfsan {
|
|
|
|
void InitializeInterceptors() {
|
2020-08-20 06:07:17 +08:00
|
|
|
CHECK(!interceptors_initialized);
|
2013-08-16 05:18:53 +08:00
|
|
|
|
|
|
|
INTERCEPT_FUNCTION(mmap);
|
|
|
|
INTERCEPT_FUNCTION(mmap64);
|
2020-10-02 02:05:34 +08:00
|
|
|
INTERCEPT_FUNCTION(munmap);
|
2020-08-20 06:07:17 +08:00
|
|
|
|
|
|
|
interceptors_initialized = true;
|
2013-08-16 05:18:53 +08:00
|
|
|
}
|
|
|
|
} // namespace __dfsan
|