53 lines
1.5 KiB
LLVM
53 lines
1.5 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
|
|
; RUN: llc -mtriple=m68k < %s | FileCheck %s
|
|
|
|
define void @sext_inreg_i1_to_i8(i1 %val, ptr %ptr) {
|
|
; CHECK-LABEL: sext_inreg_i1_to_i8:
|
|
; CHECK: .cfi_startproc
|
|
; CHECK-NEXT: ; %bb.0: ; %entry
|
|
; CHECK-NEXT: move.b (7,%sp), %d0
|
|
; CHECK-NEXT: and.b #1, %d0
|
|
; CHECK-NEXT: neg.b %d0
|
|
; CHECK-NEXT: move.l (8,%sp), %a0
|
|
; CHECK-NEXT: move.b %d0, (%a0)
|
|
; CHECK-NEXT: rts
|
|
entry:
|
|
%cond = select i1 %val, i8 -1, i8 0
|
|
store i8 %cond, ptr %ptr
|
|
ret void
|
|
}
|
|
|
|
define void @sext_inreg_i1_to_i16(i1 %val, ptr %ptr) {
|
|
; CHECK-LABEL: sext_inreg_i1_to_i16:
|
|
; CHECK: .cfi_startproc
|
|
; CHECK-NEXT: ; %bb.0: ; %entry
|
|
; CHECK-NEXT: move.b (7,%sp), %d0
|
|
; CHECK-NEXT: and.l #255, %d0
|
|
; CHECK-NEXT: and.w #1, %d0
|
|
; CHECK-NEXT: neg.w %d0
|
|
; CHECK-NEXT: move.l (8,%sp), %a0
|
|
; CHECK-NEXT: move.w %d0, (%a0)
|
|
; CHECK-NEXT: rts
|
|
entry:
|
|
%cond = select i1 %val, i16 -1, i16 0
|
|
store i16 %cond, ptr %ptr
|
|
ret void
|
|
}
|
|
|
|
define void @sext_inreg_i1_to_i32(i1 %val, ptr %ptr) {
|
|
; CHECK-LABEL: sext_inreg_i1_to_i32:
|
|
; CHECK: .cfi_startproc
|
|
; CHECK-NEXT: ; %bb.0: ; %entry
|
|
; CHECK-NEXT: move.b (7,%sp), %d0
|
|
; CHECK-NEXT: and.l #255, %d0
|
|
; CHECK-NEXT: and.l #1, %d0
|
|
; CHECK-NEXT: neg.l %d0
|
|
; CHECK-NEXT: move.l (8,%sp), %a0
|
|
; CHECK-NEXT: move.l %d0, (%a0)
|
|
; CHECK-NEXT: rts
|
|
entry:
|
|
%cond = select i1 %val, i32 -1, i32 0
|
|
store i32 %cond, ptr %ptr
|
|
ret void
|
|
}
|
|
|