blob: 5a6acc0e4f9a8ba627001a709de3c7075242c598 [file] [log] [blame]
Elliott Hughes15b641a2014-05-14 18:18:55 -07001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include <new>
Elliott Hughesf44b2322016-05-26 17:35:00 -070018
Elliott Hughes15b641a2014-05-14 18:18:55 -070019#include <stdlib.h>
20
Christopher Ferris7a3681e2017-04-24 17:48:32 -070021#include <async_safe/log.h>
Dan Albert98972592014-05-30 16:00:53 -070022
Peter Collingbourne9397bdd2020-12-08 14:26:21 -080023__attribute__((weak)) const std::nothrow_t std::nothrow = {};
Elliott Hughes15b641a2014-05-14 18:18:55 -070024
Elliott Hughesad441522024-06-05 12:26:56 +000025// We can't throw in bionic, so we go straight to the equivalent of
26// std::terminate for these two instead.
Elliott Hughes15b641a2014-05-14 18:18:55 -070027void* operator new(std::size_t size) {
28 void* p = malloc(size);
Yi Kong32bc0fc2018-08-02 17:31:13 -070029 if (p == nullptr) {
Christopher Ferris7a3681e2017-04-24 17:48:32 -070030 async_safe_fatal("new failed to allocate %zu bytes", size);
Elliott Hughes15b641a2014-05-14 18:18:55 -070031 }
32 return p;
33}
Elliott Hughes15b641a2014-05-14 18:18:55 -070034void* operator new[](std::size_t size) {
35 void* p = malloc(size);
Yi Kong32bc0fc2018-08-02 17:31:13 -070036 if (p == nullptr) {
Christopher Ferris7a3681e2017-04-24 17:48:32 -070037 async_safe_fatal("new[] failed to allocate %zu bytes", size);
Elliott Hughes15b641a2014-05-14 18:18:55 -070038 }
39 return p;
40}
41
Elliott Hughesad441522024-06-05 12:26:56 +000042// These two are the "nothrow" variants, so we just return nullptr on failure.
Elliott Hughes15b641a2014-05-14 18:18:55 -070043void* operator new(std::size_t size, const std::nothrow_t&) {
44 return malloc(size);
45}
Elliott Hughes15b641a2014-05-14 18:18:55 -070046void* operator new[](std::size_t size, const std::nothrow_t&) {
47 return malloc(size);
48}
49
Elliott Hughesad441522024-06-05 12:26:56 +000050// free() can't throw anyway (except on heap corruption, which is always fatal),
51// so there's no difference between the regular and "nothrow" variants here.
52void operator delete(void* p) noexcept { free(p); }
53void operator delete[](void* p) noexcept { free(p); }
54void operator delete(void* p, const std::nothrow_t&) noexcept { free(p); }
55void operator delete[](void* p, const std::nothrow_t&) noexcept { free(p); }
Elliott Hughes15b641a2014-05-14 18:18:55 -070056
Elliott Hughesad441522024-06-05 12:26:56 +000057// TODO: these can use free_sized() once we have it (http://b/284321795).
58void operator delete(void* p, std::size_t) noexcept { free(p); }
59void operator delete[](void* p, std::size_t) noexcept { free(p); }