Fix code gen bug on arm and mips; SeqStringSetChar overwrites a register; Add better default PrintDataTo for HInstruction
BUG= Review URL: https://codereview.chromium.org/14895019 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@14710 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
61c087dcc7
commit
5746d38351
@ -1826,7 +1826,7 @@ LInstruction* LChunkBuilder::DoDateField(HDateField* instr) {
|
||||
LInstruction* LChunkBuilder::DoSeqStringSetChar(HSeqStringSetChar* instr) {
|
||||
LOperand* string = UseRegister(instr->string());
|
||||
LOperand* index = UseRegister(instr->index());
|
||||
LOperand* value = UseRegister(instr->value());
|
||||
LOperand* value = UseTempRegister(instr->value());
|
||||
LSeqStringSetChar* result =
|
||||
new(zone()) LSeqStringSetChar(instr->encoding(), string, index, value);
|
||||
return DefineAsRegister(result);
|
||||
|
@ -806,6 +806,14 @@ void HInstruction::PrintTo(StringStream* stream) {
|
||||
}
|
||||
|
||||
|
||||
void HInstruction::PrintDataTo(StringStream *stream) {
|
||||
for (int i = 0; i < OperandCount(); ++i) {
|
||||
if (i > 0) stream->Add(" ");
|
||||
OperandAt(i)->PrintNameTo(stream);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void HInstruction::PrintMnemonicTo(StringStream* stream) {
|
||||
stream->Add("%s ", Mnemonic());
|
||||
}
|
||||
|
@ -1251,7 +1251,7 @@ class HInstruction: public HValue {
|
||||
HInstruction* previous() const { return previous_; }
|
||||
|
||||
virtual void PrintTo(StringStream* stream);
|
||||
virtual void PrintDataTo(StringStream* stream) { }
|
||||
virtual void PrintDataTo(StringStream* stream);
|
||||
|
||||
bool IsLinked() const { return block() != NULL; }
|
||||
void Unlink();
|
||||
|
@ -5439,8 +5439,7 @@ void HGraph::MarkLiveInstructions() {
|
||||
}
|
||||
|
||||
|
||||
void HGraph::MarkLive(HValue *ref, HValue* instr,
|
||||
ZoneList<HValue*>* worklist) {
|
||||
void HGraph::MarkLive(HValue* ref, HValue* instr, ZoneList<HValue*>* worklist) {
|
||||
if (!instr->CheckFlag(HValue::kIsLive)) {
|
||||
instr->SetFlag(HValue::kIsLive);
|
||||
worklist->Add(instr, zone());
|
||||
@ -5448,6 +5447,7 @@ void HGraph::MarkLive(HValue *ref, HValue* instr,
|
||||
if (FLAG_trace_dead_code_elimination) {
|
||||
HeapStringAllocator allocator;
|
||||
StringStream stream(&allocator);
|
||||
ALLOW_HANDLE_DEREF(isolate(), "debug mode printing");
|
||||
if (ref != NULL) {
|
||||
ref->PrintTo(&stream);
|
||||
} else {
|
||||
@ -10329,7 +10329,7 @@ bool HOptimizedGraphBuilder::MatchRotateRight(HValue* left,
|
||||
}
|
||||
|
||||
|
||||
bool CanBeZero(HValue *right) {
|
||||
bool CanBeZero(HValue* right) {
|
||||
if (right->IsConstant()) {
|
||||
HConstant* right_const = HConstant::cast(right);
|
||||
if (right_const->HasInteger32Value() &&
|
||||
|
@ -1845,6 +1845,7 @@ LInstruction* LChunkBuilder::DoSeqStringSetChar(HSeqStringSetChar* instr) {
|
||||
LOperand* string = UseRegister(instr->string());
|
||||
LOperand* index = UseRegister(instr->index());
|
||||
ASSERT(ecx.is_byte_register());
|
||||
// TODO(titzer): the machine code for this instruction overwrites ecx! fix!
|
||||
LOperand* value = UseFixed(instr->value(), ecx);
|
||||
LSeqStringSetChar* result =
|
||||
new(zone()) LSeqStringSetChar(instr->encoding(), string, index, value);
|
||||
|
@ -1699,7 +1699,7 @@ LInstruction* LChunkBuilder::DoDateField(HDateField* instr) {
|
||||
LInstruction* LChunkBuilder::DoSeqStringSetChar(HSeqStringSetChar* instr) {
|
||||
LOperand* string = UseRegister(instr->string());
|
||||
LOperand* index = UseRegister(instr->index());
|
||||
LOperand* value = UseRegister(instr->value());
|
||||
LOperand* value = UseTempRegister(instr->value());
|
||||
LSeqStringSetChar* result =
|
||||
new(zone()) LSeqStringSetChar(instr->encoding(), string, index, value);
|
||||
return DefineAsRegister(result);
|
||||
|
60
test/mjsunit/regress/regress-seqstrsetchar-ex1.js
Normal file
60
test/mjsunit/regress/regress-seqstrsetchar-ex1.js
Normal file
@ -0,0 +1,60 @@
|
||||
// Copyright 2013 the V8 project authors. All rights reserved.
|
||||
// Redistribution and use in source and binary forms, with or without
|
||||
// modification, are permitted provided that the following conditions are
|
||||
// met:
|
||||
//
|
||||
// * Redistributions of source code must retain the above copyright
|
||||
// notice, this list of conditions and the following disclaimer.
|
||||
// * Redistributions in binary form must reproduce the above
|
||||
// copyright notice, this list of conditions and the following
|
||||
// disclaimer in the documentation and/or other materials provided
|
||||
// with the distribution.
|
||||
// * Neither the name of Google Inc. nor the names of its
|
||||
// contributors may be used to endorse or promote products derived
|
||||
// from this software without specific prior written permission.
|
||||
//
|
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
// Flags: --allow-natives-syntax
|
||||
|
||||
// stubbed version of ToNumber
|
||||
function ToNumber(x) {
|
||||
return 311;
|
||||
}
|
||||
|
||||
// Reduced version of String.fromCharCode;
|
||||
// does not actually do the same calculation but exhibits untagging bug.
|
||||
function StringFromCharCode(code) {
|
||||
var n = %_ArgumentsLength();
|
||||
var one_byte = %NewString(n, true);
|
||||
var i;
|
||||
for (i = 0; i < n; i++) {
|
||||
var code = %_Arguments(i);
|
||||
if (!%_IsSmi(code)) code = ToNumber(code) & 0xffff;
|
||||
if (code > 0xff) break;
|
||||
}
|
||||
|
||||
var two_byte = %NewString(n - i, false);
|
||||
for (var j = 0; i < n; i++, j++) {
|
||||
var code = %_Arguments(i);
|
||||
%_TwoByteSeqStringSetChar(two_byte, j, code);
|
||||
}
|
||||
return one_byte + two_byte;
|
||||
}
|
||||
|
||||
StringFromCharCode(0xFFF, 0xFFF);
|
||||
StringFromCharCode(0x7C, 0x7C);
|
||||
%OptimizeFunctionOnNextCall(StringFromCharCode);
|
||||
StringFromCharCode(0x7C, 0x7C);
|
||||
StringFromCharCode(0xFFF, 0xFFF);
|
||||
|
35
test/mjsunit/regress/regress-seqstrsetchar-ex2.js
Normal file
35
test/mjsunit/regress/regress-seqstrsetchar-ex2.js
Normal file
@ -0,0 +1,35 @@
|
||||
// Copyright 2013 the V8 project authors. All rights reserved.
|
||||
// Redistribution and use in source and binary forms, with or without
|
||||
// modification, are permitted provided that the following conditions are
|
||||
// met:
|
||||
//
|
||||
// * Redistributions of source code must retain the above copyright
|
||||
// notice, this list of conditions and the following disclaimer.
|
||||
// * Redistributions in binary form must reproduce the above
|
||||
// copyright notice, this list of conditions and the following
|
||||
// disclaimer in the documentation and/or other materials provided
|
||||
// with the distribution.
|
||||
// * Neither the name of Google Inc. nor the names of its
|
||||
// contributors may be used to endorse or promote products derived
|
||||
// from this software without specific prior written permission.
|
||||
//
|
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
// Flags: --allow-natives-syntax
|
||||
|
||||
String.fromCharCode(0xFFF, 0xFFF);
|
||||
String.fromCharCode(0x7C, 0x7C);
|
||||
%OptimizeFunctionOnNextCall(String.fromCharCode);
|
||||
String.fromCharCode(0x7C, 0x7C);
|
||||
String.fromCharCode(0xFFF, 0xFFF);
|
||||
|
Loading…
Reference in New Issue
Block a user