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

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

Issue 1150633002: Track prologue offset of Code and use for more precise return addresses (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Created 5 years, 7 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
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, 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 // Classes that describe assembly patterns as used by inline caches. 4 // Classes that describe assembly patterns as used by inline caches.
5 5
6 #ifndef VM_INSTRUCTIONS_IA32_H_ 6 #ifndef VM_INSTRUCTIONS_IA32_H_
7 #define VM_INSTRUCTIONS_IA32_H_ 7 #define VM_INSTRUCTIONS_IA32_H_
8 8
9 #ifndef VM_INSTRUCTIONS_H_ 9 #ifndef VM_INSTRUCTIONS_H_
10 #error Do not include instructions_ia32.h directly; use instructions.h instead. 10 #error Do not include instructions_ia32.h directly; use instructions.h instead.
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after
99 public: 99 public:
100 explicit ReturnPattern(uword pc) : InstructionPattern(pc) {} 100 explicit ReturnPattern(uword pc) : InstructionPattern(pc) {}
101 101
102 virtual const int* pattern() const; 102 virtual const int* pattern() const;
103 virtual int pattern_length_in_bytes() const { return kLengthInBytes; } 103 virtual int pattern_length_in_bytes() const { return kLengthInBytes; }
104 104
105 private: 105 private:
106 static const int kLengthInBytes = 1; 106 static const int kLengthInBytes = 1;
107 }; 107 };
108 108
109
srdjan 2015/05/21 16:06:33 Please add tests for these two new patterns, best
Cutch 2015/05/22 01:11:14 Done.
110 class ProloguePattern : public InstructionPattern {
111 public:
112 explicit ProloguePattern(uword pc) : InstructionPattern(pc) {}
113
114 virtual const int* pattern() const;
srdjan 2015/05/21 16:06:33 I wonder why we are using int instead of intptr_t
Cutch 2015/05/22 01:11:14 Acknowledged.
115 virtual int pattern_length_in_bytes() const { return kLengthInBytes; }
116
117 private:
118 static const int kLengthInBytes = 3;
119 };
120
121
122 class SetFramePointerPattern : public InstructionPattern {
123 public:
124 explicit SetFramePointerPattern(uword pc) : InstructionPattern(pc) {}
125
126 virtual const int* pattern() const;
127 virtual int pattern_length_in_bytes() const { return kLengthInBytes; }
128
129 private:
130 static const int kLengthInBytes = 2;
131 };
132
109 } // namespace dart 133 } // namespace dart
110 134
111 #endif // VM_INSTRUCTIONS_IA32_H_ 135 #endif // VM_INSTRUCTIONS_IA32_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698