Commit 69186565 authored by plind44@gmail.com's avatar plind44@gmail.com

MIPS: Improve code generation for bounds checks.

Port r20872 (0e79653)

BUG=
R=plind44@gmail.com

Review URL: https://codereview.chromium.org/246253007

Patch from Balazs Kilvady <kilvadyb@homejinni.com>.

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@20892 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 13783324
...@@ -4162,42 +4162,25 @@ void LCodeGen::DoStoreNamedGeneric(LStoreNamedGeneric* instr) { ...@@ -4162,42 +4162,25 @@ void LCodeGen::DoStoreNamedGeneric(LStoreNamedGeneric* instr) {
} }
void LCodeGen::ApplyCheckIf(Condition condition,
LBoundsCheck* check,
Register src1,
const Operand& src2) {
if (FLAG_debug_code && check->hydrogen()->skip_check()) {
Label done;
__ Branch(&done, NegateCondition(condition), src1, src2);
__ stop("eliminated bounds check failed");
__ bind(&done);
} else {
DeoptimizeIf(condition, check->environment(), src1, src2);
}
}
void LCodeGen::DoBoundsCheck(LBoundsCheck* instr) { void LCodeGen::DoBoundsCheck(LBoundsCheck* instr) {
if (instr->hydrogen()->skip_check()) return; Condition cc = instr->hydrogen()->allow_equality() ? hi : hs;
Operand operand(0);
Condition condition = instr->hydrogen()->allow_equality() ? hi : hs; Register reg;
if (instr->index()->IsConstantOperand()) { if (instr->index()->IsConstantOperand()) {
int constant_index = operand = ToOperand(instr->index());
ToInteger32(LConstantOperand::cast(instr->index())); reg = ToRegister(instr->length());
if (instr->hydrogen()->length()->representation().IsSmi()) { cc = ReverseCondition(cc);
__ li(at, Operand(Smi::FromInt(constant_index)));
} else { } else {
__ li(at, Operand(constant_index)); reg = ToRegister(instr->index());
operand = ToOperand(instr->length());
} }
ApplyCheckIf(condition, if (FLAG_debug_code && instr->hydrogen()->skip_check()) {
instr, Label done;
at, __ Branch(&done, NegateCondition(cc), reg, operand);
Operand(ToRegister(instr->length()))); __ stop("eliminated bounds check failed");
__ bind(&done);
} else { } else {
ApplyCheckIf(condition, DeoptimizeIf(cc, instr->environment(), reg, operand);
instr,
ToRegister(instr->index()),
Operand(ToRegister(instr->length())));
} }
} }
......
...@@ -263,10 +263,6 @@ class LCodeGen: public LCodeGenBase { ...@@ -263,10 +263,6 @@ class LCodeGen: public LCodeGenBase {
LEnvironment* environment, LEnvironment* environment,
Register src1 = zero_reg, Register src1 = zero_reg,
const Operand& src2 = Operand(zero_reg)); const Operand& src2 = Operand(zero_reg));
void ApplyCheckIf(Condition condition,
LBoundsCheck* check,
Register src1 = zero_reg,
const Operand& src2 = Operand(zero_reg));
void AddToTranslation(LEnvironment* environment, void AddToTranslation(LEnvironment* environment,
Translation* translation, Translation* translation,
......
...@@ -1782,9 +1782,16 @@ LInstruction* LChunkBuilder::DoSeqStringSetChar(HSeqStringSetChar* instr) { ...@@ -1782,9 +1782,16 @@ LInstruction* LChunkBuilder::DoSeqStringSetChar(HSeqStringSetChar* instr) {
LInstruction* LChunkBuilder::DoBoundsCheck(HBoundsCheck* instr) { LInstruction* LChunkBuilder::DoBoundsCheck(HBoundsCheck* instr) {
LOperand* value = UseRegisterOrConstantAtStart(instr->index()); if (!FLAG_debug_code && instr->skip_check()) return NULL;
LOperand* length = UseRegister(instr->length()); LOperand* index = UseRegisterOrConstantAtStart(instr->index());
return AssignEnvironment(new(zone()) LBoundsCheck(value, length)); LOperand* length = !index->IsConstantOperand()
? UseRegisterOrConstantAtStart(instr->length())
: UseRegisterAtStart(instr->length());
LInstruction* result = new(zone()) LBoundsCheck(index, length);
if (!FLAG_debug_code || !instr->skip_check()) {
result = AssignEnvironment(result);
}
return result;
} }
......
...@@ -2091,7 +2091,7 @@ void MacroAssembler::BranchShort(Label* L, Condition cond, Register rs, ...@@ -2091,7 +2091,7 @@ void MacroAssembler::BranchShort(Label* L, Condition cond, Register rs,
case Uless_equal: case Uless_equal:
if (rt.imm32_ == 0) { if (rt.imm32_ == 0) {
offset = shifted_branch_offset(L, false); offset = shifted_branch_offset(L, false);
b(offset); beq(rs, zero_reg, offset);
} else { } else {
ASSERT(!scratch.is(rs)); ASSERT(!scratch.is(rs));
r2 = scratch; r2 = scratch;
......
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