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 | 6 |
7 #include "src/arm64/frames-arm64.h" | 7 #include "src/arm64/frames-arm64.h" |
8 #include "src/arm64/macro-assembler-arm64.h" | 8 #include "src/arm64/macro-assembler-arm64.h" |
9 #include "src/ast/scopes.h" | 9 #include "src/ast/scopes.h" |
10 #include "src/compiler/code-generator-impl.h" | 10 #include "src/compiler/code-generator-impl.h" |
(...skipping 1165 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1176 break; | 1176 break; |
1177 case kArm64Float32Min: | 1177 case kArm64Float32Min: |
1178 // (a < b) ? a : b | 1178 // (a < b) ? a : b |
1179 __ Fcmp(i.InputFloat32Register(0), i.InputFloat32Register(1)); | 1179 __ Fcmp(i.InputFloat32Register(0), i.InputFloat32Register(1)); |
1180 __ Fcsel(i.OutputFloat32Register(), i.InputFloat32Register(0), | 1180 __ Fcsel(i.OutputFloat32Register(), i.InputFloat32Register(0), |
1181 i.InputFloat32Register(1), lo); | 1181 i.InputFloat32Register(1), lo); |
1182 break; | 1182 break; |
1183 case kArm64Float32Abs: | 1183 case kArm64Float32Abs: |
1184 __ Fabs(i.OutputFloat32Register(), i.InputFloat32Register(0)); | 1184 __ Fabs(i.OutputFloat32Register(), i.InputFloat32Register(0)); |
1185 break; | 1185 break; |
| 1186 case kArm64Float32Neg: |
| 1187 __ Fneg(i.OutputFloat32Register(), i.InputFloat32Register(0)); |
| 1188 break; |
1186 case kArm64Float32Sqrt: | 1189 case kArm64Float32Sqrt: |
1187 __ Fsqrt(i.OutputFloat32Register(), i.InputFloat32Register(0)); | 1190 __ Fsqrt(i.OutputFloat32Register(), i.InputFloat32Register(0)); |
1188 break; | 1191 break; |
1189 case kArm64Float64Cmp: | 1192 case kArm64Float64Cmp: |
1190 if (instr->InputAt(1)->IsFPRegister()) { | 1193 if (instr->InputAt(1)->IsFPRegister()) { |
1191 __ Fcmp(i.InputDoubleRegister(0), i.InputDoubleRegister(1)); | 1194 __ Fcmp(i.InputDoubleRegister(0), i.InputDoubleRegister(1)); |
1192 } else { | 1195 } else { |
1193 DCHECK(instr->InputAt(1)->IsImmediate()); | 1196 DCHECK(instr->InputAt(1)->IsImmediate()); |
1194 // 0.0 is the only immediate supported by fcmp instructions. | 1197 // 0.0 is the only immediate supported by fcmp instructions. |
1195 DCHECK(i.InputDouble(1) == 0.0); | 1198 DCHECK(i.InputDouble(1) == 0.0); |
(...skipping 706 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1902 padding_size -= kInstructionSize; | 1905 padding_size -= kInstructionSize; |
1903 } | 1906 } |
1904 } | 1907 } |
1905 } | 1908 } |
1906 | 1909 |
1907 #undef __ | 1910 #undef __ |
1908 | 1911 |
1909 } // namespace compiler | 1912 } // namespace compiler |
1910 } // namespace internal | 1913 } // namespace internal |
1911 } // namespace v8 | 1914 } // namespace v8 |
OLD | NEW |