1b749af6aSRoman Lebedev // RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s
2b749af6aSRoman Lebedev // RUN: %clang_cc1 -std=c++11 -faligned-allocation -fsyntax-only -verify %s
3b749af6aSRoman Lebedev // RUN: %clang_cc1 -std=c++14 -fsyntax-only -verify %s
4b749af6aSRoman Lebedev // RUN: %clang_cc1 -std=c++14 -faligned-allocation -fsyntax-only -verify %s
5b749af6aSRoman Lebedev // RUN: %clang_cc1 -std=c++17 -fsyntax-only -verify %s
6b749af6aSRoman Lebedev // RUN: %clang_cc1 -std=c++17 -faligned-allocation -fsyntax-only -verify %s
7b749af6aSRoman Lebedev
8b749af6aSRoman Lebedev namespace std {
9b749af6aSRoman Lebedev typedef __SIZE_TYPE__ size_t;
10b749af6aSRoman Lebedev struct nothrow_t {};
11b749af6aSRoman Lebedev #if __cplusplus >= 201103L
12b749af6aSRoman Lebedev enum class align_val_t : size_t {};
13b749af6aSRoman Lebedev #else
14b749af6aSRoman Lebedev enum align_val_t {
15b749af6aSRoman Lebedev // We can't force an underlying type when targeting windows.
16b749af6aSRoman Lebedev #ifndef _WIN32
17b749af6aSRoman Lebedev __zero = 0,
18b749af6aSRoman Lebedev __max = (size_t)-1
19b749af6aSRoman Lebedev #endif
20b749af6aSRoman Lebedev };
21b749af6aSRoman Lebedev #endif
22b749af6aSRoman Lebedev } // namespace std
23b749af6aSRoman Lebedev
24*abbe42d8SRichard Smith void *operator new(std::size_t count, std::align_val_t al) __attribute__((alloc_align(2))); // #1
25b749af6aSRoman Lebedev
26b749af6aSRoman Lebedev #define OVERALIGNED alignas(__STDCPP_DEFAULT_NEW_ALIGNMENT__ * 2)
27b749af6aSRoman Lebedev
28b749af6aSRoman Lebedev struct OVERALIGNED A {
29b749af6aSRoman Lebedev A();
30b749af6aSRoman Lebedev int n[128];
31b749af6aSRoman Lebedev };
32b749af6aSRoman Lebedev
ptr_variable(int align)33b749af6aSRoman Lebedev void *ptr_variable(int align) { return new (std::align_val_t(align)) A; }
ptr_align16()34b749af6aSRoman Lebedev void *ptr_align16() { return new (std::align_val_t(16)) A; }
ptr_align15()35b8fdafe6SRoman Lebedev void *ptr_align15() { return new (std::align_val_t(15)) A; } // expected-warning {{requested alignment is not a power of 2}}
36b749af6aSRoman Lebedev
37b749af6aSRoman Lebedev struct alignas(128) S {
SS38b749af6aSRoman Lebedev S() {}
39b749af6aSRoman Lebedev };
40b749af6aSRoman Lebedev
alloc_overaligned_struct()41b749af6aSRoman Lebedev void *alloc_overaligned_struct() {
42b749af6aSRoman Lebedev return new S;
43b749af6aSRoman Lebedev }
44b749af6aSRoman Lebedev
alloc_overaligned_struct_with_extra_variable_alignment(int align)45b749af6aSRoman Lebedev void *alloc_overaligned_struct_with_extra_variable_alignment(int align) {
46b749af6aSRoman Lebedev return new (std::align_val_t(align)) S;
47b749af6aSRoman Lebedev }
alloc_overaligned_struct_with_extra_256_alignment(int align)48b749af6aSRoman Lebedev void *alloc_overaligned_struct_with_extra_256_alignment(int align) {
49b749af6aSRoman Lebedev return new (std::align_val_t(256)) S;
50b749af6aSRoman Lebedev }
alloc_overaligned_struct_with_extra_255_alignment(int align)51b749af6aSRoman Lebedev void *alloc_overaligned_struct_with_extra_255_alignment(int align) {
52b8fdafe6SRoman Lebedev return new (std::align_val_t(255)) S; // expected-warning {{requested alignment is not a power of 2}}
53b749af6aSRoman Lebedev }
54b749af6aSRoman Lebedev
align_variable(int align)55b749af6aSRoman Lebedev std::align_val_t align_variable(int align) { return std::align_val_t(align); }
align_align16()56b749af6aSRoman Lebedev std::align_val_t align_align16() { return std::align_val_t(16); }
align_align15()57b749af6aSRoman Lebedev std::align_val_t align_align15() { return std::align_val_t(15); }
58*abbe42d8SRichard Smith
59*abbe42d8SRichard Smith struct X {};
60*abbe42d8SRichard Smith void *operator new(std::size_t, X); // #2
61*abbe42d8SRichard Smith void *operator new(std::size_t, std::align_val_t, X); // #3
62*abbe42d8SRichard Smith // FIXME: Consider improving notes 1 and 3 here to say that these are aligned
63*abbe42d8SRichard Smith // allocation functions and the type is not over-aligned.
64*abbe42d8SRichard Smith X *p = new (123) X; // expected-error {{no matching function}}
65*abbe42d8SRichard Smith // expected-note@#1 {{no known conversion from 'int' to 'std::align_val_t' for 2nd argument}}
66*abbe42d8SRichard Smith // expected-note@#2 {{no known conversion from 'int' to 'X' for 2nd argument}}
67*abbe42d8SRichard Smith // expected-note@#3 {{requires 3 arguments}}
68*abbe42d8SRichard Smith // expected-note@* {{requires 1 argument, but 2 were provided}} (builtin)
69*abbe42d8SRichard Smith
70*abbe42d8SRichard Smith #ifdef __cpp_aligned_new
71*abbe42d8SRichard Smith struct alignas(__STDCPP_DEFAULT_NEW_ALIGNMENT__ * 2) Y {};
72*abbe42d8SRichard Smith Y *q = new (123) Y; // expected-error {{no matching function}}
73*abbe42d8SRichard Smith // expected-note@#1 {{requires 2 arguments, but 3 were provided}}
74*abbe42d8SRichard Smith // expected-note@#2 {{no known conversion from 'int' to 'X' for 2nd argument}}
75*abbe42d8SRichard Smith // expected-note@#3 {{no known conversion from 'int' to 'X' for 3rd argument}}
76*abbe42d8SRichard Smith // expected-note@* {{requires 1 argument, but 2 were provided}} (builtin)
77*abbe42d8SRichard Smith #endif
78*abbe42d8SRichard Smith
79*abbe42d8SRichard Smith X *r = new (std::align_val_t(32), 123) X; // expected-error {{no matching function}}
80*abbe42d8SRichard Smith // expected-note@#1 {{requires 2 arguments, but 3 were provided}}
81*abbe42d8SRichard Smith // expected-note@#2 {{requires 2 arguments, but 3 were provided}}
82*abbe42d8SRichard Smith // expected-note@#3 {{no known conversion from 'int' to 'X' for 3rd argument}}
83*abbe42d8SRichard Smith // expected-note@* {{requires 1 argument, but 3 were provided}} (builtin)
84