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 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
44 }; | 44 }; |
45 | 45 |
46 } // namespace process_types | 46 } // namespace process_types |
47 | 47 |
48 //! \brief A reader for PE images mapped into another process. | 48 //! \brief A reader for PE images mapped into another process. |
49 //! | 49 //! |
50 //! This class is capable of reading both 32-bit and 64-bit images based on the | 50 //! This class is capable of reading both 32-bit and 64-bit images based on the |
51 //! bitness of the remote process. | 51 //! bitness of the remote process. |
52 //! | 52 //! |
53 //! \sa PEImageAnnotationsReader | 53 //! \sa PEImageAnnotationsReader |
| 54 //! \sa PEImageResourceReader |
54 class PEImageReader { | 55 class PEImageReader { |
55 public: | 56 public: |
56 PEImageReader(); | 57 PEImageReader(); |
57 ~PEImageReader(); | 58 ~PEImageReader(); |
58 | 59 |
59 //! \brief Initializes the reader. | 60 //! \brief Initializes the reader. |
60 //! | 61 //! |
61 //! This method must be called only once on an object. This method must be | 62 //! This method must be called only once on an object. This method must be |
62 //! called successfully before any other method in this class may be called. | 63 //! called successfully before any other method in this class may be called. |
63 //! | 64 //! |
(...skipping 29 matching lines...) Expand all Loading... |
93 template <class Traits> | 94 template <class Traits> |
94 bool GetCrashpadInfo( | 95 bool GetCrashpadInfo( |
95 process_types::CrashpadInfo<Traits>* crashpad_info) const; | 96 process_types::CrashpadInfo<Traits>* crashpad_info) const; |
96 | 97 |
97 //! \brief Obtains information from the module's debug directory, if any. | 98 //! \brief Obtains information from the module's debug directory, if any. |
98 //! | 99 //! |
99 //! \param[out] uuid The unique identifier of the executable/PDB. | 100 //! \param[out] uuid The unique identifier of the executable/PDB. |
100 //! \param[out] age The age field for the pdb (the number of times it's been | 101 //! \param[out] age The age field for the pdb (the number of times it's been |
101 //! relinked). | 102 //! relinked). |
102 //! \param[out] pdbname Name of the pdb file. | 103 //! \param[out] pdbname Name of the pdb file. |
103 //! \return `true` on success, or `false` if the module has no debug directory | |
104 //! entry. | |
105 bool DebugDirectoryInformation(UUID* uuid, | |
106 DWORD* age, | |
107 std::string* pdbname) const; | |
108 | |
109 private: | |
110 //! \brief Implementation helper for DebugDirectoryInformation() templated by | |
111 //! `IMAGE_NT_HEADERS` type for different bitnesses. | |
112 //! | 104 //! |
113 //! \return `true` on success, with the parameters set appropriately. `false` | 105 //! \return `true` on success, with the parameters set appropriately. `false` |
114 //! on failure. This method may return `false` without logging anything in | 106 //! on failure. This method may return `false` without logging anything in |
115 //! the case of a module that does not contain relevant debugging | 107 //! the case of a module that does not contain relevant debugging |
116 //! information but is otherwise properly structured. | 108 //! information but is otherwise properly structured. |
117 template <class NtHeadersType> | 109 bool DebugDirectoryInformation(UUID* uuid, |
118 bool ReadDebugDirectoryInformation(UUID* uuid, | 110 DWORD* age, |
119 DWORD* age, | 111 std::string* pdbname) const; |
120 std::string* pdbname) const; | |
121 | 112 |
| 113 //! \brief Obtains the module’s `VS_FIXEDFILEINFO`, containing its version and |
| 114 //! type information. |
| 115 //! |
| 116 //! The data obtained from this method should be equivalent to what could be |
| 117 //! obtained by calling GetModuleVersionAndType(). Avoiding that function |
| 118 //! ensures that the data in the module loaded into the remote process will be |
| 119 //! used as-is, without the risks associated with loading the module into the |
| 120 //! reading process. |
| 121 //! |
| 122 //! \param[out] vs_fixed_file_info The VS_FIXEDFILEINFO on success. |
| 123 //! VS_FIXEDFILEINFO::dwFileFlags will have been masked with |
| 124 //! VS_FIXEDFILEINFO::dwFileFlagsMask already. |
| 125 //! |
| 126 //! \return `true` on success. `false` if the module does not contain this |
| 127 //! information, without logging any messages. `false` on failure, with |
| 128 //! a message logged. |
| 129 bool VSFixedFileInfo(VS_FIXEDFILEINFO* vs_fixed_file_info) const; |
| 130 |
| 131 private: |
122 //! \brief Reads the `IMAGE_NT_HEADERS` from the beginning of the image. | 132 //! \brief Reads the `IMAGE_NT_HEADERS` from the beginning of the image. |
123 //! | 133 //! |
124 //! \param[out] nt_headers The contents of the templated NtHeadersType | 134 //! \param[out] nt_headers The contents of the templated NtHeadersType |
125 //! structure read from the remote process. | 135 //! structure read from the remote process. |
126 //! \param[out] nt_headers_address The address of the templated NtHeadersType | 136 //! \param[out] nt_headers_address The address of the templated NtHeadersType |
127 //! structure in the remote process’ address space. If this information is | 137 //! structure in the remote process’ address space. If this information is |
128 //! not needed, this parameter may be `nullptr`. | 138 //! not needed, this parameter may be `nullptr`. |
129 //! | 139 //! |
130 //! \return `true` on success, with \a nt_headers and optionally \a | 140 //! \return `true` on success, with \a nt_headers and optionally \a |
131 //! nt_headers_address set appropriately. `false` on failure, with a | 141 //! nt_headers_address set appropriately. `false` on failure, with a |
132 //! message logged. | 142 //! message logged. |
133 template <class NtHeadersType> | 143 template <class NtHeadersType> |
134 bool ReadNtHeaders(NtHeadersType* nt_headers, | 144 bool ReadNtHeaders(NtHeadersType* nt_headers, |
135 WinVMAddress* nt_headers_address) const; | 145 WinVMAddress* nt_headers_address) const; |
136 | 146 |
137 //! \brief Finds a given section by name in the image. | 147 //! \brief Finds a given section by name in the image. |
138 template <class NtHeadersType> | 148 template <class NtHeadersType> |
139 bool GetSectionByName(const std::string& name, | 149 bool GetSectionByName(const std::string& name, |
140 IMAGE_SECTION_HEADER* section) const; | 150 IMAGE_SECTION_HEADER* section) const; |
141 | 151 |
142 //! \brief Reads memory from target process, first checking whether the range | 152 //! \brief Finds the `IMAGE_DATA_DIRECTORY` in |
143 //! requested falls inside module_range_. | 153 //! `IMAGE_OPTIONAL_HEADER::DataDirectory` at the specified \a index. |
144 //! | 154 //! |
145 //! \return `true` on success, with \a into filled out, otherwise `false` and | 155 //! \param[in] index An `IMAGE_DIRECTORY_ENTRY_*` constant specifying the |
146 //! a message will be logged. | 156 //! data to be returned. |
| 157 //! \param[out] entry The `IMAGE_DATA_DIRECTORY` found within the module. |
| 158 //! |
| 159 //! \return `true` on success, with \a entry set appropriately. `false` if the |
| 160 //! module does not contain the specified information, without logging a |
| 161 //! message. `false` on failure, with a message logged. |
| 162 bool ImageDataDirectoryEntry(size_t index, IMAGE_DATA_DIRECTORY* entry) const; |
| 163 |
| 164 //! \brief A templatized helper for ImageDataDirectoryEntry() to account for |
| 165 //! differences in \a NtHeadersType. |
| 166 template <class NtHeadersType> |
| 167 bool ImageDataDirectoryEntryT(size_t index, |
| 168 IMAGE_DATA_DIRECTORY* entry) const; |
| 169 |
| 170 //! \brief Reads memory from the target process, first checking whether the |
| 171 //! range requested falls inside module_range_. |
| 172 //! |
| 173 //! \return `true` on success, with \a into filled out, otherwise `false` with |
| 174 //! a message logged. |
147 bool CheckedReadMemory(WinVMAddress address, | 175 bool CheckedReadMemory(WinVMAddress address, |
148 WinVMSize size, | 176 WinVMSize size, |
149 void* into) const; | 177 void* into) const; |
150 | 178 |
151 ProcessReaderWin* process_reader_; // weak | 179 ProcessReaderWin* process_reader_; // weak |
152 CheckedWinAddressRange module_range_; | 180 CheckedWinAddressRange module_range_; |
153 std::string module_name_; | 181 std::string module_name_; |
154 InitializationStateDcheck initialized_; | 182 InitializationStateDcheck initialized_; |
155 | 183 |
156 DISALLOW_COPY_AND_ASSIGN(PEImageReader); | 184 DISALLOW_COPY_AND_ASSIGN(PEImageReader); |
157 }; | 185 }; |
158 | 186 |
159 } // namespace crashpad | 187 } // namespace crashpad |
160 | 188 |
161 #endif // CRASHPAD_SNAPSHOT_WIN_PE_IMAGE_READER_H_ | 189 #endif // CRASHPAD_SNAPSHOT_WIN_PE_IMAGE_READER_H_ |
OLD | NEW |