diff options
Diffstat (limited to 'llvm/test/MC/RISCV')
-rw-r--r-- | llvm/test/MC/RISCV/rv32i-aliases-invalid.s | 2 | ||||
-rw-r--r-- | llvm/test/MC/RISCV/rv32i-valid.s | 3 | ||||
-rw-r--r-- | llvm/test/MC/RISCV/rvi-aliases-valid.s | 7 |
3 files changed, 12 insertions, 0 deletions
diff --git a/llvm/test/MC/RISCV/rv32i-aliases-invalid.s b/llvm/test/MC/RISCV/rv32i-aliases-invalid.s index b50a8e4033e..4080d892a67 100644 --- a/llvm/test/MC/RISCV/rv32i-aliases-invalid.s +++ b/llvm/test/MC/RISCV/rv32i-aliases-invalid.s @@ -19,5 +19,7 @@ sll x2, x3, -1 # CHECK: :[[@LINE]]:13: error: immediate must be an integer in t srl x2, x3, -2 # CHECK: :[[@LINE]]:13: error: immediate must be an integer in the range [0, 31] sra x2, x3, -3 # CHECK: :[[@LINE]]:13: error: immediate must be an integer in the range [0, 31] +addi x1, . # CHECK: :[[@LINE]]:10: error: invalid operand for instruction + foo: .space 4 diff --git a/llvm/test/MC/RISCV/rv32i-valid.s b/llvm/test/MC/RISCV/rv32i-valid.s index 9571659b79b..3611d71ac43 100644 --- a/llvm/test/MC/RISCV/rv32i-valid.s +++ b/llvm/test/MC/RISCV/rv32i-valid.s @@ -90,6 +90,9 @@ jal s0, (0) # CHECK-ASM-AND-OBJ: jal s0, 156 # CHECK-ASM: encoding: [0x6f,0x04,0xc0,0x09] jal s0, (0xff-99) +# CHECK-ASM: encoding: [0x6f,0bAAAA0000,A,A] +# CHECK-OBJ: jal zero, 0 +jal zero, . # CHECK-ASM-AND-OBJ: jalr a0, a1, -2048 # CHECK-ASM: encoding: [0x67,0x85,0x05,0x80] diff --git a/llvm/test/MC/RISCV/rvi-aliases-valid.s b/llvm/test/MC/RISCV/rvi-aliases-valid.s index a4aef05f8be..a3050aa46f6 100644 --- a/llvm/test/MC/RISCV/rvi-aliases-valid.s +++ b/llvm/test/MC/RISCV/rvi-aliases-valid.s @@ -117,6 +117,13 @@ j foo # CHECK-OBJ: j 0 # CHECK-OBJ: R_RISCV_JAL a0 j a0 +# CHECK-S-NOALIAS: [[LABEL:.L[[:alnum:]_]+]]: +# CHECK-S-NOALIAS-NEXT: jal zero, [[LABEL]] +# CHECK-S: [[LABEL:.L[[:alnum:]_]+]]: +# CHECK-S-NEXT: j [[LABEL]] +# CHECK-OBJ-NOALIAS: jal zero, 0 +# CHECK-OBJ: j 0 +j . # CHECK-S-OBJ-NOALIAS: jal ra, 2040 # CHECK-S-OBJ: jal 2040 jal 2040 |