| 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/compiler/code-generator-impl.h" | 6 #include "src/compiler/code-generator-impl.h" |
| 7 #include "src/compiler/gap-resolver.h" | 7 #include "src/compiler/gap-resolver.h" |
| 8 #include "src/compiler/node-matchers.h" | 8 #include "src/compiler/node-matchers.h" |
| 9 #include "src/compiler/osr.h" | 9 #include "src/compiler/osr.h" |
| 10 #include "src/mips/macro-assembler-mips.h" | 10 #include "src/mips/macro-assembler-mips.h" |
| (...skipping 1083 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1094 } else { | 1094 } else { |
| 1095 __ Movt(result, zero_reg); | 1095 __ Movt(result, zero_reg); |
| 1096 } | 1096 } |
| 1097 } else { | 1097 } else { |
| 1098 if (instr->arch_opcode() == kMipsCmpD) { | 1098 if (instr->arch_opcode() == kMipsCmpD) { |
| 1099 __ cmp(cc, L, kDoubleCompareReg, left, right); | 1099 __ cmp(cc, L, kDoubleCompareReg, left, right); |
| 1100 } else { | 1100 } else { |
| 1101 DCHECK(instr->arch_opcode() == kMipsCmpS); | 1101 DCHECK(instr->arch_opcode() == kMipsCmpS); |
| 1102 __ cmp(cc, W, kDoubleCompareReg, left, right); | 1102 __ cmp(cc, W, kDoubleCompareReg, left, right); |
| 1103 } | 1103 } |
| 1104 __ mfc1(at, kDoubleCompareReg); | 1104 __ mfc1(result, kDoubleCompareReg); |
| 1105 __ srl(result, at, 31); // Cmp returns all 1s for true. | 1105 __ andi(result, result, 1); // Cmp returns all 1's/0's, use only LSB. |
| 1106 if (!predicate) // Toggle result for not equal. | 1106 if (!predicate) // Toggle result for not equal. |
| 1107 __ xori(result, result, 1); | 1107 __ xori(result, result, 1); |
| 1108 } | 1108 } |
| 1109 return; | 1109 return; |
| 1110 } else { | 1110 } else { |
| 1111 PrintF("AssembleArchBranch Unimplemented arch_opcode is : %d\n", | 1111 PrintF("AssembleArchBranch Unimplemented arch_opcode is : %d\n", |
| 1112 instr->arch_opcode()); | 1112 instr->arch_opcode()); |
| 1113 TRACE_UNIMPL(); | 1113 TRACE_UNIMPL(); |
| 1114 UNIMPLEMENTED(); | 1114 UNIMPLEMENTED(); |
| 1115 } | 1115 } |
| (...skipping 344 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1460 padding_size -= v8::internal::Assembler::kInstrSize; | 1460 padding_size -= v8::internal::Assembler::kInstrSize; |
| 1461 } | 1461 } |
| 1462 } | 1462 } |
| 1463 } | 1463 } |
| 1464 | 1464 |
| 1465 #undef __ | 1465 #undef __ |
| 1466 | 1466 |
| 1467 } // namespace compiler | 1467 } // namespace compiler |
| 1468 } // namespace internal | 1468 } // namespace internal |
| 1469 } // namespace v8 | 1469 } // namespace v8 |
| OLD | NEW |