Finish refactoring done for ia32 for the other platforms.

Make non-templatized versions of LIR printing functions.

This avoid duplicating the code for each template instance.

BUG=v8:1803
Review URL: https://chromiumcodereview.appspot.com/10123011

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@11394 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent d27ba7df
...@@ -108,22 +108,17 @@ void LInstruction::PrintTo(StringStream* stream) { ...@@ -108,22 +108,17 @@ void LInstruction::PrintTo(StringStream* stream) {
} }
template<int R, int I, int T> void LInstruction::PrintDataTo(StringStream* stream) {
void LTemplateInstruction<R, I, T>::PrintDataTo(StringStream* stream) {
stream->Add("= "); stream->Add("= ");
for (int i = 0; i < inputs_.length(); i++) { for (int i = 0; i < InputCount(); i++) {
if (i > 0) stream->Add(" "); if (i > 0) stream->Add(" ");
inputs_[i]->PrintTo(stream); InputAt(i)->PrintTo(stream);
} }
} }
template<int R, int I, int T> void LInstruction::PrintOutputOperandTo(StringStream* stream) {
void LTemplateInstruction<R, I, T>::PrintOutputOperandTo(StringStream* stream) { if (HasResult()) result()->PrintTo(stream);
for (int i = 0; i < results_.length(); i++) {
if (i > 0) stream->Add(" ");
results_[i]->PrintTo(stream);
}
} }
......
...@@ -211,8 +211,8 @@ class LInstruction: public ZoneObject { ...@@ -211,8 +211,8 @@ class LInstruction: public ZoneObject {
virtual void CompileToNative(LCodeGen* generator) = 0; virtual void CompileToNative(LCodeGen* generator) = 0;
virtual const char* Mnemonic() const = 0; virtual const char* Mnemonic() const = 0;
virtual void PrintTo(StringStream* stream); virtual void PrintTo(StringStream* stream);
virtual void PrintDataTo(StringStream* stream) = 0; virtual void PrintDataTo(StringStream* stream);
virtual void PrintOutputOperandTo(StringStream* stream) = 0; virtual void PrintOutputOperandTo(StringStream* stream);
enum Opcode { enum Opcode {
// Declare a unique enum value for each instruction. // Declare a unique enum value for each instruction.
...@@ -307,9 +307,6 @@ class LTemplateInstruction: public LInstruction { ...@@ -307,9 +307,6 @@ class LTemplateInstruction: public LInstruction {
int TempCount() { return T; } int TempCount() { return T; }
LOperand* TempAt(int i) { return temps_[i]; } LOperand* TempAt(int i) { return temps_[i]; }
virtual void PrintDataTo(StringStream* stream);
virtual void PrintOutputOperandTo(StringStream* stream);
protected: protected:
EmbeddedContainer<LOperand*, R> results_; EmbeddedContainer<LOperand*, R> results_;
EmbeddedContainer<LOperand*, I> inputs_; EmbeddedContainer<LOperand*, I> inputs_;
......
...@@ -108,22 +108,17 @@ void LInstruction::PrintTo(StringStream* stream) { ...@@ -108,22 +108,17 @@ void LInstruction::PrintTo(StringStream* stream) {
} }
template<int R, int I, int T> void LInstruction::PrintDataTo(StringStream* stream) {
void LTemplateInstruction<R, I, T>::PrintDataTo(StringStream* stream) {
stream->Add("= "); stream->Add("= ");
for (int i = 0; i < inputs_.length(); i++) { for (int i = 0; i < InputCount(); i++) {
if (i > 0) stream->Add(" "); if (i > 0) stream->Add(" ");
inputs_[i]->PrintTo(stream); InputAt(i)->PrintTo(stream);
} }
} }
template<int R, int I, int T> void LInstruction::PrintOutputOperandTo(StringStream* stream) {
void LTemplateInstruction<R, I, T>::PrintOutputOperandTo(StringStream* stream) { if (HasResult()) result()->PrintTo(stream);
for (int i = 0; i < results_.length(); i++) {
if (i > 0) stream->Add(" ");
results_[i]->PrintTo(stream);
}
} }
......
...@@ -210,8 +210,8 @@ class LInstruction: public ZoneObject { ...@@ -210,8 +210,8 @@ class LInstruction: public ZoneObject {
virtual void CompileToNative(LCodeGen* generator) = 0; virtual void CompileToNative(LCodeGen* generator) = 0;
virtual const char* Mnemonic() const = 0; virtual const char* Mnemonic() const = 0;
virtual void PrintTo(StringStream* stream); virtual void PrintTo(StringStream* stream);
virtual void PrintDataTo(StringStream* stream) = 0; virtual void PrintDataTo(StringStream* stream);
virtual void PrintOutputOperandTo(StringStream* stream) = 0; virtual void PrintOutputOperandTo(StringStream* stream);
enum Opcode { enum Opcode {
// Declare a unique enum value for each instruction. // Declare a unique enum value for each instruction.
...@@ -306,9 +306,6 @@ class LTemplateInstruction: public LInstruction { ...@@ -306,9 +306,6 @@ class LTemplateInstruction: public LInstruction {
int TempCount() { return T; } int TempCount() { return T; }
LOperand* TempAt(int i) { return temps_[i]; } LOperand* TempAt(int i) { return temps_[i]; }
virtual void PrintDataTo(StringStream* stream);
virtual void PrintOutputOperandTo(StringStream* stream);
protected: protected:
EmbeddedContainer<LOperand*, R> results_; EmbeddedContainer<LOperand*, R> results_;
EmbeddedContainer<LOperand*, I> inputs_; EmbeddedContainer<LOperand*, I> inputs_;
......
...@@ -110,22 +110,17 @@ void LInstruction::PrintTo(StringStream* stream) { ...@@ -110,22 +110,17 @@ void LInstruction::PrintTo(StringStream* stream) {
} }
template<int R, int I, int T> void LInstruction::PrintDataTo(StringStream* stream) {
void LTemplateInstruction<R, I, T>::PrintDataTo(StringStream* stream) {
stream->Add("= "); stream->Add("= ");
for (int i = 0; i < inputs_.length(); i++) { for (int i = 0; i < InputCount(); i++) {
if (i > 0) stream->Add(" "); if (i > 0) stream->Add(" ");
inputs_[i]->PrintTo(stream); InputAt(i)->PrintTo(stream);
} }
} }
template<int R, int I, int T> void LInstruction::PrintOutputOperandTo(StringStream* stream) {
void LTemplateInstruction<R, I, T>::PrintOutputOperandTo(StringStream* stream) { if (HasResult()) result()->PrintTo(stream);
for (int i = 0; i < results_.length(); i++) {
if (i > 0) stream->Add(" ");
results_[i]->PrintTo(stream);
}
} }
......
...@@ -212,8 +212,8 @@ class LInstruction: public ZoneObject { ...@@ -212,8 +212,8 @@ class LInstruction: public ZoneObject {
virtual void CompileToNative(LCodeGen* generator) = 0; virtual void CompileToNative(LCodeGen* generator) = 0;
virtual const char* Mnemonic() const = 0; virtual const char* Mnemonic() const = 0;
virtual void PrintTo(StringStream* stream); virtual void PrintTo(StringStream* stream);
virtual void PrintDataTo(StringStream* stream) = 0; virtual void PrintDataTo(StringStream* stream);
virtual void PrintOutputOperandTo(StringStream* stream) = 0; virtual void PrintOutputOperandTo(StringStream* stream);
enum Opcode { enum Opcode {
// Declare a unique enum value for each instruction. // Declare a unique enum value for each instruction.
...@@ -308,9 +308,6 @@ class LTemplateInstruction: public LInstruction { ...@@ -308,9 +308,6 @@ class LTemplateInstruction: public LInstruction {
int TempCount() { return T; } int TempCount() { return T; }
LOperand* TempAt(int i) { return temps_[i]; } LOperand* TempAt(int i) { return temps_[i]; }
virtual void PrintDataTo(StringStream* stream);
virtual void PrintOutputOperandTo(StringStream* stream);
protected: protected:
EmbeddedContainer<LOperand*, R> results_; EmbeddedContainer<LOperand*, R> results_;
EmbeddedContainer<LOperand*, I> inputs_; EmbeddedContainer<LOperand*, I> inputs_;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment