aboutsummaryrefslogtreecommitdiff
path: root/compiler-rt/lib/dfsan/dfsan_interceptors.cpp
blob: 7efb182ac8d4fcdeb65ffc22812b850cc7652e9f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
//===-- dfsan_interceptors.cpp --------------------------------------------===//
//
// 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
//
//===----------------------------------------------------------------------===//
//
// This file is a part of DataFlowSanitizer.
//
// Interceptors for standard library functions.
//===----------------------------------------------------------------------===//

#include <sys/syscall.h>
#include <unistd.h>

#include "dfsan/dfsan.h"
#include "interception/interception.h"
#include "sanitizer_common/sanitizer_common.h"

using namespace __sanitizer;

namespace {

bool interceptors_initialized;

}  // namespace

INTERCEPTOR(void *, mmap, void *addr, SIZE_T length, int prot, int flags,
            int fd, OFF_T offset) {
  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)
    dfsan_set_label(0, res, RoundUpTo(length, GetPageSizeCached()));
  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);
  if (res != (void *)-1)
    dfsan_set_label(0, res, RoundUpTo(length, GetPageSizeCached()));
  return res;
}

INTERCEPTOR(int, munmap, void *addr, SIZE_T length) {
  int res = REAL(munmap)(addr, length);
  if (res != -1)
    dfsan_set_label(0, addr, RoundUpTo(length, GetPageSizeCached()));
  return res;
}

namespace __dfsan {
void InitializeInterceptors() {
  CHECK(!interceptors_initialized);

  INTERCEPT_FUNCTION(mmap);
  INTERCEPT_FUNCTION(mmap64);
  INTERCEPT_FUNCTION(munmap);

  interceptors_initialized = true;
}
}  // namespace __dfsan