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 // This is declared here so the crash reporter can access the memory directly | 17 // This is declared here so the crash reporter can access the memory directly |
18 // in compromised context without going through the standard library. | 18 // in compromised context without going through the standard library. |
19 BASE_EXPORT extern char g_linux_distro[]; | 19 BASE_EXPORT extern char g_linux_distro[]; |
20 | 20 |
21 // Get the Linux Distro if we can, or return "Unknown". | 21 // Get the Linux Distro if we can, or return "Unknown". |
22 BASE_EXPORT std::string GetLinuxDistro(); | 22 BASE_EXPORT std::string GetLinuxDistro(); |
23 | 23 |
24 // Set the Linux Distro string. | 24 // Set the Linux Distro string. |
25 BASE_EXPORT void SetLinuxDistro(const std::string& distro); | 25 BASE_EXPORT void SetLinuxDistro(const std::string& distro); |
26 | 26 |
| 27 // Return the inode number for the UNIX domain socket |fd|. |
| 28 BASE_EXPORT bool FileDescriptorGetInode(ino_t* inode_out, int fd); |
| 29 |
| 30 // Find the process which holds the given socket, named by inode number. If |
| 31 // multiple processes hold the socket, this function returns false. |
| 32 BASE_EXPORT bool FindProcessHoldingSocket(pid_t* pid_out, ino_t socket_inode); |
| 33 |
27 // For a given process |pid|, look through all its threads and find the first | 34 // For a given process |pid|, look through all its threads and find the first |
28 // thread with /proc/[pid]/task/[thread_id]/syscall whose first N bytes matches | 35 // thread with /proc/[pid]/task/[thread_id]/syscall whose first N bytes matches |
29 // |expected_data|, where N is the length of |expected_data|. | 36 // |expected_data|, where N is the length of |expected_data|. |
30 // Returns the thread id or -1 on error. If |syscall_supported| is | 37 // Returns the thread id or -1 on error. If |syscall_supported| is |
31 // set to false the kernel does not support syscall in procfs. | 38 // set to false the kernel does not support syscall in procfs. |
32 BASE_EXPORT pid_t FindThreadIDWithSyscall(pid_t pid, | 39 BASE_EXPORT pid_t FindThreadIDWithSyscall(pid_t pid, |
33 const std::string& expected_data, | 40 const std::string& expected_data, |
34 bool* syscall_supported); | 41 bool* syscall_supported); |
35 | 42 |
36 } // namespace base | 43 } // namespace base |
37 | 44 |
38 #endif // BASE_LINUX_UTIL_H_ | 45 #endif // BASE_LINUX_UTIL_H_ |
OLD | NEW |