| # RUN: llc -mtriple=x86_64 -run-pass=implicit-null-checks %s -o - | FileCheck %s |
| --- | |
| |
| define i32 @reg-rewrite(i32* %x) { |
| entry: |
| br i1 undef, label %is_null, label %not_null, !make.implicit !0 |
| |
| is_null: |
| ret i32 42 |
| |
| not_null: |
| ret i32 100 |
| } |
| |
| !0 = !{} |
| |
| ... |
| --- |
| # Check that the TEST instruction is replaced with |
| # FAULTING_OP only if there are no instructions |
| # between the TEST and conditional jump |
| # that clobber the register used in TEST. |
| name: reg-rewrite |
| |
| alignment: 4 |
| tracksRegLiveness: true |
| liveins: |
| - { reg: '$rdi' } |
| |
| body: | |
| bb.0.entry: |
| liveins: $rdi |
| |
| TEST64rr $rdi, $rdi, implicit-def $eflags |
| ; CHECK-LABEL: bb.0.entry |
| ; CHECK-NOT: FAULTING_OP |
| renamable $rdi = MOV64ri 5000 |
| JE_1 %bb.2, implicit $eflags |
| |
| bb.1.not_null: |
| liveins: $rdi, $rsi |
| |
| $rax = MOV64rm renamable $rdi, 1, $noreg, 4, $noreg |
| RETQ $eax |
| |
| bb.2.is_null: |
| $eax = MOV32ri 200 |
| RETQ $eax |
| ... |