# 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: 16 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 JCC_1 %bb.2, 4, 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 ...