OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/v8.h" | 5 #include "src/v8.h" |
6 | 6 |
7 #if V8_TARGET_ARCH_IA32 | 7 #if V8_TARGET_ARCH_IA32 |
8 | 8 |
9 #include "src/base/bits.h" | 9 #include "src/base/bits.h" |
10 #include "src/base/division-by-constant.h" | 10 #include "src/base/division-by-constant.h" |
(...skipping 2643 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2654 pcmpeqd(dst, dst); | 2654 pcmpeqd(dst, dst); |
2655 if (ntz == 0) { | 2655 if (ntz == 0) { |
2656 psrlq(dst, 64 - cnt); | 2656 psrlq(dst, 64 - cnt); |
2657 } else { | 2657 } else { |
2658 psllq(dst, 64 - cnt); | 2658 psllq(dst, 64 - cnt); |
2659 if (nlz != 0) psrlq(dst, nlz); | 2659 if (nlz != 0) psrlq(dst, nlz); |
2660 } | 2660 } |
2661 } else if (lower == 0) { | 2661 } else if (lower == 0) { |
2662 Move(dst, upper); | 2662 Move(dst, upper); |
2663 psllq(dst, 32); | 2663 psllq(dst, 32); |
2664 } else { | 2664 } else if (CpuFeatures::IsSupported(SSE4_1)) { |
| 2665 CpuFeatureScope scope(this, SSE4_1); |
2665 push(eax); | 2666 push(eax); |
2666 Move(eax, Immediate(lower)); | 2667 Move(eax, Immediate(lower)); |
2667 movd(dst, Operand(eax)); | 2668 movd(dst, Operand(eax)); |
2668 Move(eax, Immediate(upper)); | 2669 Move(eax, Immediate(upper)); |
2669 if (CpuFeatures::IsSupported(SSE4_1)) { | 2670 pinsrd(dst, Operand(eax), 1); |
2670 CpuFeatureScope scope(this, SSE4_1); | |
2671 pinsrd(dst, Operand(eax), 1); | |
2672 } else { | |
2673 psllq(dst, 32); | |
2674 movd(xmm0, Operand(eax)); | |
2675 orpd(dst, xmm0); | |
2676 } | |
2677 pop(eax); | 2671 pop(eax); |
| 2672 } else { |
| 2673 push(Immediate(upper)); |
| 2674 push(Immediate(lower)); |
| 2675 movsd(dst, Operand(esp, 0)); |
| 2676 add(esp, Immediate(kDoubleSize)); |
2678 } | 2677 } |
2679 } | 2678 } |
2680 } | 2679 } |
2681 | 2680 |
2682 | 2681 |
2683 void MacroAssembler::SetCounter(StatsCounter* counter, int value) { | 2682 void MacroAssembler::SetCounter(StatsCounter* counter, int value) { |
2684 if (FLAG_native_code_counters && counter->Enabled()) { | 2683 if (FLAG_native_code_counters && counter->Enabled()) { |
2685 mov(Operand::StaticVariable(ExternalReference(counter)), Immediate(value)); | 2684 mov(Operand::StaticVariable(ExternalReference(counter)), Immediate(value)); |
2686 } | 2685 } |
2687 } | 2686 } |
(...skipping 751 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3439 if (mag.shift > 0) sar(edx, mag.shift); | 3438 if (mag.shift > 0) sar(edx, mag.shift); |
3440 mov(eax, dividend); | 3439 mov(eax, dividend); |
3441 shr(eax, 31); | 3440 shr(eax, 31); |
3442 add(edx, eax); | 3441 add(edx, eax); |
3443 } | 3442 } |
3444 | 3443 |
3445 | 3444 |
3446 } } // namespace v8::internal | 3445 } } // namespace v8::internal |
3447 | 3446 |
3448 #endif // V8_TARGET_ARCH_IA32 | 3447 #endif // V8_TARGET_ARCH_IA32 |
OLD | NEW |