blob: 1e4e628a8be3f2e6aea73d4e84a38060066e8ed8 [file] [log] [blame]
Alexey Samsonov2c5fc3b2012-06-04 14:27:50 +00001//===-- sanitizer_linux.cc ------------------------------------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file is shared between AddressSanitizer and ThreadSanitizer
11// run-time libraries and implements linux-specific functions from
12// sanitizer_libc.h.
13//===----------------------------------------------------------------------===//
14#ifdef __linux__
15
Alexey Samsonov5bbf8292012-06-05 14:25:27 +000016#include "sanitizer_internal_defs.h"
Alexey Samsonov2c5fc3b2012-06-04 14:27:50 +000017#include "sanitizer_libc.h"
18
Alexey Samsonovdde1f112012-06-05 07:05:10 +000019#include <fcntl.h>
Alexey Samsonov2c5fc3b2012-06-04 14:27:50 +000020#include <sys/mman.h>
Alexey Samsonovdde1f112012-06-05 07:05:10 +000021#include <sys/stat.h>
Alexey Samsonov2c5fc3b2012-06-04 14:27:50 +000022#include <sys/syscall.h>
23#include <sys/types.h>
24#include <unistd.h>
25
26namespace __sanitizer {
27
28void *internal_mmap(void *addr, uptr length, int prot, int flags,
29 int fd, u64 offset) {
30#if __WORDSIZE == 64
31 return (void *)syscall(__NR_mmap, addr, length, prot, flags, fd, offset);
32#else
33 return (void *)syscall(__NR_mmap2, addr, length, prot, flags, fd, offset);
34#endif
35}
36
Alexey Samsonov7ac77d62012-06-05 09:49:25 +000037int internal_munmap(void *addr, uptr length) {
38 return syscall(__NR_munmap, addr, length);
39}
40
Alexey Samsonov03c8b842012-06-05 08:32:53 +000041int internal_close(fd_t fd) {
42 return syscall(__NR_close, fd);
43}
44
Alexey Samsonovdde1f112012-06-05 07:05:10 +000045fd_t internal_open(const char *filename, bool write) {
46 return syscall(__NR_open, filename,
Kostya Serebryany64166ca2012-06-06 14:11:31 +000047 write ? O_WRONLY | O_CREAT /*| O_CLOEXEC*/ : O_RDONLY, 0660);
Alexey Samsonovdde1f112012-06-05 07:05:10 +000048}
49
Alexey Samsonov03c8b842012-06-05 08:32:53 +000050uptr internal_read(fd_t fd, void *buf, uptr count) {
51 return (uptr)syscall(__NR_read, fd, buf, count);
52}
53
54uptr internal_write(fd_t fd, const void *buf, uptr count) {
55 return (uptr)syscall(__NR_write, fd, buf, count);
56}
57
Alexey Samsonovca2b5d72012-06-06 07:30:33 +000058uptr internal_filesize(fd_t fd) {
59 struct stat st = {};
60 if (syscall(__NR_fstat, fd, &st))
61 return -1;
62 return (uptr)st.st_size;
63}
64
65int internal_dup2(int oldfd, int newfd) {
66 return syscall(__NR_dup2, oldfd, newfd);
67}
68
Alexey Samsonov2c5fc3b2012-06-04 14:27:50 +000069} // namespace __sanitizer
70
71#endif // __linux__