mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-16 11:06:33 +00:00
[RISCV] Fix More RV32 Signed Immediates (#120658)
This commit is contained in:
parent
95c5386ddb
commit
c361fd5a7a
@ -530,7 +530,7 @@ public:
|
||||
if (!IsConstantImm)
|
||||
IsValid = RISCVAsmParser::classifySymbolRef(getImm(), VK);
|
||||
else
|
||||
IsValid = isShiftedInt<N - 1, 1>(Imm);
|
||||
IsValid = isShiftedInt<N - 1, 1>(fixImmediateForRV32(Imm, isRV64Imm()));
|
||||
return IsValid && VK == RISCVMCExpr::VK_RISCV_None;
|
||||
}
|
||||
|
||||
@ -943,7 +943,8 @@ public:
|
||||
RISCVMCExpr::VariantKind VK = RISCVMCExpr::VK_RISCV_None;
|
||||
int64_t Imm;
|
||||
bool IsConstantImm = evaluateConstantImm(getImm(), Imm, VK);
|
||||
return IsConstantImm && isShiftedInt<7, 5>(Imm) &&
|
||||
return IsConstantImm &&
|
||||
isShiftedInt<7, 5>(fixImmediateForRV32(Imm, isRV64Imm())) &&
|
||||
VK == RISCVMCExpr::VK_RISCV_None;
|
||||
}
|
||||
|
||||
@ -955,7 +956,8 @@ public:
|
||||
int64_t Imm;
|
||||
RISCVMCExpr::VariantKind VK = RISCVMCExpr::VK_RISCV_None;
|
||||
bool IsConstantImm = evaluateConstantImm(getImm(), Imm, VK);
|
||||
return IsConstantImm && (Imm != 0) && isShiftedInt<6, 4>(Imm) &&
|
||||
return IsConstantImm && (Imm != 0) &&
|
||||
isShiftedInt<6, 4>(fixImmediateForRV32(Imm, isRV64Imm())) &&
|
||||
VK == RISCVMCExpr::VK_RISCV_None;
|
||||
}
|
||||
|
||||
|
@ -26,3 +26,31 @@ c.jal 2046
|
||||
# CHECK-ASM: c.addi a1, -1
|
||||
# CHECK-ASM: encoding: [0xfd,0x15]
|
||||
c.addi a1, 0xffffffff
|
||||
|
||||
# CHECK-OBJ: c.addi16sp sp, -352
|
||||
# CHECK-ASM: c.addi16sp sp, -352
|
||||
# CHECK-ASM: encoding: [0x0d,0x71]
|
||||
c.addi16sp sp, 0xfffffea0
|
||||
|
||||
## Branch and Jump immediates are relative but printed as their absolute address
|
||||
## when disassembling.
|
||||
|
||||
# CHECK-OBJ: c.beqz a2, 0xffffff06
|
||||
# CHECK-ASM: c.beqz a2, -256
|
||||
# CHECK-ASM: encoding: [0x01,0xd2]
|
||||
c.beqz a2, 0xffffff00
|
||||
|
||||
# CHECK-OBJ: c.beqz a0, 0xffffff16
|
||||
# CHECK-ASM: .insn cb 1, 6, a0, -242
|
||||
# CHECK-ASM: encoding: [0x19,0xd5]
|
||||
.insn cb 1, 6, a0, 0xffffff0e
|
||||
|
||||
# CHECK-OBJ: c.jal 0xfffffab4
|
||||
# CHECK-ASM: c.jal -1366
|
||||
# CHECK-ASM: encoding: [0x6d,0x34]
|
||||
c.jal 0xfffffaaa
|
||||
|
||||
# CHECK-OBJ: c.j 0xfffffcd8
|
||||
# CHECK-ASM: .insn cj 1, 5, -820
|
||||
# CHECK-ASM: encoding: [0xf1,0xb1]
|
||||
.insn cj 1, 5, 0xfffffccc
|
||||
|
@ -2,7 +2,7 @@
|
||||
# RUN: | FileCheck -check-prefixes=CHECK-ASM,CHECK-ASM-AND-OBJ %s
|
||||
# RUN: llvm-mc -filetype=obj -triple=riscv32 < %s \
|
||||
# RUN: | llvm-objdump -M no-aliases --no-print-imm-hex -d -r - \
|
||||
# RUN: | FileCheck -check-prefixes=CHECK-ASM-AND-OBJ %s
|
||||
# RUN: | FileCheck -check-prefixes=CHECK-OBJ,CHECK-ASM-AND-OBJ %s
|
||||
|
||||
# CHECK-ASM-AND-OBJ: addi a0, a1, -1
|
||||
# CHECK-ASM: encoding: [0x13,0x85,0xf5,0xff]
|
||||
@ -16,3 +16,46 @@ lw a1, 0xfffff9ab(a2)
|
||||
# CHECK-ASM-AND-OBJ: sw a1, -8(a2)
|
||||
# CHECK-ASM: encoding: [0x23,0x2c,0xb6,0xfe]
|
||||
sw a1, 0xfffffff8(a2)
|
||||
|
||||
## Branch and Jump immediates are relative but printed as their absolute address
|
||||
## when disassembling.
|
||||
|
||||
# CHECK-ASM: beq t0, t1, -4096
|
||||
# CHECK-ASM: encoding: [0x63,0x80,0x62,0x80]
|
||||
# CHECK-OBJ: beq t0, t1, 0xfffff010
|
||||
beq t0, t1, 0xfffff000
|
||||
|
||||
# CHECK-ASM: bne t1, t2, -4082
|
||||
# CHECK-ASM: encoding: [0x63,0x17,0x73,0x80]
|
||||
# CHECK-OBJ: bne t1, t2, 0xfffff022
|
||||
bne t1, t2, 0xfffff00e
|
||||
|
||||
# CHECK-ASM: beq t2, zero, -3550
|
||||
# CHECK-ASM: encoding: [0x63,0x81,0x03,0xa2]
|
||||
# CHECK-OBJ: beq t2, zero, 0xfffff23a
|
||||
beqz t2, 0xfffff222
|
||||
|
||||
# CHECK-ASM: .insn b 99, 0, a0, a1, -3004
|
||||
# CHECK-ASM: encoding: [0x63,0x02,0xb5,0xc4]
|
||||
# CHECK-OBJ: beq a0, a1, 0xfffff460
|
||||
.insn b BRANCH, 0, a0, a1, 0xfffff444
|
||||
|
||||
# CHECK-ASM: jal ra, -2458
|
||||
# CHECK-ASM: encoding: [0xef,0xf0,0x6f,0xe6]
|
||||
# CHECK-OBJ: jal ra, 0xfffff686
|
||||
jal ra, 0xfffff666
|
||||
|
||||
# CHECK-ASM: jal ra, -1912
|
||||
# CHECK-ASM: encoding: [0xef,0xf0,0x9f,0x88]
|
||||
# CHECK-OBJ: jal ra, 0xfffff8ac
|
||||
jal 0xfffff888
|
||||
|
||||
# CHECK-ASM: jal zero, -1366
|
||||
# CHECK-ASM: encoding: [0x6f,0xf0,0xbf,0xaa]
|
||||
# CHECK-OBJ: jal zero, 0xfffffad2
|
||||
j 0xfffffaaa
|
||||
|
||||
# CHECK-ASM: .insn j 111, a0, -820
|
||||
# CHECK-ASM: encoding: [0x6f,0x65,0xe6,0xff]
|
||||
# CHECK-OBJ: jal a0, 0xfff6682a
|
||||
.insn j JAL, a0, 0xfffffccc
|
||||
|
18
llvm/test/MC/RISCV/rv32zcibop-valid-rv32.s
Normal file
18
llvm/test/MC/RISCV/rv32zcibop-valid-rv32.s
Normal file
@ -0,0 +1,18 @@
|
||||
# RUN: llvm-mc %s -triple=riscv32 -mattr=+zicbop -show-encoding \
|
||||
# RUN: | FileCheck -check-prefixes=CHECK-ASM,CHECK-ASM-AND-OBJ %s
|
||||
# RUN: llvm-mc -filetype=obj -triple=riscv32 -mattr=+zicbop < %s \
|
||||
# RUN: | llvm-objdump --no-print-imm-hex --mattr=+zicbop -d -r - \
|
||||
# RUN: | FileCheck --check-prefix=CHECK-ASM-AND-OBJ %s
|
||||
|
||||
## This test checks that 32-bit hex immediates are accepted for the `prefetch.*`
|
||||
## instructions on rv32.
|
||||
|
||||
# CHECK-ASM-AND-OBJ: prefetch.i -2048(t0)
|
||||
# CHECK-ASM: encoding: [0x13,0xe0,0x02,0x80]
|
||||
prefetch.i 0xfffff800(t0)
|
||||
# CHECK-ASM-AND-OBJ: prefetch.r -2048(t1)
|
||||
# CHECK-ASM: encoding: [0x13,0x60,0x13,0x80]
|
||||
prefetch.r 0xfffff800(t1)
|
||||
# CHECK-ASM-AND-OBJ: prefetch.w -2048(t2)
|
||||
# CHECK-ASM: encoding: [0x13,0xe0,0x33,0x80]
|
||||
prefetch.w 0xfffff800(t2)
|
Loading…
x
Reference in New Issue
Block a user