Commit ac2560c8 authored by Igor Sheludko's avatar Igor Sheludko Committed by Commit Bot

[sparkplug] Fix short builtin calls

... and don't enable them for CFI builds.

Bug: v8:11527
Change-Id: I651473833c1e74d942bd75dc7574dbca45b34b64
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2786855Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
Commit-Queue: Igor Sheludko <ishell@chromium.org>
Cr-Commit-Position: refs/heads/master@{#73672}
parent 070159f3
...@@ -379,8 +379,10 @@ if (v8_multi_arch_build && ...@@ -379,8 +379,10 @@ if (v8_multi_arch_build &&
v8_enable_pointer_compression = !v8_enable_pointer_compression v8_enable_pointer_compression = !v8_enable_pointer_compression
v8_enable_pointer_compression_shared_cage = v8_enable_pointer_compression v8_enable_pointer_compression_shared_cage = v8_enable_pointer_compression
} }
if (v8_enable_short_builtin_calls && !v8_enable_pointer_compression) { if (v8_enable_short_builtin_calls &&
(!v8_enable_pointer_compression || v8_control_flow_integrity)) {
# Disable short calls when pointer compression is not enabled. # Disable short calls when pointer compression is not enabled.
# Or when CFI is enabled (until the CFI-related issues are fixed).
v8_enable_short_builtin_calls = false v8_enable_short_builtin_calls = false
} }
if (v8_enable_shared_ro_heap == "") { if (v8_enable_shared_ro_heap == "") {
......
...@@ -8803,8 +8803,8 @@ void Isolate::GetCodeRange(void** start, size_t* length_in_bytes) { ...@@ -8803,8 +8803,8 @@ void Isolate::GetCodeRange(void** start, size_t* length_in_bytes) {
void Isolate::GetEmbeddedCodeRange(const void** start, void Isolate::GetEmbeddedCodeRange(const void** start,
size_t* length_in_bytes) { size_t* length_in_bytes) {
i::Isolate* isolate = reinterpret_cast<i::Isolate*>(this); // Note, we should return the embedded code rande from the .text section here.
i::EmbeddedData d = i::EmbeddedData::FromBlob(isolate); i::EmbeddedData d = i::EmbeddedData::FromBlob();
*start = reinterpret_cast<const void*>(d.code()); *start = reinterpret_cast<const void*>(d.code());
*length_in_bytes = d.code_size(); *length_in_bytes = d.code_size();
} }
......
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