Chromium Code Reviews| Index: base/win/iat_patch_function.cc |
| diff --git a/base/win/iat_patch_function.cc b/base/win/iat_patch_function.cc |
| index a4a89028b870f34aa089951009ce06c6ac6f426c..bcc3bdff22fbbece9d5f3d1da82132dd48724133 100644 |
| --- a/base/win/iat_patch_function.cc |
| +++ b/base/win/iat_patch_function.cc |
| @@ -56,11 +56,24 @@ DWORD ModifyCode(void* old_code, void* new_code, int length) { |
| } |
| // Change the page protection so that we can write. |
| + MEMORY_BASIC_INFORMATION memory_info; |
| DWORD error = NO_ERROR; |
| DWORD old_page_protection = 0; |
| + |
| + if (!::VirtualQuery(old_code, &memory_info, sizeof(memory_info))) { |
| + error = GetLastError(); |
| + NOTREACHED(); |
|
rvargas (doing something else)
2014/01/21 21:19:49
On second thoughts, we should probably just remove
Cait (Slow)
2014/01/21 21:47:19
Done.
|
| + return error; |
| + } |
| + |
| + DWORD is_executable = (PAGE_EXECUTE | PAGE_EXECUTE_READ | |
| + PAGE_EXECUTE_READWRITE | PAGE_EXECUTE_WRITECOPY) & |
| + memory_info.Protect; |
|
rvargas (doing something else)
2014/01/21 20:03:26
tiny nit: one less space here.
Cait (Slow)
2014/01/21 21:47:19
Done.
|
| + |
| if (VirtualProtect(old_code, |
| length, |
| - PAGE_READWRITE, |
| + is_executable ? PAGE_EXECUTE_READWRITE : |
| + PAGE_READWRITE, |
| &old_page_protection)) { |
| // Write the data. |