blob: 69b801fddbf3b33f3c485bf87014ab7870ad04ba [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc -mtriple=riscv32 -mattr=+zcmp -verify-machineinstrs < %s \
; RUN: | FileCheck %s --check-prefix=ZCMP
; RUN: llc -mtriple=riscv32 -mattr=+zcmp,+zilsd -verify-machineinstrs < %s \
; RUN: | FileCheck %s --check-prefix=ZCMP-ZILSD
; RUN: llc -mtriple=riscv32 -mattr=+xqccmp -verify-machineinstrs < %s \
; RUN: | FileCheck %s --check-prefix=XQCCMP
; RUN: llc -mtriple=riscv32 -mattr=+xqccmp,+zilsd -verify-machineinstrs < %s \
; RUN: | FileCheck %s --check-prefix=XQCCMP-ZILSD
declare i32 @foo()
declare void @bar()
define void @c_expand_asm_operands(ptr %p, i32 %a) optsize nounwind{
; ZCMP-LABEL: c_expand_asm_operands:
; ZCMP: # %bb.0: # %entry
; ZCMP-NEXT: cm.push {ra, s0-s2}, -16
; ZCMP-NEXT: addi s0, sp, 16
; ZCMP-NEXT: cm.mvsa01 s2, s1
; ZCMP-NEXT: call foo
; ZCMP-NEXT: addi s1, s1, 15
; ZCMP-NEXT: andi s1, s1, -16
; ZCMP-NEXT: sub a0, sp, s1
; ZCMP-NEXT: mv sp, a0
; ZCMP-NEXT: sw a0, 0(s2)
; ZCMP-NEXT: addi sp, s0, -16
; ZCMP-NEXT: cm.pop {ra, s0-s2}, 16
; ZCMP-NEXT: tail bar
;
; ZCMP-ZILSD-LABEL: c_expand_asm_operands:
; ZCMP-ZILSD: # %bb.0: # %entry
; ZCMP-ZILSD-NEXT: cm.push {ra, s0-s2}, -16
; ZCMP-ZILSD-NEXT: addi s0, sp, 16
; ZCMP-ZILSD-NEXT: cm.mvsa01 s2, s1
; ZCMP-ZILSD-NEXT: call foo
; ZCMP-ZILSD-NEXT: addi s1, s1, 15
; ZCMP-ZILSD-NEXT: andi s1, s1, -16
; ZCMP-ZILSD-NEXT: sub a0, sp, s1
; ZCMP-ZILSD-NEXT: mv sp, a0
; ZCMP-ZILSD-NEXT: sw a0, 0(s2)
; ZCMP-ZILSD-NEXT: addi sp, s0, -16
; ZCMP-ZILSD-NEXT: cm.pop {ra, s0-s2}, 16
; ZCMP-ZILSD-NEXT: tail bar
;
; XQCCMP-LABEL: c_expand_asm_operands:
; XQCCMP: # %bb.0: # %entry
; XQCCMP-NEXT: qc.cm.pushfp {ra, s0-s2}, -16
; XQCCMP-NEXT: qc.cm.mvsa01 s2, s1
; XQCCMP-NEXT: call foo
; XQCCMP-NEXT: addi s1, s1, 15
; XQCCMP-NEXT: andi s1, s1, -16
; XQCCMP-NEXT: sub a0, sp, s1
; XQCCMP-NEXT: mv sp, a0
; XQCCMP-NEXT: sw a0, 0(s2)
; XQCCMP-NEXT: addi sp, s0, -16
; XQCCMP-NEXT: qc.cm.pop {ra, s0-s2}, 16
; XQCCMP-NEXT: tail bar
;
; XQCCMP-ZILSD-LABEL: c_expand_asm_operands:
; XQCCMP-ZILSD: # %bb.0: # %entry
; XQCCMP-ZILSD-NEXT: qc.cm.pushfp {ra, s0-s2}, -16
; XQCCMP-ZILSD-NEXT: qc.cm.mvsa01 s2, s1
; XQCCMP-ZILSD-NEXT: call foo
; XQCCMP-ZILSD-NEXT: addi s1, s1, 15
; XQCCMP-ZILSD-NEXT: andi s1, s1, -16
; XQCCMP-ZILSD-NEXT: sub a0, sp, s1
; XQCCMP-ZILSD-NEXT: mv sp, a0
; XQCCMP-ZILSD-NEXT: sw a0, 0(s2)
; XQCCMP-ZILSD-NEXT: addi sp, s0, -16
; XQCCMP-ZILSD-NEXT: qc.cm.pop {ra, s0-s2}, 16
; XQCCMP-ZILSD-NEXT: tail bar
entry:
%call1 = call i32 @foo()
%0 = alloca i8, i32 %a, align 8
store ptr %0, ptr %p, align 8
tail call void @bar()
ret void
}