345 lines
		
	
	
		
			9.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			345 lines
		
	
	
		
			9.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
 | 
						|
; RUN: llc -mtriple=riscv32 -verify-machineinstrs < %s \
 | 
						|
; RUN:   | FileCheck -check-prefix=RV32I %s
 | 
						|
 | 
						|
define zeroext i8 @uint8_arg_to_uint8_ret(i8 zeroext %a) nounwind {
 | 
						|
; RV32I-LABEL: uint8_arg_to_uint8_ret:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  ret i8 %a
 | 
						|
}
 | 
						|
 | 
						|
declare void @receive_uint8(i8 zeroext)
 | 
						|
 | 
						|
define void @pass_uint8_as_uint8(i8 zeroext %a) nounwind {
 | 
						|
; RV32I-LABEL: pass_uint8_as_uint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call receive_uint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  call void @receive_uint8(i8 zeroext %a)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
declare zeroext i8 @return_uint8()
 | 
						|
 | 
						|
define zeroext i8 @ret_callresult_uint8_as_uint8() nounwind {
 | 
						|
; RV32I-LABEL: ret_callresult_uint8_as_uint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call return_uint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = call zeroext i8 @return_uint8()
 | 
						|
  ret i8 %1
 | 
						|
}
 | 
						|
 | 
						|
define signext i8 @uint8_arg_to_sint8_ret(i8 zeroext %a) nounwind {
 | 
						|
; RV32I-LABEL: uint8_arg_to_sint8_ret:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    slli a0, a0, 24
 | 
						|
; RV32I-NEXT:    srai a0, a0, 24
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  ret i8 %a
 | 
						|
}
 | 
						|
 | 
						|
declare void @receive_sint8(i8 signext)
 | 
						|
 | 
						|
define void @pass_uint8_as_sint8(i8 zeroext %a) nounwind {
 | 
						|
; RV32I-LABEL: pass_uint8_as_sint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    slli a0, a0, 24
 | 
						|
; RV32I-NEXT:    srai a0, a0, 24
 | 
						|
; RV32I-NEXT:    call receive_sint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
 | 
						|
  call void @receive_sint8(i8 signext %a)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
define signext i8 @ret_callresult_uint8_as_sint8() nounwind {
 | 
						|
; RV32I-LABEL: ret_callresult_uint8_as_sint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call return_uint8
 | 
						|
; RV32I-NEXT:    slli a0, a0, 24
 | 
						|
; RV32I-NEXT:    srai a0, a0, 24
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = call zeroext i8 @return_uint8()
 | 
						|
  ret i8 %1
 | 
						|
}
 | 
						|
 | 
						|
define signext i32 @uint8_arg_to_anyint32_ret(i8 zeroext %a) nounwind {
 | 
						|
; RV32I-LABEL: uint8_arg_to_anyint32_ret:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = zext i8 %a to i32
 | 
						|
  ret i32 %1
 | 
						|
}
 | 
						|
 | 
						|
declare void @receive_anyint32(i32 signext)
 | 
						|
 | 
						|
define void @pass_uint8_as_anyint32(i8 zeroext %a) nounwind {
 | 
						|
; RV32I-LABEL: pass_uint8_as_anyint32:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call receive_anyint32
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = zext i8 %a to i32
 | 
						|
  call void @receive_anyint32(i32 signext %1)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
define signext i32 @ret_callresult_uint8_as_anyint32() nounwind {
 | 
						|
; RV32I-LABEL: ret_callresult_uint8_as_anyint32:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call return_uint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = call zeroext i8 @return_uint8()
 | 
						|
  %2 = zext i8 %1 to i32
 | 
						|
  ret i32 %2
 | 
						|
}
 | 
						|
 | 
						|
define zeroext i8 @sint8_arg_to_uint8_ret(i8 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: sint8_arg_to_uint8_ret:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    andi a0, a0, 255
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  ret i8 %a
 | 
						|
}
 | 
						|
 | 
						|
define void @pass_sint8_as_uint8(i8 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: pass_sint8_as_uint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    andi a0, a0, 255
 | 
						|
; RV32I-NEXT:    call receive_uint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  call void @receive_uint8(i8 zeroext %a)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
declare signext i8 @return_sint8()
 | 
						|
 | 
						|
define zeroext i8 @ret_callresult_sint8_as_uint8() nounwind {
 | 
						|
; RV32I-LABEL: ret_callresult_sint8_as_uint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call return_sint8
 | 
						|
; RV32I-NEXT:    andi a0, a0, 255
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = call signext i8 @return_sint8()
 | 
						|
  ret i8 %1
 | 
						|
}
 | 
						|
 | 
						|
define signext i8 @sint8_arg_to_sint8_ret(i8 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: sint8_arg_to_sint8_ret:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  ret i8 %a
 | 
						|
}
 | 
						|
 | 
						|
define void @pass_sint8_as_sint8(i8 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: pass_sint8_as_sint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call receive_sint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  call void @receive_sint8(i8 signext %a)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
define signext i8 @ret_callresult_sint8_as_sint8() nounwind {
 | 
						|
; RV32I-LABEL: ret_callresult_sint8_as_sint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call return_sint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = call signext i8 @return_sint8()
 | 
						|
  ret i8 %1
 | 
						|
}
 | 
						|
 | 
						|
define signext i32 @sint8_arg_to_anyint32_ret(i8 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: sint8_arg_to_anyint32_ret:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = sext i8 %a to i32
 | 
						|
  ret i32 %1
 | 
						|
}
 | 
						|
 | 
						|
define void @pass_sint8_as_anyint32(i8 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: pass_sint8_as_anyint32:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call receive_anyint32
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = sext i8 %a to i32
 | 
						|
  call void @receive_anyint32(i32 signext %1)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
define signext i32 @ret_callresult_sint8_as_anyint32() nounwind {
 | 
						|
; RV32I-LABEL: ret_callresult_sint8_as_anyint32:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call return_sint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = call signext i8 @return_sint8()
 | 
						|
  %2 = sext i8 %1 to i32
 | 
						|
  ret i32 %2
 | 
						|
}
 | 
						|
 | 
						|
define zeroext i8 @anyint32_arg_to_uint8_ret(i32 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: anyint32_arg_to_uint8_ret:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    andi a0, a0, 255
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = trunc i32 %a to i8
 | 
						|
  ret i8 %1
 | 
						|
}
 | 
						|
 | 
						|
define void @pass_anyint32_as_uint8(i32 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: pass_anyint32_as_uint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    andi a0, a0, 255
 | 
						|
; RV32I-NEXT:    call receive_uint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = trunc i32 %a to i8
 | 
						|
  call void @receive_uint8(i8 zeroext %1)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
declare signext i32 @return_anyint32()
 | 
						|
 | 
						|
define zeroext i8 @ret_callresult_anyint32_as_uint8() nounwind {
 | 
						|
; RV32I-LABEL: ret_callresult_anyint32_as_uint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call return_anyint32
 | 
						|
; RV32I-NEXT:    andi a0, a0, 255
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = call signext i32 @return_anyint32()
 | 
						|
  %2 = trunc i32 %1 to i8
 | 
						|
  ret i8 %2
 | 
						|
}
 | 
						|
 | 
						|
define signext i8 @anyint32_arg_to_sint8_ret(i32 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: anyint32_arg_to_sint8_ret:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    slli a0, a0, 24
 | 
						|
; RV32I-NEXT:    srai a0, a0, 24
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = trunc i32 %a to i8
 | 
						|
  ret i8 %1
 | 
						|
}
 | 
						|
 | 
						|
define void @pass_anyint32_as_sint8(i32 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: pass_anyint32_as_sint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    slli a0, a0, 24
 | 
						|
; RV32I-NEXT:    srai a0, a0, 24
 | 
						|
; RV32I-NEXT:    call receive_sint8
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = trunc i32 %a to i8
 | 
						|
  call void @receive_sint8(i8 signext %1)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
define signext i8 @ret_callresult_anyint32_as_sint8() nounwind {
 | 
						|
; RV32I-LABEL: ret_callresult_anyint32_as_sint8:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call return_anyint32
 | 
						|
; RV32I-NEXT:    slli a0, a0, 24
 | 
						|
; RV32I-NEXT:    srai a0, a0, 24
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = call signext i32 @return_anyint32()
 | 
						|
  %2 = trunc i32 %1 to i8
 | 
						|
  ret i8 %2
 | 
						|
}
 | 
						|
 | 
						|
define signext i32 @anyint32_arg_to_anyint32_ret(i32 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: anyint32_arg_to_anyint32_ret:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  ret i32 %a
 | 
						|
}
 | 
						|
 | 
						|
define void @pass_anyint32_as_anyint32(i32 signext %a) nounwind {
 | 
						|
; RV32I-LABEL: pass_anyint32_as_anyint32:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call receive_anyint32
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  call void @receive_anyint32(i32 signext %a)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
define signext i32 @ret_callresult_anyint32_as_anyint32() nounwind {
 | 
						|
; RV32I-LABEL: ret_callresult_anyint32_as_anyint32:
 | 
						|
; RV32I:       # %bb.0:
 | 
						|
; RV32I-NEXT:    addi sp, sp, -16
 | 
						|
; RV32I-NEXT:    sw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    call return_anyint32
 | 
						|
; RV32I-NEXT:    lw ra, 12(sp)
 | 
						|
; RV32I-NEXT:    addi sp, sp, 16
 | 
						|
; RV32I-NEXT:    ret
 | 
						|
  %1 = call signext i32 @return_anyint32()
 | 
						|
  ret i32 %1
 | 
						|
}
 | 
						|
 |