blob: e42ffad27ed45a789d3a8575e7a8d07a7fd84a5a [file] [log] [blame]
Scott Graham66962112018-06-08 12:42:08 -07001// -*- C++ -*-
2//===----------------------------- new ------------------------------------===//
3//
4// The LLVM Compiler Infrastructure
5//
6// This file is dual licensed under the MIT and the University of Illinois Open
7// Source Licenses. See LICENSE.TXT for details.
8//
9//===----------------------------------------------------------------------===//
10
11#ifndef _LIBCPP_NEW
12#define _LIBCPP_NEW
13
14/*
15 new synopsis
16
17namespace std
18{
19
20class bad_alloc
21 : public exception
22{
23public:
24 bad_alloc() noexcept;
25 bad_alloc(const bad_alloc&) noexcept;
26 bad_alloc& operator=(const bad_alloc&) noexcept;
27 virtual const char* what() const noexcept;
28};
29
30class bad_array_length : public bad_alloc // FIXME: Not part of C++
31{
32public:
33 bad_array_length() noexcept;
34};
35
36class bad_array_new_length : public bad_alloc // C++14
37{
38public:
39 bad_array_new_length() noexcept;
40};
41
42enum class align_val_t : size_t {}; // C++17
43struct nothrow_t {};
44extern const nothrow_t nothrow;
45typedef void (*new_handler)();
46new_handler set_new_handler(new_handler new_p) noexcept;
47new_handler get_new_handler() noexcept;
48
49// 21.6.4, pointer optimization barrier
50template <class T> constexpr T* launder(T* p) noexcept; // C++17
51} // std
52
53void* operator new(std::size_t size); // replaceable, nodiscard in C++2a
54void* operator new(std::size_t size, std::align_val_t alignment); // replaceable, C++17, nodiscard in C++2a
55void* operator new(std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++2a
56void* operator new(std::size_t size, std::align_val_t alignment,
57 const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++2a
58void operator delete(void* ptr) noexcept; // replaceable
59void operator delete(void* ptr, std::size_t size) noexcept; // replaceable, C++14
60void operator delete(void* ptr, std::align_val_t alignment) noexcept; // replaceable, C++17
61void operator delete(void* ptr, std::size_t size,
62 std::align_val_t alignment) noexcept; // replaceable, C++17
63void operator delete(void* ptr, const std::nothrow_t&) noexcept; // replaceable
64void operator delete(void* ptr, std:align_val_t alignment,
65 const std::nothrow_t&) noexcept; // replaceable, C++17
66
67void* operator new[](std::size_t size); // replaceable, nodiscard in C++2a
68void* operator new[](std::size_t size,
69 std::align_val_t alignment) noexcept; // replaceable, C++17, nodiscard in C++2a
70void* operator new[](std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++2a
71void* operator new[](std::size_t size, std::align_val_t alignment,
72 const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++2a
73void operator delete[](void* ptr) noexcept; // replaceable
74void operator delete[](void* ptr, std::size_t size) noexcept; // replaceable, C++14
75void operator delete[](void* ptr,
76 std::align_val_t alignment) noexcept; // replaceable, C++17
77void operator delete[](void* ptr, std::size_t size,
78 std::align_val_t alignment) noexcept; // replaceable, C++17
79void operator delete[](void* ptr, const std::nothrow_t&) noexcept; // replaceable
80void operator delete[](void* ptr, std::align_val_t alignment,
81 const std::nothrow_t&) noexcept; // replaceable, C++17
82
83void* operator new (std::size_t size, void* ptr) noexcept; // nodiscard in C++2a
84void* operator new[](std::size_t size, void* ptr) noexcept; // nodiscard in C++2a
85void operator delete (void* ptr, void*) noexcept;
86void operator delete[](void* ptr, void*) noexcept;
87
88*/
89
90#include <__config>
91#include <exception>
92#include <type_traits>
93#include <cstddef>
94#ifdef _LIBCPP_NO_EXCEPTIONS
95#include <cstdlib>
96#endif
97
98#if defined(_LIBCPP_ABI_MICROSOFT) && !defined(_LIBCPP_NO_VCRUNTIME)
99#include <new.h>
100#endif
101
102#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
103#pragma GCC system_header
104#endif
105
106#if !(defined(_LIBCPP_BUILDING_NEW) || _LIBCPP_STD_VER >= 14 || \
107 (defined(__cpp_sized_deallocation) && __cpp_sized_deallocation >= 201309))
108# define _LIBCPP_HAS_NO_SIZED_DEALLOCATION
109#endif
110
111#if !defined(_LIBCPP_HAS_NO_ALIGNED_ALLOCATION) && \
112 (!(defined(_LIBCPP_BUILDING_NEW) || _LIBCPP_STD_VER > 14 || \
113 (defined(__cpp_aligned_new) && __cpp_aligned_new >= 201606)))
114# define _LIBCPP_HAS_NO_ALIGNED_ALLOCATION
115#endif
116
117
118#if !__has_builtin(__builtin_operator_new) || \
119 __has_builtin(__builtin_operator_new) < 201802L || \
120 defined(_LIBCPP_HAS_NO_ALIGNED_ALLOCATION) || \
121 !defined(__cpp_aligned_new) || __cpp_aligned_new < 201606
122#define _LIBCPP_HAS_NO_BUILTIN_ALIGNED_OPERATOR_NEW_DELETE
123#endif
124
125namespace std // purposefully not using versioning namespace
126{
127
128#if !defined(_LIBCPP_ABI_MICROSOFT) || defined(_LIBCPP_NO_VCRUNTIME)
129struct _LIBCPP_TYPE_VIS nothrow_t {};
130extern _LIBCPP_FUNC_VIS const nothrow_t nothrow;
131
132class _LIBCPP_EXCEPTION_ABI bad_alloc
133 : public exception
134{
135public:
136 bad_alloc() _NOEXCEPT;
137 virtual ~bad_alloc() _NOEXCEPT;
138 virtual const char* what() const _NOEXCEPT;
139};
140
141class _LIBCPP_EXCEPTION_ABI bad_array_new_length
142 : public bad_alloc
143{
144public:
145 bad_array_new_length() _NOEXCEPT;
146 virtual ~bad_array_new_length() _NOEXCEPT;
147 virtual const char* what() const _NOEXCEPT;
148};
149
150typedef void (*new_handler)();
151_LIBCPP_FUNC_VIS new_handler set_new_handler(new_handler) _NOEXCEPT;
152_LIBCPP_FUNC_VIS new_handler get_new_handler() _NOEXCEPT;
153
154#endif // !_LIBCPP_ABI_MICROSOFT || _LIBCPP_NO_VCRUNTIME
155
156_LIBCPP_NORETURN _LIBCPP_FUNC_VIS void __throw_bad_alloc(); // not in C++ spec
157
158#if defined(_LIBCPP_BUILDING_LIBRARY) || (_LIBCPP_STD_VER > 11)
159
160class _LIBCPP_EXCEPTION_ABI _LIBCPP_AVAILABILITY_BAD_ARRAY_LENGTH
161 bad_array_length : public bad_alloc {
162public:
163 bad_array_length() _NOEXCEPT;
164 virtual ~bad_array_length() _NOEXCEPT;
165 virtual const char* what() const _NOEXCEPT;
166};
167
168#define _LIBCPP_BAD_ARRAY_LENGTH_DEFINED
169
170#endif // defined(_LIBCPP_BUILDING_NEW) || (_LIBCPP_STD_VER > 11)
171
172#if !defined(_LIBCPP_ABI_MICROSOFT) || defined(_LIBCPP_NO_VCRUNTIME)
173#if !defined(_LIBCPP_HAS_NO_ALIGNED_ALLOCATION) || _LIBCPP_STD_VER > 14
174#ifndef _LIBCPP_CXX03_LANG
175enum class _LIBCPP_ENUM_VIS align_val_t : size_t { };
176#else
177enum align_val_t { __zero = 0, __max = (size_t)-1 };
178#endif
179#endif
180#endif
181
182} // std
183
184#if defined(_LIBCPP_CXX03_LANG)
185#define _THROW_BAD_ALLOC throw(std::bad_alloc)
186#else
187#define _THROW_BAD_ALLOC
188#endif
189
190#if !defined(_LIBCPP_ABI_MICROSOFT) || defined(_LIBCPP_NO_VCRUNTIME)
191
192_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz) _THROW_BAD_ALLOC;
193_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz, const std::nothrow_t&) _NOEXCEPT _NOALIAS;
194_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p) _NOEXCEPT;
195_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p, const std::nothrow_t&) _NOEXCEPT;
196#ifndef _LIBCPP_HAS_NO_SIZED_DEALLOCATION
197_LIBCPP_OVERRIDABLE_FUNC_VIS _LIBCPP_AVAILABILITY_SIZED_NEW_DELETE void operator delete(void* __p, std::size_t __sz) _NOEXCEPT;
198#endif
199
200_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz) _THROW_BAD_ALLOC;
201_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz, const std::nothrow_t&) _NOEXCEPT _NOALIAS;
202_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p) _NOEXCEPT;
203_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p, const std::nothrow_t&) _NOEXCEPT;
204#ifndef _LIBCPP_HAS_NO_SIZED_DEALLOCATION
205_LIBCPP_OVERRIDABLE_FUNC_VIS _LIBCPP_AVAILABILITY_SIZED_NEW_DELETE void operator delete[](void* __p, std::size_t __sz) _NOEXCEPT;
206#endif
207
208#ifndef _LIBCPP_HAS_NO_ALIGNED_ALLOCATION
209_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz, std::align_val_t) _THROW_BAD_ALLOC;
210_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz, std::align_val_t, const std::nothrow_t&) _NOEXCEPT _NOALIAS;
211_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p, std::align_val_t) _NOEXCEPT;
212_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p, std::align_val_t, const std::nothrow_t&) _NOEXCEPT;
213#ifndef _LIBCPP_HAS_NO_SIZED_DEALLOCATION
214_LIBCPP_OVERRIDABLE_FUNC_VIS _LIBCPP_AVAILABILITY_SIZED_NEW_DELETE void operator delete(void* __p, std::size_t __sz, std::align_val_t) _NOEXCEPT;
215#endif
216
217_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz, std::align_val_t) _THROW_BAD_ALLOC;
218_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz, std::align_val_t, const std::nothrow_t&) _NOEXCEPT _NOALIAS;
219_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p, std::align_val_t) _NOEXCEPT;
220_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p, std::align_val_t, const std::nothrow_t&) _NOEXCEPT;
221#ifndef _LIBCPP_HAS_NO_SIZED_DEALLOCATION
222_LIBCPP_OVERRIDABLE_FUNC_VIS _LIBCPP_AVAILABILITY_SIZED_NEW_DELETE void operator delete[](void* __p, std::size_t __sz, std::align_val_t) _NOEXCEPT;
223#endif
224#endif
225
226_LIBCPP_NODISCARD_AFTER_CXX17 inline _LIBCPP_INLINE_VISIBILITY void* operator new (std::size_t, void* __p) _NOEXCEPT {return __p;}
227_LIBCPP_NODISCARD_AFTER_CXX17 inline _LIBCPP_INLINE_VISIBILITY void* operator new[](std::size_t, void* __p) _NOEXCEPT {return __p;}
228inline _LIBCPP_INLINE_VISIBILITY void operator delete (void*, void*) _NOEXCEPT {}
229inline _LIBCPP_INLINE_VISIBILITY void operator delete[](void*, void*) _NOEXCEPT {}
230
231#endif // !_LIBCPP_ABI_MICROSOFT || _LIBCPP_NO_VCRUNTIME
232
233_LIBCPP_BEGIN_NAMESPACE_STD
234
235_LIBCPP_CONSTEXPR inline _LIBCPP_INLINE_VISIBILITY bool __is_overaligned_for_new(size_t __align) _NOEXCEPT {
236#ifdef __STDCPP_DEFAULT_NEW_ALIGNMENT__
237 return __align > __STDCPP_DEFAULT_NEW_ALIGNMENT__;
238#else
239 return __align > alignment_of<max_align_t>::value;
240#endif
241}
242
243inline _LIBCPP_INLINE_VISIBILITY void *__libcpp_allocate(size_t __size, size_t __align) {
244#ifndef _LIBCPP_HAS_NO_ALIGNED_ALLOCATION
245 if (__is_overaligned_for_new(__align)) {
246 const align_val_t __align_val = static_cast<align_val_t>(__align);
247# ifdef _LIBCPP_HAS_NO_BUILTIN_ALIGNED_OPERATOR_NEW_DELETE
248 return ::operator new(__size, __align_val);
249# else
250 return __builtin_operator_new(__size, __align_val);
251# endif
252 }
253#else
254 ((void)__align);
255#endif
256#ifdef _LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE
257 return ::operator new(__size);
258#else
259 return __builtin_operator_new(__size);
260#endif
261}
262
263inline _LIBCPP_INLINE_VISIBILITY void __libcpp_deallocate(void* __ptr, size_t __align) {
264#ifndef _LIBCPP_HAS_NO_ALIGNED_ALLOCATION
265 if (__is_overaligned_for_new(__align)) {
266 const align_val_t __align_val = static_cast<align_val_t>(__align);
267# ifdef _LIBCPP_HAS_NO_BUILTIN_ALIGNED_OPERATOR_NEW_DELETE
268 return ::operator delete(__ptr, __align_val);
269# else
270 return __builtin_operator_delete(__ptr, __align_val);
271# endif
272 }
273#else
274 ((void)__align);
275#endif
276#ifdef _LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE
277 return ::operator delete(__ptr);
278#else
279 return __builtin_operator_delete(__ptr);
280#endif
281}
282
283#ifdef _LIBCPP_BAD_ARRAY_LENGTH_DEFINED
284_LIBCPP_NORETURN inline _LIBCPP_ALWAYS_INLINE
285#ifndef _LIBCPP_NO_EXCEPTIONS
286_LIBCPP_AVAILABILITY_BAD_ARRAY_LENGTH
287#endif
288void __throw_bad_array_length()
289{
290#ifndef _LIBCPP_NO_EXCEPTIONS
291 throw bad_array_length();
292#else
293 _VSTD::abort();
294#endif
295}
296#endif
297
298template <class _Tp>
299_LIBCPP_NODISCARD_AFTER_CXX17 inline
300_LIBCPP_CONSTEXPR _Tp* __launder(_Tp* __p) _NOEXCEPT
301{
302 static_assert (!(is_function<_Tp>::value), "can't launder functions" );
303 static_assert (!(is_same<void, typename remove_cv<_Tp>::type>::value), "can't launder cv-void" );
304#ifdef _LIBCPP_COMPILER_HAS_BUILTIN_LAUNDER
305 return __builtin_launder(__p);
306#else
307 return __p;
308#endif
309}
310
311
312#if _LIBCPP_STD_VER > 14
313template <class _Tp>
314_LIBCPP_NODISCARD_AFTER_CXX17 inline _LIBCPP_INLINE_VISIBILITY
315constexpr _Tp* launder(_Tp* __p) noexcept
316{
317 return _VSTD::__launder(__p);
318}
319#endif
320
321_LIBCPP_END_NAMESPACE_STD
322
323#endif // _LIBCPP_NEW