1 //===-- sanitizer_platform_limits_linux.cc --------------------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file is a part of Sanitizer common code.
12 // Sizes and layouts of linux kernel data structures.
13 //===----------------------------------------------------------------------===//
15 // This is a separate compilation unit for linux headers that conflict with
17 // Most "normal" includes go in sanitizer_platform_limits_posix.cc
19 #include "sanitizer_platform.h"
22 #include "sanitizer_internal_defs.h"
23 #include "sanitizer_platform_limits_posix.h"
25 // For offsetof -> __builtin_offsetof definition.
28 // With old kernels (and even new kernels on powerpc) asm/stat.h uses types that
29 // are not defined anywhere in userspace headers. Fake them. This seems to work
30 // fine with newer headers, too.
31 #include <asm/posix_types.h>
32 #if defined(__x86_64__) || defined(__mips__)
35 #define ino_t __kernel_ino_t
36 #define mode_t __kernel_mode_t
37 #define nlink_t __kernel_nlink_t
38 #define uid_t __kernel_uid_t
39 #define gid_t __kernel_gid_t
40 #define off_t __kernel_off_t
41 // This header seems to contain the definitions of _kernel_ stat* structs.
51 #include <linux/aio_abi.h>
53 #if !SANITIZER_ANDROID
54 #include <sys/statfs.h>
55 #include <linux/perf_event.h>
58 namespace __sanitizer {
59 #if !SANITIZER_ANDROID
60 unsigned struct_statfs64_sz = sizeof(struct statfs64);
62 } // namespace __sanitizer
64 #if !defined(__powerpc64__) && !defined(__x86_64__) && !defined(__aarch64__)\
66 COMPILER_CHECK(struct___old_kernel_stat_sz == sizeof(struct __old_kernel_stat));
69 COMPILER_CHECK(struct_kernel_stat_sz == sizeof(struct stat));
72 COMPILER_CHECK(struct_kernel_stat64_sz == sizeof(struct stat64));
75 CHECK_TYPE_SIZE(io_event);
76 CHECK_SIZE_AND_OFFSET(io_event, data);
77 CHECK_SIZE_AND_OFFSET(io_event, obj);
78 CHECK_SIZE_AND_OFFSET(io_event, res);
79 CHECK_SIZE_AND_OFFSET(io_event, res2);
81 #if !SANITIZER_ANDROID
82 COMPILER_CHECK(sizeof(struct __sanitizer_perf_event_attr) <=
83 sizeof(struct perf_event_attr));
84 CHECK_SIZE_AND_OFFSET(perf_event_attr, type);
85 CHECK_SIZE_AND_OFFSET(perf_event_attr, size);
88 COMPILER_CHECK(iocb_cmd_pread == IOCB_CMD_PREAD);
89 COMPILER_CHECK(iocb_cmd_pwrite == IOCB_CMD_PWRITE);
90 #if !SANITIZER_ANDROID
91 COMPILER_CHECK(iocb_cmd_preadv == IOCB_CMD_PREADV);
92 COMPILER_CHECK(iocb_cmd_pwritev == IOCB_CMD_PWRITEV);
95 CHECK_TYPE_SIZE(iocb);
96 CHECK_SIZE_AND_OFFSET(iocb, aio_data);
97 // Skip aio_key, it's weird.
98 CHECK_SIZE_AND_OFFSET(iocb, aio_lio_opcode);
99 CHECK_SIZE_AND_OFFSET(iocb, aio_reqprio);
100 CHECK_SIZE_AND_OFFSET(iocb, aio_fildes);
101 CHECK_SIZE_AND_OFFSET(iocb, aio_buf);
102 CHECK_SIZE_AND_OFFSET(iocb, aio_nbytes);
103 CHECK_SIZE_AND_OFFSET(iocb, aio_offset);
105 #endif // SANITIZER_LINUX