Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(604)

Side by Side Diff: runtime/vm/assembler_arm.cc

Issue 19875002: Adds reciprocal squre root SIMD instructions for ARM. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « runtime/vm/assembler_arm.h ('k') | runtime/vm/assembler_arm_test.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include "vm/globals.h" 5 #include "vm/globals.h"
6 #if defined(TARGET_ARCH_ARM) 6 #if defined(TARGET_ARCH_ARM)
7 7
8 #include "vm/assembler.h" 8 #include "vm/assembler.h"
9 #include "vm/simulator.h" 9 #include "vm/simulator.h"
10 #include "vm/runtime_entry.h" 10 #include "vm/runtime_entry.h"
(...skipping 1335 matching lines...) Expand 10 before | Expand all | Expand 10 after
1346 EmitSIMDqqq(B24 | B23 | B21 | B20 | B19 | B17 | B16 | B10 | B8, kSWord, 1346 EmitSIMDqqq(B24 | B23 | B21 | B20 | B19 | B17 | B16 | B10 | B8, kSWord,
1347 qd, Q0, qm); 1347 qd, Q0, qm);
1348 } 1348 }
1349 1349
1350 1350
1351 void Assembler::vrecpsqs(QRegister qd, QRegister qn, QRegister qm) { 1351 void Assembler::vrecpsqs(QRegister qd, QRegister qn, QRegister qm) {
1352 EmitSIMDqqq(B11 | B10 | B9 | B8 | B4, kSWord, qd, qn, qm); 1352 EmitSIMDqqq(B11 | B10 | B9 | B8 | B4, kSWord, qd, qn, qm);
1353 } 1353 }
1354 1354
1355 1355
1356 void Assembler::vrsqrteqs(QRegister qd, QRegister qm) {
1357 EmitSIMDqqq(B24 | B23 | B21 | B20 | B19 | B17 | B16 | B10 | B8 | B7,
1358 kSWord, qd, Q0, qm);
1359 }
1360
1361
1362 void Assembler::vrsqrtsqs(QRegister qd, QRegister qn, QRegister qm) {
1363 EmitSIMDqqq(B21 | B11 | B10 | B9 | B8 | B4, kSWord, qd, qn, qm);
1364 }
1365
1366
1356 void Assembler::vdup(OperandSize sz, QRegister qd, DRegister dm, int idx) { 1367 void Assembler::vdup(OperandSize sz, QRegister qd, DRegister dm, int idx) {
1357 ASSERT((sz != kDWord) && (sz != kSWord) && (sz != kWordPair)); 1368 ASSERT((sz != kDWord) && (sz != kSWord) && (sz != kWordPair));
1358 int code = 0; 1369 int code = 0;
1359 1370
1360 switch (sz) { 1371 switch (sz) {
1361 case kByte: 1372 case kByte:
1362 case kUnsignedByte: { 1373 case kUnsignedByte: {
1363 ASSERT((idx >= 0) && (idx < 8)); 1374 ASSERT((idx >= 0) && (idx < 8));
1364 code = 1 | (idx << 1); 1375 code = 1 | (idx << 1);
1365 break; 1376 break;
(...skipping 1128 matching lines...) Expand 10 before | Expand all | Expand 10 after
2494 2505
2495 const char* Assembler::FpuRegisterName(FpuRegister reg) { 2506 const char* Assembler::FpuRegisterName(FpuRegister reg) {
2496 ASSERT((0 <= reg) && (reg < kNumberOfFpuRegisters)); 2507 ASSERT((0 <= reg) && (reg < kNumberOfFpuRegisters));
2497 return fpu_reg_names[reg]; 2508 return fpu_reg_names[reg];
2498 } 2509 }
2499 2510
2500 } // namespace dart 2511 } // namespace dart
2501 2512
2502 #endif // defined TARGET_ARCH_ARM 2513 #endif // defined TARGET_ARCH_ARM
2503 2514
OLDNEW
« no previous file with comments | « runtime/vm/assembler_arm.h ('k') | runtime/vm/assembler_arm_test.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698