Author: ericwf Date: Sun May 7 17:10:56 2017 New Revision: 302384 URL: http://llvm.org/viewvc/llvm-project?rev=302384&view=rev Log: Temporarly XFAIL aligned new/delete tests on Windows.
Libc++ doesn't provide its own definitions of new/delete on Windows, instead using the versions provided by VCRuntime. However VCRuntime does not yet implement aligned new/delete so these tests fail. It might be possible for libc++ to provide its own definitions only for aligned new/delete as long as MSVC doesn't provide it. However before this can be done libc++ needs to figure out how to implement std::get_new_handler. Modified: libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/delete_align_val_t_replace.pass.cpp libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t.pass.cpp libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow.pass.cpp libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow_replace.pass.cpp libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/delete_align_val_t_replace.pass.cpp libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t.pass.cpp libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow.pass.cpp libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow_replace.pass.cpp Modified: libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/delete_align_val_t_replace.pass.cpp URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/delete_align_val_t_replace.pass.cpp?rev=302384&r1=302383&r2=302384&view=diff ============================================================================== --- libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/delete_align_val_t_replace.pass.cpp (original) +++ libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/delete_align_val_t_replace.pass.cpp Sun May 7 17:10:56 2017 @@ -24,6 +24,11 @@ // XFAIL: with_system_cxx_lib=macosx10.7 // XFAIL: with_system_cxx_lib=macosx10.8 +// 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 + #include <new> #include <cstddef> #include <cstdlib> Modified: libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t.pass.cpp URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t.pass.cpp?rev=302384&r1=302383&r2=302384&view=diff ============================================================================== --- libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t.pass.cpp (original) +++ libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t.pass.cpp Sun May 7 17:10:56 2017 @@ -22,6 +22,12 @@ // XFAIL: with_system_cxx_lib=macosx10.7 // XFAIL: with_system_cxx_lib=macosx10.8 + +// 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 link. +// XFAIL: LIBCXX-WINDOWS-FIXME + // test operator new #include <new> @@ -36,7 +42,7 @@ constexpr auto OverAligned = alignof(std int new_handler_called = 0; -void new_handler() +void my_new_handler() { ++new_handler_called; std::set_new_handler(0); @@ -52,7 +58,7 @@ struct alignas(OverAligned) A void test_throw_max_size() { #ifndef TEST_HAS_NO_EXCEPTIONS - std::set_new_handler(new_handler); + std::set_new_handler(my_new_handler); try { void* vp = operator new[] (std::numeric_limits<std::size_t>::max(), Modified: libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow.pass.cpp URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow.pass.cpp?rev=302384&r1=302383&r2=302384&view=diff ============================================================================== --- libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow.pass.cpp (original) +++ libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow.pass.cpp Sun May 7 17:10:56 2017 @@ -22,6 +22,11 @@ // XFAIL: with_system_cxx_lib=macosx10.7 // XFAIL: with_system_cxx_lib=macosx10.8 +// 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> Modified: libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow_replace.pass.cpp URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow_replace.pass.cpp?rev=302384&r1=302383&r2=302384&view=diff ============================================================================== --- libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow_replace.pass.cpp (original) +++ libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.array/new_align_val_t_nothrow_replace.pass.cpp Sun May 7 17:10:56 2017 @@ -19,6 +19,11 @@ // XFAIL: no-aligned-allocation +// 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. +// XFAIL: LIBCXX-WINDOWS-FIXME + // test operator new nothrow by replacing only operator new #include <new> Modified: libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/delete_align_val_t_replace.pass.cpp URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/delete_align_val_t_replace.pass.cpp?rev=302384&r1=302383&r2=302384&view=diff ============================================================================== --- libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/delete_align_val_t_replace.pass.cpp (original) +++ libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/delete_align_val_t_replace.pass.cpp Sun May 7 17:10:56 2017 @@ -23,6 +23,11 @@ // XFAIL: with_system_cxx_lib=macosx10.7 // XFAIL: with_system_cxx_lib=macosx10.8 +// 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 + #include <new> #include <cstddef> #include <cstdlib> Modified: libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t.pass.cpp URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t.pass.cpp?rev=302384&r1=302383&r2=302384&view=diff ============================================================================== --- libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t.pass.cpp (original) +++ libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t.pass.cpp Sun May 7 17:10:56 2017 @@ -22,6 +22,11 @@ // FIXME turn this into an XFAIL // UNSUPPORTED: no-aligned-allocation +// 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 #include <new> Modified: libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow.pass.cpp URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow.pass.cpp?rev=302384&r1=302383&r2=302384&view=diff ============================================================================== --- libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow.pass.cpp (original) +++ libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow.pass.cpp Sun May 7 17:10:56 2017 @@ -22,6 +22,11 @@ // FIXME turn this into an XFAIL // UNSUPPORTED: no-aligned-allocation +// 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> Modified: libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow_replace.pass.cpp URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow_replace.pass.cpp?rev=302384&r1=302383&r2=302384&view=diff ============================================================================== --- libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow_replace.pass.cpp (original) +++ libcxx/trunk/test/std/language.support/support.dynamic/new.delete/new.delete.single/new_align_val_t_nothrow_replace.pass.cpp Sun May 7 17:10:56 2017 @@ -19,6 +19,11 @@ // XFAIL: no-aligned-allocation +// 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. +// XFAIL: LIBCXX-WINDOWS-FIXME + // test operator new nothrow by replacing only operator new #include <new> _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits