Compiler projects using 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(ptr byval(%struct.Six) %a) {
  ret void
}
; CHECK-LABEL: _f@8:
; CHECK: retl $8

define x86_thiscallcc void @g(ptr %this, ptr byval(%struct.Six) %a) {
  ret void
}
; CHECK-LABEL: _g:
; CHECK: retl $8

define x86_fastcallcc void @h(i32 inreg %x, i32 inreg %y, ptr byval(%struct.Six) %a) {
  ret void
}
; CHECK-LABEL: @h@16:
; CHECK: retl $8