Fixed branch distances.

Forgot a few kNear occurences, only happens with --deopt-every-n-times.
Death to manual jump distance calculation! :-P

TBR=jarin@chromium.org

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

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@24151 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 3a7cd5d2
...@@ -4843,11 +4843,11 @@ void LCodeGen::DoDoubleToI(LDoubleToI* instr) { ...@@ -4843,11 +4843,11 @@ void LCodeGen::DoDoubleToI(LDoubleToI* instr) {
Label lost_precision, is_nan, minus_zero, done; Label lost_precision, is_nan, minus_zero, done;
XMMRegister input_reg = ToDoubleRegister(input); XMMRegister input_reg = ToDoubleRegister(input);
XMMRegister xmm_scratch = double_scratch0(); XMMRegister xmm_scratch = double_scratch0();
Label::Distance dist = DeoptEveryNTimes() ? Label::kFar : Label::kNear;
__ DoubleToI(result_reg, input_reg, xmm_scratch, __ DoubleToI(result_reg, input_reg, xmm_scratch,
instr->hydrogen()->GetMinusZeroMode(), &lost_precision, instr->hydrogen()->GetMinusZeroMode(), &lost_precision,
&is_nan, &minus_zero, &is_nan, &minus_zero, dist);
DeoptEveryNTimes() ? Label::kFar : Label::kNear); __ jmp(&done, dist);
__ jmp(&done, Label::kNear);
__ bind(&lost_precision); __ bind(&lost_precision);
DeoptimizeIf(no_condition, instr, "lost precision"); DeoptimizeIf(no_condition, instr, "lost precision");
__ bind(&is_nan); __ bind(&is_nan);
...@@ -4869,10 +4869,11 @@ void LCodeGen::DoDoubleToSmi(LDoubleToSmi* instr) { ...@@ -4869,10 +4869,11 @@ void LCodeGen::DoDoubleToSmi(LDoubleToSmi* instr) {
Label lost_precision, is_nan, minus_zero, done; Label lost_precision, is_nan, minus_zero, done;
XMMRegister input_reg = ToDoubleRegister(input); XMMRegister input_reg = ToDoubleRegister(input);
XMMRegister xmm_scratch = double_scratch0(); XMMRegister xmm_scratch = double_scratch0();
Label::Distance dist = DeoptEveryNTimes() ? Label::kFar : Label::kNear;
__ DoubleToI(result_reg, input_reg, xmm_scratch, __ DoubleToI(result_reg, input_reg, xmm_scratch,
instr->hydrogen()->GetMinusZeroMode(), &lost_precision, &is_nan, instr->hydrogen()->GetMinusZeroMode(), &lost_precision, &is_nan,
&minus_zero, DeoptEveryNTimes() ? Label::kFar : Label::kNear); &minus_zero, dist);
__ jmp(&done, Label::kNear); __ jmp(&done, dist);
__ bind(&lost_precision); __ bind(&lost_precision);
DeoptimizeIf(no_condition, instr, "lost precision"); DeoptimizeIf(no_condition, instr, "lost precision");
__ bind(&is_nan); __ bind(&is_nan);
......
...@@ -5038,11 +5038,11 @@ void LCodeGen::DoDoubleToI(LDoubleToI* instr) { ...@@ -5038,11 +5038,11 @@ void LCodeGen::DoDoubleToI(LDoubleToI* instr) {
} else { } else {
Label lost_precision, is_nan, minus_zero, done; Label lost_precision, is_nan, minus_zero, done;
XMMRegister xmm_scratch = double_scratch0(); XMMRegister xmm_scratch = double_scratch0();
Label::Distance dist = DeoptEveryNTimes() ? Label::kFar : Label::kNear;
__ DoubleToI(result_reg, input_reg, xmm_scratch, __ DoubleToI(result_reg, input_reg, xmm_scratch,
instr->hydrogen()->GetMinusZeroMode(), &lost_precision, instr->hydrogen()->GetMinusZeroMode(), &lost_precision,
&is_nan, &minus_zero, &is_nan, &minus_zero, dist);
DeoptEveryNTimes() ? Label::kFar : Label::kNear); __ jmp(&done, dist);
__ jmp(&done, Label::kNear);
__ bind(&lost_precision); __ bind(&lost_precision);
DeoptimizeIf(no_condition, instr, "lost precision"); DeoptimizeIf(no_condition, instr, "lost precision");
__ bind(&is_nan); __ bind(&is_nan);
...@@ -5065,10 +5065,11 @@ void LCodeGen::DoDoubleToSmi(LDoubleToSmi* instr) { ...@@ -5065,10 +5065,11 @@ void LCodeGen::DoDoubleToSmi(LDoubleToSmi* instr) {
Label lost_precision, is_nan, minus_zero, done; Label lost_precision, is_nan, minus_zero, done;
XMMRegister xmm_scratch = double_scratch0(); XMMRegister xmm_scratch = double_scratch0();
Label::Distance dist = DeoptEveryNTimes() ? Label::kFar : Label::kNear;
__ DoubleToI(result_reg, input_reg, xmm_scratch, __ DoubleToI(result_reg, input_reg, xmm_scratch,
instr->hydrogen()->GetMinusZeroMode(), &lost_precision, &is_nan, instr->hydrogen()->GetMinusZeroMode(), &lost_precision, &is_nan,
&minus_zero, DeoptEveryNTimes() ? Label::kFar : Label::kNear); &minus_zero, dist);
__ jmp(&done, Label::kNear); __ jmp(&done, dist);
__ bind(&lost_precision); __ bind(&lost_precision);
DeoptimizeIf(no_condition, instr, "lost precision"); DeoptimizeIf(no_condition, instr, "lost precision");
__ bind(&is_nan); __ bind(&is_nan);
......
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