annotate clang/test/CodeGen/arm64-be-hfa-vararg.c @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents 1d019706d866
children 5f17cb93ff66
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // RUN: %clang_cc1 -triple aarch64_be-linux-gnu -ffreestanding -emit-llvm -O0 -o - %s | FileCheck %s
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 #include <stdarg.h>
anatofuz
parents:
diff changeset
4
anatofuz
parents:
diff changeset
5 // A single member HFA must be aligned just like a non-HFA register argument.
anatofuz
parents:
diff changeset
6 double callee(int a, ...) {
anatofuz
parents:
diff changeset
7 // CHECK: [[REGPP:%.*]] = getelementptr inbounds %struct.__va_list, %struct.__va_list* [[VA:%.*]], i32 0, i32 2
anatofuz
parents:
diff changeset
8 // CHECK: [[REGP:%.*]] = load i8*, i8** [[REGPP]], align 8
anatofuz
parents:
diff changeset
9 // CHECK: [[OFFSET0:%.*]] = getelementptr inbounds i8, i8* [[REGP]], i32 {{.*}}
anatofuz
parents:
diff changeset
10 // CHECK: [[OFFSET1:%.*]] = getelementptr inbounds i8, i8* [[OFFSET0]], i64 8
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 // CHECK: [[MEMPP:%.*]] = getelementptr inbounds %struct.__va_list, %struct.__va_list* [[VA:%.*]], i32 0, i32 0
anatofuz
parents:
diff changeset
13 // CHECK: [[MEMP:%.*]] = load i8*, i8** [[MEMPP]], align 8
anatofuz
parents:
diff changeset
14 // CHECK: [[NEXTP:%.*]] = getelementptr inbounds i8, i8* [[MEMP]], i64 8
anatofuz
parents:
diff changeset
15 // CHECK: store i8* [[NEXTP]], i8** [[MEMPP]], align 8
anatofuz
parents:
diff changeset
16 va_list vl;
anatofuz
parents:
diff changeset
17 va_start(vl, a);
anatofuz
parents:
diff changeset
18 double result = va_arg(vl, struct { double a; }).a;
anatofuz
parents:
diff changeset
19 va_end(vl);
anatofuz
parents:
diff changeset
20 return result;
anatofuz
parents:
diff changeset
21 }