OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef BASE_LINUX_UTIL_H_ | 5 #ifndef BASE_LINUX_UTIL_H_ |
6 #define BASE_LINUX_UTIL_H_ | 6 #define BASE_LINUX_UTIL_H_ |
7 | 7 |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 #include <sys/types.h> | 9 #include <sys/types.h> |
10 | 10 |
11 #include <string> | 11 #include <string> |
12 | 12 |
13 #include "base/base_export.h" | 13 #include "base/base_export.h" |
14 | 14 |
15 namespace base { | 15 namespace base { |
16 | 16 |
17 BASE_EXPORT extern const char kFindInodeSwitch[]; | 17 BASE_EXPORT extern const char kFindInodeSwitch[]; |
18 | 18 |
19 // This should be kept in sync with sandbox/linux/suid/sandbox.c | |
20 BASE_EXPORT extern const long kSUIDSandboxApiNumber; | |
21 BASE_EXPORT extern const char kSandboxEnvironmentApiRequest[]; | |
22 BASE_EXPORT extern const char kSandboxEnvironmentApiProvides[]; | |
23 | |
24 // This is declared here so the crash reporter can access the memory directly | 19 // This is declared here so the crash reporter can access the memory directly |
25 // in compromised context without going through the standard library. | 20 // in compromised context without going through the standard library. |
26 BASE_EXPORT extern char g_linux_distro[]; | 21 BASE_EXPORT extern char g_linux_distro[]; |
27 | 22 |
28 // Get the Linux Distro if we can, or return "Unknown". | 23 // Get the Linux Distro if we can, or return "Unknown". |
29 BASE_EXPORT std::string GetLinuxDistro(); | 24 BASE_EXPORT std::string GetLinuxDistro(); |
30 | 25 |
31 // Set the Linux Distro string. | 26 // Set the Linux Distro string. |
32 BASE_EXPORT void SetLinuxDistro(const std::string& distro); | 27 BASE_EXPORT void SetLinuxDistro(const std::string& distro); |
33 | 28 |
34 // Return the inode number for the UNIX domain socket |fd|. | 29 // Return the inode number for the UNIX domain socket |fd|. |
35 BASE_EXPORT bool FileDescriptorGetInode(ino_t* inode_out, int fd); | 30 BASE_EXPORT bool FileDescriptorGetInode(ino_t* inode_out, int fd); |
36 | 31 |
37 // Find the process which holds the given socket, named by inode number. If | 32 // Find the process which holds the given socket, named by inode number. If |
38 // multiple processes hold the socket, this function returns false. | 33 // multiple processes hold the socket, this function returns false. |
39 BASE_EXPORT bool FindProcessHoldingSocket(pid_t* pid_out, ino_t socket_inode); | 34 BASE_EXPORT bool FindProcessHoldingSocket(pid_t* pid_out, ino_t socket_inode); |
40 | 35 |
41 // For a given process |pid|, look through all its threads and find the first | 36 // For a given process |pid|, look through all its threads and find the first |
42 // thread with /proc/[pid]/task/[thread_id]/syscall whose first N bytes matches | 37 // thread with /proc/[pid]/task/[thread_id]/syscall whose first N bytes matches |
43 // |expected_data|, where N is the length of |expected_data|. | 38 // |expected_data|, where N is the length of |expected_data|. |
44 // Returns the thread id or -1 on error. If |syscall_supported| is | 39 // Returns the thread id or -1 on error. If |syscall_supported| is |
45 // set to false the kernel does not support syscall in procfs. | 40 // set to false the kernel does not support syscall in procfs. |
46 BASE_EXPORT pid_t FindThreadIDWithSyscall(pid_t pid, | 41 BASE_EXPORT pid_t FindThreadIDWithSyscall(pid_t pid, |
47 const std::string& expected_data, | 42 const std::string& expected_data, |
48 bool* syscall_supported); | 43 bool* syscall_supported); |
49 | 44 |
50 } // namespace base | 45 } // namespace base |
51 | 46 |
52 #endif // BASE_LINUX_UTIL_H_ | 47 #endif // BASE_LINUX_UTIL_H_ |
OLD | NEW |