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

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

Issue 292433008: Allows unboxed doubles to be disabled. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 6 years, 7 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/flow_graph_compiler.h ('k') | runtime/vm/flow_graph_compiler_arm64.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" // Needed here to get TARGET_ARCH_ARM. 5 #include "vm/globals.h" // Needed here to get TARGET_ARCH_ARM.
6 #if defined(TARGET_ARCH_ARM) 6 #if defined(TARGET_ARCH_ARM)
7 7
8 #include "vm/flow_graph_compiler.h" 8 #include "vm/flow_graph_compiler.h"
9 9
10 #include "vm/ast_printer.h" 10 #include "vm/ast_printer.h"
11 #include "vm/compiler.h" 11 #include "vm/compiler.h"
12 #include "vm/cpu.h" 12 #include "vm/cpu.h"
13 #include "vm/dart_entry.h" 13 #include "vm/dart_entry.h"
14 #include "vm/deopt_instructions.h" 14 #include "vm/deopt_instructions.h"
15 #include "vm/il_printer.h" 15 #include "vm/il_printer.h"
16 #include "vm/locations.h" 16 #include "vm/locations.h"
17 #include "vm/object_store.h" 17 #include "vm/object_store.h"
18 #include "vm/parser.h" 18 #include "vm/parser.h"
19 #include "vm/stack_frame.h" 19 #include "vm/stack_frame.h"
20 #include "vm/stub_code.h" 20 #include "vm/stub_code.h"
21 #include "vm/symbols.h" 21 #include "vm/symbols.h"
22 22
23 namespace dart { 23 namespace dart {
24 24
25 DEFINE_FLAG(bool, trap_on_deoptimization, false, "Trap on deoptimization."); 25 DEFINE_FLAG(bool, trap_on_deoptimization, false, "Trap on deoptimization.");
26 DEFINE_FLAG(bool, unbox_mints, true, "Optimize 64-bit integer arithmetic."); 26 DEFINE_FLAG(bool, unbox_mints, true, "Optimize 64-bit integer arithmetic.");
27 DEFINE_FLAG(bool, unbox_doubles, true, "Optimize double arithmetic.");
27 DECLARE_FLAG(int, optimization_counter_threshold); 28 DECLARE_FLAG(int, optimization_counter_threshold);
28 DECLARE_FLAG(int, reoptimization_counter_threshold); 29 DECLARE_FLAG(int, reoptimization_counter_threshold);
29 DECLARE_FLAG(bool, enable_type_checks); 30 DECLARE_FLAG(bool, enable_type_checks);
30 DECLARE_FLAG(bool, eliminate_type_checks); 31 DECLARE_FLAG(bool, eliminate_type_checks);
31 DECLARE_FLAG(bool, enable_simd_inline); 32 DECLARE_FLAG(bool, enable_simd_inline);
32 33
33 34
34 FlowGraphCompiler::~FlowGraphCompiler() { 35 FlowGraphCompiler::~FlowGraphCompiler() {
35 // BlockInfos are zone-allocated, so their destructors are not called. 36 // BlockInfos are zone-allocated, so their destructors are not called.
36 // Verify the labels explicitly here. 37 // Verify the labels explicitly here.
37 for (int i = 0; i < block_info_.length(); ++i) { 38 for (int i = 0; i < block_info_.length(); ++i) {
38 ASSERT(!block_info_[i]->jump_label()->IsLinked()); 39 ASSERT(!block_info_[i]->jump_label()->IsLinked());
39 } 40 }
40 } 41 }
41 42
42 43
44 bool FlowGraphCompiler::SupportsUnboxedDoubles() {
45 return TargetCPUFeatures::vfp_supported() && FLAG_unbox_doubles;
46 }
47
48
43 bool FlowGraphCompiler::SupportsUnboxedMints() { 49 bool FlowGraphCompiler::SupportsUnboxedMints() {
44 return TargetCPUFeatures::neon_supported() && FLAG_unbox_mints; 50 return TargetCPUFeatures::neon_supported() && FLAG_unbox_mints;
45 } 51 }
46 52
47 53
48 bool FlowGraphCompiler::SupportsUnboxedSimd128() { 54 bool FlowGraphCompiler::SupportsUnboxedSimd128() {
49 return TargetCPUFeatures::neon_supported() && FLAG_enable_simd_inline; 55 return TargetCPUFeatures::neon_supported() && FLAG_enable_simd_inline;
50 } 56 }
51 57
52 58
(...skipping 1536 matching lines...) Expand 10 before | Expand all | Expand 10 after
1589 __ LoadFromOffset(kWord, destination.reg(), FP, source_offset); 1595 __ LoadFromOffset(kWord, destination.reg(), FP, source_offset);
1590 } else { 1596 } else {
1591 ASSERT(destination.IsStackSlot()); 1597 ASSERT(destination.IsStackSlot());
1592 const intptr_t source_offset = source.ToStackSlotOffset(); 1598 const intptr_t source_offset = source.ToStackSlotOffset();
1593 const intptr_t dest_offset = destination.ToStackSlotOffset(); 1599 const intptr_t dest_offset = destination.ToStackSlotOffset();
1594 __ LoadFromOffset(kWord, TMP, FP, source_offset); 1600 __ LoadFromOffset(kWord, TMP, FP, source_offset);
1595 __ StoreToOffset(kWord, TMP, FP, dest_offset); 1601 __ StoreToOffset(kWord, TMP, FP, dest_offset);
1596 } 1602 }
1597 } else if (source.IsFpuRegister()) { 1603 } else if (source.IsFpuRegister()) {
1598 if (destination.IsFpuRegister()) { 1604 if (destination.IsFpuRegister()) {
1599 __ vmovq(destination.fpu_reg(), source.fpu_reg()); 1605 if (TargetCPUFeatures::neon_supported()) {
1606 __ vmovq(destination.fpu_reg(), source.fpu_reg());
1607 } else {
1608 // If we're not inlining simd values, then only the even numbered D
1609 // register will have anything in them.
1610 __ vmovd(EvenDRegisterOf(destination.fpu_reg()),
1611 EvenDRegisterOf(source.fpu_reg()));
1612 }
1600 } else { 1613 } else {
1601 if (destination.IsDoubleStackSlot()) { 1614 if (destination.IsDoubleStackSlot()) {
1602 const intptr_t dest_offset = destination.ToStackSlotOffset(); 1615 const intptr_t dest_offset = destination.ToStackSlotOffset();
1603 DRegister src = EvenDRegisterOf(source.fpu_reg()); 1616 DRegister src = EvenDRegisterOf(source.fpu_reg());
1604 __ StoreDToOffset(src, FP, dest_offset); 1617 __ StoreDToOffset(src, FP, dest_offset);
1605 } else { 1618 } else {
1606 ASSERT(destination.IsQuadStackSlot()); 1619 ASSERT(destination.IsQuadStackSlot());
1607 const intptr_t dest_offset = destination.ToStackSlotOffset(); 1620 const intptr_t dest_offset = destination.ToStackSlotOffset();
1608 const DRegister dsrc0 = EvenDRegisterOf(source.fpu_reg()); 1621 const DRegister dsrc0 = EvenDRegisterOf(source.fpu_reg());
1609 __ StoreMultipleDToOffset(dsrc0, 2, FP, dest_offset); 1622 __ StoreMultipleDToOffset(dsrc0, 2, FP, dest_offset);
(...skipping 194 matching lines...) Expand 10 before | Expand all | Expand 10 after
1804 DRegister dreg = EvenDRegisterOf(reg); 1817 DRegister dreg = EvenDRegisterOf(reg);
1805 __ vldrd(dreg, Address(SP, kDoubleSize, Address::PostIndex)); 1818 __ vldrd(dreg, Address(SP, kDoubleSize, Address::PostIndex));
1806 } 1819 }
1807 1820
1808 1821
1809 #undef __ 1822 #undef __
1810 1823
1811 } // namespace dart 1824 } // namespace dart
1812 1825
1813 #endif // defined TARGET_ARCH_ARM 1826 #endif // defined TARGET_ARCH_ARM
OLDNEW
« no previous file with comments | « runtime/vm/flow_graph_compiler.h ('k') | runtime/vm/flow_graph_compiler_arm64.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698