Implementing rlwimi.
This commit is contained in:
parent
9c86c29140
commit
80d74dbe03
|
@ -1207,7 +1207,7 @@ XEEMITTER(rldicrx, 0x78000004, MD )(FunctionGenerator& g, IRBuilder<>& b, I
|
|||
XEDISASMR(rldimix, 0x7800000C, MD )(InstrData& i, InstrDisasm& d) {
|
||||
d.Init("rldimi", "Rotate Left Doubleword Immediate then Mask Insert",
|
||||
i.MD.Rc ? InstrDisasm::kRc : 0);
|
||||
d.AddRegOperand(InstrRegister::kGPR, i.MD.RA, InstrRegister::kWrite);
|
||||
d.AddRegOperand(InstrRegister::kGPR, i.MD.RA, InstrRegister::kReadWrite);
|
||||
d.AddRegOperand(InstrRegister::kGPR, i.MD.RT, InstrRegister::kRead);
|
||||
d.AddUImmOperand((i.MD.SH5 << 5) | i.MD.SH, 1);
|
||||
d.AddUImmOperand((i.MD.MB5 << 5) | i.MD.MB, 1);
|
||||
|
@ -1221,7 +1221,7 @@ XEEMITTER(rldimix, 0x7800000C, MD )(FunctionGenerator& g, IRBuilder<>& b, I
|
|||
XEDISASMR(rlwimix, 0x50000000, M )(InstrData& i, InstrDisasm& d) {
|
||||
d.Init("rlwimi", "Rotate Left Word Immediate then Mask Insert",
|
||||
i.M.Rc ? InstrDisasm::kRc : 0);
|
||||
d.AddRegOperand(InstrRegister::kGPR, i.M.RA, InstrRegister::kWrite);
|
||||
d.AddRegOperand(InstrRegister::kGPR, i.M.RA, InstrRegister::kReadWrite);
|
||||
d.AddRegOperand(InstrRegister::kGPR, i.M.RT, InstrRegister::kRead);
|
||||
d.AddUImmOperand(i.M.SH, 1);
|
||||
d.AddUImmOperand(i.M.MB, 1);
|
||||
|
@ -1233,8 +1233,23 @@ XEEMITTER(rlwimix, 0x50000000, M )(FunctionGenerator& g, IRBuilder<>& b, I
|
|||
// r <- ROTL32((RS)[32:63], n)
|
||||
// m <- MASK(MB+32, ME+32)
|
||||
// RA <- r&m | (RA)&¬m
|
||||
XEINSTRNOTIMPLEMENTED();
|
||||
return 1;
|
||||
|
||||
// ROTL32(x, y) = rotl(i64.(x||x), y)
|
||||
Value* v = b.CreateAnd(g.gpr_value(i.M.RT), UINT32_MAX);
|
||||
v = b.CreateOr(b.CreateShl(v, 32), v);
|
||||
// (v << shift) | (v >> (32 - shift));
|
||||
v = b.CreateOr(b.CreateShl(v, i.M.SH), b.CreateLShr(v, 32 - i.M.SH));
|
||||
uint64_t m = XEMASK(i.M.MB + 32, i.M.ME + 32);
|
||||
v = b.CreateAnd(v, m);
|
||||
v = b.CreateOr(v, b.CreateAnd(g.gpr_value(i.M.RA), ~m));
|
||||
g.update_gpr_value(i.M.RA, v);
|
||||
|
||||
if (i.M.Rc) {
|
||||
// With cr0 update.
|
||||
g.update_cr_with_cond(0, v, b.getInt64(0), true);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
XEDISASMR(rlwinmx, 0x54000000, M )(InstrData& i, InstrDisasm& d) {
|
||||
|
|
Binary file not shown.
|
@ -0,0 +1,9 @@
|
|||
|
||||
rlwimi.o: file format elf64-powerpc
|
||||
|
||||
|
||||
Disassembly of section .text:
|
||||
|
||||
0000000082010000 <.text>:
|
||||
82010000: 50 86 10 3a rlwimi r6,r4,2,0,29
|
||||
82010004: 4e 80 00 20 blr
|
|
@ -0,0 +1,8 @@
|
|||
# REGISTER_IN r4 0xCAFEBABE90003000
|
||||
# REGISTER_IN r6 0xDEADBEEF00000003
|
||||
|
||||
rlwimi r6, r4, 2, 0, 0x1D
|
||||
|
||||
blr
|
||||
# REGISTER_OUT r4 0xCAFEBABE90003000
|
||||
# REGISTER_OUT r6 0xDEADBEEF4000C003
|
Loading…
Reference in New Issue