annotate libcxxabi/test/cxa_vec_new_overflow_PR41395.pass.cpp @ 174:f935e5e0dbe7

merged
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 12:28:41 +0900
parents 0572611fdcc8
children 2e18cbf3894f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
9 // UNSUPPORTED: no-exceptions
150
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 #include "cxxabi.h"
anatofuz
parents:
diff changeset
12 #include <new>
anatofuz
parents:
diff changeset
13 #include <cassert>
anatofuz
parents:
diff changeset
14
anatofuz
parents:
diff changeset
15 void dummy_ctor(void*) { assert(false && "should not be called"); }
anatofuz
parents:
diff changeset
16 void dummy_dtor(void*) { assert(false && "should not be called"); }
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 void *dummy_alloc(size_t) { assert(false && "should not be called"); }
anatofuz
parents:
diff changeset
19 void dummy_dealloc(void*) { assert(false && "should not be called"); }
anatofuz
parents:
diff changeset
20 void dummy_dealloc_sized(void*, size_t) { assert(false && "should not be called"); }
anatofuz
parents:
diff changeset
21
anatofuz
parents:
diff changeset
22
anatofuz
parents:
diff changeset
23 bool check_mul_overflows(size_t x, size_t y) {
anatofuz
parents:
diff changeset
24 size_t tmp = x * y;
anatofuz
parents:
diff changeset
25 if (tmp / x != y)
anatofuz
parents:
diff changeset
26 return true;
anatofuz
parents:
diff changeset
27 return false;
anatofuz
parents:
diff changeset
28 }
anatofuz
parents:
diff changeset
29
anatofuz
parents:
diff changeset
30 bool check_add_overflows(size_t x, size_t y) {
anatofuz
parents:
diff changeset
31 size_t tmp = x + y;
anatofuz
parents:
diff changeset
32 if (tmp < x)
anatofuz
parents:
diff changeset
33 return true;
anatofuz
parents:
diff changeset
34
anatofuz
parents:
diff changeset
35 return false;
anatofuz
parents:
diff changeset
36 }
anatofuz
parents:
diff changeset
37
anatofuz
parents:
diff changeset
38 void test_overflow_in_multiplication() {
anatofuz
parents:
diff changeset
39 const size_t elem_count = std::size_t(1) << (sizeof(std::size_t) * 8 - 2);
anatofuz
parents:
diff changeset
40 const size_t elem_size = 8;
anatofuz
parents:
diff changeset
41 const size_t padding = 0;
anatofuz
parents:
diff changeset
42 assert(check_mul_overflows(elem_count, elem_size));
anatofuz
parents:
diff changeset
43
anatofuz
parents:
diff changeset
44 try {
anatofuz
parents:
diff changeset
45 __cxxabiv1::__cxa_vec_new(elem_count, elem_size, padding, dummy_ctor,
anatofuz
parents:
diff changeset
46 dummy_dtor);
anatofuz
parents:
diff changeset
47 assert(false && "allocation should fail");
anatofuz
parents:
diff changeset
48 } catch (std::bad_array_new_length const&) {
anatofuz
parents:
diff changeset
49 // OK
anatofuz
parents:
diff changeset
50 } catch (...) {
anatofuz
parents:
diff changeset
51 assert(false && "unexpected exception");
anatofuz
parents:
diff changeset
52 }
anatofuz
parents:
diff changeset
53
anatofuz
parents:
diff changeset
54 try {
anatofuz
parents:
diff changeset
55 __cxxabiv1::__cxa_vec_new2(elem_count, elem_size, padding, dummy_ctor,
anatofuz
parents:
diff changeset
56 dummy_dtor, &dummy_alloc, &dummy_dealloc);
anatofuz
parents:
diff changeset
57 assert(false && "allocation should fail");
anatofuz
parents:
diff changeset
58 } catch (std::bad_array_new_length const&) {
anatofuz
parents:
diff changeset
59 // OK
anatofuz
parents:
diff changeset
60 } catch (...) {
anatofuz
parents:
diff changeset
61 assert(false && "unexpected exception");
anatofuz
parents:
diff changeset
62 }
anatofuz
parents:
diff changeset
63
anatofuz
parents:
diff changeset
64 try {
anatofuz
parents:
diff changeset
65 __cxxabiv1::__cxa_vec_new3(elem_count, elem_size, padding, dummy_ctor,
anatofuz
parents:
diff changeset
66 dummy_dtor, &dummy_alloc, &dummy_dealloc_sized);
anatofuz
parents:
diff changeset
67 assert(false && "allocation should fail");
anatofuz
parents:
diff changeset
68 } catch (std::bad_array_new_length const&) {
anatofuz
parents:
diff changeset
69 // OK
anatofuz
parents:
diff changeset
70 } catch (...) {
anatofuz
parents:
diff changeset
71 assert(false && "unexpected exception");
anatofuz
parents:
diff changeset
72 }
anatofuz
parents:
diff changeset
73 }
anatofuz
parents:
diff changeset
74
anatofuz
parents:
diff changeset
75 void test_overflow_in_addition() {
anatofuz
parents:
diff changeset
76 const size_t elem_size = 4;
anatofuz
parents:
diff changeset
77 const size_t elem_count = static_cast<size_t>(-1) / 4u;
anatofuz
parents:
diff changeset
78 #if defined(_LIBCXXABI_ARM_EHABI)
anatofuz
parents:
diff changeset
79 const size_t padding = 8;
anatofuz
parents:
diff changeset
80 #else
anatofuz
parents:
diff changeset
81 const size_t padding = sizeof(std::size_t);
anatofuz
parents:
diff changeset
82 #endif
anatofuz
parents:
diff changeset
83 assert(!check_mul_overflows(elem_count, elem_size));
anatofuz
parents:
diff changeset
84 assert(check_add_overflows(elem_count * elem_size, padding));
anatofuz
parents:
diff changeset
85 try {
anatofuz
parents:
diff changeset
86 __cxxabiv1::__cxa_vec_new(elem_count, elem_size, padding, dummy_ctor,
anatofuz
parents:
diff changeset
87 dummy_dtor);
anatofuz
parents:
diff changeset
88 assert(false && "allocation should fail");
anatofuz
parents:
diff changeset
89 } catch (std::bad_array_new_length const&) {
anatofuz
parents:
diff changeset
90 // OK
anatofuz
parents:
diff changeset
91 } catch (...) {
anatofuz
parents:
diff changeset
92 assert(false && "unexpected exception");
anatofuz
parents:
diff changeset
93 }
anatofuz
parents:
diff changeset
94
anatofuz
parents:
diff changeset
95
anatofuz
parents:
diff changeset
96 try {
anatofuz
parents:
diff changeset
97 __cxxabiv1::__cxa_vec_new2(elem_count, elem_size, padding, dummy_ctor,
anatofuz
parents:
diff changeset
98 dummy_dtor, &dummy_alloc, &dummy_dealloc);
anatofuz
parents:
diff changeset
99 assert(false && "allocation should fail");
anatofuz
parents:
diff changeset
100 } catch (std::bad_array_new_length const&) {
anatofuz
parents:
diff changeset
101 // OK
anatofuz
parents:
diff changeset
102 } catch (...) {
anatofuz
parents:
diff changeset
103 assert(false && "unexpected exception");
anatofuz
parents:
diff changeset
104 }
anatofuz
parents:
diff changeset
105
anatofuz
parents:
diff changeset
106 try {
anatofuz
parents:
diff changeset
107 __cxxabiv1::__cxa_vec_new3(elem_count, elem_size, padding, dummy_ctor,
anatofuz
parents:
diff changeset
108 dummy_dtor, &dummy_alloc, &dummy_dealloc_sized);
anatofuz
parents:
diff changeset
109 assert(false && "allocation should fail");
anatofuz
parents:
diff changeset
110 } catch (std::bad_array_new_length const&) {
anatofuz
parents:
diff changeset
111 // OK
anatofuz
parents:
diff changeset
112 } catch (...) {
anatofuz
parents:
diff changeset
113 assert(false && "unexpected exception");
anatofuz
parents:
diff changeset
114 }
anatofuz
parents:
diff changeset
115 }
anatofuz
parents:
diff changeset
116
anatofuz
parents:
diff changeset
117 int main(int, char**) {
anatofuz
parents:
diff changeset
118 test_overflow_in_multiplication();
anatofuz
parents:
diff changeset
119 test_overflow_in_addition();
anatofuz
parents:
diff changeset
120
anatofuz
parents:
diff changeset
121 return 0;
anatofuz
parents:
diff changeset
122 }