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

Unified Diff: runtime/vm/intrinsifier_ia32.cc

Issue 266913010: Refactor 'dart:profiler' UserTag API (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 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 side-by-side diff with in-line comments
Download patch
Index: runtime/vm/intrinsifier_ia32.cc
diff --git a/runtime/vm/intrinsifier_ia32.cc b/runtime/vm/intrinsifier_ia32.cc
index 958e6ce436bb2f0afe0bdd34665003cacea857e2..d13ba65dfa40f2f9da28d11309666ee3ebcbedf8 100644
--- a/runtime/vm/intrinsifier_ia32.cc
+++ b/runtime/vm/intrinsifier_ia32.cc
@@ -1749,6 +1749,8 @@ void Intrinsifier::UserTag_makeCurrent(Assembler* assembler) {
const Address user_tag_addr =
Address::Absolute(reinterpret_cast<uword>(isolate) +
Isolate::user_tag_offset());
+ // EBX: Current user tag.
+ __ movl(EBX, current_tag_addr);
zra 2014/05/06 15:27:24 Here, too?
Cutch 2014/05/06 17:00:25 Done.
// EAX: UserTag.
__ movl(EAX, Address(ESP, + 1 * kWordSize));
// Set Isolate::current_tag_.
@@ -1758,40 +1760,30 @@ void Intrinsifier::UserTag_makeCurrent(Assembler* assembler) {
// Set Isolate::user_tag_.
__ movl(user_tag_addr, EAX);
// Set return value.
- const Immediate& raw_null =
- Immediate(reinterpret_cast<int32_t>(Object::null()));
- __ movl(EAX, raw_null);
+ __ movl(EAX, EBX);
__ ret();
}
-void Intrinsifier::Profiler_getCurrentTag(Assembler* assembler) {
+void Intrinsifier::UserTag_defaultTag(Assembler* assembler) {
Isolate* isolate = Isolate::Current();
- const Address current_tag_addr =
- Address::Absolute(reinterpret_cast<uword>(isolate) +
- Isolate::current_tag_offset());
- // Set return value to Isolate::current_tag_.
- __ movl(EAX, current_tag_addr);
+ const Address default_tag_addr =
+ Address::Absolute(
+ reinterpret_cast<uword>(isolate->object_store()) +
+ ObjectStore::default_tag_offset());
+ // Set return value.
+ __ movl(EAX, default_tag_addr);
__ ret();
}
-void Intrinsifier::Profiler_clearCurrentTag(Assembler* assembler) {
+void Intrinsifier::Profiler_getCurrentTag(Assembler* assembler) {
Isolate* isolate = Isolate::Current();
const Address current_tag_addr =
Address::Absolute(reinterpret_cast<uword>(isolate) +
Isolate::current_tag_offset());
- const Address user_tag_addr =
- Address::Absolute(reinterpret_cast<uword>(isolate) +
- Isolate::user_tag_offset());
// Set return value to Isolate::current_tag_.
__ movl(EAX, current_tag_addr);
- // Clear Isolate::current_tag_.
- const Immediate& raw_null =
- Immediate(reinterpret_cast<int32_t>(UserTag::null()));
- __ movl(current_tag_addr, raw_null);
- // Clear Isolate::user_tag_.
- __ movl(user_tag_addr, Immediate(0));
__ ret();
}

Powered by Google App Engine
This is Rietveld 408576698