llvm-project/llvm/test/CodeGen/AArch64/varargs-fixed-i16.ll
Tim Northover 3ed58d4df6 AArch64: allocate small fixed args properly in varargs functions.
On Darwin, function arguments occupy their real size when passed on the stack
(e.g. an i16 only consumes 2 bytes). This means that, even for fixed args in
varargs calls we need to keep track of the original type being passed before
any DAG/GISel promotions. Existing logic only applied this fix to the
non-varargs case leading to mismatch between caller & callee in those
situations.

On Linux & Windows these arguments always occupy a 64-bit slot anyway so
there's no special handling needed.
2023-01-18 11:35:24 +00:00

24 lines
1.0 KiB
LLVM

; RUN: llc -mtriple=arm64-apple-macosx %s -o - | FileCheck %s --check-prefix=CHECK-DARWIN
; RUN: llc -mtriple=arm64-apple-macosx %s -o - -global-isel | FileCheck %s --check-prefix=CHECK-DARWIN
; RUN: llc -mtriple=aarch64-linux-gnu %s -o - | FileCheck %s --check-prefix=CHECK-LINWIN
; RUN: llc -mtriple=aarch64-linux-gnu %s -o - -global-isel | FileCheck %s --check-prefix=CHECK-LINWIN
; RUN: llc -mtriple=aarch64-windows-msvc %s -o - | FileCheck %s --check-prefix=CHECK-LINWIN
; RUN: llc -mtriple=aarch64-windows-msvc %s -o - -global-isel | FileCheck %s --check-prefix=CHECK-LINWIN
declare i16 @foo([8 x i64], i16 signext, i16 signext %a, ...)
define void @bar() {
; CHECK-DARWIN-LABEL: bar:
; CHECK-LINWIN-LABEL: bar:
; CHECK-DARWIN: mov [[TMP:w[0-9]+]], #2752512
; CHECK-DARWIN: str [[TMP]], [sp]
; CHECK-LINWIN: mov [[TMP:w[0-9]+]], #42
; CHECK-LINWIN: str{{h?}} wzr, [sp]
; CHECK-LINWIN: str{{h?}} [[TMP]], [sp, #8]
call i16([8 x i64], i16, i16, ...) @foo([8 x i64] poison, i16 signext 0, i16 signext 42)
ret void
}