| OLD | NEW |
| 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2014, 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_ARM64. | 5 #include "vm/globals.h" // Needed here to get TARGET_ARCH_ARM64. |
| 6 #if defined(TARGET_ARCH_ARM64) | 6 #if defined(TARGET_ARCH_ARM64) |
| 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" |
| (...skipping 1139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1150 const StubEntry& stub_entry, | 1150 const StubEntry& stub_entry, |
| 1151 RawPcDescriptors::Kind kind, | 1151 RawPcDescriptors::Kind kind, |
| 1152 LocationSummary* locs) { | 1152 LocationSummary* locs) { |
| 1153 __ BranchLinkPatchable(stub_entry); | 1153 __ BranchLinkPatchable(stub_entry); |
| 1154 AddCurrentDescriptor(kind, deopt_id, token_pos); | 1154 AddCurrentDescriptor(kind, deopt_id, token_pos); |
| 1155 RecordSafepoint(locs); | 1155 RecordSafepoint(locs); |
| 1156 // Marks either the continuation point in unoptimized code or the | 1156 // Marks either the continuation point in unoptimized code or the |
| 1157 // deoptimization point in optimized code, after call. | 1157 // deoptimization point in optimized code, after call. |
| 1158 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); | 1158 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); |
| 1159 if (is_optimizing()) { | 1159 if (is_optimizing()) { |
| 1160 AddDeoptIndexAtCall(deopt_id_after, token_pos); | 1160 AddDeoptIndexAtCall(deopt_id_after); |
| 1161 } else { | 1161 } else { |
| 1162 // Add deoptimization continuation point after the call and before the | 1162 // Add deoptimization continuation point after the call and before the |
| 1163 // arguments are removed. | 1163 // arguments are removed. |
| 1164 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1164 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| 1165 } | 1165 } |
| 1166 } | 1166 } |
| 1167 | 1167 |
| 1168 | 1168 |
| 1169 void FlowGraphCompiler::GenerateStaticDartCall(intptr_t deopt_id, | 1169 void FlowGraphCompiler::GenerateStaticDartCall(intptr_t deopt_id, |
| 1170 TokenPosition token_pos, | 1170 TokenPosition token_pos, |
| 1171 const StubEntry& stub_entry, | 1171 const StubEntry& stub_entry, |
| 1172 RawPcDescriptors::Kind kind, | 1172 RawPcDescriptors::Kind kind, |
| 1173 LocationSummary* locs, | 1173 LocationSummary* locs, |
| 1174 const Function& target) { | 1174 const Function& target) { |
| 1175 // Call sites to the same target can share object pool entries. These | 1175 // Call sites to the same target can share object pool entries. These |
| 1176 // call sites are never patched for breakpoints: the function is deoptimized | 1176 // call sites are never patched for breakpoints: the function is deoptimized |
| 1177 // and the unoptimized code with IC calls for static calls is patched instead. | 1177 // and the unoptimized code with IC calls for static calls is patched instead. |
| 1178 ASSERT(is_optimizing()); | 1178 ASSERT(is_optimizing()); |
| 1179 __ BranchLinkWithEquivalence(stub_entry, target); | 1179 __ BranchLinkWithEquivalence(stub_entry, target); |
| 1180 | 1180 |
| 1181 AddCurrentDescriptor(kind, deopt_id, token_pos); | 1181 AddCurrentDescriptor(kind, deopt_id, token_pos); |
| 1182 RecordSafepoint(locs); | 1182 RecordSafepoint(locs); |
| 1183 // Marks either the continuation point in unoptimized code or the | 1183 // Marks either the continuation point in unoptimized code or the |
| 1184 // deoptimization point in optimized code, after call. | 1184 // deoptimization point in optimized code, after call. |
| 1185 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); | 1185 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); |
| 1186 if (is_optimizing()) { | 1186 if (is_optimizing()) { |
| 1187 AddDeoptIndexAtCall(deopt_id_after, token_pos); | 1187 AddDeoptIndexAtCall(deopt_id_after); |
| 1188 } else { | 1188 } else { |
| 1189 // Add deoptimization continuation point after the call and before the | 1189 // Add deoptimization continuation point after the call and before the |
| 1190 // arguments are removed. | 1190 // arguments are removed. |
| 1191 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1191 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| 1192 } | 1192 } |
| 1193 AddStaticCallTarget(target); | 1193 AddStaticCallTarget(target); |
| 1194 } | 1194 } |
| 1195 | 1195 |
| 1196 | 1196 |
| 1197 void FlowGraphCompiler::GenerateRuntimeCall(TokenPosition token_pos, | 1197 void FlowGraphCompiler::GenerateRuntimeCall(TokenPosition token_pos, |
| 1198 intptr_t deopt_id, | 1198 intptr_t deopt_id, |
| 1199 const RuntimeEntry& entry, | 1199 const RuntimeEntry& entry, |
| 1200 intptr_t argument_count, | 1200 intptr_t argument_count, |
| 1201 LocationSummary* locs) { | 1201 LocationSummary* locs) { |
| 1202 __ CallRuntime(entry, argument_count); | 1202 __ CallRuntime(entry, argument_count); |
| 1203 AddCurrentDescriptor(RawPcDescriptors::kOther, deopt_id, token_pos); | 1203 AddCurrentDescriptor(RawPcDescriptors::kOther, deopt_id, token_pos); |
| 1204 RecordSafepoint(locs); | 1204 RecordSafepoint(locs); |
| 1205 if (deopt_id != Thread::kNoDeoptId) { | 1205 if (deopt_id != Thread::kNoDeoptId) { |
| 1206 // Marks either the continuation point in unoptimized code or the | 1206 // Marks either the continuation point in unoptimized code or the |
| 1207 // deoptimization point in optimized code, after call. | 1207 // deoptimization point in optimized code, after call. |
| 1208 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); | 1208 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); |
| 1209 if (is_optimizing()) { | 1209 if (is_optimizing()) { |
| 1210 AddDeoptIndexAtCall(deopt_id_after, token_pos); | 1210 AddDeoptIndexAtCall(deopt_id_after); |
| 1211 } else { | 1211 } else { |
| 1212 // Add deoptimization continuation point after the call and before the | 1212 // Add deoptimization continuation point after the call and before the |
| 1213 // arguments are removed. | 1213 // arguments are removed. |
| 1214 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1214 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| 1215 } | 1215 } |
| 1216 } | 1216 } |
| 1217 } | 1217 } |
| 1218 | 1218 |
| 1219 | 1219 |
| 1220 void FlowGraphCompiler::EmitEdgeCounter(intptr_t edge_id) { | 1220 void FlowGraphCompiler::EmitEdgeCounter(intptr_t edge_id) { |
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1329 try_index = CurrentTryIndex(); | 1329 try_index = CurrentTryIndex(); |
| 1330 } | 1330 } |
| 1331 pc_descriptors_list()->AddDescriptor(RawPcDescriptors::kOther, | 1331 pc_descriptors_list()->AddDescriptor(RawPcDescriptors::kOther, |
| 1332 assembler()->CodeSize(), | 1332 assembler()->CodeSize(), |
| 1333 Thread::kNoDeoptId, | 1333 Thread::kNoDeoptId, |
| 1334 token_pos, | 1334 token_pos, |
| 1335 try_index); | 1335 try_index); |
| 1336 } else if (is_optimizing()) { | 1336 } else if (is_optimizing()) { |
| 1337 AddCurrentDescriptor(RawPcDescriptors::kOther, | 1337 AddCurrentDescriptor(RawPcDescriptors::kOther, |
| 1338 Thread::kNoDeoptId, token_pos); | 1338 Thread::kNoDeoptId, token_pos); |
| 1339 AddDeoptIndexAtCall(deopt_id_after, token_pos); | 1339 AddDeoptIndexAtCall(deopt_id_after); |
| 1340 } else { | 1340 } else { |
| 1341 AddCurrentDescriptor(RawPcDescriptors::kOther, | 1341 AddCurrentDescriptor(RawPcDescriptors::kOther, |
| 1342 Thread::kNoDeoptId, token_pos); | 1342 Thread::kNoDeoptId, token_pos); |
| 1343 // Add deoptimization continuation point after the call and before the | 1343 // Add deoptimization continuation point after the call and before the |
| 1344 // arguments are removed. | 1344 // arguments are removed. |
| 1345 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1345 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| 1346 } | 1346 } |
| 1347 __ Drop(argument_count); | 1347 __ Drop(argument_count); |
| 1348 } | 1348 } |
| 1349 | 1349 |
| (...skipping 13 matching lines...) Expand all Loading... |
| 1363 __ LoadUniqueObject(R5, ic_data); | 1363 __ LoadUniqueObject(R5, ic_data); |
| 1364 __ LoadUniqueObject(CODE_REG, initial_stub); | 1364 __ LoadUniqueObject(CODE_REG, initial_stub); |
| 1365 __ ldr(TMP, FieldAddress(CODE_REG, Code::checked_entry_point_offset())); | 1365 __ ldr(TMP, FieldAddress(CODE_REG, Code::checked_entry_point_offset())); |
| 1366 __ blr(TMP); | 1366 __ blr(TMP); |
| 1367 | 1367 |
| 1368 AddCurrentDescriptor(RawPcDescriptors::kOther, | 1368 AddCurrentDescriptor(RawPcDescriptors::kOther, |
| 1369 Thread::kNoDeoptId, token_pos); | 1369 Thread::kNoDeoptId, token_pos); |
| 1370 RecordSafepoint(locs); | 1370 RecordSafepoint(locs); |
| 1371 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); | 1371 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); |
| 1372 if (is_optimizing()) { | 1372 if (is_optimizing()) { |
| 1373 AddDeoptIndexAtCall(deopt_id_after, token_pos); | 1373 AddDeoptIndexAtCall(deopt_id_after); |
| 1374 } else { | 1374 } else { |
| 1375 // Add deoptimization continuation point after the call and before the | 1375 // Add deoptimization continuation point after the call and before the |
| 1376 // arguments are removed. | 1376 // arguments are removed. |
| 1377 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1377 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| 1378 } | 1378 } |
| 1379 __ Drop(argument_count); | 1379 __ Drop(argument_count); |
| 1380 } | 1380 } |
| 1381 | 1381 |
| 1382 | 1382 |
| 1383 void FlowGraphCompiler::EmitUnoptimizedStaticCall( | 1383 void FlowGraphCompiler::EmitUnoptimizedStaticCall( |
| (...skipping 549 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1933 void ParallelMoveResolver::RestoreFpuScratch(FpuRegister reg) { | 1933 void ParallelMoveResolver::RestoreFpuScratch(FpuRegister reg) { |
| 1934 __ PopDouble(reg); | 1934 __ PopDouble(reg); |
| 1935 } | 1935 } |
| 1936 | 1936 |
| 1937 | 1937 |
| 1938 #undef __ | 1938 #undef __ |
| 1939 | 1939 |
| 1940 } // namespace dart | 1940 } // namespace dart |
| 1941 | 1941 |
| 1942 #endif // defined TARGET_ARCH_ARM64 | 1942 #endif // defined TARGET_ARCH_ARM64 |
| OLD | NEW |