MIPS: Add rotate-right instruction to hydrogen and use it instead of bitwise operations of the form ((x >>> i) | (x << (32 - i))).
Port r12855 (be965042) BUG= TEST= Review URL: https://chromiumcodereview.appspot.com/11293140 Patch from Akos Palfi <palfia@homejinni.com>. git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@12971 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
db4375e338
commit
5df210bd35
@ -1148,6 +1148,9 @@ void LCodeGen::DoShiftI(LShiftI* instr) {
|
|||||||
// No need to mask the right operand on MIPS, it is built into the variable
|
// No need to mask the right operand on MIPS, it is built into the variable
|
||||||
// shift instructions.
|
// shift instructions.
|
||||||
switch (instr->op()) {
|
switch (instr->op()) {
|
||||||
|
case Token::ROR:
|
||||||
|
__ Ror(result, left, Operand(ToRegister(right_op)));
|
||||||
|
break;
|
||||||
case Token::SAR:
|
case Token::SAR:
|
||||||
__ srav(result, left, ToRegister(right_op));
|
__ srav(result, left, ToRegister(right_op));
|
||||||
break;
|
break;
|
||||||
@ -1169,6 +1172,13 @@ void LCodeGen::DoShiftI(LShiftI* instr) {
|
|||||||
int value = ToInteger32(LConstantOperand::cast(right_op));
|
int value = ToInteger32(LConstantOperand::cast(right_op));
|
||||||
uint8_t shift_count = static_cast<uint8_t>(value & 0x1F);
|
uint8_t shift_count = static_cast<uint8_t>(value & 0x1F);
|
||||||
switch (instr->op()) {
|
switch (instr->op()) {
|
||||||
|
case Token::ROR:
|
||||||
|
if (shift_count != 0) {
|
||||||
|
__ Ror(result, left, Operand(shift_count));
|
||||||
|
} else {
|
||||||
|
__ Move(result, left);
|
||||||
|
}
|
||||||
|
break;
|
||||||
case Token::SAR:
|
case Token::SAR:
|
||||||
if (shift_count != 0) {
|
if (shift_count != 0) {
|
||||||
__ sra(result, left, shift_count);
|
__ sra(result, left, shift_count);
|
||||||
|
@ -177,6 +177,7 @@ const char* LArithmeticT::Mnemonic() const {
|
|||||||
case Token::BIT_AND: return "bit-and-t";
|
case Token::BIT_AND: return "bit-and-t";
|
||||||
case Token::BIT_OR: return "bit-or-t";
|
case Token::BIT_OR: return "bit-or-t";
|
||||||
case Token::BIT_XOR: return "bit-xor-t";
|
case Token::BIT_XOR: return "bit-xor-t";
|
||||||
|
case Token::ROR: return "ror-t";
|
||||||
case Token::SHL: return "sll-t";
|
case Token::SHL: return "sll-t";
|
||||||
case Token::SAR: return "sra-t";
|
case Token::SAR: return "sra-t";
|
||||||
case Token::SHR: return "srl-t";
|
case Token::SHR: return "srl-t";
|
||||||
|
Loading…
Reference in New Issue
Block a user