blob: 0d2f20e70a4ebf6b7fb2fdea699dd6c3291ee921 [file] [log] [blame]
[email protected]9bc8cff2010-04-03 01:05:391// Copyright (c) 2010 The Chromium Authors. All rights reserved.
[email protected]75ae5422009-04-21 17:20:102// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
[email protected]9bc8cff2010-04-03 01:05:395#ifndef BASE_LINUX_UTIL_H_
6#define BASE_LINUX_UTIL_H_
[email protected]32b76ef2010-07-26 23:08:247#pragma once
[email protected]75ae5422009-04-21 17:20:108
9#include <stdint.h>
[email protected]b28af7522009-10-29 18:21:3010#include <sys/types.h>
[email protected]75ae5422009-04-21 17:20:1011
[email protected]912c6452009-07-17 05:55:5112#include <string>
13
[email protected]75ae5422009-04-21 17:20:1014namespace base {
15
[email protected]8ecd3aad2009-11-04 08:32:2216static const char kFindInodeSwitch[] = "--find-inode";
17
[email protected]6dde9d72010-08-26 08:55:2218// This is declared here so the crash reporter can access the memory directly
19// in compromised context without going through the standard library.
20extern char g_linux_distro[];
21
[email protected]912c6452009-07-17 05:55:5122// Get the Linux Distro if we can, or return "Unknown", similar to
23// GetWinVersion() in base/win_util.h.
24std::string GetLinuxDistro();
25
[email protected]6dde9d72010-08-26 08:55:2226// Set the Linux Distro string.
27void SetLinuxDistro(const std::string& distro);
28
[email protected]85ebe8f2009-10-29 04:02:5529// Return the inode number for the UNIX domain socket |fd|.
30bool FileDescriptorGetInode(ino_t* inode_out, int fd);
31
32// Find the process which holds the given socket, named by inode number. If
33// multiple processes hold the socket, this function returns false.
34bool FindProcessHoldingSocket(pid_t* pid_out, ino_t socket_inode);
35
[email protected]662183142010-07-16 19:28:1736// For a given process |pid|, look through all its threads and find the first
37// thread with /proc/[pid]/task/[thread_id]/syscall whose first N bytes matches
38// |expected_data|, where N is the length of |expected_data|.
39// Returns the thread id or -1 on error.
40pid_t FindThreadIDWithSyscall(pid_t pid, const std::string& expected_data);
41
[email protected]75ae5422009-04-21 17:20:1042} // namespace base
43
[email protected]9bc8cff2010-04-03 01:05:3944#endif // BASE_LINUX_UTIL_H_