mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-09 05:31:19 +00:00
b4e63ec23a
In the code below on 32-bit targets, x would previously get forwarded to g() without sign-extension to 32 bits as required by the parameter attribute. void g(signed short); void f(unsigned short x) { g(x); } git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@262352 91177308-0d34-0410-b5e6-96231b3b80d8
41 lines
874 B
LLVM
41 lines
874 B
LLVM
; RUN: llc -mtriple=i686-unknown-linux-gnu -o - %s | FileCheck %s
|
|
|
|
declare void @f(i16 signext)
|
|
declare void @g(i32 signext)
|
|
|
|
|
|
define void @flags_match(i16 signext %x) {
|
|
entry:
|
|
tail call void @f(i16 signext %x)
|
|
ret void
|
|
|
|
; The parameter flags match; do the tail call.
|
|
; CHECK-LABEL: flags_match:
|
|
; CHECK: jmp f
|
|
}
|
|
|
|
define void @flags_mismatch(i16 zeroext %x) {
|
|
entry:
|
|
tail call void @f(i16 signext %x)
|
|
ret void
|
|
|
|
; The parameter flags mismatch. %x has not been sign-extended,
|
|
; so tail call is not possible.
|
|
; CHECK-LABEL: flags_mismatch:
|
|
; CHECK: movswl
|
|
; CHECK: calll f
|
|
}
|
|
|
|
|
|
define void @mismatch_doesnt_matter(i32 zeroext %x) {
|
|
entry:
|
|
tail call void @g(i32 signext %x)
|
|
ret void
|
|
|
|
; The parameter flags mismatch, but the type is wide enough that
|
|
; no extension takes place in practice, so do the tail call.
|
|
|
|
; CHECK-LABEL: mismatch_doesnt_matter:
|
|
; CHECK: jmp g
|
|
}
|