OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 3151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3162 __ test(output_reg, Immediate(1)); | 3162 __ test(output_reg, Immediate(1)); |
3163 DeoptimizeIf(not_zero, instr->environment()); | 3163 DeoptimizeIf(not_zero, instr->environment()); |
3164 __ bind(&non_zero); | 3164 __ bind(&non_zero); |
3165 } | 3165 } |
3166 __ roundsd(xmm_scratch, input_reg, Assembler::kRoundDown); | 3166 __ roundsd(xmm_scratch, input_reg, Assembler::kRoundDown); |
3167 __ cvttsd2si(output_reg, Operand(xmm_scratch)); | 3167 __ cvttsd2si(output_reg, Operand(xmm_scratch)); |
3168 // Overflow is signalled with minint. | 3168 // Overflow is signalled with minint. |
3169 __ cmp(output_reg, 0x80000000u); | 3169 __ cmp(output_reg, 0x80000000u); |
3170 DeoptimizeIf(equal, instr->environment()); | 3170 DeoptimizeIf(equal, instr->environment()); |
3171 } else { | 3171 } else { |
3172 Label negative_sign; | 3172 Label negative_sign, done; |
3173 Label done; | |
3174 // Deoptimize on unordered. | 3173 // Deoptimize on unordered. |
3175 __ xorps(xmm_scratch, xmm_scratch); // Zero the register. | 3174 __ xorps(xmm_scratch, xmm_scratch); // Zero the register. |
3176 __ ucomisd(input_reg, xmm_scratch); | 3175 __ ucomisd(input_reg, xmm_scratch); |
3177 DeoptimizeIf(parity_even, instr->environment()); | 3176 DeoptimizeIf(parity_even, instr->environment()); |
3178 __ j(below, &negative_sign, Label::kNear); | 3177 __ j(below, &negative_sign, Label::kNear); |
3179 | 3178 |
3180 if (instr->hydrogen()->CheckFlag(HValue::kBailoutOnMinusZero)) { | 3179 if (instr->hydrogen()->CheckFlag(HValue::kBailoutOnMinusZero)) { |
3181 // Check for negative zero. | 3180 // Check for negative zero. |
3182 Label positive_sign; | 3181 Label positive_sign; |
3183 __ j(above, &positive_sign, Label::kNear); | 3182 __ j(above, &positive_sign, Label::kNear); |
3184 __ movmskpd(output_reg, input_reg); | 3183 __ movmskpd(output_reg, input_reg); |
3185 __ test(output_reg, Immediate(1)); | 3184 __ test(output_reg, Immediate(1)); |
3186 DeoptimizeIf(not_zero, instr->environment()); | 3185 DeoptimizeIf(not_zero, instr->environment()); |
3187 __ Set(output_reg, Immediate(0)); | 3186 __ Set(output_reg, Immediate(0)); |
3188 __ jmp(&done, Label::kNear); | 3187 __ jmp(&done, Label::kNear); |
3189 __ bind(&positive_sign); | 3188 __ bind(&positive_sign); |
3190 } | 3189 } |
3191 | 3190 |
3192 // Use truncating instruction (OK because input is positive). | 3191 // Use truncating instruction (OK because input is positive). |
3193 __ cvttsd2si(output_reg, Operand(input_reg)); | 3192 __ cvttsd2si(output_reg, Operand(input_reg)); |
3194 // Overflow is signalled with minint. | 3193 // Overflow is signalled with minint. |
3195 __ cmp(output_reg, 0x80000000u); | 3194 __ cmp(output_reg, 0x80000000u); |
3196 DeoptimizeIf(equal, instr->environment()); | 3195 DeoptimizeIf(equal, instr->environment()); |
3197 __ jmp(&done, Label::kNear); | 3196 __ jmp(&done, Label::kNear); |
3198 | 3197 |
3199 // Non-zero negative reaches here | 3198 // Non-zero negative reaches here. |
3200 __ bind(&negative_sign); | 3199 __ bind(&negative_sign); |
3201 // Truncate, then compare and compensate | 3200 // Truncate, then compare and compensate. |
3202 __ cvttsd2si(output_reg, Operand(input_reg)); | 3201 __ cvttsd2si(output_reg, Operand(input_reg)); |
3203 __ cvtsi2sd(xmm_scratch, output_reg); | 3202 __ cvtsi2sd(xmm_scratch, output_reg); |
3204 __ ucomisd(input_reg, xmm_scratch); | 3203 __ ucomisd(input_reg, xmm_scratch); |
3205 __ j(equal, &done, Label::kNear); | 3204 __ j(equal, &done, Label::kNear); |
3206 __ sub(output_reg, Immediate(1)); | 3205 __ sub(output_reg, Immediate(1)); |
3207 DeoptimizeIf(overflow, instr->environment()); | 3206 DeoptimizeIf(overflow, instr->environment()); |
3208 | 3207 |
3209 __ bind(&done); | 3208 __ bind(&done); |
3210 } | 3209 } |
3211 } | 3210 } |
(...skipping 2124 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
5336 FixedArray::kHeaderSize - kPointerSize)); | 5335 FixedArray::kHeaderSize - kPointerSize)); |
5337 __ bind(&done); | 5336 __ bind(&done); |
5338 } | 5337 } |
5339 | 5338 |
5340 | 5339 |
5341 #undef __ | 5340 #undef __ |
5342 | 5341 |
5343 } } // namespace v8::internal | 5342 } } // namespace v8::internal |
5344 | 5343 |
5345 #endif // V8_TARGET_ARCH_IA32 | 5344 #endif // V8_TARGET_ARCH_IA32 |
OLD | NEW |