aboutsummaryrefslogtreecommitdiff
path: root/clang/test/CodeGen/AArch64/pure-scalable-args-empty-union.c
blob: 804e14a2ea34b65987a3635aed3bf4e617d4dbea (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
// RUN: %clang_cc1        -O3 -triple aarch64 -target-feature +sve -mvscale-min=1 -mvscale-max=1 -emit-llvm -o - %s | FileCheck %s --check-prefixes=CHECK-C
// RUN: %clang_cc1 -x c++ -O3 -triple aarch64 -target-feature +sve -mvscale-min=1 -mvscale-max=1 -emit-llvm -o - %s | FileCheck %s --check-prefixes=CHECK-CXX

typedef __SVFloat32_t fvec32 __attribute__((arm_sve_vector_bits(128)));

// PST containing an empty union: when compiled as C pass it in registers,
// when compiled as C++ - in memory.
typedef struct {
  fvec32 x[4];
  union {} u;
} S0;

#ifdef __cplusplus
extern "C"
#endif
void use0(S0);

void f0(S0 *p) {
  use0(*p);
}
// CHECK-C:   declare void @use0(<vscale x 4 x float>, <vscale x 4 x float>, <vscale x 4 x float>, <vscale x 4 x float>)
// CHECK-CXX: declare void @use0(ptr dead_on_return noundef)

#ifdef __cplusplus

// PST containing an empty union with `[[no_unique_address]]`` - pass in registers.
typedef struct {
   fvec32 x[4];
   [[no_unique_address]]
   union {} u;
} S1;

extern "C" void use1(S1);
void f1(S1 *p) {
  use1(*p);
}
// CHECK-CXX: declare void @use1(<vscale x 4 x float>, <vscale x 4 x float>, <vscale x 4 x float>, <vscale x 4 x float>)

#endif // __cplusplus