mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-11 16:37:42 +00:00
[Mips Assembler] Add support for OR macro with imediate opperand
Mips assembler supports macros that allows the OR instruction to have an immediate parameter. This patch adds an instruction alias that converts this macro into a Mips ORI instruction. Contributer: Vladimir Medic git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@178316 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c26392aa5d
commit
af7da5cb99
@ -342,7 +342,9 @@ def : InstAlias<"daddu $rs, $rt, $imm",
|
||||
def : InstAlias<"dadd $rs, $rt, $imm",
|
||||
(DADDi CPU64RegsOpnd:$rs, CPU64RegsOpnd:$rt, simm16_64:$imm),
|
||||
1>;
|
||||
|
||||
def : InstAlias<"or $rs, $rt, $imm",
|
||||
(ORi64 CPU64RegsOpnd:$rs, CPU64RegsOpnd:$rt, uimm16_64:$imm),
|
||||
1>, Requires<[HasMips64]>;
|
||||
/// Move between CPU and coprocessor registers
|
||||
|
||||
let DecoderNamespace = "Mips64" in {
|
||||
|
@ -1015,6 +1015,9 @@ def : InstAlias<"slt $rs, $rt, $imm",
|
||||
def : InstAlias<"xor $rs, $rt, $imm",
|
||||
(XORi CPURegsOpnd:$rs, CPURegsOpnd:$rt, simm16:$imm), 0>,
|
||||
Requires<[NotMips64]>;
|
||||
def : InstAlias<"or $rs, $rt, $imm",
|
||||
(ORi CPURegsOpnd:$rs, CPURegsOpnd:$rt, simm16:$imm), 0>,
|
||||
Requires<[NotMips64]>;
|
||||
def : InstAlias<"nop", (SLL ZERO, ZERO, 0), 1>;
|
||||
def : InstAlias<"mfc0 $rt, $rd",
|
||||
(MFC0_3OP CPURegsOpnd:$rt, CPURegsOpnd:$rd, 0), 0>;
|
||||
|
@ -13,6 +13,7 @@
|
||||
# CHECK: ins $19, $9, 6, 7 # encoding: [0x84,0x61,0x33,0x7d]
|
||||
# CHECK: nor $9, $6, $7 # encoding: [0x27,0x48,0xc7,0x00]
|
||||
# CHECK: or $3, $3, $5 # encoding: [0x25,0x18,0x65,0x00]
|
||||
# CHECK: ori $4, $5, 17767 # encoding: [0x67,0x45,0xa4,0x34]
|
||||
# CHECK: ori $9, $6, 17767 # encoding: [0x67,0x45,0xc9,0x34]
|
||||
# CHECK: rotr $9, $6, 7 # encoding: [0xc2,0x49,0x26,0x00]
|
||||
# CHECK: rotrv $9, $6, $7 # encoding: [0x46,0x48,0xe6,0x00]
|
||||
@ -40,6 +41,7 @@
|
||||
ins $19, $9, 6,7
|
||||
nor $9, $6, $7
|
||||
or $3, $3, $5
|
||||
or $4, $5, 17767
|
||||
ori $9, $6, 17767
|
||||
rotr $9, $6, 7
|
||||
rotrv $9, $6, $7
|
||||
|
Loading…
x
Reference in New Issue
Block a user