Commit 43aca435 authored by Liu Yu's avatar Liu Yu Committed by V8 LUCI CQ

Reland "[sparkplug] Adjust compare and jump function in sparkplug"

This is a reland of febfbb21

Original change's description:
> [sparkplug] Adjust compare and jump function in sparkplug
>
> Mips and risc-v do not have the flag register and can not decide
> whether to jump through flags in JumpIf();
>
> Therefor, we merge the comparison with the jump;
>
> Bug: v8:11803
>
> Change-Id: If53752da93b97e8ff65affdfe99e5de8e1a1493f
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2921034
> Auto-Submit: Liu yu <liuyu@loongson.cn>
> Commit-Queue: Zhao Jiazhong <zhaojiazhong-hf@loongson.cn>
> Reviewed-by: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Toon Verwaest <verwaest@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#75001}

Bug: v8:11803
Change-Id: Ib3cb89d8a9f59aad3fbd857881699e84e8fcd8aa
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2945538
Commit-Queue: Leszek Swirski <leszeks@chromium.org>
Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
Cr-Commit-Position: refs/heads/master@{#75078}
parent ae922188
...@@ -97,9 +97,6 @@ void BaselineAssembler::JumpTarget() { ...@@ -97,9 +97,6 @@ void BaselineAssembler::JumpTarget() {
void BaselineAssembler::Jump(Label* target, Label::Distance distance) { void BaselineAssembler::Jump(Label* target, Label::Distance distance) {
__ b(target); __ b(target);
} }
void BaselineAssembler::JumpIf(Condition cc, Label* target, Label::Distance) {
__ b(AsMasmCondition(cc), target);
}
void BaselineAssembler::JumpIfRoot(Register value, RootIndex index, void BaselineAssembler::JumpIfRoot(Register value, RootIndex index,
Label* target, Label::Distance) { Label* target, Label::Distance) {
__ JumpIfRoot(value, index, target); __ JumpIfRoot(value, index, target);
...@@ -136,19 +133,30 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) { ...@@ -136,19 +133,30 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) {
__ RecordComment("]"); __ RecordComment("]");
} }
void BaselineAssembler::Test(Register value, int mask) { void BaselineAssembler::TestAndBranch(Register value, int mask, Condition cc,
Label* target, Label::Distance) {
__ tst(value, Operand(mask)); __ tst(value, Operand(mask));
__ b(AsMasmCondition(cc), target);
} }
void BaselineAssembler::CmpObjectType(Register object, void BaselineAssembler::JumpIf(Condition cc, Register lhs, const Operand& rhs,
InstanceType instance_type, Label* target, Label::Distance) {
Register map) { __ cmp(lhs, Operand(rhs));
__ b(AsMasmCondition(cc), target);
}
void BaselineAssembler::JumpIfObjectType(Condition cc, Register object,
InstanceType instance_type,
Register map, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register type = temps.AcquireScratch(); Register type = temps.AcquireScratch();
__ CompareObjectType(object, map, type, instance_type); __ LoadMap(map, object);
__ ldrh(type, FieldMemOperand(map, Map::kInstanceTypeOffset));
JumpIf(cc, type, Operand(instance_type), target);
} }
void BaselineAssembler::CmpInstanceType(Register map, void BaselineAssembler::JumpIfInstanceType(Condition cc, Register map,
InstanceType instance_type) { InstanceType instance_type,
Label* target, Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register type = temps.AcquireScratch(); Register type = temps.AcquireScratch();
if (FLAG_debug_code) { if (FLAG_debug_code) {
...@@ -156,36 +164,47 @@ void BaselineAssembler::CmpInstanceType(Register map, ...@@ -156,36 +164,47 @@ void BaselineAssembler::CmpInstanceType(Register map,
__ CompareObjectType(map, type, type, MAP_TYPE); __ CompareObjectType(map, type, type, MAP_TYPE);
__ Assert(eq, AbortReason::kUnexpectedValue); __ Assert(eq, AbortReason::kUnexpectedValue);
} }
__ CompareInstanceType(map, type, instance_type); __ ldrh(type, FieldMemOperand(map, Map::kInstanceTypeOffset));
JumpIf(cc, type, Operand(instance_type), target);
} }
void BaselineAssembler::Cmp(Register value, Smi smi) { void BaselineAssembler::JumpIfPointer(Condition cc, Register value,
__ cmp(value, Operand(smi)); MemOperand operand, Label* target,
} Label::Distance) {
void BaselineAssembler::ComparePointer(Register value, MemOperand operand) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register tmp = temps.AcquireScratch(); Register tmp = temps.AcquireScratch();
__ ldr(tmp, operand); __ ldr(tmp, operand);
__ cmp(value, tmp); JumpIf(cc, value, Operand(tmp), target);
}
void BaselineAssembler::JumpIfSmi(Condition cc, Register value, Smi smi,
Label* target, Label::Distance) {
__ AssertSmi(value);
JumpIf(cc, value, Operand(smi), target);
} }
void BaselineAssembler::SmiCompare(Register lhs, Register rhs) { void BaselineAssembler::JumpIfSmi(Condition cc, Register lhs, Register rhs,
Label* target, Label::Distance) {
__ AssertSmi(lhs); __ AssertSmi(lhs);
__ AssertSmi(rhs); __ AssertSmi(rhs);
__ cmp(lhs, rhs); JumpIf(cc, lhs, Operand(rhs), target);
} }
void BaselineAssembler::CompareTagged(Register value, MemOperand operand) { void BaselineAssembler::JumpIfTagged(Condition cc, Register value,
MemOperand operand, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register tmp = temps.AcquireScratch(); Register tmp = temps.AcquireScratch();
__ ldr(tmp, operand); __ ldr(tmp, operand);
__ cmp(value, tmp); JumpIf(cc, value, Operand(tmp), target);
} }
void BaselineAssembler::CompareTagged(MemOperand operand, Register value) { void BaselineAssembler::JumpIfTagged(Condition cc, MemOperand operand,
Register value, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register tmp = temps.AcquireScratch(); Register tmp = temps.AcquireScratch();
__ ldr(tmp, operand); __ ldr(tmp, operand);
__ cmp(tmp, value); JumpIf(cc, tmp, Operand(value), target);
} }
void BaselineAssembler::CompareByte(Register value, int32_t byte) { void BaselineAssembler::JumpIfByte(Condition cc, Register value, int32_t byte,
__ cmp(value, Operand(byte)); Label* target, Label::Distance) {
JumpIf(cc, value, Operand(byte), target);
} }
void BaselineAssembler::Move(interpreter::Register output, Register source) { void BaselineAssembler::Move(interpreter::Register output, Register source) {
...@@ -360,7 +379,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target, ...@@ -360,7 +379,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target,
__ str(value, FieldMemOperand(target, offset)); __ str(value, FieldMemOperand(target, offset));
} }
void BaselineAssembler::AddToInterruptBudget(int32_t weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
int32_t weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
LoadFunction(feedback_cell); LoadFunction(feedback_cell);
...@@ -374,9 +394,15 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) { ...@@ -374,9 +394,15 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) {
__ add(interrupt_budget, interrupt_budget, Operand(weight), SetCC); __ add(interrupt_budget, interrupt_budget, Operand(weight), SetCC);
__ str(interrupt_budget, __ str(interrupt_budget,
FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset)); FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset));
if (skip_interrupt_label) {
// Use compare flags set by add
DCHECK_LT(weight, 0);
__ b(ge, skip_interrupt_label);
}
} }
void BaselineAssembler::AddToInterruptBudget(Register weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
Register weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
LoadFunction(feedback_cell); LoadFunction(feedback_cell);
...@@ -390,6 +416,7 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) { ...@@ -390,6 +416,7 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) {
__ add(interrupt_budget, interrupt_budget, weight, SetCC); __ add(interrupt_budget, interrupt_budget, weight, SetCC);
__ str(interrupt_budget, __ str(interrupt_budget,
FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset)); FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset));
if (skip_interrupt_label) __ b(ge, skip_interrupt_label);
} }
void BaselineAssembler::AddSmi(Register lhs, Smi rhs) { void BaselineAssembler::AddSmi(Register lhs, Smi rhs) {
...@@ -405,8 +432,8 @@ void BaselineAssembler::Switch(Register reg, int case_value_base, ...@@ -405,8 +432,8 @@ void BaselineAssembler::Switch(Register reg, int case_value_base,
// Mostly copied from code-generator-arm.cc // Mostly copied from code-generator-arm.cc
ScratchRegisterScope scope(this); ScratchRegisterScope scope(this);
__ cmp(reg, Operand(num_labels)); JumpIf(Condition::kUnsignedGreaterThanEqual, reg, Operand(num_labels),
JumpIf(Condition::kUnsignedGreaterThanEqual, &fallthrough); &fallthrough);
// Ensure to emit the constant pool first if necessary. // Ensure to emit the constant pool first if necessary.
__ CheckConstPool(true, true); __ CheckConstPool(true, true);
__ BlockConstPoolFor(num_labels); __ BlockConstPoolFor(num_labels);
...@@ -430,11 +457,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) { ...@@ -430,11 +457,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) {
Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister(); Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister();
__ RecordComment("[ Update Interrupt Budget"); __ RecordComment("[ Update Interrupt Budget");
__ AddToInterruptBudget(weight);
// Use compare flags set by add
Label skip_interrupt_label; Label skip_interrupt_label;
__ JumpIf(Condition::kGreaterThanEqual, &skip_interrupt_label); __ AddToInterruptBudgetAndJumpIfNotExceeded(weight, &skip_interrupt_label);
{ {
__ masm()->SmiTag(params_size); __ masm()->SmiTag(params_size);
__ Push(params_size, kInterpreterAccumulatorRegister); __ Push(params_size, kInterpreterAccumulatorRegister);
...@@ -460,8 +485,8 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) { ...@@ -460,8 +485,8 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) {
// If actual is bigger than formal, then we should use it to free up the stack // If actual is bigger than formal, then we should use it to free up the stack
// arguments. // arguments.
Label corrected_args_count; Label corrected_args_count;
__ masm()->cmp(params_size, actual_params_size); __ JumpIf(Condition::kGreaterThanEqual, params_size,
__ JumpIf(Condition::kGreaterThanEqual, &corrected_args_count); Operand(actual_params_size), &corrected_args_count);
__ masm()->mov(params_size, actual_params_size); __ masm()->mov(params_size, actual_params_size);
__ Bind(&corrected_args_count); __ Bind(&corrected_args_count);
......
...@@ -75,7 +75,7 @@ void BaselineCompiler::PrologueFillFrame() { ...@@ -75,7 +75,7 @@ void BaselineCompiler::PrologueFillFrame() {
__ Push(kInterpreterAccumulatorRegister); __ Push(kInterpreterAccumulatorRegister);
} }
__ masm()->sub(scratch, scratch, Operand(1), SetCC); __ masm()->sub(scratch, scratch, Operand(1), SetCC);
__ JumpIf(Condition::kGreaterThan, &loop); __ masm()->b(gt, &loop);
} }
__ RecordComment("]"); __ RecordComment("]");
} }
......
...@@ -95,9 +95,6 @@ void BaselineAssembler::JumpTarget() { __ JumpTarget(); } ...@@ -95,9 +95,6 @@ void BaselineAssembler::JumpTarget() { __ JumpTarget(); }
void BaselineAssembler::Jump(Label* target, Label::Distance distance) { void BaselineAssembler::Jump(Label* target, Label::Distance distance) {
__ B(target); __ B(target);
} }
void BaselineAssembler::JumpIf(Condition cc, Label* target, Label::Distance) {
__ B(AsMasmCondition(cc), target);
}
void BaselineAssembler::JumpIfRoot(Register value, RootIndex index, void BaselineAssembler::JumpIfRoot(Register value, RootIndex index,
Label* target, Label::Distance) { Label* target, Label::Distance) {
__ JumpIfRoot(value, index, target); __ JumpIfRoot(value, index, target);
...@@ -152,19 +149,29 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) { ...@@ -152,19 +149,29 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) {
} }
} }
void BaselineAssembler::Test(Register value, int mask) { void BaselineAssembler::TestAndBranch(Register value, int mask, Condition cc,
Label* target, Label::Distance) {
__ Tst(value, Immediate(mask)); __ Tst(value, Immediate(mask));
__ B(AsMasmCondition(cc), target);
} }
void BaselineAssembler::CmpObjectType(Register object, void BaselineAssembler::JumpIf(Condition cc, Register lhs, const Operand& rhs,
InstanceType instance_type, Label* target, Label::Distance) {
Register map) { __ CompareAndBranch(lhs, rhs, AsMasmCondition(cc), target);
}
void BaselineAssembler::JumpIfObjectType(Condition cc, Register object,
InstanceType instance_type,
Register map, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register type = temps.AcquireScratch(); Register type = temps.AcquireScratch();
__ CompareObjectType(object, map, type, instance_type); __ LoadMap(map, object);
__ Ldrh(type, FieldMemOperand(map, Map::kInstanceTypeOffset));
JumpIf(cc, type, instance_type, target);
} }
void BaselineAssembler::CmpInstanceType(Register map, void BaselineAssembler::JumpIfInstanceType(Condition cc, Register map,
InstanceType instance_type) { InstanceType instance_type,
Label* target, Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register type = temps.AcquireScratch(); Register type = temps.AcquireScratch();
if (FLAG_debug_code) { if (FLAG_debug_code) {
...@@ -172,34 +179,48 @@ void BaselineAssembler::CmpInstanceType(Register map, ...@@ -172,34 +179,48 @@ void BaselineAssembler::CmpInstanceType(Register map,
__ CompareObjectType(map, type, type, MAP_TYPE); __ CompareObjectType(map, type, type, MAP_TYPE);
__ Assert(eq, AbortReason::kUnexpectedValue); __ Assert(eq, AbortReason::kUnexpectedValue);
} }
__ CompareInstanceType(map, type, instance_type); __ Ldrh(type, FieldMemOperand(map, Map::kInstanceTypeOffset));
JumpIf(cc, type, instance_type, target);
} }
void BaselineAssembler::Cmp(Register value, Smi smi) { __ Cmp(value, smi); } void BaselineAssembler::JumpIfPointer(Condition cc, Register value,
void BaselineAssembler::ComparePointer(Register value, MemOperand operand) { MemOperand operand, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register tmp = temps.AcquireScratch(); Register tmp = temps.AcquireScratch();
__ Ldr(tmp, operand); __ Ldr(tmp, operand);
__ Cmp(value, tmp); JumpIf(cc, value, tmp, target);
}
void BaselineAssembler::JumpIfSmi(Condition cc, Register value, Smi smi,
Label* target, Label::Distance distance) {
__ AssertSmi(value);
__ CompareTaggedAndBranch(value, smi, AsMasmCondition(cc), target);
} }
void BaselineAssembler::SmiCompare(Register lhs, Register rhs) {
void BaselineAssembler::JumpIfSmi(Condition cc, Register lhs, Register rhs,
Label* target, Label::Distance) {
__ AssertSmi(lhs); __ AssertSmi(lhs);
__ AssertSmi(rhs); __ AssertSmi(rhs);
__ CmpTagged(lhs, rhs); __ CompareTaggedAndBranch(lhs, rhs, AsMasmCondition(cc), target);
} }
void BaselineAssembler::CompareTagged(Register value, MemOperand operand) { void BaselineAssembler::JumpIfTagged(Condition cc, Register value,
MemOperand operand, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register tmp = temps.AcquireScratch(); Register tmp = temps.AcquireScratch();
__ Ldr(tmp, operand); __ Ldr(tmp, operand);
__ CmpTagged(value, tmp); __ CompareTaggedAndBranch(value, tmp, AsMasmCondition(cc), target);
} }
void BaselineAssembler::CompareTagged(MemOperand operand, Register value) { void BaselineAssembler::JumpIfTagged(Condition cc, MemOperand operand,
Register value, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register tmp = temps.AcquireScratch(); Register tmp = temps.AcquireScratch();
__ Ldr(tmp, operand); __ Ldr(tmp, operand);
__ CmpTagged(tmp, value); __ CompareTaggedAndBranch(tmp, value, AsMasmCondition(cc), target);
} }
void BaselineAssembler::CompareByte(Register value, int32_t byte) { void BaselineAssembler::JumpIfByte(Condition cc, Register value, int32_t byte,
__ Cmp(value, Immediate(byte)); Label* target, Label::Distance) {
JumpIf(cc, value, Immediate(byte), target);
} }
void BaselineAssembler::Move(interpreter::Register output, Register source) { void BaselineAssembler::Move(interpreter::Register output, Register source) {
...@@ -430,7 +451,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target, ...@@ -430,7 +451,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target,
__ StoreTaggedField(value, FieldMemOperand(target, offset)); __ StoreTaggedField(value, FieldMemOperand(target, offset));
} }
void BaselineAssembler::AddToInterruptBudget(int32_t weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
int32_t weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
LoadFunction(feedback_cell); LoadFunction(feedback_cell);
...@@ -444,9 +466,15 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) { ...@@ -444,9 +466,15 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) {
__ Adds(interrupt_budget, interrupt_budget, weight); __ Adds(interrupt_budget, interrupt_budget, weight);
__ Str(interrupt_budget, __ Str(interrupt_budget,
FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset)); FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset));
if (skip_interrupt_label) {
// Use compare flags set by Adds
DCHECK_LT(weight, 0);
__ B(ge, skip_interrupt_label);
}
} }
void BaselineAssembler::AddToInterruptBudget(Register weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
Register weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
LoadFunction(feedback_cell); LoadFunction(feedback_cell);
...@@ -460,6 +488,7 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) { ...@@ -460,6 +488,7 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) {
__ Adds(interrupt_budget, interrupt_budget, weight.W()); __ Adds(interrupt_budget, interrupt_budget, weight.W());
__ Str(interrupt_budget, __ Str(interrupt_budget,
FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset)); FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset));
if (skip_interrupt_label) __ B(ge, skip_interrupt_label);
} }
void BaselineAssembler::AddSmi(Register lhs, Smi rhs) { void BaselineAssembler::AddSmi(Register lhs, Smi rhs) {
...@@ -482,8 +511,7 @@ void BaselineAssembler::Switch(Register reg, int case_value_base, ...@@ -482,8 +511,7 @@ void BaselineAssembler::Switch(Register reg, int case_value_base,
ScratchRegisterScope scope(this); ScratchRegisterScope scope(this);
Register temp = scope.AcquireScratch(); Register temp = scope.AcquireScratch();
Label table; Label table;
__ Cmp(reg, num_labels); JumpIf(Condition::kUnsignedGreaterThanEqual, reg, num_labels, &fallthrough);
JumpIf(Condition::kUnsignedGreaterThanEqual, &fallthrough);
__ Adr(temp, &table); __ Adr(temp, &table);
int entry_size_log2 = 2; int entry_size_log2 = 2;
#ifdef V8_ENABLE_CONTROL_FLOW_INTEGRITY #ifdef V8_ENABLE_CONTROL_FLOW_INTEGRITY
...@@ -513,11 +541,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) { ...@@ -513,11 +541,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) {
Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister(); Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister();
__ RecordComment("[ Update Interrupt Budget"); __ RecordComment("[ Update Interrupt Budget");
__ AddToInterruptBudget(weight);
// Use compare flags set by add
Label skip_interrupt_label; Label skip_interrupt_label;
__ JumpIf(Condition::kGreaterThanEqual, &skip_interrupt_label); __ AddToInterruptBudgetAndJumpIfNotExceeded(weight, &skip_interrupt_label);
{ {
__ masm()->SmiTag(params_size); __ masm()->SmiTag(params_size);
__ masm()->Push(params_size, kInterpreterAccumulatorRegister); __ masm()->Push(params_size, kInterpreterAccumulatorRegister);
...@@ -543,8 +569,8 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) { ...@@ -543,8 +569,8 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) {
// If actual is bigger than formal, then we should use it to free up the stack // If actual is bigger than formal, then we should use it to free up the stack
// arguments. // arguments.
Label corrected_args_count; Label corrected_args_count;
__ masm()->Cmp(params_size, actual_params_size); __ JumpIf(Condition::kGreaterThanEqual, params_size, actual_params_size,
__ JumpIf(Condition::kGreaterThanEqual, &corrected_args_count); &corrected_args_count);
__ masm()->Mov(params_size, actual_params_size); __ masm()->Mov(params_size, actual_params_size);
__ Bind(&corrected_args_count); __ Bind(&corrected_args_count);
......
...@@ -96,7 +96,7 @@ void BaselineCompiler::PrologueFillFrame() { ...@@ -96,7 +96,7 @@ void BaselineCompiler::PrologueFillFrame() {
kInterpreterAccumulatorRegister); kInterpreterAccumulatorRegister);
} }
__ masm()->Subs(scratch, scratch, 1); __ masm()->Subs(scratch, scratch, 1);
__ JumpIf(Condition::kGreaterThan, &loop); __ masm()->B(gt, &loop);
} }
__ RecordComment("]"); __ RecordComment("]");
} }
......
...@@ -46,8 +46,6 @@ class BaselineAssembler { ...@@ -46,8 +46,6 @@ class BaselineAssembler {
// Marks the current position as a valid jump target on CFI enabled // Marks the current position as a valid jump target on CFI enabled
// architectures. // architectures.
inline void JumpTarget(); inline void JumpTarget();
inline void JumpIf(Condition cc, Label* target,
Label::Distance distance = Label::kFar);
inline void Jump(Label* target, Label::Distance distance = Label::kFar); inline void Jump(Label* target, Label::Distance distance = Label::kFar);
inline void JumpIfRoot(Register value, RootIndex index, Label* target, inline void JumpIfRoot(Register value, RootIndex index, Label* target,
Label::Distance distance = Label::kFar); Label::Distance distance = Label::kFar);
...@@ -58,18 +56,35 @@ class BaselineAssembler { ...@@ -58,18 +56,35 @@ class BaselineAssembler {
inline void JumpIfNotSmi(Register value, Label* target, inline void JumpIfNotSmi(Register value, Label* target,
Label::Distance distance = Label::kFar); Label::Distance distance = Label::kFar);
inline void Test(Register value, int mask); inline void TestAndBranch(Register value, int mask, Condition cc,
Label* target,
inline void CmpObjectType(Register object, InstanceType instance_type, Label::Distance distance = Label::kFar);
Register map);
inline void CmpInstanceType(Register map, InstanceType instance_type); inline void JumpIf(Condition cc, Register lhs, const Operand& rhs,
inline void Cmp(Register value, Smi smi); Label* target, Label::Distance distance = Label::kFar);
inline void ComparePointer(Register value, MemOperand operand); inline void JumpIfObjectType(Condition cc, Register object,
InstanceType instance_type, Register map,
Label* target,
Label::Distance distance = Label::kFar);
inline void JumpIfInstanceType(Condition cc, Register map,
InstanceType instance_type, Label* target,
Label::Distance distance = Label::kFar);
inline void JumpIfPointer(Condition cc, Register value, MemOperand operand,
Label* target,
Label::Distance distance = Label::kFar);
inline Condition CheckSmi(Register value); inline Condition CheckSmi(Register value);
inline void SmiCompare(Register lhs, Register rhs); inline void JumpIfSmi(Condition cc, Register value, Smi smi, Label* target,
inline void CompareTagged(Register value, MemOperand operand); Label::Distance distance = Label::kFar);
inline void CompareTagged(MemOperand operand, Register value); inline void JumpIfSmi(Condition cc, Register lhs, Register rhs, Label* target,
inline void CompareByte(Register value, int32_t byte); Label::Distance distance = Label::kFar);
inline void JumpIfTagged(Condition cc, Register value, MemOperand operand,
Label* target,
Label::Distance distance = Label::kFar);
inline void JumpIfTagged(Condition cc, MemOperand operand, Register value,
Label* target,
Label::Distance distance = Label::kFar);
inline void JumpIfByte(Condition cc, Register value, int32_t byte,
Label* target, Label::Distance distance = Label::kFar);
inline void LoadMap(Register output, Register value); inline void LoadMap(Register output, Register value);
inline void LoadRoot(Register output, RootIndex index); inline void LoadRoot(Register output, RootIndex index);
...@@ -147,8 +162,10 @@ class BaselineAssembler { ...@@ -147,8 +162,10 @@ class BaselineAssembler {
// Loads the feedback cell from the function, and sets flags on add so that // Loads the feedback cell from the function, and sets flags on add so that
// we can compare afterward. // we can compare afterward.
inline void AddToInterruptBudget(int32_t weight); inline void AddToInterruptBudgetAndJumpIfNotExceeded(
inline void AddToInterruptBudget(Register weight); int32_t weight, Label* skip_interrupt_label);
inline void AddToInterruptBudgetAndJumpIfNotExceeded(
Register weight, Label* skip_interrupt_label);
inline void AddSmi(Register lhs, Smi rhs); inline void AddSmi(Register lhs, Smi rhs);
inline void SmiUntag(Register value); inline void SmiUntag(Register value);
......
This diff is collapsed.
...@@ -98,10 +98,6 @@ void BaselineAssembler::JumpTarget() { ...@@ -98,10 +98,6 @@ void BaselineAssembler::JumpTarget() {
void BaselineAssembler::Jump(Label* target, Label::Distance distance) { void BaselineAssembler::Jump(Label* target, Label::Distance distance) {
__ jmp(target, distance); __ jmp(target, distance);
} }
void BaselineAssembler::JumpIf(Condition cc, Label* target,
Label::Distance distance) {
__ j(AsMasmCondition(cc), target, distance);
}
void BaselineAssembler::JumpIfRoot(Register value, RootIndex index, void BaselineAssembler::JumpIfRoot(Register value, RootIndex index,
Label* target, Label::Distance distance) { Label* target, Label::Distance distance) {
__ JumpIfRoot(value, index, target, distance); __ JumpIfRoot(value, index, target, distance);
...@@ -131,22 +127,33 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) { ...@@ -131,22 +127,33 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) {
__ RecordComment("]"); __ RecordComment("]");
} }
void BaselineAssembler::Test(Register value, int mask) { void BaselineAssembler::TestAndBranch(Register value, int mask, Condition cc,
Label* target, Label::Distance distance) {
if ((mask & 0xff) == mask) { if ((mask & 0xff) == mask) {
__ test_b(value, Immediate(mask)); __ test_b(value, Immediate(mask));
} else { } else {
__ test(value, Immediate(mask)); __ test(value, Immediate(mask));
} }
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::CmpObjectType(Register object, void BaselineAssembler::JumpIf(Condition cc, Register lhs, const Operand& rhs,
InstanceType instance_type, Label* target, Label::Distance distance) {
Register map) { __ cmp(lhs, rhs);
__ j(AsMasmCondition(cc), target, distance);
}
void BaselineAssembler::JumpIfObjectType(Condition cc, Register object,
InstanceType instance_type,
Register map, Label* target,
Label::Distance distance) {
__ AssertNotSmi(object); __ AssertNotSmi(object);
__ CmpObjectType(object, instance_type, map); __ CmpObjectType(object, instance_type, map);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::CmpInstanceType(Register map, void BaselineAssembler::JumpIfInstanceType(Condition cc, Register map,
InstanceType instance_type) { InstanceType instance_type,
Label* target,
Label::Distance distance) {
if (FLAG_debug_code) { if (FLAG_debug_code) {
__ movd(xmm0, eax); __ movd(xmm0, eax);
__ AssertNotSmi(map); __ AssertNotSmi(map);
...@@ -155,30 +162,45 @@ void BaselineAssembler::CmpInstanceType(Register map, ...@@ -155,30 +162,45 @@ void BaselineAssembler::CmpInstanceType(Register map,
__ movd(eax, xmm0); __ movd(eax, xmm0);
} }
__ CmpInstanceType(map, instance_type); __ CmpInstanceType(map, instance_type);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::Cmp(Register value, Smi smi) { void BaselineAssembler::JumpIfPointer(Condition cc, Register value,
MemOperand operand, Label* target,
Label::Distance distance) {
JumpIf(cc, value, operand, target, distance);
}
void BaselineAssembler::JumpIfSmi(Condition cc, Register value, Smi smi,
Label* target, Label::Distance distance) {
if (smi.value() == 0) { if (smi.value() == 0) {
__ test(value, value); __ test(value, value);
} else { } else {
__ cmp(value, Immediate(smi)); __ cmp(value, Immediate(smi));
} }
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::ComparePointer(Register value, MemOperand operand) { void BaselineAssembler::JumpIfSmi(Condition cc, Register lhs, Register rhs,
__ cmp(value, operand); Label* target, Label::Distance distance) {
}
void BaselineAssembler::SmiCompare(Register lhs, Register rhs) {
__ AssertSmi(lhs); __ AssertSmi(lhs);
__ AssertSmi(rhs); __ AssertSmi(rhs);
__ cmp(lhs, rhs); __ cmp(lhs, rhs);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::CompareTagged(Register value, MemOperand operand) { void BaselineAssembler::JumpIfTagged(Condition cc, Register value,
__ cmp(value, operand); MemOperand operand, Label* target,
Label::Distance distance) {
__ cmp(operand, value);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::CompareTagged(MemOperand operand, Register value) { void BaselineAssembler::JumpIfTagged(Condition cc, MemOperand operand,
Register value, Label* target,
Label::Distance distance) {
__ cmp(operand, value); __ cmp(operand, value);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::CompareByte(Register value, int32_t byte) { void BaselineAssembler::JumpIfByte(Condition cc, Register value, int32_t byte,
Label* target, Label::Distance distance) {
__ cmpb(value, Immediate(byte)); __ cmpb(value, Immediate(byte));
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::Move(interpreter::Register output, Register source) { void BaselineAssembler::Move(interpreter::Register output, Register source) {
return __ mov(RegisterFrameOperand(output), source); return __ mov(RegisterFrameOperand(output), source);
...@@ -329,7 +351,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target, ...@@ -329,7 +351,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target,
__ mov(FieldOperand(target, offset), value); __ mov(FieldOperand(target, offset), value);
} }
void BaselineAssembler::AddToInterruptBudget(int32_t weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
int32_t weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
LoadFunction(feedback_cell); LoadFunction(feedback_cell);
...@@ -337,9 +360,14 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) { ...@@ -337,9 +360,14 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) {
JSFunction::kFeedbackCellOffset); JSFunction::kFeedbackCellOffset);
__ add(FieldOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset), __ add(FieldOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset),
Immediate(weight)); Immediate(weight));
if (skip_interrupt_label) {
DCHECK_LT(weight, 0);
__ j(greater_equal, skip_interrupt_label);
}
} }
void BaselineAssembler::AddToInterruptBudget(Register weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
Register weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
DCHECK(!AreAliased(feedback_cell, weight)); DCHECK(!AreAliased(feedback_cell, weight));
...@@ -348,6 +376,7 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) { ...@@ -348,6 +376,7 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) {
JSFunction::kFeedbackCellOffset); JSFunction::kFeedbackCellOffset);
__ add(FieldOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset), __ add(FieldOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset),
weight); weight);
if (skip_interrupt_label) __ j(greater_equal, skip_interrupt_label);
} }
void BaselineAssembler::AddSmi(Register lhs, Smi rhs) { void BaselineAssembler::AddSmi(Register lhs, Smi rhs) {
...@@ -387,11 +416,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) { ...@@ -387,11 +416,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) {
Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister(); Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister();
__ RecordComment("[ Update Interrupt Budget"); __ RecordComment("[ Update Interrupt Budget");
__ AddToInterruptBudget(weight);
// Use compare flags set by AddToInterruptBudget
Label skip_interrupt_label; Label skip_interrupt_label;
__ JumpIf(Condition::kGreaterThanEqual, &skip_interrupt_label); __ AddToInterruptBudgetAndJumpIfNotExceeded(weight, &skip_interrupt_label);
{ {
__ masm()->SmiTag(params_size); __ masm()->SmiTag(params_size);
__ Push(params_size, kInterpreterAccumulatorRegister); __ Push(params_size, kInterpreterAccumulatorRegister);
...@@ -420,7 +447,7 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) { ...@@ -420,7 +447,7 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) {
// arguments. // arguments.
Label corrected_args_count; Label corrected_args_count;
__ masm()->cmp(params_size, actual_params_size); __ masm()->cmp(params_size, actual_params_size);
__ JumpIf(Condition::kGreaterThanEqual, &corrected_args_count, Label::kNear); __ masm()->j(greater_equal, &corrected_args_count);
__ masm()->mov(params_size, actual_params_size); __ masm()->mov(params_size, actual_params_size);
__ Bind(&corrected_args_count); __ Bind(&corrected_args_count);
......
...@@ -72,7 +72,7 @@ void BaselineCompiler::PrologueFillFrame() { ...@@ -72,7 +72,7 @@ void BaselineCompiler::PrologueFillFrame() {
__ Push(kInterpreterAccumulatorRegister); __ Push(kInterpreterAccumulatorRegister);
} }
__ masm()->dec(scratch); __ masm()->dec(scratch);
__ JumpIf(Condition::kGreaterThan, &loop); __ masm()->j(greater, &loop);
} }
__ RecordComment("]"); __ RecordComment("]");
} }
......
...@@ -92,9 +92,6 @@ void BaselineAssembler::JumpTarget() { ...@@ -92,9 +92,6 @@ void BaselineAssembler::JumpTarget() {
void BaselineAssembler::Jump(Label* target, Label::Distance distance) { void BaselineAssembler::Jump(Label* target, Label::Distance distance) {
__ jmp(target); __ jmp(target);
} }
void BaselineAssembler::JumpIf(Condition cc, Label* target, Label::Distance) {
__ Branch(target, AsMasmCondition(cc), kTestReg, Operand((int64_t)0));
}
void BaselineAssembler::JumpIfRoot(Register value, RootIndex index, void BaselineAssembler::JumpIfRoot(Register value, RootIndex index,
Label* target, Label::Distance) { Label* target, Label::Distance) {
__ JumpIfRoot(value, index, target); __ JumpIfRoot(value, index, target);
...@@ -139,72 +136,95 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) { ...@@ -139,72 +136,95 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) {
} }
} }
void BaselineAssembler::Test(Register value, int mask) { void BaselineAssembler::TestAndBranch(Register value, int mask, Condition cc,
__ And(kTestReg, value, Operand(mask)); Label* target, Label::Distance) {
ScratchRegisterScope temps(this);
Register tmp = temps.AcquireScratch();
__ And(tmp, value, Operand(mask));
__ Branch(target, AsMasmCondition(cc), tmp, Operand(mask));
} }
void BaselineAssembler::CmpObjectType(Register object, void BaselineAssembler::JumpIf(Condition cc, Register lhs, const Operand& rhs,
InstanceType instance_type, Label* target, Label::Distance) {
Register map) { __ Branch(target, AsMasmCondition(cc), lhs, Operand(rhs));
}
void BaselineAssembler::JumpIfObjectType(Condition cc, Register object,
InstanceType instance_type,
Register map, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register type = temps.AcquireScratch(); Register type = temps.AcquireScratch();
__ GetObjectType(object, map, type); __ GetObjectType(object, map, type);
__ Sub64(kTestReg, type, Operand(instance_type)); __ Branch(target, AsMasmCondition(cc), type, Operand(instance_type));
} }
void BaselineAssembler::CmpInstanceType(Register value, void BaselineAssembler::JumpIfInstanceType(Condition cc, Register map,
InstanceType instance_type) { InstanceType instance_type,
Label* target, Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register type = temps.AcquireScratch(); Register type = temps.AcquireScratch();
__ Ld(type, FieldMemOperand(value, Map::kInstanceTypeOffset)); __ Ld(type, FieldMemOperand(map, Map::kInstanceTypeOffset));
__ Sub64(kTestReg, type, Operand(instance_type)); __ Branch(target, AsMasmCondition(cc), type, Operand(instance_type));
} }
void BaselineAssembler::JumpIfPointer(Condition cc, Register value,
void BaselineAssembler::Cmp(Register value, Smi smi) { MemOperand operand, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this);
Register temp = temps.AcquireScratch();
__ Ld(temp, operand);
__ Branch(target, AsMasmCondition(cc), value, Operand(temp));
}
void BaselineAssembler::JumpIfSmi(Condition cc, Register value, Smi smi,
Label* target, Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register temp = temps.AcquireScratch(); Register temp = temps.AcquireScratch();
__ li(temp, Operand(smi)); __ li(temp, Operand(smi));
__ SmiUntag(temp); __ SmiUntag(temp);
__ Sub64(kTestReg, value, temp); __ Branch(target, AsMasmCondition(cc), value, Operand(temp));
} }
void BaselineAssembler::ComparePointer(Register value, MemOperand operand) { void BaselineAssembler::JumpIfSmi(Condition cc, Register lhs, Register rhs,
Label* target, Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register temp = temps.AcquireScratch(); Register temp = temps.AcquireScratch();
__ Ld(temp, operand);
__ Sub64(kTestReg, value, temp);
}
void BaselineAssembler::SmiCompare(Register lhs, Register rhs) {
__ AssertSmi(lhs); __ AssertSmi(lhs);
__ AssertSmi(rhs); __ AssertSmi(rhs);
if (COMPRESS_POINTERS_BOOL) { if (COMPRESS_POINTERS_BOOL) {
__ Sub32(kTestReg, lhs, rhs); __ Sub32(temp, lhs, rhs);
} else { } else {
__ Sub64(kTestReg, lhs, rhs); __ Sub64(temp, lhs, rhs);
} }
__ Branch(target, AsMasmCondition(cc), temp, Operand(zero_reg));
} }
void BaselineAssembler::CompareTagged(Register value, MemOperand operand) { void BaselineAssembler::JumpIfTagged(Condition cc, Register value,
MemOperand operand, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register tmp = temps.AcquireScratch(); Register tmp1 = temps.AcquireScratch();
__ Ld(tmp, operand); Register tmp2 = temps.AcquireScratch();
__ Ld(tmp1, operand);
if (COMPRESS_POINTERS_BOOL) { if (COMPRESS_POINTERS_BOOL) {
__ Sub32(kTestReg, value, tmp); __ Sub32(tmp2, value, tmp1);
} else { } else {
__ Sub64(kTestReg, value, tmp); __ Sub64(tmp2, value, tmp1);
} }
__ Branch(target, AsMasmCondition(cc), tmp2, Operand(zero_reg));
} }
void BaselineAssembler::CompareTagged(MemOperand operand, Register value) { void BaselineAssembler::JumpIfTagged(Condition cc, MemOperand operand,
Register value, Label* target,
Label::Distance) {
ScratchRegisterScope temps(this); ScratchRegisterScope temps(this);
Register tmp = temps.AcquireScratch(); Register tmp1 = temps.AcquireScratch();
__ Ld(tmp, operand); Register tmp2 = temps.AcquireScratch();
__ Ld(tmp1, operand);
if (COMPRESS_POINTERS_BOOL) { if (COMPRESS_POINTERS_BOOL) {
__ Sub32(kTestReg, tmp, value); __ Sub32(tmp2, tmp1, value);
} else { } else {
__ Sub64(kTestReg, tmp, value); __ Sub64(tmp2, tmp1, value);
} }
__ Branch(target, AsMasmCondition(cc), tmp2, Operand(zero_reg));
} }
void BaselineAssembler::JumpIfByte(Condition cc, Register value, int32_t byte,
void BaselineAssembler::CompareByte(Register value, int32_t byte) { Label* target, Label::Distance) {
__ Sub64(kTestReg, value, Operand(byte)); __ Branch(target, AsMasmCondition(cc), value, Operand(byte));
} }
void BaselineAssembler::Move(interpreter::Register output, Register source) { void BaselineAssembler::Move(interpreter::Register output, Register source) {
...@@ -473,7 +493,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target, ...@@ -473,7 +493,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target,
__ Sd(value, FieldMemOperand(target, offset)); __ Sd(value, FieldMemOperand(target, offset));
} }
void BaselineAssembler::AddToInterruptBudget(int32_t weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
int32_t weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
LoadFunction(feedback_cell); LoadFunction(feedback_cell);
...@@ -487,9 +508,14 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) { ...@@ -487,9 +508,14 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) {
__ Add64(interrupt_budget, interrupt_budget, weight); __ Add64(interrupt_budget, interrupt_budget, weight);
__ Sd(interrupt_budget, __ Sd(interrupt_budget,
FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset)); FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset));
if (skip_interrupt_label) {
DCHECK_LT(weight, 0);
__ Branch(skip_interrupt_label, ge, interrupt_budget, Operand(weight));
}
} }
void BaselineAssembler::AddToInterruptBudget(Register weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
Register weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
LoadFunction(feedback_cell); LoadFunction(feedback_cell);
...@@ -503,6 +529,8 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) { ...@@ -503,6 +529,8 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) {
__ Add64(interrupt_budget, interrupt_budget, weight); __ Add64(interrupt_budget, interrupt_budget, weight);
__ Sd(interrupt_budget, __ Sd(interrupt_budget,
FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset)); FieldMemOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset));
if (skip_interrupt_label)
__ Branch(skip_interrupt_label, ge, interrupt_budget, Operand(weight));
} }
void BaselineAssembler::AddSmi(Register lhs, Smi rhs) { void BaselineAssembler::AddSmi(Register lhs, Smi rhs) {
...@@ -561,11 +589,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) { ...@@ -561,11 +589,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) {
Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister(); Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister();
__ RecordComment("[ Update Interrupt Budget"); __ RecordComment("[ Update Interrupt Budget");
__ AddToInterruptBudget(weight);
// Use compare flags set by add
Label skip_interrupt_label; Label skip_interrupt_label;
__ JumpIf(Condition::kGreaterThanEqual, &skip_interrupt_label); __ AddToInterruptBudgetAndJumpIfNotExceeded(weight, &skip_interrupt_label);
{ {
__ masm()->SmiTag(params_size); __ masm()->SmiTag(params_size);
__ masm()->Push(params_size, kInterpreterAccumulatorRegister); __ masm()->Push(params_size, kInterpreterAccumulatorRegister);
......
...@@ -88,8 +88,7 @@ void BaselineCompiler::PrologueFillFrame() { ...@@ -88,8 +88,7 @@ void BaselineCompiler::PrologueFillFrame() {
__ masm()->Push(kInterpreterAccumulatorRegister, __ masm()->Push(kInterpreterAccumulatorRegister,
kInterpreterAccumulatorRegister); kInterpreterAccumulatorRegister);
} }
__ masm()->Sub64(scratch, scratch, 1); __ masm()->Branch(&loop, gt, scratch, Operand(1));
__ JumpIf(Condition::kGreaterThan, &loop);
} }
__ RecordComment("]"); __ RecordComment("]");
} }
......
...@@ -100,10 +100,6 @@ void BaselineAssembler::JumpTarget() { ...@@ -100,10 +100,6 @@ void BaselineAssembler::JumpTarget() {
void BaselineAssembler::Jump(Label* target, Label::Distance distance) { void BaselineAssembler::Jump(Label* target, Label::Distance distance) {
__ jmp(target, distance); __ jmp(target, distance);
} }
void BaselineAssembler::JumpIf(Condition cc, Label* target,
Label::Distance distance) {
__ j(AsMasmCondition(cc), target, distance);
}
void BaselineAssembler::JumpIfRoot(Register value, RootIndex index, void BaselineAssembler::JumpIfRoot(Register value, RootIndex index,
Label* target, Label::Distance distance) { Label* target, Label::Distance distance) {
__ JumpIfRoot(value, index, target, distance); __ JumpIfRoot(value, index, target, distance);
...@@ -143,45 +139,74 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) { ...@@ -143,45 +139,74 @@ void BaselineAssembler::TailCallBuiltin(Builtin builtin) {
} }
} }
void BaselineAssembler::Test(Register value, int mask) { void BaselineAssembler::TestAndBranch(Register value, int mask, Condition cc,
Label* target, Label::Distance distance) {
if ((mask & 0xff) == mask) { if ((mask & 0xff) == mask) {
__ testb(value, Immediate(mask)); __ testb(value, Immediate(mask));
} else { } else {
__ testl(value, Immediate(mask)); __ testl(value, Immediate(mask));
} }
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::CmpObjectType(Register object, void BaselineAssembler::JumpIf(Condition cc, Register lhs, const Operand& rhs,
InstanceType instance_type, Label* target, Label::Distance distance) {
Register map) { __ cmpq(lhs, rhs);
__ j(AsMasmCondition(cc), target, distance);
}
void BaselineAssembler::JumpIfObjectType(Condition cc, Register object,
InstanceType instance_type,
Register map, Label* target,
Label::Distance distance) {
__ AssertNotSmi(object); __ AssertNotSmi(object);
__ CmpObjectType(object, instance_type, map); __ CmpObjectType(object, instance_type, map);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::CmpInstanceType(Register map, void BaselineAssembler::JumpIfInstanceType(Condition cc, Register map,
InstanceType instance_type) { InstanceType instance_type,
Label* target,
Label::Distance distance) {
if (FLAG_debug_code) { if (FLAG_debug_code) {
__ AssertNotSmi(map); __ AssertNotSmi(map);
__ CmpObjectType(map, MAP_TYPE, kScratchRegister); __ CmpObjectType(map, MAP_TYPE, kScratchRegister);
__ Assert(equal, AbortReason::kUnexpectedValue); __ Assert(equal, AbortReason::kUnexpectedValue);
} }
__ CmpInstanceType(map, instance_type); __ CmpInstanceType(map, instance_type);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::Cmp(Register value, Smi smi) { __ Cmp(value, smi); } void BaselineAssembler::JumpIfPointer(Condition cc, Register value,
void BaselineAssembler::ComparePointer(Register value, MemOperand operand) { MemOperand operand, Label* target,
Label::Distance distance) {
__ cmpq(value, operand); __ cmpq(value, operand);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::SmiCompare(Register lhs, Register rhs) { void BaselineAssembler::JumpIfSmi(Condition cc, Register lhs, Smi smi,
Label* target, Label::Distance distance) {
__ SmiCompare(lhs, smi);
__ j(AsMasmCondition(cc), target, distance);
}
void BaselineAssembler::JumpIfSmi(Condition cc, Register lhs, Register rhs,
Label* target, Label::Distance distance) {
__ SmiCompare(lhs, rhs); __ SmiCompare(lhs, rhs);
__ j(AsMasmCondition(cc), target, distance);
} }
// cmp_tagged // cmp_tagged
void BaselineAssembler::CompareTagged(Register value, MemOperand operand) { void BaselineAssembler::JumpIfTagged(Condition cc, Register value,
MemOperand operand, Label* target,
Label::Distance distance) {
__ cmp_tagged(value, operand); __ cmp_tagged(value, operand);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::CompareTagged(MemOperand operand, Register value) { void BaselineAssembler::JumpIfTagged(Condition cc, MemOperand operand,
Register value, Label* target,
Label::Distance distance) {
__ cmp_tagged(operand, value); __ cmp_tagged(operand, value);
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::CompareByte(Register value, int32_t byte) { void BaselineAssembler::JumpIfByte(Condition cc, Register value, int32_t byte,
Label* target, Label::Distance distance) {
__ cmpb(value, Immediate(byte)); __ cmpb(value, Immediate(byte));
__ j(AsMasmCondition(cc), target, distance);
} }
void BaselineAssembler::Move(interpreter::Register output, Register source) { void BaselineAssembler::Move(interpreter::Register output, Register source) {
...@@ -330,7 +355,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target, ...@@ -330,7 +355,8 @@ void BaselineAssembler::StoreTaggedFieldNoWriteBarrier(Register target,
__ StoreTaggedField(FieldOperand(target, offset), value); __ StoreTaggedField(FieldOperand(target, offset), value);
} }
void BaselineAssembler::AddToInterruptBudget(int32_t weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
int32_t weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
LoadFunction(feedback_cell); LoadFunction(feedback_cell);
...@@ -338,9 +364,14 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) { ...@@ -338,9 +364,14 @@ void BaselineAssembler::AddToInterruptBudget(int32_t weight) {
JSFunction::kFeedbackCellOffset); JSFunction::kFeedbackCellOffset);
__ addl(FieldOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset), __ addl(FieldOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset),
Immediate(weight)); Immediate(weight));
if (skip_interrupt_label) {
DCHECK_LT(weight, 0);
__ j(greater_equal, skip_interrupt_label);
}
} }
void BaselineAssembler::AddToInterruptBudget(Register weight) { void BaselineAssembler::AddToInterruptBudgetAndJumpIfNotExceeded(
Register weight, Label* skip_interrupt_label) {
ScratchRegisterScope scratch_scope(this); ScratchRegisterScope scratch_scope(this);
Register feedback_cell = scratch_scope.AcquireScratch(); Register feedback_cell = scratch_scope.AcquireScratch();
LoadFunction(feedback_cell); LoadFunction(feedback_cell);
...@@ -348,6 +379,7 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) { ...@@ -348,6 +379,7 @@ void BaselineAssembler::AddToInterruptBudget(Register weight) {
JSFunction::kFeedbackCellOffset); JSFunction::kFeedbackCellOffset);
__ addl(FieldOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset), __ addl(FieldOperand(feedback_cell, FeedbackCell::kInterruptBudgetOffset),
weight); weight);
if (skip_interrupt_label) __ j(greater_equal, skip_interrupt_label);
} }
void BaselineAssembler::AddSmi(Register lhs, Smi rhs) { void BaselineAssembler::AddSmi(Register lhs, Smi rhs) {
...@@ -393,11 +425,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) { ...@@ -393,11 +425,9 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) {
Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister(); Register params_size = BaselineLeaveFrameDescriptor::ParamsSizeRegister();
__ RecordComment("[ Update Interrupt Budget"); __ RecordComment("[ Update Interrupt Budget");
__ AddToInterruptBudget(weight);
// Use compare flags set by AddToInterruptBudget
Label skip_interrupt_label; Label skip_interrupt_label;
__ JumpIf(Condition::kGreaterThanEqual, &skip_interrupt_label); __ AddToInterruptBudgetAndJumpIfNotExceeded(weight, &skip_interrupt_label);
{ {
__ masm()->SmiTag(params_size); __ masm()->SmiTag(params_size);
__ Push(params_size, kInterpreterAccumulatorRegister); __ Push(params_size, kInterpreterAccumulatorRegister);
...@@ -425,7 +455,7 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) { ...@@ -425,7 +455,7 @@ void BaselineAssembler::EmitReturn(MacroAssembler* masm) {
// arguments. // arguments.
Label corrected_args_count; Label corrected_args_count;
__ masm()->cmpq(params_size, actual_params_size); __ masm()->cmpq(params_size, actual_params_size);
__ JumpIf(Condition::kGreaterThanEqual, &corrected_args_count, Label::kNear); __ masm()->j(greater_equal, &corrected_args_count);
__ masm()->movq(params_size, actual_params_size); __ masm()->movq(params_size, actual_params_size);
__ Bind(&corrected_args_count); __ Bind(&corrected_args_count);
......
...@@ -72,7 +72,7 @@ void BaselineCompiler::PrologueFillFrame() { ...@@ -72,7 +72,7 @@ void BaselineCompiler::PrologueFillFrame() {
__ Push(kInterpreterAccumulatorRegister); __ Push(kInterpreterAccumulatorRegister);
} }
__ masm()->decl(scratch); __ masm()->decl(scratch);
__ JumpIf(Condition::kGreaterThan, &loop); __ masm()->j(greater, &loop);
} }
__ RecordComment("]"); __ RecordComment("]");
} }
......
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