Commit cabf5631 authored by Georgia Kouveli's avatar Georgia Kouveli Committed by Commit Bot

[wasm] Add missing i-cache flushes.

Change-Id: I6504174103af71cba65a078d1918cddd748c6067
Reviewed-on: https://chromium-review.googlesource.com/934283Reviewed-by: 's avatarBen Titzer <titzer@chromium.org>
Commit-Queue: Georgia Kouveli <georgia.kouveli@arm.com>
Cr-Commit-Position: refs/heads/master@{#51908}
parent 2f8e903e
...@@ -70,8 +70,7 @@ void PatchTrampolineAndStubCalls( ...@@ -70,8 +70,7 @@ void PatchTrampolineAndStubCalls(
#else #else
Address new_target = old_target; Address new_target = old_target;
#endif #endif
it.rinfo()->set_target_address(new_target, SKIP_WRITE_BARRIER, it.rinfo()->set_target_address(new_target, SKIP_WRITE_BARRIER);
SKIP_ICACHE_FLUSH);
} }
} }
...@@ -320,7 +319,7 @@ WasmCode* NativeModule::AddOwnedCode( ...@@ -320,7 +319,7 @@ WasmCode* NativeModule::AddOwnedCode(
uint32_t stack_slots, size_t safepoint_table_offset, uint32_t stack_slots, size_t safepoint_table_offset,
size_t handler_table_offset, size_t handler_table_offset,
std::shared_ptr<ProtectedInstructions> protected_instructions, std::shared_ptr<ProtectedInstructions> protected_instructions,
WasmCode::Tier tier) { WasmCode::Tier tier, bool flush_icache) {
// both allocation and insertion in owned_code_ happen in the same critical // both allocation and insertion in owned_code_ happen in the same critical
// section, thus ensuring owned_code_'s elements are rarely if ever moved. // section, thus ensuring owned_code_'s elements are rarely if ever moved.
base::LockGuard<base::Mutex> lock(&allocation_mutex_); base::LockGuard<base::Mutex> lock(&allocation_mutex_);
...@@ -341,9 +340,10 @@ WasmCode* NativeModule::AddOwnedCode( ...@@ -341,9 +340,10 @@ WasmCode* NativeModule::AddOwnedCode(
auto insert_before = std::upper_bound(owned_code_.begin(), owned_code_.end(), auto insert_before = std::upper_bound(owned_code_.begin(), owned_code_.end(),
code, owned_code_comparer_); code, owned_code_comparer_);
owned_code_.insert(insert_before, std::move(code)); owned_code_.insert(insert_before, std::move(code));
if (flush_icache) {
Assembler::FlushICache(ret->instructions().start(), Assembler::FlushICache(ret->instructions().start(),
ret->instructions().size()); ret->instructions().size());
}
return ret; return ret;
} }
...@@ -397,7 +397,8 @@ WasmCode* NativeModule::AddAnonymousCode(Handle<Code> code, ...@@ -397,7 +397,8 @@ WasmCode* NativeModule::AddAnonymousCode(Handle<Code> code,
Nothing<uint32_t>(), kind, code->constant_pool_offset(), Nothing<uint32_t>(), kind, code->constant_pool_offset(),
(code->has_safepoint_info() ? code->stack_slots() : 0), (code->has_safepoint_info() ? code->stack_slots() : 0),
(code->has_safepoint_info() ? code->safepoint_table_offset() : 0), (code->has_safepoint_info() ? code->safepoint_table_offset() : 0),
code->handler_table_offset(), protected_instructions, WasmCode::kOther); code->handler_table_offset(), protected_instructions, WasmCode::kOther,
false /* flush_icache */);
if (ret == nullptr) return nullptr; if (ret == nullptr) return nullptr;
intptr_t delta = ret->instructions().start() - code->instruction_start(); intptr_t delta = ret->instructions().start() - code->instruction_start();
int mask = RelocInfo::kApplyMask | RelocInfo::kCodeTargetMask | int mask = RelocInfo::kApplyMask | RelocInfo::kCodeTargetMask |
...@@ -420,6 +421,10 @@ WasmCode* NativeModule::AddAnonymousCode(Handle<Code> code, ...@@ -420,6 +421,10 @@ WasmCode* NativeModule::AddAnonymousCode(Handle<Code> code,
} }
} }
} }
// Flush the i-cache here instead of in AddOwnedCode, to include the changes
// made while iterating over the RelocInfo above.
Assembler::FlushICache(ret->instructions().start(),
ret->instructions().size());
return ret; return ret;
} }
...@@ -440,7 +445,7 @@ WasmCode* NativeModule::AddCode( ...@@ -440,7 +445,7 @@ WasmCode* NativeModule::AddCode(
std::move(reloc_info), static_cast<size_t>(desc.reloc_size), Just(index), std::move(reloc_info), static_cast<size_t>(desc.reloc_size), Just(index),
WasmCode::kFunction, desc.instr_size - desc.constant_pool_size, WasmCode::kFunction, desc.instr_size - desc.constant_pool_size,
frame_slots, safepoint_table_offset, handler_table_offset, frame_slots, safepoint_table_offset, handler_table_offset,
std::move(protected_instructions), tier); std::move(protected_instructions), tier, SKIP_ICACHE_FLUSH);
if (ret == nullptr) return nullptr; if (ret == nullptr) return nullptr;
code_table_[index] = ret; code_table_[index] = ret;
...@@ -476,6 +481,10 @@ WasmCode* NativeModule::AddCode( ...@@ -476,6 +481,10 @@ WasmCode* NativeModule::AddCode(
it.rinfo()->apply(delta); it.rinfo()->apply(delta);
} }
} }
// Flush the i-cache here instead of in AddOwnedCode, to include the changes
// made while iterating over the RelocInfo above.
Assembler::FlushICache(ret->instructions().start(),
ret->instructions().size());
return ret; return ret;
} }
...@@ -695,7 +704,8 @@ WasmCode* NativeModule::CloneCode(const WasmCode* original_code) { ...@@ -695,7 +704,8 @@ WasmCode* NativeModule::CloneCode(const WasmCode* original_code) {
original_code->kind(), original_code->constant_pool_offset_, original_code->kind(), original_code->constant_pool_offset_,
original_code->stack_slots(), original_code->safepoint_table_offset_, original_code->stack_slots(), original_code->safepoint_table_offset_,
original_code->handler_table_offset_, original_code->handler_table_offset_,
original_code->protected_instructions_, original_code->tier()); original_code->protected_instructions_, original_code->tier(),
false /* flush_icache */);
if (ret == nullptr) return nullptr; if (ret == nullptr) return nullptr;
if (!ret->IsAnonymous()) { if (!ret->IsAnonymous()) {
code_table_[ret->index()] = ret; code_table_[ret->index()] = ret;
...@@ -707,6 +717,10 @@ WasmCode* NativeModule::CloneCode(const WasmCode* original_code) { ...@@ -707,6 +717,10 @@ WasmCode* NativeModule::CloneCode(const WasmCode* original_code) {
!it.done(); it.next()) { !it.done(); it.next()) {
it.rinfo()->apply(delta); it.rinfo()->apply(delta);
} }
// Flush the i-cache here instead of in AddOwnedCode, to include the changes
// made while iterating over the RelocInfo above.
Assembler::FlushICache(ret->instructions().start(),
ret->instructions().size());
return ret; return ret;
} }
......
...@@ -296,7 +296,7 @@ class V8_EXPORT_PRIVATE NativeModule final { ...@@ -296,7 +296,7 @@ class V8_EXPORT_PRIVATE NativeModule final {
uint32_t stack_slots, size_t safepoint_table_offset, uint32_t stack_slots, size_t safepoint_table_offset,
size_t handler_table_offset, size_t handler_table_offset,
std::shared_ptr<ProtectedInstructions>, std::shared_ptr<ProtectedInstructions>,
WasmCode::Tier tier); WasmCode::Tier tier, bool flush_icache = true);
WasmCode* CloneCode(const WasmCode*); WasmCode* CloneCode(const WasmCode*);
bool CloneTrampolinesAndStubs(const NativeModule* other); bool CloneTrampolinesAndStubs(const NativeModule* other);
WasmCode* Lookup(Address); WasmCode* Lookup(Address);
......
...@@ -156,7 +156,7 @@ bool CodeSpecialization::ApplyToWholeInstance( ...@@ -156,7 +156,7 @@ bool CodeSpecialization::ApplyToWholeInstance(
case RelocInfo::JS_TO_WASM_CALL: { case RelocInfo::JS_TO_WASM_CALL: {
const WasmCode* new_code = native_module->GetCode(exp.index); const WasmCode* new_code = native_module->GetCode(exp.index);
it.rinfo()->set_js_to_wasm_address(new_code->instructions().start(), it.rinfo()->set_js_to_wasm_address(new_code->instructions().start(),
SKIP_ICACHE_FLUSH); icache_flush_mode);
} break; } break;
default: default:
UNREACHABLE(); UNREACHABLE();
......
...@@ -553,7 +553,7 @@ bool NativeModuleDeserializer::ReadCode() { ...@@ -553,7 +553,7 @@ bool NativeModuleDeserializer::ReadCode() {
code_buffer, std::move(reloc_info), reloc_size, Just(index_), code_buffer, std::move(reloc_info), reloc_size, Just(index_),
WasmCode::kFunction, constant_pool_offset, stack_slot_count, WasmCode::kFunction, constant_pool_offset, stack_slot_count,
safepoint_table_offset, handler_table_offset, protected_instructions, safepoint_table_offset, handler_table_offset, protected_instructions,
tier); tier, false /* flush_icache */);
if (ret == nullptr) return false; if (ret == nullptr) return false;
native_module_->code_table_[index_] = ret; native_module_->code_table_[index_] = ret;
...@@ -569,7 +569,7 @@ bool NativeModuleDeserializer::ReadCode() { ...@@ -569,7 +569,7 @@ bool NativeModuleDeserializer::ReadCode() {
case RelocInfo::EMBEDDED_OBJECT: { case RelocInfo::EMBEDDED_OBJECT: {
// We only expect {undefined}. We check for that when we add code. // We only expect {undefined}. We check for that when we add code.
iter.rinfo()->set_target_object(isolate_->heap()->undefined_value(), iter.rinfo()->set_target_object(isolate_->heap()->undefined_value(),
SKIP_WRITE_BARRIER); SKIP_WRITE_BARRIER, SKIP_ICACHE_FLUSH);
break; break;
} }
case RelocInfo::CODE_TARGET: { case RelocInfo::CODE_TARGET: {
...@@ -591,6 +591,11 @@ bool NativeModuleDeserializer::ReadCode() { ...@@ -591,6 +591,11 @@ bool NativeModuleDeserializer::ReadCode() {
break; break;
} }
} }
// Flush the i-cache here instead of in AddOwnedCode, to include the changes
// made while iterating over the RelocInfo above.
Assembler::FlushICache(ret->instructions().start(),
ret->instructions().size());
if (source_position_size > 0) { if (source_position_size > 0) {
Handle<ByteArray> source_positions = isolate_->factory()->NewByteArray( Handle<ByteArray> source_positions = isolate_->factory()->NewByteArray(
static_cast<int>(source_position_size), TENURED); static_cast<int>(source_position_size), TENURED);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment