Fix a race condition in x64 code cache involving RtlGrowFunctionTable

This commit is contained in:
Dr. Chat 2016-07-19 13:59:40 -05:00
parent 18ff97e6b6
commit 2d55b12cc9
1 changed files with 27 additions and 21 deletions

View File

@ -90,7 +90,9 @@ void X64CodeCache::set_indirection_default(uint32_t default_value) {
void X64CodeCache::AddIndirection(uint32_t guest_address, void X64CodeCache::AddIndirection(uint32_t guest_address,
uint32_t host_address) { uint32_t host_address) {
assert_not_null(indirection_table_base_); if (!indirection_table_base_) {
return;
}
uint32_t* indirection_slot = reinterpret_cast<uint32_t*>( uint32_t* indirection_slot = reinterpret_cast<uint32_t*>(
indirection_table_base_ + (guest_address - kIndirectionTableBase)); indirection_table_base_ + (guest_address - kIndirectionTableBase));
@ -158,11 +160,14 @@ void* X64CodeCache::PlaceGuestCode(uint32_t guest_address, void* machine_code,
(uint64_t(code_address - generated_code_base_) << 32) | (uint64_t(code_address - generated_code_base_) << 32) |
generated_code_offset_, generated_code_offset_,
function_info); function_info);
}
// If we are going above the high water mark of committed memory, commit some // TODO(DrChat): The following code doesn't really need to be under the
// more. It's ok if multiple threads do this, as redundant commits aren't // global lock except for PlaceCode (but it depends on the previous code
// harmful. // already being ran)
// If we are going above the high water mark of committed memory, commit
// some more. It's ok if multiple threads do this, as redundant commits
// aren't harmful.
size_t old_commit_mark = generated_code_commit_mark_; size_t old_commit_mark = generated_code_commit_mark_;
if (high_mark > old_commit_mark) { if (high_mark > old_commit_mark) {
size_t new_commit_mark = old_commit_mark + 16 * 1024 * 1024; size_t new_commit_mark = old_commit_mark + 16 * 1024 * 1024;
@ -179,6 +184,7 @@ void* X64CodeCache::PlaceGuestCode(uint32_t guest_address, void* machine_code,
// Notify subclasses of placed code. // Notify subclasses of placed code.
PlaceCode(guest_address, machine_code, code_size, stack_size, code_address, PlaceCode(guest_address, machine_code, code_size, stack_size, code_address,
unwind_reservation); unwind_reservation);
}
// Now that everything is ready, fix up the indirection table. // Now that everything is ready, fix up the indirection table.
// Note that we do support code that doesn't have an indirection fixup, so // Note that we do support code that doesn't have an indirection fixup, so