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

Side by Side Diff: runtime/vm/assembler_arm.h

Issue 11956004: Fix vm code base so that it can be built for --arch=simarm (no snapshot yet). (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 7 years, 11 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 | « no previous file | runtime/vm/assembler_arm.cc » ('j') | runtime/vm/flow_graph_compiler_ia32.cc » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, 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 #ifndef VM_ASSEMBLER_ARM_H_ 5 #ifndef VM_ASSEMBLER_ARM_H_
6 #define VM_ASSEMBLER_ARM_H_ 6 #define VM_ASSEMBLER_ARM_H_
7 7
8 #ifndef VM_ASSEMBLER_H_ 8 #ifndef VM_ASSEMBLER_H_
9 #error Do not include assembler_arm.h directly; use assembler.h instead. 9 #error Do not include assembler_arm.h directly; use assembler.h instead.
10 #endif 10 #endif
11 11
12 #include "platform/assert.h" 12 #include "platform/assert.h"
13 #include "vm/constants_arm.h" 13 #include "vm/constants_arm.h"
14 14
15 namespace dart { 15 namespace dart {
16 16
17 class Operand : public ValueObject {
18 protected:
19 // Operand can be sub classed (e.g: Address).
srdjan 2013/01/16 19:06:30 s/sub classes/ subclassed/
regis 2013/01/16 23:14:42 Done.
20 Operand() { }
21
22 private:
23 DISALLOW_ALLOCATION();
24 };
25
26
27 class Address : public Operand {
28 public:
29 Address(Register base, int32_t disp) {
30 UNIMPLEMENTED();
31 }
32 private:
33 DISALLOW_ALLOCATION();
34 };
35
36
37 class FieldAddress : public Address {
38 public:
39 FieldAddress(Register base, int32_t disp)
40 : Address(base, disp - kHeapObjectTag) {}
41 };
42
43
17 class Label : public ValueObject { 44 class Label : public ValueObject {
18 public: 45 public:
19 Label() : position_(0) { } 46 Label() : position_(0) { }
20 47
21 ~Label() { 48 ~Label() {
22 // Assert if label is being destroyed with unresolved branches pending. 49 // Assert if label is being destroyed with unresolved branches pending.
23 ASSERT(!IsLinked()); 50 ASSERT(!IsLinked());
24 } 51 }
25 52
26 // Returns the position for bound and linked labels. Cannot be used 53 // Returns the position for bound and linked labels. Cannot be used
27 // for unused labels. 54 // for unused labels.
28 int Position() const { 55 int Position() const {
29 ASSERT(!IsUnused()); 56 ASSERT(!IsUnused());
30 return IsBound() ? -position_ - kWordSize : position_ - kWordSize; 57 return IsBound() ? -position_ - kWordSize : position_ - kWordSize;
31 } 58 }
32 59
33 bool IsBound() const { return position_ < 0; } 60 bool IsBound() const { return position_ < 0; }
34 bool IsUnused() const { return position_ == 0; } 61 bool IsUnused() const { return position_ == 0; }
35 bool IsLinked() const { return position_ > 0; } 62 bool IsLinked() const { return position_ > 0; }
36 63
64
srdjan 2013/01/16 19:06:30 delete line
regis 2013/01/16 23:14:42 Done.
37 private: 65 private:
38 int position_; 66 int position_;
39 67
40 void Reinitialize() { 68 void Reinitialize() {
41 position_ = 0; 69 position_ = 0;
42 } 70 }
43 71
44 void BindTo(int position) { 72 void BindTo(int position) {
45 ASSERT(!IsBound()); 73 ASSERT(!IsBound());
46 position_ = -position - kWordSize; 74 position_ = -position - kWordSize;
47 ASSERT(IsBound()); 75 ASSERT(IsBound());
48 } 76 }
49 77
50 void LinkTo(int position) { 78 void LinkTo(int position) {
51 ASSERT(!IsBound()); 79 ASSERT(!IsBound());
52 position_ = position + kWordSize; 80 position_ = position + kWordSize;
53 ASSERT(IsLinked()); 81 ASSERT(IsLinked());
54 } 82 }
55 83
56 friend class Assembler; 84 friend class Assembler;
57 DISALLOW_COPY_AND_ASSIGN(Label); 85 DISALLOW_COPY_AND_ASSIGN(Label);
58 }; 86 };
59 87
60 88
61 class Assembler { 89 class CPUFeatures : public AllStatic {
62 public: 90 public:
63 Assembler() { } 91 static void InitOnce() { }
92 };
93
94
95 class Assembler : public ValueObject {
96 public:
97 Assembler() { UNIMPLEMENTED(); }
64 ~Assembler() { } 98 ~Assembler() { }
65 99
66 // Macros for High-level operations. 100 void PopRegister(Register r) {
67 void AddConstant(Register reg, int value, Condition cond = AL) { 101 UNIMPLEMENTED();
102 }
103
104 void Bind(Label* label) {
68 UNIMPLEMENTED(); 105 UNIMPLEMENTED();
69 } 106 }
70 107
71 // Misc. functionality 108 // Misc. functionality
72 int CodeSize() const { 109 int CodeSize() const {
73 UNIMPLEMENTED(); 110 UNIMPLEMENTED();
74 return 0; 111 return 0;
75 } 112 }
76 int prologue_offset() const { 113 int prologue_offset() const {
77 UNIMPLEMENTED(); 114 UNIMPLEMENTED();
(...skipping 10 matching lines...) Expand all
88 // Debugging and bringup support. 125 // Debugging and bringup support.
89 void Stop(const char* message) { UNIMPLEMENTED(); } 126 void Stop(const char* message) { UNIMPLEMENTED(); }
90 void Unimplemented(const char* message); 127 void Unimplemented(const char* message);
91 void Untested(const char* message); 128 void Untested(const char* message);
92 void Unreachable(const char* message); 129 void Unreachable(const char* message);
93 130
94 static void InitializeMemoryWithBreakpoints(uword data, int length) { 131 static void InitializeMemoryWithBreakpoints(uword data, int length) {
95 UNIMPLEMENTED(); 132 UNIMPLEMENTED();
96 } 133 }
97 134
135 void Comment(const char* format, ...) PRINTF_ATTRIBUTE(2, 3) {
136 UNIMPLEMENTED();
137 }
138
139 const Code::Comments& GetCodeComments() const {
140 UNIMPLEMENTED();
141 return Code::Comments::New(0);
142 }
143
144 static const char* RegisterName(Register reg) {
145 UNIMPLEMENTED();
146 return NULL;
147 }
148
149 static const char* FpuRegisterName(FpuRegister reg) {
150 UNIMPLEMENTED();
151 return NULL;
152 }
153
98 private: 154 private:
99 ZoneGrowableArray<int>* pointer_offsets_; 155 ZoneGrowableArray<int>* pointer_offsets_;
100 DISALLOW_ALLOCATION(); 156 DISALLOW_ALLOCATION();
101 DISALLOW_COPY_AND_ASSIGN(Assembler); 157 DISALLOW_COPY_AND_ASSIGN(Assembler);
102 }; 158 };
103 159
104 } // namespace dart 160 } // namespace dart
105 161
106 #endif // VM_ASSEMBLER_ARM_H_ 162 #endif // VM_ASSEMBLER_ARM_H_
OLDNEW
« no previous file with comments | « no previous file | runtime/vm/assembler_arm.cc » ('j') | runtime/vm/flow_graph_compiler_ia32.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698