| //===----------------------------------------------------------------------===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file is dual licensed under the MIT and the University of Illinois Open |
| // Source Licenses. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| // UNSUPPORTED: c++98, c++03, c++11, c++14 |
| |
| // dylibs shipped before macosx10.13 do not provide aligned allocation, so that's a link error |
| // UNSUPPORTED: with_system_cxx_lib=macosx10.12 |
| // UNSUPPORTED: with_system_cxx_lib=macosx10.11 |
| // UNSUPPORTED: with_system_cxx_lib=macosx10.10 |
| // UNSUPPORTED: with_system_cxx_lib=macosx10.9 |
| // UNSUPPORTED: with_system_cxx_lib=macosx10.8 |
| // UNSUPPORTED: with_system_cxx_lib=macosx10.7 |
| |
| // Using aligned allocation functions is a compiler error when deploying to |
| // platforms older than macosx10.13 |
| // UNSUPPORTED: macosx10.12 |
| // UNSUPPORTED: macosx10.11 |
| // UNSUPPORTED: macosx10.10 |
| // UNSUPPORTED: macosx10.9 |
| // UNSUPPORTED: macosx10.8 |
| // UNSUPPORTED: macosx10.7 |
| |
| // asan and msan will not call the new handler. |
| // UNSUPPORTED: sanitizer-new-delete |
| |
| // FIXME turn this into an XFAIL |
| // UNSUPPORTED: no-aligned-allocation && !gcc |
| |
| // On Windows libc++ doesn't provide its own definitions for new/delete |
| // but instead depends on the ones in VCRuntime. However VCRuntime does not |
| // yet provide aligned new/delete definitions so this test fails to compile/link. |
| // XFAIL: LIBCXX-WINDOWS-FIXME |
| |
| // test operator new (nothrow) |
| |
| #include <new> |
| #include <cstddef> |
| #include <cstdint> |
| #include <cassert> |
| #include <limits> |
| |
| #include "test_macros.h" |
| |
| constexpr auto OverAligned = __STDCPP_DEFAULT_NEW_ALIGNMENT__ * 2; |
| |
| int new_handler_called = 0; |
| |
| void my_new_handler() |
| { |
| ++new_handler_called; |
| std::set_new_handler(0); |
| } |
| |
| bool A_constructed = false; |
| |
| struct alignas(OverAligned) A |
| { |
| A() {A_constructed = true;} |
| ~A() {A_constructed = false;} |
| }; |
| |
| void test_max_alloc() { |
| std::set_new_handler(my_new_handler); |
| auto do_test = []() { |
| void* vp = operator new (std::numeric_limits<std::size_t>::max(), |
| std::align_val_t(OverAligned), |
| std::nothrow); |
| assert(new_handler_called == 1); |
| assert(vp == 0); |
| }; |
| #ifndef TEST_HAS_NO_EXCEPTIONS |
| try |
| { |
| do_test(); |
| } |
| catch (...) |
| { |
| assert(false); |
| } |
| #else |
| do_test(); |
| #endif |
| } |
| |
| int main() |
| { |
| { |
| A* ap = new(std::nothrow) A; |
| assert(ap); |
| assert(reinterpret_cast<std::uintptr_t>(ap) % OverAligned == 0); |
| assert(A_constructed); |
| delete ap; |
| assert(!A_constructed); |
| } |
| { |
| test_max_alloc(); |
| } |
| } |