Commit c77ca6b3 authored by Lu Yahan's avatar Lu Yahan Committed by V8 LUCI CQ

[riscv64] Fix uncorrectly branch

Change-Id: Ic73b5414e62de76a3d4d604c52686c273d9a1b44
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2970813
Commit-Queue: Yahan Lu <yahan@iscas.ac.cn>
Commit-Queue: Ji Qiu <qiuji@iscas.ac.cn>
Auto-Submit: Yahan Lu <yahan@iscas.ac.cn>
Reviewed-by: 's avatarJi Qiu <qiuji@iscas.ac.cn>
Cr-Commit-Position: refs/heads/master@{#75238}
parent d92ad3b8
...@@ -4640,7 +4640,7 @@ void TurboAssembler::LoadCodeObjectEntry(Register destination, ...@@ -4640,7 +4640,7 @@ void TurboAssembler::LoadCodeObjectEntry(Register destination,
if (options().isolate_independent_code) { if (options().isolate_independent_code) {
DCHECK(root_array_available()); DCHECK(root_array_available());
Label if_code_is_off_heap, no_builtin_index, out; Label if_code_is_off_heap, out;
UseScratchRegisterScope temps(this); UseScratchRegisterScope temps(this);
Register scratch = temps.Acquire(); Register scratch = temps.Acquire();
...@@ -4653,11 +4653,10 @@ void TurboAssembler::LoadCodeObjectEntry(Register destination, ...@@ -4653,11 +4653,10 @@ void TurboAssembler::LoadCodeObjectEntry(Register destination,
// trampoline. Otherwise, just call the Code object as always. // trampoline. Otherwise, just call the Code object as always.
Lw(scratch, FieldMemOperand(code_object, Code::kFlagsOffset)); Lw(scratch, FieldMemOperand(code_object, Code::kFlagsOffset));
Branch(&if_code_is_off_heap, ne, scratch, And(scratch, scratch, Operand(Code::IsOffHeapTrampoline::kMask));
Operand(Code::IsOffHeapTrampoline::kMask)); Branch(&if_code_is_off_heap, ne, scratch, Operand(zero_reg));
// Not an off-heap trampoline object, the entry point is at // Not an off-heap trampoline object, the entry point is at
// Code::raw_instruction_start(). // Code::raw_instruction_start().
bind(&no_builtin_index);
Add64(destination, code_object, Code::kHeaderSize - kHeapObjectTag); Add64(destination, code_object, Code::kHeaderSize - kHeapObjectTag);
Branch(&out); Branch(&out);
...@@ -4665,9 +4664,6 @@ void TurboAssembler::LoadCodeObjectEntry(Register destination, ...@@ -4665,9 +4664,6 @@ void TurboAssembler::LoadCodeObjectEntry(Register destination,
// table. // table.
bind(&if_code_is_off_heap); bind(&if_code_is_off_heap);
Lw(scratch, FieldMemOperand(code_object, Code::kBuiltinIndexOffset)); Lw(scratch, FieldMemOperand(code_object, Code::kBuiltinIndexOffset));
// TODO(RISCV): https://github.com/v8-riscv/v8/issues/373
Branch(&no_builtin_index, eq, scratch,
Operand(static_cast<int>(Builtin::kNoBuiltinId)));
slli(destination, scratch, kSystemPointerSizeLog2); slli(destination, scratch, kSystemPointerSizeLog2);
Add64(destination, destination, kRootRegister); Add64(destination, destination, kRootRegister);
Ld(destination, Ld(destination,
......
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