vec.cc (__aeabi_vec_dtor_cookie): Handle NULL array address.
authorMark Mitchell <mark@codesourcery.com>
Fri, 27 Jun 2008 23:02:06 +0000 (23:02 +0000)
committerMark Mitchell <mmitchel@gcc.gnu.org>
Fri, 27 Jun 2008 23:02:06 +0000 (23:02 +0000)
2008-06-27  Mark Mitchell  <mark@codesourcery.com>

* libsupc++/vec.cc (__aeabi_vec_dtor_cookie): Handle NULL array
address.
(__aeabi_vec_delete): Likewise.
(__aeabi_vec_delete3): Likewise.
(__aeabi_vec_delete3_nodtor): Likewise.

2008-06-27  Mark Mitchell  <mark@codesourcery.com>

* g++.dg/abi/arm_cxa_vec2.C: New test.

From-SVN: r137207

gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/abi/arm_cxa_vec2.C [new file with mode: 0644]
libstdc++-v3/ChangeLog
libstdc++-v3/libsupc++/vec.cc

index d0d635d3357e46f11d791c80c0a95663607b387e..d4de302f794d84251870ebb75d96fd84825e5222 100644 (file)
@@ -1,3 +1,7 @@
+2008-06-27  Mark Mitchell  <mark@codesourcery.com>
+
+       * g++.dg/abi/arm_cxa_vec2.C: New test.
+
 2008-06-28  Jakub Jelinek  <jakub@redhat.com>
 
        PR c++/36364
diff --git a/gcc/testsuite/g++.dg/abi/arm_cxa_vec2.C b/gcc/testsuite/g++.dg/abi/arm_cxa_vec2.C
new file mode 100644 (file)
index 0000000..76f327a
--- /dev/null
@@ -0,0 +1,41 @@
+// Check that ARM vector delete functions accept NULL pointers as
+// inputs.
+// { dg-do run { target arm*-*-* } }
+
+#ifdef __ARM_EABI__
+#include <cxxabi.h>
+
+typedef void *(dtor_type)(void *);
+
+extern "C" {
+  void abort();
+  void *__aeabi_vec_dtor_cookie(void *, dtor_type);
+  void __aeabi_vec_delete(void *, dtor_type);
+  void __aeabi_vec_delete3(void *, 
+                          dtor_type, 
+                          void (*)(void *, __SIZE_TYPE__));
+  void __aeabi_vec_delete3_nodtor(void *, 
+                                 void (*)(void *, __SIZE_TYPE__));
+}
+
+// These functions should never be called.
+void* dtor(void *)
+{
+  abort ();
+}
+
+void dealloc(void *, size_t) {
+  abort ();
+}
+
+int main () {
+  if (__aeabi_vec_dtor_cookie (NULL, &dtor) != NULL)
+    return 1;
+  // These do not return values, but should not crash.
+  __aeabi_vec_delete (NULL, &dtor);
+  __aeabi_vec_delete3 (NULL, &dtor, &dealloc);
+  __aeabi_vec_delete3_nodtor (NULL, &dealloc);
+}
+#else
+int main () {}
+#endif
index 1531ff3b2d7310009105a9090c4cd7984923ef52..cfb15d246d2914ca8946e7ed06068f7787c666c0 100644 (file)
@@ -1,3 +1,11 @@
+2008-06-27  Mark Mitchell  <mark@codesourcery.com>
+
+       * libsupc++/vec.cc (__aeabi_vec_dtor_cookie): Handle NULL array
+       address.
+       (__aeabi_vec_delete): Likewise.
+       (__aeabi_vec_delete3): Likewise.
+       (__aeabi_vec_delete3_nodtor): Likewise.
+
 2008-06-27  Paolo Carlini  <paolo.carlini@oracle.com>
 
        * include/bits/stl_algo.h (is_partitioned): Add in C++0x mode.
index 67caec866274ebcde5ff53a6509d0243fbefc3c1..a29bbc73266ca359cf6a2ec0051721ce43792022 100644 (file)
@@ -461,6 +461,9 @@ namespace __aeabiv1
   __aeabi_vec_dtor_cookie (void *array_address, 
                           abi::__cxa_cdtor_type destructor)
   {
+    if (!array_address)
+      return NULL;
+
     abi::__cxa_vec_dtor (array_address, 
                         reinterpret_cast<std::size_t *>(array_address)[-1],
                         reinterpret_cast<std::size_t *>(array_address)[-2],
@@ -473,6 +476,9 @@ namespace __aeabiv1
   __aeabi_vec_delete (void *array_address, 
                      abi::__cxa_cdtor_type destructor)
   {
+    if (!array_address)
+      return;
+
     abi::__cxa_vec_delete (array_address,
                           reinterpret_cast<std::size_t *>(array_address)[-2],
                           2 * sizeof (std::size_t),
@@ -484,6 +490,9 @@ namespace __aeabiv1
                       abi::__cxa_cdtor_type destructor,
                       void (*dealloc) (void *, std::size_t))
   {
+    if (!array_address)
+      return;
+
     abi::__cxa_vec_delete3 (array_address,
                            reinterpret_cast<std::size_t *>(array_address)[-2],
                            2 * sizeof (std::size_t),
@@ -494,6 +503,9 @@ namespace __aeabiv1
   __aeabi_vec_delete3_nodtor (void *array_address,
                              void (*dealloc) (void *, std::size_t))
   {
+    if (!array_address)
+      return;
+
     abi::__cxa_vec_delete3 (array_address,
                            reinterpret_cast<std::size_t *>(array_address)[-2],
                            2 * sizeof (std::size_t),