OLD | NEW |
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/flow_graph_allocator.h" | 5 #include "vm/flow_graph_allocator.h" |
6 | 6 |
7 #include "vm/bit_vector.h" | 7 #include "vm/bit_vector.h" |
8 #include "vm/intermediate_language.h" | 8 #include "vm/intermediate_language.h" |
9 #include "vm/il_printer.h" | 9 #include "vm/il_printer.h" |
10 #include "vm/flow_graph.h" | 10 #include "vm/flow_graph.h" |
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
94 intrinsic_mode_(intrinsic_mode) { | 94 intrinsic_mode_(intrinsic_mode) { |
95 for (intptr_t i = 0; i < vreg_count_; i++) { | 95 for (intptr_t i = 0; i < vreg_count_; i++) { |
96 live_ranges_.Add(NULL); | 96 live_ranges_.Add(NULL); |
97 } | 97 } |
98 for (intptr_t i = 0; i < vreg_count_; i++) { | 98 for (intptr_t i = 0; i < vreg_count_; i++) { |
99 value_representations_.Add(kNoRepresentation); | 99 value_representations_.Add(kNoRepresentation); |
100 } | 100 } |
101 | 101 |
102 // All registers are marked as "not blocked" (array initialized to false). | 102 // All registers are marked as "not blocked" (array initialized to false). |
103 // Mark the unavailable ones as "blocked" (true). | 103 // Mark the unavailable ones as "blocked" (true). |
104 for (intptr_t i = 0; i < kFirstFreeCpuRegister; i++) { | 104 for (intptr_t i = 0; i < kNumberOfCpuRegisters; i++) { |
105 blocked_cpu_registers_[i] = true; | 105 if ((kDartAvailableCpuRegs & (1 << i)) == 0) { |
| 106 blocked_cpu_registers_[i] = true; |
| 107 } |
106 } | 108 } |
107 for (intptr_t i = kLastFreeCpuRegister + 1; i < kNumberOfCpuRegisters; i++) { | |
108 blocked_cpu_registers_[i] = true; | |
109 } | |
110 if (TMP != kNoRegister) { | |
111 blocked_cpu_registers_[TMP] = true; | |
112 } | |
113 if (TMP2 != kNoRegister) { | |
114 blocked_cpu_registers_[TMP2] = true; | |
115 } | |
116 if (PP != kNoRegister) { | |
117 blocked_cpu_registers_[PP] = true; | |
118 } | |
119 blocked_cpu_registers_[SPREG] = true; | |
120 blocked_cpu_registers_[FPREG] = true; | |
121 blocked_cpu_registers_[THR] = true; | |
122 | 109 |
123 // FpuTMP is used as scratch by optimized code and parallel move resolver. | 110 // FpuTMP is used as scratch by optimized code and parallel move resolver. |
124 blocked_fpu_registers_[FpuTMP] = true; | 111 blocked_fpu_registers_[FpuTMP] = true; |
125 | 112 |
126 // Block additional registers needed preserved when generating intrinsics. | 113 // Block additional registers needed preserved when generating intrinsics. |
127 // TODO(fschneider): Handle saving and restoring these registers when | 114 // TODO(fschneider): Handle saving and restoring these registers when |
128 // generating intrinsic code. | 115 // generating intrinsic code. |
129 if (intrinsic_mode) { | 116 if (intrinsic_mode) { |
130 blocked_cpu_registers_[ARGS_DESC_REG] = true; | 117 blocked_cpu_registers_[ARGS_DESC_REG] = true; |
131 } | 118 } |
(...skipping 2887 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3019 THR_Print("-- [after ssa allocator] ir [%s] -------------\n", | 3006 THR_Print("-- [after ssa allocator] ir [%s] -------------\n", |
3020 function.ToFullyQualifiedCString()); | 3007 function.ToFullyQualifiedCString()); |
3021 FlowGraphPrinter printer(flow_graph_, true); | 3008 FlowGraphPrinter printer(flow_graph_, true); |
3022 printer.PrintBlocks(); | 3009 printer.PrintBlocks(); |
3023 THR_Print("----------------------------------------------\n"); | 3010 THR_Print("----------------------------------------------\n"); |
3024 } | 3011 } |
3025 } | 3012 } |
3026 | 3013 |
3027 | 3014 |
3028 } // namespace dart | 3015 } // namespace dart |
OLD | NEW |