mirror of git://gcc.gnu.org/git/gcc.git
re PR c++/50594 (Option -fwhole-program discards replaced new operator for std::string)
2011-10-12 Paolo Carlini <paolo.carlini@oracle.com> PR c++/50594 * decl.c (cxx_init_decl_processing): Add __attribute__((externally_visible)) to operator new and operator delete library fn. 2011-10-12 Paolo Carlini <paolo.carlini@oracle.com> PR c++/50594 * libsupc++/new (operator new, operator delete): Decorate with __attribute__((__externally_visible__)). * include/bits/c++config: Add _GLIBCXX_THROW. * libsupc++/del_op.cc: Adjust. * libsupc++/del_opv.cc: Likewise. * libsupc++/del_opnt.cc: Likewise. * libsupc++/del_opvnt.cc: Likewise. * libsupc++/new_op.cc: Likewise. * libsupc++/new_opv.cc: Likewise. * libsupc++/new_opnt.cc: Likewise. * libsupc++/new_opvnt.cc: Likewise. * testsuite/18_support/50594.cc: New. * testsuite/ext/profile/mutex_extensions_neg.cc: Adjust dg-error line number. From-SVN: r179863
This commit is contained in:
parent
0a6fa37645
commit
578f023490
|
@ -1,3 +1,10 @@
|
||||||
|
2011-10-12 Paolo Carlini <paolo.carlini@oracle.com>
|
||||||
|
|
||||||
|
PR c++/50594
|
||||||
|
* decl.c (cxx_init_decl_processing): Add
|
||||||
|
__attribute__((externally_visible)) to operator new and
|
||||||
|
operator delete library fn.
|
||||||
|
|
||||||
2011-10-11 Michael Meissner <meissner@linux.vnet.ibm.com>
|
2011-10-11 Michael Meissner <meissner@linux.vnet.ibm.com>
|
||||||
|
|
||||||
* decl.c (duplicate_decls): Delete old interface with two parallel
|
* decl.c (duplicate_decls): Delete old interface with two parallel
|
||||||
|
|
|
@ -3654,7 +3654,7 @@ cxx_init_decl_processing (void)
|
||||||
current_lang_name = lang_name_cplusplus;
|
current_lang_name = lang_name_cplusplus;
|
||||||
|
|
||||||
{
|
{
|
||||||
tree newattrs;
|
tree newattrs, extvisattr;
|
||||||
tree newtype, deltype;
|
tree newtype, deltype;
|
||||||
tree ptr_ftype_sizetype;
|
tree ptr_ftype_sizetype;
|
||||||
tree new_eh_spec;
|
tree new_eh_spec;
|
||||||
|
@ -3684,12 +3684,15 @@ cxx_init_decl_processing (void)
|
||||||
|
|
||||||
/* Ensure attribs.c is initialized. */
|
/* Ensure attribs.c is initialized. */
|
||||||
init_attributes ();
|
init_attributes ();
|
||||||
newattrs
|
extvisattr = build_tree_list (get_identifier ("externally_visible"),
|
||||||
= build_tree_list (get_identifier ("alloc_size"),
|
NULL_TREE);
|
||||||
build_tree_list (NULL_TREE, integer_one_node));
|
newattrs = tree_cons (get_identifier ("alloc_size"),
|
||||||
|
build_tree_list (NULL_TREE, integer_one_node),
|
||||||
|
extvisattr);
|
||||||
newtype = cp_build_type_attribute_variant (ptr_ftype_sizetype, newattrs);
|
newtype = cp_build_type_attribute_variant (ptr_ftype_sizetype, newattrs);
|
||||||
newtype = build_exception_variant (newtype, new_eh_spec);
|
newtype = build_exception_variant (newtype, new_eh_spec);
|
||||||
deltype = build_exception_variant (void_ftype_ptr, empty_except_spec);
|
deltype = cp_build_type_attribute_variant (void_ftype_ptr, extvisattr);
|
||||||
|
deltype = build_exception_variant (deltype, empty_except_spec);
|
||||||
push_cp_library_fn (NEW_EXPR, newtype);
|
push_cp_library_fn (NEW_EXPR, newtype);
|
||||||
push_cp_library_fn (VEC_NEW_EXPR, newtype);
|
push_cp_library_fn (VEC_NEW_EXPR, newtype);
|
||||||
global_delete_fndecl = push_cp_library_fn (DELETE_EXPR, deltype);
|
global_delete_fndecl = push_cp_library_fn (DELETE_EXPR, deltype);
|
||||||
|
|
|
@ -1,3 +1,21 @@
|
||||||
|
2011-10-12 Paolo Carlini <paolo.carlini@oracle.com>
|
||||||
|
|
||||||
|
PR c++/50594
|
||||||
|
* libsupc++/new (operator new, operator delete): Decorate with
|
||||||
|
__attribute__((__externally_visible__)).
|
||||||
|
* include/bits/c++config: Add _GLIBCXX_THROW.
|
||||||
|
* libsupc++/del_op.cc: Adjust.
|
||||||
|
* libsupc++/del_opv.cc: Likewise.
|
||||||
|
* libsupc++/del_opnt.cc: Likewise.
|
||||||
|
* libsupc++/del_opvnt.cc: Likewise.
|
||||||
|
* libsupc++/new_op.cc: Likewise.
|
||||||
|
* libsupc++/new_opv.cc: Likewise.
|
||||||
|
* libsupc++/new_opnt.cc: Likewise.
|
||||||
|
* libsupc++/new_opvnt.cc: Likewise.
|
||||||
|
* testsuite/18_support/50594.cc: New.
|
||||||
|
* testsuite/ext/profile/mutex_extensions_neg.cc: Adjust dg-error
|
||||||
|
line number.
|
||||||
|
|
||||||
2011-10-11 Emil Wojak <emil@wojak.eu>
|
2011-10-11 Emil Wojak <emil@wojak.eu>
|
||||||
|
|
||||||
PR c++/50661
|
PR c++/50661
|
||||||
|
|
|
@ -103,9 +103,11 @@
|
||||||
# ifdef __GXX_EXPERIMENTAL_CXX0X__
|
# ifdef __GXX_EXPERIMENTAL_CXX0X__
|
||||||
# define _GLIBCXX_NOEXCEPT noexcept
|
# define _GLIBCXX_NOEXCEPT noexcept
|
||||||
# define _GLIBCXX_USE_NOEXCEPT noexcept
|
# define _GLIBCXX_USE_NOEXCEPT noexcept
|
||||||
|
# define _GLIBCXX_THROW(_EXC)
|
||||||
# else
|
# else
|
||||||
# define _GLIBCXX_NOEXCEPT
|
# define _GLIBCXX_NOEXCEPT
|
||||||
# define _GLIBCXX_USE_NOEXCEPT throw()
|
# define _GLIBCXX_USE_NOEXCEPT throw()
|
||||||
|
# define _GLIBCXX_THROW(_EXC) throw(_EXC)
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
||||||
|
|
||||||
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2007, 2009 Free Software Foundation
|
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2007, 2009, 2010, 2011
|
||||||
|
// Free Software Foundation
|
||||||
//
|
//
|
||||||
// This file is part of GCC.
|
// This file is part of GCC.
|
||||||
//
|
//
|
||||||
|
@ -41,7 +42,7 @@ _GLIBCXX_END_NAMESPACE_VERSION
|
||||||
#include "new"
|
#include "new"
|
||||||
|
|
||||||
_GLIBCXX_WEAK_DEFINITION void
|
_GLIBCXX_WEAK_DEFINITION void
|
||||||
operator delete(void* ptr) throw ()
|
operator delete(void* ptr) _GLIBCXX_USE_NOEXCEPT
|
||||||
{
|
{
|
||||||
if (ptr)
|
if (ptr)
|
||||||
std::free(ptr);
|
std::free(ptr);
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
||||||
|
|
||||||
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009 Free Software Foundation
|
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009, 2010, 2011
|
||||||
|
// Free Software Foundation
|
||||||
//
|
//
|
||||||
// This file is part of GCC.
|
// This file is part of GCC.
|
||||||
//
|
//
|
||||||
|
@ -29,7 +30,7 @@
|
||||||
extern "C" void free (void *);
|
extern "C" void free (void *);
|
||||||
|
|
||||||
_GLIBCXX_WEAK_DEFINITION void
|
_GLIBCXX_WEAK_DEFINITION void
|
||||||
operator delete (void *ptr, const std::nothrow_t&) throw ()
|
operator delete (void *ptr, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT
|
||||||
{
|
{
|
||||||
free (ptr);
|
free (ptr);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
||||||
|
|
||||||
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009 Free Software Foundation
|
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009, 2010, 2011
|
||||||
|
// Free Software Foundation
|
||||||
//
|
//
|
||||||
// This file is part of GCC.
|
// This file is part of GCC.
|
||||||
//
|
//
|
||||||
|
@ -27,7 +28,7 @@
|
||||||
#include "new"
|
#include "new"
|
||||||
|
|
||||||
_GLIBCXX_WEAK_DEFINITION void
|
_GLIBCXX_WEAK_DEFINITION void
|
||||||
operator delete[] (void *ptr) throw ()
|
operator delete[] (void *ptr) _GLIBCXX_USE_NOEXCEPT
|
||||||
{
|
{
|
||||||
::operator delete (ptr);
|
::operator delete (ptr);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
||||||
|
|
||||||
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009 Free Software Foundation
|
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009, 2010, 2011
|
||||||
|
// Free Software Foundation
|
||||||
//
|
//
|
||||||
// This file is part of GCC.
|
// This file is part of GCC.
|
||||||
//
|
//
|
||||||
|
@ -27,7 +28,7 @@
|
||||||
#include "new"
|
#include "new"
|
||||||
|
|
||||||
_GLIBCXX_WEAK_DEFINITION void
|
_GLIBCXX_WEAK_DEFINITION void
|
||||||
operator delete[] (void *ptr, const std::nothrow_t&) throw ()
|
operator delete[] (void *ptr, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT
|
||||||
{
|
{
|
||||||
::operator delete (ptr);
|
::operator delete (ptr);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
// The -*- C++ -*- dynamic memory management header.
|
// The -*- C++ -*- dynamic memory management header.
|
||||||
|
|
||||||
// Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
// Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
||||||
// 2003, 2004, 2005, 2006, 2007, 2009, 2010
|
// 2003, 2004, 2005, 2006, 2007, 2009, 2010, 2011
|
||||||
// Free Software Foundation
|
// Free Software Foundation
|
||||||
|
|
||||||
// This file is part of GCC.
|
// This file is part of GCC.
|
||||||
|
@ -90,22 +90,32 @@ namespace std
|
||||||
* Placement new and delete signatures (take a memory address argument,
|
* Placement new and delete signatures (take a memory address argument,
|
||||||
* does nothing) may not be replaced by a user's program.
|
* does nothing) may not be replaced by a user's program.
|
||||||
*/
|
*/
|
||||||
void* operator new(std::size_t) throw (std::bad_alloc);
|
void* operator new(std::size_t) _GLIBCXX_THROW (std::bad_alloc)
|
||||||
void* operator new[](std::size_t) throw (std::bad_alloc);
|
__attribute__((__externally_visible__));
|
||||||
void operator delete(void*) throw();
|
void* operator new[](std::size_t) _GLIBCXX_THROW (std::bad_alloc)
|
||||||
void operator delete[](void*) throw();
|
__attribute__((__externally_visible__));
|
||||||
void* operator new(std::size_t, const std::nothrow_t&) throw();
|
void operator delete(void*) _GLIBCXX_USE_NOEXCEPT
|
||||||
void* operator new[](std::size_t, const std::nothrow_t&) throw();
|
__attribute__((__externally_visible__));
|
||||||
void operator delete(void*, const std::nothrow_t&) throw();
|
void operator delete[](void*) _GLIBCXX_USE_NOEXCEPT
|
||||||
void operator delete[](void*, const std::nothrow_t&) throw();
|
__attribute__((__externally_visible__));
|
||||||
|
void* operator new(std::size_t, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT
|
||||||
|
__attribute__((__externally_visible__));
|
||||||
|
void* operator new[](std::size_t, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT
|
||||||
|
__attribute__((__externally_visible__));
|
||||||
|
void operator delete(void*, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT
|
||||||
|
__attribute__((__externally_visible__));
|
||||||
|
void operator delete[](void*, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT
|
||||||
|
__attribute__((__externally_visible__));
|
||||||
|
|
||||||
// Default placement versions of operator new.
|
// Default placement versions of operator new.
|
||||||
inline void* operator new(std::size_t, void* __p) throw() { return __p; }
|
inline void* operator new(std::size_t, void* __p) _GLIBCXX_USE_NOEXCEPT
|
||||||
inline void* operator new[](std::size_t, void* __p) throw() { return __p; }
|
{ return __p; }
|
||||||
|
inline void* operator new[](std::size_t, void* __p) _GLIBCXX_USE_NOEXCEPT
|
||||||
|
{ return __p; }
|
||||||
|
|
||||||
// Default placement versions of operator delete.
|
// Default placement versions of operator delete.
|
||||||
inline void operator delete (void*, void*) throw() { }
|
inline void operator delete (void*, void*) _GLIBCXX_USE_NOEXCEPT { }
|
||||||
inline void operator delete[](void*, void*) throw() { }
|
inline void operator delete[](void*, void*) _GLIBCXX_USE_NOEXCEPT { }
|
||||||
//@}
|
//@}
|
||||||
} // extern "C++"
|
} // extern "C++"
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ extern "C" void *malloc (std::size_t);
|
||||||
extern new_handler __new_handler;
|
extern new_handler __new_handler;
|
||||||
|
|
||||||
_GLIBCXX_WEAK_DEFINITION void *
|
_GLIBCXX_WEAK_DEFINITION void *
|
||||||
operator new (std::size_t sz) throw (std::bad_alloc)
|
operator new (std::size_t sz) _GLIBCXX_THROW (std::bad_alloc)
|
||||||
{
|
{
|
||||||
void *p;
|
void *p;
|
||||||
|
|
||||||
|
|
|
@ -34,7 +34,7 @@ extern "C" void *malloc (std::size_t);
|
||||||
extern new_handler __new_handler;
|
extern new_handler __new_handler;
|
||||||
|
|
||||||
_GLIBCXX_WEAK_DEFINITION void *
|
_GLIBCXX_WEAK_DEFINITION void *
|
||||||
operator new (std::size_t sz, const std::nothrow_t&) throw()
|
operator new (std::size_t sz, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT
|
||||||
{
|
{
|
||||||
void *p;
|
void *p;
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
||||||
|
|
||||||
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009 Free Software Foundation
|
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009, 2010, 2011
|
||||||
|
// Free Software Foundation
|
||||||
//
|
//
|
||||||
// This file is part of GCC.
|
// This file is part of GCC.
|
||||||
//
|
//
|
||||||
|
@ -27,7 +28,7 @@
|
||||||
#include "new"
|
#include "new"
|
||||||
|
|
||||||
_GLIBCXX_WEAK_DEFINITION void*
|
_GLIBCXX_WEAK_DEFINITION void*
|
||||||
operator new[] (std::size_t sz) throw (std::bad_alloc)
|
operator new[] (std::size_t sz) _GLIBCXX_THROW (std::bad_alloc)
|
||||||
{
|
{
|
||||||
return ::operator new(sz);
|
return ::operator new(sz);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
// Boilerplate support routines for -*- C++ -*- dynamic memory management.
|
||||||
|
|
||||||
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009 Free Software Foundation
|
// Copyright (C) 1997, 1998, 1999, 2000, 2004, 2009, 2010, 2011
|
||||||
|
// Free Software Foundation
|
||||||
//
|
//
|
||||||
// This file is part of GCC.
|
// This file is part of GCC.
|
||||||
//
|
//
|
||||||
|
@ -27,7 +28,8 @@
|
||||||
#include "new"
|
#include "new"
|
||||||
|
|
||||||
_GLIBCXX_WEAK_DEFINITION void*
|
_GLIBCXX_WEAK_DEFINITION void*
|
||||||
operator new[] (std::size_t sz, const std::nothrow_t& nothrow) throw()
|
operator new[] (std::size_t sz, const std::nothrow_t& nothrow)
|
||||||
|
_GLIBCXX_USE_NOEXCEPT
|
||||||
{
|
{
|
||||||
return ::operator new(sz, nothrow);
|
return ::operator new(sz, nothrow);
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,72 @@
|
||||||
|
// { dg-options "-fwhole-program" }
|
||||||
|
|
||||||
|
// Copyright (C) 2011 Free Software Foundation
|
||||||
|
//
|
||||||
|
// This file is part of the GNU ISO C++ Library. This library is free
|
||||||
|
// software; you can redistribute it and/or modify it under the
|
||||||
|
// terms of the GNU General Public License as published by the
|
||||||
|
// Free Software Foundation; either version 3, or (at your option)
|
||||||
|
// any later version.
|
||||||
|
|
||||||
|
// This library is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
|
||||||
|
// You should have received a copy of the GNU General Public License along
|
||||||
|
// with this library; see the file COPYING3. If not see
|
||||||
|
// <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#include <new>
|
||||||
|
#include <string>
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <testsuite_hooks.h>
|
||||||
|
|
||||||
|
bool user_new_called;
|
||||||
|
bool user_delete_called;
|
||||||
|
|
||||||
|
void* operator new(std::size_t n)
|
||||||
|
#ifndef __GXX_EXPERIMENTAL_CXX0X__
|
||||||
|
throw(std::bad_alloc)
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
user_new_called = true;
|
||||||
|
|
||||||
|
void* p = std::malloc(n);
|
||||||
|
|
||||||
|
if (!p)
|
||||||
|
throw std::bad_alloc();
|
||||||
|
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
|
||||||
|
void operator delete(void* p)
|
||||||
|
#ifdef __GXX_EXPERIMENTAL_CXX0X__
|
||||||
|
noexcept
|
||||||
|
#else
|
||||||
|
throw()
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
user_delete_called = true;
|
||||||
|
|
||||||
|
std::free(p);
|
||||||
|
}
|
||||||
|
|
||||||
|
// libstdc++/50594
|
||||||
|
void test01()
|
||||||
|
{
|
||||||
|
bool test __attribute__((unused)) = true;
|
||||||
|
|
||||||
|
{
|
||||||
|
std::string s = "Hello World.";
|
||||||
|
}
|
||||||
|
|
||||||
|
VERIFY( user_new_called );
|
||||||
|
VERIFY( user_delete_called );
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
test01();
|
||||||
|
return 0;
|
||||||
|
}
|
|
@ -25,4 +25,4 @@
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
// { dg-error "multiple inlined namespaces" "" { target *-*-* } 256 }
|
// { dg-error "multiple inlined namespaces" "" { target *-*-* } 258 }
|
||||||
|
|
Loading…
Reference in New Issue