Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Crashpad Authors. All rights reserved. | 1 // Copyright 2015 The Crashpad Authors. All rights reserved. |
| 2 // | 2 // |
| 3 // Licensed under the Apache License, Version 2.0 (the "License"); | 3 // Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 // you may not use this file except in compliance with the License. | 4 // you may not use this file except in compliance with the License. |
| 5 // You may obtain a copy of the License at | 5 // You may obtain a copy of the License at |
| 6 // | 6 // |
| 7 // http://www.apache.org/licenses/LICENSE-2.0 | 7 // http://www.apache.org/licenses/LICENSE-2.0 |
| 8 // | 8 // |
| 9 // Unless required by applicable law or agreed to in writing, software | 9 // Unless required by applicable law or agreed to in writing, software |
| 10 // distributed under the License is distributed on an "AS IS" BASIS, | 10 // distributed under the License is distributed on an "AS IS" BASIS, |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 43 //! \brief The base address of the loaded DLL. | 43 //! \brief The base address of the loaded DLL. |
| 44 WinVMAddress dll_base; | 44 WinVMAddress dll_base; |
| 45 | 45 |
| 46 //! \brief The size of the module. | 46 //! \brief The size of the module. |
| 47 WinVMSize size; | 47 WinVMSize size; |
| 48 | 48 |
| 49 //! \brief The module's timestamp. | 49 //! \brief The module's timestamp. |
| 50 time_t timestamp; | 50 time_t timestamp; |
| 51 }; | 51 }; |
| 52 | 52 |
| 53 struct Handle { | |
| 54 Handle(); | |
| 55 ~Handle(); | |
| 56 | |
| 57 //! \brief A string representation of the handle's type. | |
| 58 std::wstring type_name; | |
| 59 | |
| 60 //! \brief The handle's value. | |
| 61 uint32_t handle; | |
|
Mark Mentovai
2015/10/14 22:49:55
This is at least as good a place for the comment a
scottmg
2015/10/15 00:17:42
Done.
| |
| 62 | |
| 63 //! \brief The attributes for the handle, e.g. `OBJ_INHERIT`, | |
| 64 //! `OBJ_CASE_INSENSITIVE`, etc. | |
| 65 uint32_t attributes; | |
| 66 | |
| 67 //! \brief The ACCESS_MASK for the handle in this process. Ref: | |
|
Mark Mentovai
2015/10/14 22:49:55
`ACCESS_MASK`
scottmg
2015/10/15 00:17:42
Done.
| |
| 68 //! http://blogs.msdn.com/b/openspecification/archive/2010/04/01/about-the-a ccess-mask-structure.aspx | |
|
Mark Mentovai
2015/10/14 22:49:55
The URL reference shouldn’t be part of the \brief.
scottmg
2015/10/15 00:17:42
Done.
| |
| 69 uint32_t granted_access; | |
| 70 | |
| 71 //! \brief The number of kernel references to the object that this handle | |
| 72 //! refers to. | |
| 73 uint32_t pointer_count; | |
| 74 | |
| 75 //! \brief The number of open handles to the object that this handle refers | |
| 76 //! to. | |
| 77 uint32_t handle_count; | |
| 78 }; | |
| 79 | |
| 53 ProcessInfo(); | 80 ProcessInfo(); |
| 54 ~ProcessInfo(); | 81 ~ProcessInfo(); |
| 55 | 82 |
| 56 //! \brief Initializes this object with information about the given | 83 //! \brief Initializes this object with information about the given |
| 57 //! \a process. | 84 //! \a process. |
| 58 //! | 85 //! |
| 59 //! This method must be called successfully prior to calling any other | 86 //! This method must be called successfully prior to calling any other |
| 60 //! method in this class. This method may only be called once. | 87 //! method in this class. This method may only be called once. |
| 61 //! | 88 //! |
| 62 //! \return `true` on success, `false` on failure with a message logged. | 89 //! \return `true` on success, `false` on failure with a message logged. |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 99 //! \brief Given a range to be read from the target process, returns a vector | 126 //! \brief Given a range to be read from the target process, returns a vector |
| 100 //! of ranges, representing the readable portions of the original range. | 127 //! of ranges, representing the readable portions of the original range. |
| 101 //! | 128 //! |
| 102 //! \param[in] range The range being identified. | 129 //! \param[in] range The range being identified. |
| 103 //! | 130 //! |
| 104 //! \return A vector of ranges corresponding to the portion of \a range that | 131 //! \return A vector of ranges corresponding to the portion of \a range that |
| 105 //! is readable based on the memory map. | 132 //! is readable based on the memory map. |
| 106 std::vector<CheckedRange<WinVMAddress, WinVMSize>> GetReadableRanges( | 133 std::vector<CheckedRange<WinVMAddress, WinVMSize>> GetReadableRanges( |
| 107 const CheckedRange<WinVMAddress, WinVMSize>& range) const; | 134 const CheckedRange<WinVMAddress, WinVMSize>& range) const; |
| 108 | 135 |
| 136 //! \brief Retrieves information about open handles in the target process. | |
| 137 const std::vector<Handle>& Handles() const { return handles_; } | |
| 138 | |
| 109 private: | 139 private: |
| 110 template <class Traits> | 140 template <class Traits> |
| 111 friend bool GetProcessBasicInformation(HANDLE process, | 141 friend bool GetProcessBasicInformation(HANDLE process, |
| 112 bool is_wow64, | 142 bool is_wow64, |
| 113 ProcessInfo* process_info, | 143 ProcessInfo* process_info, |
| 114 WinVMAddress* peb_address, | 144 WinVMAddress* peb_address, |
| 115 WinVMSize* peb_size); | 145 WinVMSize* peb_size); |
| 116 template <class Traits> | 146 template <class Traits> |
| 117 friend bool ReadProcessData(HANDLE process, | 147 friend bool ReadProcessData(HANDLE process, |
| 118 WinVMAddress peb_address_vmaddr, | 148 WinVMAddress peb_address_vmaddr, |
| 119 ProcessInfo* process_info); | 149 ProcessInfo* process_info); |
| 120 | 150 |
| 121 friend bool ReadMemoryInfo(HANDLE process, | 151 friend bool ReadMemoryInfo(HANDLE process, |
| 122 bool is_64_bit, | 152 bool is_64_bit, |
| 123 ProcessInfo* process_info); | 153 ProcessInfo* process_info); |
| 124 | 154 |
| 155 template <class Traits> | |
| 156 std::vector<Handle> BuildHandleVector(HANDLE process) const; | |
| 157 | |
| 125 pid_t process_id_; | 158 pid_t process_id_; |
| 126 pid_t inherited_from_process_id_; | 159 pid_t inherited_from_process_id_; |
| 127 std::wstring command_line_; | 160 std::wstring command_line_; |
| 128 WinVMAddress peb_address_; | 161 WinVMAddress peb_address_; |
| 129 WinVMSize peb_size_; | 162 WinVMSize peb_size_; |
| 130 std::vector<Module> modules_; | 163 std::vector<Module> modules_; |
| 131 std::vector<MEMORY_BASIC_INFORMATION64> memory_info_; | 164 std::vector<MEMORY_BASIC_INFORMATION64> memory_info_; |
| 165 std::vector<Handle> handles_; | |
| 132 bool is_64_bit_; | 166 bool is_64_bit_; |
| 133 bool is_wow64_; | 167 bool is_wow64_; |
| 134 InitializationStateDcheck initialized_; | 168 InitializationStateDcheck initialized_; |
| 135 | 169 |
| 136 DISALLOW_COPY_AND_ASSIGN(ProcessInfo); | 170 DISALLOW_COPY_AND_ASSIGN(ProcessInfo); |
| 137 }; | 171 }; |
| 138 | 172 |
| 139 //! \brief Given a memory map of a process, and a range to be read from the | 173 //! \brief Given a memory map of a process, and a range to be read from the |
| 140 //! target process, returns a vector of ranges, representing the readable | 174 //! target process, returns a vector of ranges, representing the readable |
| 141 //! portions of the original range. | 175 //! portions of the original range. |
| 142 //! | 176 //! |
| 143 //! This is a free function for testing, but prefer | 177 //! This is a free function for testing, but prefer |
| 144 //! ProcessInfo::GetReadableRanges(). | 178 //! ProcessInfo::GetReadableRanges(). |
| 145 std::vector<CheckedRange<WinVMAddress, WinVMSize>> GetReadableRangesOfMemoryMap( | 179 std::vector<CheckedRange<WinVMAddress, WinVMSize>> GetReadableRangesOfMemoryMap( |
| 146 const CheckedRange<WinVMAddress, WinVMSize>& range, | 180 const CheckedRange<WinVMAddress, WinVMSize>& range, |
| 147 const std::vector<MEMORY_BASIC_INFORMATION64>& memory_info); | 181 const std::vector<MEMORY_BASIC_INFORMATION64>& memory_info); |
| 148 | 182 |
| 149 } // namespace crashpad | 183 } // namespace crashpad |
| 150 | 184 |
| 151 #endif // CRASHPAD_UTIL_WIN_PROCESS_INFO_H_ | 185 #endif // CRASHPAD_UTIL_WIN_PROCESS_INFO_H_ |
| OLD | NEW |