OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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/compiler/code-generator.h" | 5 #include "src/compiler/code-generator.h" |
6 #include "src/compilation-info.h" | 6 #include "src/compilation-info.h" |
7 #include "src/compiler/code-generator-impl.h" | 7 #include "src/compiler/code-generator-impl.h" |
8 #include "src/compiler/gap-resolver.h" | 8 #include "src/compiler/gap-resolver.h" |
9 #include "src/compiler/node-matchers.h" | 9 #include "src/compiler/node-matchers.h" |
10 #include "src/compiler/osr.h" | 10 #include "src/compiler/osr.h" |
(...skipping 2008 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2019 Label false_value; | 2019 Label false_value; |
2020 DCHECK_NE(0u, instr->OutputCount()); | 2020 DCHECK_NE(0u, instr->OutputCount()); |
2021 Register result = i.OutputRegister(instr->OutputCount() - 1); | 2021 Register result = i.OutputRegister(instr->OutputCount() - 1); |
2022 Condition cc = kNoCondition; | 2022 Condition cc = kNoCondition; |
2023 // MIPS does not have condition code flags, so compare and branch are | 2023 // MIPS does not have condition code flags, so compare and branch are |
2024 // implemented differently than on the other arch's. The compare operations | 2024 // implemented differently than on the other arch's. The compare operations |
2025 // emit mips pseudo-instructions, which are checked and handled here. | 2025 // emit mips pseudo-instructions, which are checked and handled here. |
2026 | 2026 |
2027 if (instr->arch_opcode() == kMips64Tst) { | 2027 if (instr->arch_opcode() == kMips64Tst) { |
2028 cc = FlagsConditionToConditionTst(condition); | 2028 cc = FlagsConditionToConditionTst(condition); |
2029 __ And(kScratchReg, i.InputRegister(0), i.InputOperand(1)); | 2029 if (instr->InputAt(1)->IsImmediate() && |
2030 __ Sltu(result, zero_reg, kScratchReg); | 2030 base::bits::IsPowerOfTwo64(i.InputOperand(1).immediate())) { |
| 2031 uint16_t pos = |
| 2032 base::bits::CountTrailingZeros64(i.InputOperand(1).immediate()); |
| 2033 __ ExtractBits(result, i.InputRegister(0), pos, 1); |
| 2034 } else { |
| 2035 __ And(kScratchReg, i.InputRegister(0), i.InputOperand(1)); |
| 2036 __ Sltu(result, zero_reg, kScratchReg); |
| 2037 } |
2031 if (cc == eq) { | 2038 if (cc == eq) { |
2032 // Sltu produces 0 for equality, invert the result. | 2039 // Sltu produces 0 for equality, invert the result. |
2033 __ xori(result, result, 1); | 2040 __ xori(result, result, 1); |
2034 } | 2041 } |
2035 return; | 2042 return; |
2036 } else if (instr->arch_opcode() == kMips64Dadd || | 2043 } else if (instr->arch_opcode() == kMips64Dadd || |
2037 instr->arch_opcode() == kMips64Dsub) { | 2044 instr->arch_opcode() == kMips64Dsub) { |
2038 cc = FlagsConditionToConditionOvf(condition); | 2045 cc = FlagsConditionToConditionOvf(condition); |
2039 // Check for overflow creates 1 or 0 for result. | 2046 // Check for overflow creates 1 or 0 for result. |
2040 __ dsrl32(kScratchReg, i.OutputRegister(), 31); | 2047 __ dsrl32(kScratchReg, i.OutputRegister(), 31); |
(...skipping 502 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2543 padding_size -= v8::internal::Assembler::kInstrSize; | 2550 padding_size -= v8::internal::Assembler::kInstrSize; |
2544 } | 2551 } |
2545 } | 2552 } |
2546 } | 2553 } |
2547 | 2554 |
2548 #undef __ | 2555 #undef __ |
2549 | 2556 |
2550 } // namespace compiler | 2557 } // namespace compiler |
2551 } // namespace internal | 2558 } // namespace internal |
2552 } // namespace v8 | 2559 } // namespace v8 |
OLD | NEW |