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

Unified Diff: runtime/vm/intermediate_language_mips.cc

Issue 105143011: Optimize one byte string comparisons. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 7 years 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/intermediate_language_mips.cc
===================================================================
--- runtime/vm/intermediate_language_mips.cc (revision 31282)
+++ runtime/vm/intermediate_language_mips.cc (working copy)
@@ -780,7 +780,7 @@
}
-LocationSummary* StringFromCharCodeInstr::MakeLocationSummary(bool opt) const {
+LocationSummary* StringCharCodeInstr::MakeLocationSummary(bool opt) const {
const intptr_t kNumInputs = 1;
// TODO(fschneider): Allow immediate operands for the char code.
return LocationSummary::Make(kNumInputs,
@@ -789,18 +789,36 @@
}
-void StringFromCharCodeInstr::EmitNativeCode(FlowGraphCompiler* compiler) {
- Register char_code = locs()->in(0).reg();
- Register result = locs()->out().reg();
+void StringCharCodeInstr::EmitNativeCode(FlowGraphCompiler* compiler) {
+ if (kind() == StringCharCodeInstr::kFromCharCode) {
+ Register char_code = locs()->in(0).reg();
+ Register result = locs()->out().reg();
- __ TraceSimMsg("StringFromCharCodeInstr");
+ __ TraceSimMsg("StringCharCodeInstr From");
- __ LoadImmediate(result,
- reinterpret_cast<uword>(Symbols::PredefinedAddress()));
- __ AddImmediate(result, Symbols::kNullCharCodeSymbolOffset * kWordSize);
- __ sll(TMP, char_code, 1); // Char code is a smi.
- __ addu(TMP, TMP, result);
- __ lw(result, Address(TMP));
+ __ LoadImmediate(result,
+ reinterpret_cast<uword>(Symbols::PredefinedAddress()));
+ __ AddImmediate(result, Symbols::kNullCharCodeSymbolOffset * kWordSize);
+ __ sll(TMP, char_code, 1); // Char code is a smi.
+ __ addu(TMP, TMP, result);
+ __ lw(result, Address(TMP));
+ } else {
+ __ TraceSimMsg("StringCharCodeInstr To");
+
+ ASSERT(kind() == StringCharCodeInstr::kToCharCode);
+ ASSERT(cid_ == kOneByteStringCid);
+ Register str = locs()->in(0).reg();
+ Register result = locs()->out().reg();
+ Label done, is_one;
+ __ lw(result, FieldAddress(str, String::length_offset()));
+ __ BranchEqual(result, Smi::RawValue(1), &is_one);
+ __ LoadImmediate(result, Smi::RawValue(-1));
+ __ b(&done);
+ __ Bind(&is_one);
+ __ lbu(result, FieldAddress(str, OneByteString::data_offset()));
+ __ SmiTag(result);
+ __ Bind(&done);
+ }
}

Powered by Google App Engine
This is Rietveld 408576698