mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-09 10:31:14 +00:00
7911f2db78
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@214982 91177308-0d34-0410-b5e6-96231b3b80d8
28 lines
771 B
LLVM
28 lines
771 B
LLVM
; RUN: llc < %s -mtriple=i686-win32 | FileCheck %s
|
|
|
|
; Previously we would forget to align to stack slot alignment after placing a
|
|
; byval argument. Subsequent arguments would align themselves, but if it was
|
|
; the last argument, the argument size would not be a multiple of stack slot
|
|
; size. This resulted in retl $6 in callee-cleanup functions, as well as subtle
|
|
; varargs bugs.
|
|
|
|
%struct.Six = type { [6 x i8] }
|
|
|
|
define x86_stdcallcc void @f(%struct.Six* byval %a) {
|
|
ret void
|
|
}
|
|
; CHECK-LABEL: _f@8:
|
|
; CHECK: retl $8
|
|
|
|
define x86_thiscallcc void @g(i8* %this, %struct.Six* byval %a) {
|
|
ret void
|
|
}
|
|
; CHECK-LABEL: _g:
|
|
; CHECK: retl $8
|
|
|
|
define x86_fastcallcc void @h(i32 inreg %x, i32 inreg %y, %struct.Six* byval %a) {
|
|
ret void
|
|
}
|
|
; CHECK-LABEL: @h@8:
|
|
; CHECK: retl $8
|