diff options
Diffstat (limited to 'llvm/test')
| -rw-r--r-- | llvm/test/CodeGen/MIR/X86/jump-table-info.mir | 104 | ||||
| -rw-r--r-- | llvm/test/CodeGen/MIR/X86/undefined-jump-table-id.mir | 80 |
2 files changed, 183 insertions, 1 deletions
diff --git a/llvm/test/CodeGen/MIR/X86/jump-table-info.mir b/llvm/test/CodeGen/MIR/X86/jump-table-info.mir index 0246f9f21d1..a52a87257b2 100644 --- a/llvm/test/CodeGen/MIR/X86/jump-table-info.mir +++ b/llvm/test/CodeGen/MIR/X86/jump-table-info.mir @@ -1,5 +1,6 @@ # RUN: llc -start-after branch-folder -stop-after branch-folder -o /dev/null %s | FileCheck %s -# This test ensures that the MIR parser parses the jump table info correctly. +# This test ensures that the MIR parser parses the jump table info and jump +# table operands correctly. --- | @@ -28,6 +29,31 @@ ret i32 8 } + define i32 @test_jumptable2(i32 %in) { + entry: + switch i32 %in, label %def [ + i32 0, label %lbl1 + i32 1, label %lbl2 + i32 2, label %lbl3 + i32 3, label %lbl4 + ] + + def: + ret i32 0 + + lbl1: + ret i32 1 + + lbl2: + ret i32 2 + + lbl3: + ret i32 4 + + lbl4: + ret i32 8 + } + ... --- name: test_jumptable @@ -46,17 +72,93 @@ body: - id: 0 name: entry successors: [ '%bb.2.def', '%bb.1.entry' ] + instructions: + - '%eax = MOV32rr %edi, implicit-def %rax' + - 'CMP32ri8 %edi, 3, implicit-def %eflags' + - 'JA_1 %bb.2.def, implicit %eflags' - id: 1 name: entry successors: [ '%bb.3.lbl1', '%bb.4.lbl2', '%bb.5.lbl3', '%bb.6.lbl4' ] + instructions: + # CHECK: %rcx = LEA64r %rip, 1, _, %jump-table.0, _ + - '%rcx = LEA64r %rip, 1, _, %jump-table.0, _' + - '%rax = MOVSX64rm32 %rcx, 4, %rax, 0, _' + - '%rax = ADD64rr %rax, %rcx, implicit-def %eflags' + - 'JMP64r %rax' - id: 2 name: def + instructions: + - '%eax = MOV32r0 implicit-def %eflags' + - 'RETQ %eax' - id: 3 name: lbl1 + instructions: + - '%eax = MOV32ri 1' + - 'RETQ %eax' - id: 4 name: lbl2 + instructions: + - '%eax = MOV32ri 2' + - 'RETQ %eax' - id: 5 name: lbl3 + instructions: + - '%eax = MOV32ri 4' + - 'RETQ %eax' - id: 6 name: lbl4 + instructions: + - '%eax = MOV32ri 8' + - 'RETQ %eax' +... +--- +name: test_jumptable2 +jumpTable: + kind: label-difference32 + entries: + - id: 1 + blocks: [ '%bb.3.lbl1', '%bb.4.lbl2', '%bb.5.lbl3', '%bb.6.lbl4' ] +body: + - id: 0 + name: entry + successors: [ '%bb.2.def', '%bb.1.entry' ] + instructions: + - '%eax = MOV32rr %edi, implicit-def %rax' + - 'CMP32ri8 %edi, 3, implicit-def %eflags' + - 'JA_1 %bb.2.def, implicit %eflags' + - id: 1 + name: entry + successors: [ '%bb.3.lbl1', '%bb.4.lbl2', '%bb.5.lbl3', '%bb.6.lbl4' ] + instructions: + # Verify that the printer will use an id of 0 for this jump table: + # CHECK: %rcx = LEA64r %rip, 1, _, %jump-table.0, _ + - '%rcx = LEA64r %rip, 1, _, %jump-table.1, _' + - '%rax = MOVSX64rm32 %rcx, 4, %rax, 0, _' + - '%rax = ADD64rr %rax, %rcx, implicit-def %eflags' + - 'JMP64r %rax' + - id: 2 + name: def + instructions: + - '%eax = MOV32r0 implicit-def %eflags' + - 'RETQ %eax' + - id: 3 + name: lbl1 + instructions: + - '%eax = MOV32ri 1' + - 'RETQ %eax' + - id: 4 + name: lbl2 + instructions: + - '%eax = MOV32ri 2' + - 'RETQ %eax' + - id: 5 + name: lbl3 + instructions: + - '%eax = MOV32ri 4' + - 'RETQ %eax' + - id: 6 + name: lbl4 + instructions: + - '%eax = MOV32ri 8' + - 'RETQ %eax' ... diff --git a/llvm/test/CodeGen/MIR/X86/undefined-jump-table-id.mir b/llvm/test/CodeGen/MIR/X86/undefined-jump-table-id.mir new file mode 100644 index 00000000000..f4bc41cd8f7 --- /dev/null +++ b/llvm/test/CodeGen/MIR/X86/undefined-jump-table-id.mir @@ -0,0 +1,80 @@ +# RUN: not llc -march=x86-64 -start-after branch-folder -stop-after branch-folder -o /dev/null %s 2>&1 | FileCheck %s + +--- | + + define i32 @test_jumptable(i32 %in) { + entry: + switch i32 %in, label %def [ + i32 0, label %lbl1 + i32 1, label %lbl2 + i32 2, label %lbl3 + i32 3, label %lbl4 + ] + + def: + ret i32 0 + + lbl1: + ret i32 1 + + lbl2: + ret i32 2 + + lbl3: + ret i32 4 + + lbl4: + ret i32 8 + } + +... +--- +name: test_jumptable +jumpTable: + kind: label-difference32 + entries: + - id: 0 + blocks: [ '%bb.3.lbl1', '%bb.4.lbl2', '%bb.5.lbl3', '%bb.6.lbl4' ] +body: + - id: 0 + name: entry + successors: [ '%bb.2.def', '%bb.1.entry' ] + instructions: + - '%eax = MOV32rr %edi, implicit-def %rax' + - 'CMP32ri8 %edi, 3, implicit-def %eflags' + - 'JA_1 %bb.2.def, implicit %eflags' + - id: 1 + name: entry + successors: [ '%bb.3.lbl1', '%bb.4.lbl2', '%bb.5.lbl3', '%bb.6.lbl4' ] + instructions: + # CHECK: [[@LINE+1]]:36: use of undefined jump table '%jump-table.2' + - '%rcx = LEA64r %rip, 1, _, %jump-table.2, _' + - '%rax = MOVSX64rm32 %rcx, 4, %rax, 0, _' + - '%rax = ADD64rr %rax, %rcx, implicit-def %eflags' + - 'JMP64r %rax' + - id: 2 + name: def + instructions: + - '%eax = MOV32r0 implicit-def %eflags' + - 'RETQ %eax' + - id: 3 + name: lbl1 + instructions: + - '%eax = MOV32ri 1' + - 'RETQ %eax' + - id: 4 + name: lbl2 + instructions: + - '%eax = MOV32ri 2' + - 'RETQ %eax' + - id: 5 + name: lbl3 + instructions: + - '%eax = MOV32ri 4' + - 'RETQ %eax' + - id: 6 + name: lbl4 + instructions: + - '%eax = MOV32ri 8' + - 'RETQ %eax' +... |

