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

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

Issue 23672011: Fix the previously ineffective assert checking the number of arguments passed to (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 7 years, 3 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/runtime_entry.h ('k') | runtime/vm/runtime_entry_ia32.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) 2011, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2011, 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/runtime_entry.h" 8 #include "vm/runtime_entry.h"
9 9
10 #include "vm/assembler.h" 10 #include "vm/assembler.h"
11 #include "vm/simulator.h" 11 #include "vm/simulator.h"
12 #include "vm/stub_code.h" 12 #include "vm/stub_code.h"
13 13
14 namespace dart { 14 namespace dart {
15 15
16 #define __ assembler-> 16 #define __ assembler->
17 17
18 18
19 // Generate code to call into the stub which will call the runtime 19 // Generate code to call into the stub which will call the runtime
20 // function. Input for the stub is as follows: 20 // function. Input for the stub is as follows:
21 // SP : points to the arguments and return value array. 21 // SP : points to the arguments and return value array.
22 // R5 : address of the runtime function to call. 22 // R5 : address of the runtime function to call.
23 // R4 : number of arguments to the call. 23 // R4 : number of arguments to the call.
24 void RuntimeEntry::Call(Assembler* assembler) const { 24 void RuntimeEntry::Call(Assembler* assembler, intptr_t argument_count) const {
25 // Compute the effective address. When running under the simulator, 25 // Compute the effective address. When running under the simulator,
26 // this is a redirection address that forces the simulator to call 26 // this is a redirection address that forces the simulator to call
27 // into the runtime system. 27 // into the runtime system.
28 uword entry = GetEntryPoint(); 28 uword entry = GetEntryPoint();
29 #if defined(USING_SIMULATOR) 29 #if defined(USING_SIMULATOR)
30 // Redirection to leaf runtime calls supports a maximum of 4 arguments passed 30 // Redirection to leaf runtime calls supports a maximum of 4 arguments passed
31 // in registers (maximum 2 double arguments for leaf float runtime calls). 31 // in registers (maximum 2 double arguments for leaf float runtime calls).
32 ASSERT(argument_count() >= 0); 32 ASSERT(argument_count >= 0);
33 ASSERT(!is_leaf() || 33 ASSERT(!is_leaf() ||
34 (!is_float() && (argument_count() <= 4)) || 34 (!is_float() && (argument_count <= 4)) ||
35 (argument_count() <= 2)); 35 (argument_count <= 2));
36 Simulator::CallKind call_kind = 36 Simulator::CallKind call_kind =
37 is_leaf() ? (is_float() ? Simulator::kLeafFloatRuntimeCall 37 is_leaf() ? (is_float() ? Simulator::kLeafFloatRuntimeCall
38 : Simulator::kLeafRuntimeCall) 38 : Simulator::kLeafRuntimeCall)
39 : Simulator::kRuntimeCall; 39 : Simulator::kRuntimeCall;
40 entry = 40 entry =
41 Simulator::RedirectExternalReference(entry, call_kind, argument_count()); 41 Simulator::RedirectExternalReference(entry, call_kind, argument_count);
42 #endif 42 #endif
43 if (is_leaf()) { 43 if (is_leaf()) {
44 ASSERT(argument_count == this->argument_count());
44 ExternalLabel label(name(), entry); 45 ExternalLabel label(name(), entry);
45 __ BranchLink(&label); 46 __ BranchLink(&label);
46 } else { 47 } else {
48 // Argument count is not checked here, but in the runtime entry for a more
49 // informative error message.
47 __ LoadImmediate(R5, entry); 50 __ LoadImmediate(R5, entry);
48 __ LoadImmediate(R4, argument_count()); 51 __ LoadImmediate(R4, argument_count);
49 __ BranchLink(&StubCode::CallToRuntimeLabel()); 52 __ BranchLink(&StubCode::CallToRuntimeLabel());
50 } 53 }
51 } 54 }
52 55
53 } // namespace dart 56 } // namespace dart
54 57
55 #endif // defined TARGET_ARCH_ARM 58 #endif // defined TARGET_ARCH_ARM
OLDNEW
« no previous file with comments | « runtime/vm/runtime_entry.h ('k') | runtime/vm/runtime_entry_ia32.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698