| 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/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" |
| (...skipping 1064 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1075 ASSERT(assembler()->constant_pool_allowed()); | 1075 ASSERT(assembler()->constant_pool_allowed()); |
| 1076 GenerateDeferredCode(); | 1076 GenerateDeferredCode(); |
| 1077 } | 1077 } |
| 1078 | 1078 |
| 1079 | 1079 |
| 1080 void FlowGraphCompiler::GenerateCall(TokenPosition token_pos, | 1080 void FlowGraphCompiler::GenerateCall(TokenPosition token_pos, |
| 1081 const StubEntry& stub_entry, | 1081 const StubEntry& stub_entry, |
| 1082 RawPcDescriptors::Kind kind, | 1082 RawPcDescriptors::Kind kind, |
| 1083 LocationSummary* locs) { | 1083 LocationSummary* locs) { |
| 1084 __ BranchLink(stub_entry); | 1084 __ BranchLink(stub_entry); |
| 1085 EmitCallsiteMetaData(token_pos, Thread::kNoDeoptId, kind, locs); | 1085 AddCurrentDescriptor(kind, Thread::kNoDeoptId, token_pos); |
| 1086 RecordSafepoint(locs); |
| 1086 } | 1087 } |
| 1087 | 1088 |
| 1088 | 1089 |
| 1089 void FlowGraphCompiler::GeneratePatchableCall(TokenPosition token_pos, | 1090 void FlowGraphCompiler::GeneratePatchableCall(TokenPosition token_pos, |
| 1090 const StubEntry& stub_entry, | 1091 const StubEntry& stub_entry, |
| 1091 RawPcDescriptors::Kind kind, | 1092 RawPcDescriptors::Kind kind, |
| 1092 LocationSummary* locs) { | 1093 LocationSummary* locs) { |
| 1093 __ BranchLinkPatchable(stub_entry); | 1094 __ BranchLinkPatchable(stub_entry); |
| 1094 EmitCallsiteMetaData(token_pos, Thread::kNoDeoptId, kind, locs); | 1095 AddCurrentDescriptor(kind, Thread::kNoDeoptId, token_pos); |
| 1096 RecordSafepoint(locs); |
| 1095 } | 1097 } |
| 1096 | 1098 |
| 1097 | 1099 |
| 1098 void FlowGraphCompiler::GenerateDartCall(intptr_t deopt_id, | 1100 void FlowGraphCompiler::GenerateDartCall(intptr_t deopt_id, |
| 1099 TokenPosition token_pos, | 1101 TokenPosition token_pos, |
| 1100 const StubEntry& stub_entry, | 1102 const StubEntry& stub_entry, |
| 1101 RawPcDescriptors::Kind kind, | 1103 RawPcDescriptors::Kind kind, |
| 1102 LocationSummary* locs) { | 1104 LocationSummary* locs) { |
| 1103 __ BranchLinkPatchable(stub_entry); | 1105 __ BranchLinkPatchable(stub_entry); |
| 1104 EmitCallsiteMetaData(token_pos, deopt_id, kind, locs); | 1106 AddCurrentDescriptor(kind, deopt_id, token_pos); |
| 1107 RecordSafepoint(locs); |
| 1105 // Marks either the continuation point in unoptimized code or the | 1108 // Marks either the continuation point in unoptimized code or the |
| 1106 // deoptimization point in optimized code, after call. | 1109 // deoptimization point in optimized code, after call. |
| 1107 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); | 1110 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); |
| 1108 if (is_optimizing()) { | 1111 if (is_optimizing()) { |
| 1109 AddDeoptIndexAtCall(deopt_id_after); | 1112 AddDeoptIndexAtCall(deopt_id_after); |
| 1110 } else { | 1113 } else { |
| 1111 // Add deoptimization continuation point after the call and before the | 1114 // Add deoptimization continuation point after the call and before the |
| 1112 // arguments are removed. | 1115 // arguments are removed. |
| 1113 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1116 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| 1114 } | 1117 } |
| 1115 } | 1118 } |
| 1116 | 1119 |
| 1117 | 1120 |
| 1118 void FlowGraphCompiler::GenerateStaticDartCall(intptr_t deopt_id, | 1121 void FlowGraphCompiler::GenerateStaticDartCall(intptr_t deopt_id, |
| 1119 TokenPosition token_pos, | 1122 TokenPosition token_pos, |
| 1120 const StubEntry& stub_entry, | 1123 const StubEntry& stub_entry, |
| 1121 RawPcDescriptors::Kind kind, | 1124 RawPcDescriptors::Kind kind, |
| 1122 LocationSummary* locs, | 1125 LocationSummary* locs, |
| 1123 const Function& target) { | 1126 const Function& target) { |
| 1124 // Call sites to the same target can share object pool entries. These | 1127 // Call sites to the same target can share object pool entries. These |
| 1125 // call sites are never patched for breakpoints: the function is deoptimized | 1128 // call sites are never patched for breakpoints: the function is deoptimized |
| 1126 // and the unoptimized code with IC calls for static calls is patched instead. | 1129 // and the unoptimized code with IC calls for static calls is patched instead. |
| 1127 ASSERT(is_optimizing()); | 1130 ASSERT(is_optimizing()); |
| 1128 __ BranchLinkWithEquivalence(stub_entry, target); | 1131 __ BranchLinkWithEquivalence(stub_entry, target); |
| 1129 | 1132 |
| 1130 EmitCallsiteMetaData(token_pos, deopt_id, kind, locs); | 1133 AddCurrentDescriptor(kind, deopt_id, token_pos); |
| 1134 RecordSafepoint(locs); |
| 1131 // Marks either the continuation point in unoptimized code or the | 1135 // Marks either the continuation point in unoptimized code or the |
| 1132 // deoptimization point in optimized code, after call. | 1136 // deoptimization point in optimized code, after call. |
| 1133 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); | 1137 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); |
| 1134 if (is_optimizing()) { | 1138 if (is_optimizing()) { |
| 1135 AddDeoptIndexAtCall(deopt_id_after); | 1139 AddDeoptIndexAtCall(deopt_id_after); |
| 1136 } else { | 1140 } else { |
| 1137 // Add deoptimization continuation point after the call and before the | 1141 // Add deoptimization continuation point after the call and before the |
| 1138 // arguments are removed. | 1142 // arguments are removed. |
| 1139 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1143 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| 1140 } | 1144 } |
| 1141 AddStaticCallTarget(target); | 1145 AddStaticCallTarget(target); |
| 1142 } | 1146 } |
| 1143 | 1147 |
| 1144 | 1148 |
| 1145 void FlowGraphCompiler::GenerateRuntimeCall(TokenPosition token_pos, | 1149 void FlowGraphCompiler::GenerateRuntimeCall(TokenPosition token_pos, |
| 1146 intptr_t deopt_id, | 1150 intptr_t deopt_id, |
| 1147 const RuntimeEntry& entry, | 1151 const RuntimeEntry& entry, |
| 1148 intptr_t argument_count, | 1152 intptr_t argument_count, |
| 1149 LocationSummary* locs) { | 1153 LocationSummary* locs) { |
| 1150 __ CallRuntime(entry, argument_count); | 1154 __ CallRuntime(entry, argument_count); |
| 1151 EmitCallsiteMetaData(token_pos, deopt_id, RawPcDescriptors::kOther, locs); | 1155 AddCurrentDescriptor(RawPcDescriptors::kOther, deopt_id, token_pos); |
| 1156 RecordSafepoint(locs); |
| 1152 if (deopt_id != Thread::kNoDeoptId) { | 1157 if (deopt_id != Thread::kNoDeoptId) { |
| 1153 // Marks either the continuation point in unoptimized code or the | 1158 // Marks either the continuation point in unoptimized code or the |
| 1154 // deoptimization point in optimized code, after call. | 1159 // deoptimization point in optimized code, after call. |
| 1155 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); | 1160 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); |
| 1156 if (is_optimizing()) { | 1161 if (is_optimizing()) { |
| 1157 AddDeoptIndexAtCall(deopt_id_after); | 1162 AddDeoptIndexAtCall(deopt_id_after); |
| 1158 } else { | 1163 } else { |
| 1159 // Add deoptimization continuation point after the call and before the | 1164 // Add deoptimization continuation point after the call and before the |
| 1160 // arguments are removed. | 1165 // arguments are removed. |
| 1161 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1166 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| (...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1283 AddCurrentDescriptor(RawPcDescriptors::kOther, Thread::kNoDeoptId, | 1288 AddCurrentDescriptor(RawPcDescriptors::kOther, Thread::kNoDeoptId, |
| 1284 token_pos); | 1289 token_pos); |
| 1285 AddDeoptIndexAtCall(deopt_id_after); | 1290 AddDeoptIndexAtCall(deopt_id_after); |
| 1286 } else { | 1291 } else { |
| 1287 AddCurrentDescriptor(RawPcDescriptors::kOther, Thread::kNoDeoptId, | 1292 AddCurrentDescriptor(RawPcDescriptors::kOther, Thread::kNoDeoptId, |
| 1288 token_pos); | 1293 token_pos); |
| 1289 // Add deoptimization continuation point after the call and before the | 1294 // Add deoptimization continuation point after the call and before the |
| 1290 // arguments are removed. | 1295 // arguments are removed. |
| 1291 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1296 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| 1292 } | 1297 } |
| 1293 EmitCatchEntryState(pending_deoptimization_env_, try_index); | |
| 1294 __ Drop(argument_count); | 1298 __ Drop(argument_count); |
| 1295 } | 1299 } |
| 1296 | 1300 |
| 1297 | 1301 |
| 1298 void FlowGraphCompiler::EmitSwitchableInstanceCall(const ICData& ic_data, | 1302 void FlowGraphCompiler::EmitSwitchableInstanceCall(const ICData& ic_data, |
| 1299 intptr_t argument_count, | 1303 intptr_t argument_count, |
| 1300 intptr_t deopt_id, | 1304 intptr_t deopt_id, |
| 1301 TokenPosition token_pos, | 1305 TokenPosition token_pos, |
| 1302 LocationSummary* locs) { | 1306 LocationSummary* locs) { |
| 1303 ASSERT(ic_data.NumArgsTested() == 1); | 1307 ASSERT(ic_data.NumArgsTested() == 1); |
| 1304 const Code& initial_stub = | 1308 const Code& initial_stub = |
| 1305 Code::ZoneHandle(StubCode::ICCallThroughFunction_entry()->code()); | 1309 Code::ZoneHandle(StubCode::ICCallThroughFunction_entry()->code()); |
| 1306 | 1310 |
| 1307 __ Comment("SwitchableCall"); | 1311 __ Comment("SwitchableCall"); |
| 1308 | 1312 |
| 1309 __ LoadFromOffset(kWord, R0, SP, (argument_count - 1) * kWordSize); | 1313 __ LoadFromOffset(kWord, R0, SP, (argument_count - 1) * kWordSize); |
| 1310 __ LoadUniqueObject(CODE_REG, initial_stub); | 1314 __ LoadUniqueObject(CODE_REG, initial_stub); |
| 1311 __ ldr(LR, FieldAddress(CODE_REG, Code::checked_entry_point_offset())); | 1315 __ ldr(LR, FieldAddress(CODE_REG, Code::checked_entry_point_offset())); |
| 1312 __ LoadUniqueObject(R9, ic_data); | 1316 __ LoadUniqueObject(R9, ic_data); |
| 1313 __ blx(LR); | 1317 __ blx(LR); |
| 1314 | 1318 |
| 1315 EmitCallsiteMetaData(token_pos, Thread::kNoDeoptId, RawPcDescriptors::kOther, | 1319 AddCurrentDescriptor(RawPcDescriptors::kOther, Thread::kNoDeoptId, token_pos); |
| 1316 locs); | 1320 RecordSafepoint(locs); |
| 1317 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); | 1321 const intptr_t deopt_id_after = Thread::ToDeoptAfter(deopt_id); |
| 1318 if (is_optimizing()) { | 1322 if (is_optimizing()) { |
| 1319 AddDeoptIndexAtCall(deopt_id_after); | 1323 AddDeoptIndexAtCall(deopt_id_after); |
| 1320 } else { | 1324 } else { |
| 1321 // Add deoptimization continuation point after the call and before the | 1325 // Add deoptimization continuation point after the call and before the |
| 1322 // arguments are removed. | 1326 // arguments are removed. |
| 1323 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); | 1327 AddCurrentDescriptor(RawPcDescriptors::kDeopt, deopt_id_after, token_pos); |
| 1324 } | 1328 } |
| 1325 __ Drop(argument_count); | 1329 __ Drop(argument_count); |
| 1326 } | 1330 } |
| (...skipping 575 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1902 DRegister dreg = EvenDRegisterOf(reg); | 1906 DRegister dreg = EvenDRegisterOf(reg); |
| 1903 __ vldrd(dreg, Address(SP, kDoubleSize, Address::PostIndex)); | 1907 __ vldrd(dreg, Address(SP, kDoubleSize, Address::PostIndex)); |
| 1904 } | 1908 } |
| 1905 | 1909 |
| 1906 | 1910 |
| 1907 #undef __ | 1911 #undef __ |
| 1908 | 1912 |
| 1909 } // namespace dart | 1913 } // namespace dart |
| 1910 | 1914 |
| 1911 #endif // defined TARGET_ARCH_ARM | 1915 #endif // defined TARGET_ARCH_ARM |
| OLD | NEW |