1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef BASE_PROCESS_PROCESS_HANDLE_H_
6 #define BASE_PROCESS_PROCESS_HANDLE_H_
8 #include "base/base_export.h"
9 #include "base/basictypes.h"
10 #include "base/files/file_path.h"
11 #include "build/build_config.h"
13 #include <sys/types.h>
20 // ProcessHandle is a platform specific type which represents the underlying OS
21 // handle to a process.
22 // ProcessId is a number which identifies the process in the OS.
24 typedef HANDLE ProcessHandle
;
25 typedef DWORD ProcessId
;
26 typedef HANDLE UserTokenHandle
;
27 const ProcessHandle kNullProcessHandle
= NULL
;
28 const ProcessId kNullProcessId
= 0;
29 #elif defined(OS_POSIX)
30 // On POSIX, our ProcessHandle will just be the PID.
31 typedef pid_t ProcessHandle
;
32 typedef pid_t ProcessId
;
33 const ProcessHandle kNullProcessHandle
= 0;
34 const ProcessId kNullProcessId
= 0;
35 #endif // defined(OS_WIN)
37 // Returns the id of the current process.
38 BASE_EXPORT ProcessId
GetCurrentProcId();
40 // Returns the ProcessHandle of the current process.
41 BASE_EXPORT ProcessHandle
GetCurrentProcessHandle();
43 // Converts a PID to a process handle. This handle must be closed by
44 // CloseProcessHandle when you are done with it. Returns true on success.
45 BASE_EXPORT
bool OpenProcessHandle(ProcessId pid
, ProcessHandle
* handle
);
47 // Converts a PID to a process handle using the desired access flags. Use a
48 // combination of the kProcessAccess* flags defined above for |access_flags|.
49 BASE_EXPORT
bool OpenProcessHandleWithAccess(ProcessId pid
,
51 ProcessHandle
* handle
);
53 // Closes the process handle opened by OpenProcessHandle.
54 BASE_EXPORT
void CloseProcessHandle(ProcessHandle process
);
56 // Returns the unique ID for the specified process. This is functionally the
57 // same as Windows' GetProcessId(), but works on versions of Windows before
58 // Win XP SP1 as well.
59 BASE_EXPORT ProcessId
GetProcId(ProcessHandle process
);
68 // Determine the integrity level of the specified process. Returns false
69 // if the system does not support integrity levels (pre-Vista) or in the case
70 // of an underlying system failure.
71 BASE_EXPORT
bool GetProcessIntegrityLevel(ProcessHandle process
,
72 IntegrityLevel
* level
);
76 // Returns the path to the executable of the given process.
77 BASE_EXPORT FilePath
GetProcessExecutablePath(ProcessHandle process
);
79 // Returns the ID for the parent of the given process.
80 BASE_EXPORT ProcessId
GetParentProcessId(ProcessHandle process
);
85 #endif // BASE_PROCESS_PROCESS_HANDLE_H_