Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/src/hotspot/share/jfr/utilities/jfrAllocation.hpp
41149 views
1
/*
2
* Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved.
3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
*
5
* This code is free software; you can redistribute it and/or modify it
6
* under the terms of the GNU General Public License version 2 only, as
7
* published by the Free Software Foundation.
8
*
9
* This code is distributed in the hope that it will be useful, but WITHOUT
10
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12
* version 2 for more details (a copy is included in the LICENSE file that
13
* accompanied this code).
14
*
15
* You should have received a copy of the GNU General Public License version
16
* 2 along with this work; if not, write to the Free Software Foundation,
17
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18
*
19
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20
* or visit www.oracle.com if you need additional information or have any
21
* questions.
22
*
23
*/
24
25
#ifndef SHARE_JFR_UTILITIES_JFRALLOCATION_HPP
26
#define SHARE_JFR_UTILITIES_JFRALLOCATION_HPP
27
28
#include "memory/allocation.hpp"
29
#include "utilities/exceptions.hpp"
30
31
/*
32
* A subclass to the CHeapObj<mtTracing> allocator, useful for critical
33
* Jfr subsystems. Critical in this context means subsystems for which
34
* allocations are crucial to the bootstrap and initialization of Jfr.
35
* The default behaviour by a CHeapObj is to call vm_exit_out_of_memory()
36
* on allocation failure and this is problematic in combination with the
37
* Jfr on-demand, dynamic start at runtime, capability.
38
* We would not like a user dynamically starting Jfr to
39
* tear down the VM she is about to inspect as a side effect.
40
*
41
* This allocator uses the RETURN_NULL capabilities
42
* instead of calling vm_exit_out_of_memory() until Jfr is properly started.
43
* This allows for controlled behaviour on allocation failures during startup,
44
* which means we can take actions on failure, such as transactional rollback
45
* (deallocations and restorations).
46
* In addition, this allocator allows for easy hooking of memory
47
* allocations / deallocations for debugging purposes.
48
*/
49
50
class JfrCHeapObj : public CHeapObj<mtTracing> {
51
private:
52
static void on_memory_allocation(const void* allocation, size_t size);
53
static char* allocate_array_noinline(size_t elements, size_t element_size);
54
55
public:
56
NOINLINE void* operator new(size_t size) throw();
57
NOINLINE void* operator new (size_t size, const std::nothrow_t& nothrow_constant) throw();
58
NOINLINE void* operator new [](size_t size) throw();
59
NOINLINE void* operator new [](size_t size, const std::nothrow_t& nothrow_constant) throw();
60
void operator delete(void* p, size_t size);
61
void operator delete [] (void* p, size_t size);
62
static char* realloc_array(char* old, size_t size);
63
static void free(void* p, size_t size = 0);
64
65
template <class T>
66
static T* new_array(size_t size) {
67
T* const memory = (T*)allocate_array_noinline(size, sizeof(T));
68
on_memory_allocation(memory, sizeof(T) * size);
69
return memory;
70
}
71
};
72
73
#endif // SHARE_JFR_UTILITIES_JFRALLOCATION_HPP
74
75