annotate src/share/vm/memory/allocation.hpp @ 8804:91bf0bdae37b

8008217: CDS: Class data sharing limits the malloc heap on Solaris Summary: In 64bit VM move CDS archive address to 32G on all platforms using new flag SharedBaseAddress. In 32bit VM set CDS archive address to 3Gb on Linux and let other OSs pick the address. Reviewed-by: kvn, dcubed, zgu, hseigel
author coleenp
date Wed, 20 Mar 2013 08:04:54 -0400
parents 4102b59539ce
children 5fc51c1ecdeb 83f27710f5f7
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
2 * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 342
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 342
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 342
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
25 #ifndef SHARE_VM_MEMORY_ALLOCATION_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
26 #define SHARE_VM_MEMORY_ALLOCATION_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
27
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
28 #include "runtime/globals.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
29 #include "utilities/globalDefinitions.hpp"
6854
fb19af007ffc 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 6725
diff changeset
30 #include "utilities/macros.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
31 #ifdef COMPILER1
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
32 #include "c1/c1_globals.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
33 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
34 #ifdef COMPILER2
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
35 #include "opto/c2_globals.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
36 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
37
3302
2a3da7eaf4a6 7036747: 7017009 reappeared, problem with ElfStringTable
zgu
parents: 2307
diff changeset
38 #include <new>
2a3da7eaf4a6 7036747: 7017009 reappeared, problem with ElfStringTable
zgu
parents: 2307
diff changeset
39
0
a61af66fc99e Initial load
duke
parents:
diff changeset
40 #define ARENA_ALIGN_M1 (((size_t)(ARENA_AMALLOC_ALIGNMENT)) - 1)
a61af66fc99e Initial load
duke
parents:
diff changeset
41 #define ARENA_ALIGN_MASK (~((size_t)ARENA_ALIGN_M1))
a61af66fc99e Initial load
duke
parents:
diff changeset
42 #define ARENA_ALIGN(x) ((((size_t)(x)) + ARENA_ALIGN_M1) & ARENA_ALIGN_MASK)
a61af66fc99e Initial load
duke
parents:
diff changeset
43
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
44
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
45 // noinline attribute
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
46 #ifdef _WINDOWS
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
47 #define _NOINLINE_ __declspec(noinline)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
48 #else
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
49 #if __GNUC__ < 3 // gcc 2.x does not support noinline attribute
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
50 #define _NOINLINE_
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
51 #else
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
52 #define _NOINLINE_ __attribute__ ((noinline))
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
53 #endif
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
54 #endif
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
55
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
56 class AllocFailStrategy {
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
57 public:
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
58 enum AllocFailEnum { EXIT_OOM, RETURN_NULL };
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
59 };
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
60 typedef AllocFailStrategy::AllocFailEnum AllocFailType;
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
61
0
a61af66fc99e Initial load
duke
parents:
diff changeset
62 // All classes in the virtual machine must be subclassed
a61af66fc99e Initial load
duke
parents:
diff changeset
63 // by one of the following allocation classes:
a61af66fc99e Initial load
duke
parents:
diff changeset
64 //
a61af66fc99e Initial load
duke
parents:
diff changeset
65 // For objects allocated in the resource area (see resourceArea.hpp).
a61af66fc99e Initial load
duke
parents:
diff changeset
66 // - ResourceObj
a61af66fc99e Initial load
duke
parents:
diff changeset
67 //
a61af66fc99e Initial load
duke
parents:
diff changeset
68 // For objects allocated in the C-heap (managed by: free & malloc).
a61af66fc99e Initial load
duke
parents:
diff changeset
69 // - CHeapObj
a61af66fc99e Initial load
duke
parents:
diff changeset
70 //
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // For objects allocated on the stack.
a61af66fc99e Initial load
duke
parents:
diff changeset
72 // - StackObj
a61af66fc99e Initial load
duke
parents:
diff changeset
73 //
a61af66fc99e Initial load
duke
parents:
diff changeset
74 // For embedded objects.
a61af66fc99e Initial load
duke
parents:
diff changeset
75 // - ValueObj
a61af66fc99e Initial load
duke
parents:
diff changeset
76 //
a61af66fc99e Initial load
duke
parents:
diff changeset
77 // For classes used as name spaces.
a61af66fc99e Initial load
duke
parents:
diff changeset
78 // - AllStatic
a61af66fc99e Initial load
duke
parents:
diff changeset
79 //
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
80 // For classes in Metaspace (class data)
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
81 // - MetaspaceObj
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
82 //
0
a61af66fc99e Initial load
duke
parents:
diff changeset
83 // The printable subclasses are used for debugging and define virtual
a61af66fc99e Initial load
duke
parents:
diff changeset
84 // member functions for printing. Classes that avoid allocating the
a61af66fc99e Initial load
duke
parents:
diff changeset
85 // vtbl entries in the objects should therefore not be the printable
a61af66fc99e Initial load
duke
parents:
diff changeset
86 // subclasses.
a61af66fc99e Initial load
duke
parents:
diff changeset
87 //
a61af66fc99e Initial load
duke
parents:
diff changeset
88 // The following macros and function should be used to allocate memory
a61af66fc99e Initial load
duke
parents:
diff changeset
89 // directly in the resource area or in the C-heap:
a61af66fc99e Initial load
duke
parents:
diff changeset
90 //
a61af66fc99e Initial load
duke
parents:
diff changeset
91 // NEW_RESOURCE_ARRAY(type,size)
a61af66fc99e Initial load
duke
parents:
diff changeset
92 // NEW_RESOURCE_OBJ(type)
a61af66fc99e Initial load
duke
parents:
diff changeset
93 // NEW_C_HEAP_ARRAY(type,size)
a61af66fc99e Initial load
duke
parents:
diff changeset
94 // NEW_C_HEAP_OBJ(type)
a61af66fc99e Initial load
duke
parents:
diff changeset
95 // char* AllocateHeap(size_t size, const char* name);
a61af66fc99e Initial load
duke
parents:
diff changeset
96 // void FreeHeap(void* p);
a61af66fc99e Initial load
duke
parents:
diff changeset
97 //
a61af66fc99e Initial load
duke
parents:
diff changeset
98 // C-heap allocation can be traced using +PrintHeapAllocation.
a61af66fc99e Initial load
duke
parents:
diff changeset
99 // malloc and free should therefore never called directly.
a61af66fc99e Initial load
duke
parents:
diff changeset
100
a61af66fc99e Initial load
duke
parents:
diff changeset
101 // Base class for objects allocated in the C-heap.
a61af66fc99e Initial load
duke
parents:
diff changeset
102
a61af66fc99e Initial load
duke
parents:
diff changeset
103 // In non product mode we introduce a super class for all allocation classes
a61af66fc99e Initial load
duke
parents:
diff changeset
104 // that supports printing.
a61af66fc99e Initial load
duke
parents:
diff changeset
105 // We avoid the superclass in product mode since some C++ compilers add
a61af66fc99e Initial load
duke
parents:
diff changeset
106 // a word overhead for empty super classes.
a61af66fc99e Initial load
duke
parents:
diff changeset
107
a61af66fc99e Initial load
duke
parents:
diff changeset
108 #ifdef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
109 #define ALLOCATION_SUPER_CLASS_SPEC
a61af66fc99e Initial load
duke
parents:
diff changeset
110 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
111 #define ALLOCATION_SUPER_CLASS_SPEC : public AllocatedObj
a61af66fc99e Initial load
duke
parents:
diff changeset
112 class AllocatedObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
113 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
114 // Printing support
a61af66fc99e Initial load
duke
parents:
diff changeset
115 void print() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
116 void print_value() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
117
a61af66fc99e Initial load
duke
parents:
diff changeset
118 virtual void print_on(outputStream* st) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
119 virtual void print_value_on(outputStream* st) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
120 };
a61af66fc99e Initial load
duke
parents:
diff changeset
121 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
122
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
123
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
124 /*
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
125 * MemoryType bitmap layout:
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
126 * | 16 15 14 13 12 11 10 09 | 08 07 06 05 | 04 03 02 01 |
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
127 * | memory type | object | reserved |
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
128 * | | type | |
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
129 */
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
130 enum MemoryType {
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
131 // Memory type by sub systems. It occupies lower byte.
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
132 mtNone = 0x0000, // undefined
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
133 mtClass = 0x0100, // memory class for Java classes
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
134 mtThread = 0x0200, // memory for thread objects
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
135 mtThreadStack = 0x0300,
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
136 mtCode = 0x0400, // memory for generated code
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
137 mtGC = 0x0500, // memory for GC
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
138 mtCompiler = 0x0600, // memory for compiler
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
139 mtInternal = 0x0700, // memory used by VM, but does not belong to
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
140 // any of above categories, and not used for
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
141 // native memory tracking
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
142 mtOther = 0x0800, // memory not used by VM
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
143 mtSymbol = 0x0900, // symbol
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
144 mtNMT = 0x0A00, // memory used by native memory tracking
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
145 mtChunk = 0x0B00, // chunk that holds content of arenas
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
146 mtJavaHeap = 0x0C00, // Java heap
6882
716c64bda5ba 7199092: NMT: NMT needs to deal overlapped virtual memory ranges
zgu
parents: 6872
diff changeset
147 mtClassShared = 0x0D00, // class data sharing
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 7434
diff changeset
148 mtTest = 0x0E00, // Test type for verifying NMT
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 7434
diff changeset
149 mt_number_of_types = 0x000E, // number of memory types (mtDontTrack
6882
716c64bda5ba 7199092: NMT: NMT needs to deal overlapped virtual memory ranges
zgu
parents: 6872
diff changeset
150 // is not included as validate type)
7971
4102b59539ce 8005012: Add WB APIs to better support NMT testing
ctornqvi
parents: 7434
diff changeset
151 mtDontTrack = 0x0F00, // memory we do not or cannot track
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
152 mt_masks = 0x7F00,
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
153
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
154 // object type mask
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
155 otArena = 0x0010, // an arena object
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
156 otNMTRecorder = 0x0020, // memory recorder object
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
157 ot_masks = 0x00F0
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
158 };
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
159
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
160 #define IS_MEMORY_TYPE(flags, type) ((flags & mt_masks) == type)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
161 #define HAS_VALID_MEMORY_TYPE(flags)((flags & mt_masks) != mtNone)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
162 #define FLAGS_TO_MEMORY_TYPE(flags) (flags & mt_masks)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
163
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
164 #define IS_ARENA_OBJ(flags) ((flags & ot_masks) == otArena)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
165 #define IS_NMT_RECORDER(flags) ((flags & ot_masks) == otNMTRecorder)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
166 #define NMT_CAN_TRACK(flags) (!IS_NMT_RECORDER(flags) && !(IS_MEMORY_TYPE(flags, mtDontTrack)))
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
167
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
168 typedef unsigned short MEMFLAGS;
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
169
6854
fb19af007ffc 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 6725
diff changeset
170 #if INCLUDE_NMT
fb19af007ffc 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 6725
diff changeset
171
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
172 extern bool NMT_track_callsite;
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
173
6854
fb19af007ffc 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 6725
diff changeset
174 #else
fb19af007ffc 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 6725
diff changeset
175
fb19af007ffc 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 6725
diff changeset
176 const bool NMT_track_callsite = false;
fb19af007ffc 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 6725
diff changeset
177
fb19af007ffc 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 6725
diff changeset
178 #endif // INCLUDE_NMT
fb19af007ffc 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 6725
diff changeset
179
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
180 // debug build does not inline
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
181 #if defined(_DEBUG_)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
182 #define CURRENT_PC (NMT_track_callsite ? os::get_caller_pc(1) : 0)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
183 #define CALLER_PC (NMT_track_callsite ? os::get_caller_pc(2) : 0)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
184 #define CALLER_CALLER_PC (NMT_track_callsite ? os::get_caller_pc(3) : 0)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
185 #else
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
186 #define CURRENT_PC (NMT_track_callsite? os::get_caller_pc(0) : 0)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
187 #define CALLER_PC (NMT_track_callsite ? os::get_caller_pc(1) : 0)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
188 #define CALLER_CALLER_PC (NMT_track_callsite ? os::get_caller_pc(2) : 0)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
189 #endif
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
190
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
191
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
192
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
193 template <MEMFLAGS F> class CHeapObj ALLOCATION_SUPER_CLASS_SPEC {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
194 public:
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
195 _NOINLINE_ void* operator new(size_t size, address caller_pc = 0);
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
196 _NOINLINE_ void* operator new (size_t size, const std::nothrow_t& nothrow_constant,
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
197 address caller_pc = 0);
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
198
0
a61af66fc99e Initial load
duke
parents:
diff changeset
199 void operator delete(void* p);
a61af66fc99e Initial load
duke
parents:
diff changeset
200 };
a61af66fc99e Initial load
duke
parents:
diff changeset
201
a61af66fc99e Initial load
duke
parents:
diff changeset
202 // Base class for objects allocated on the stack only.
a61af66fc99e Initial load
duke
parents:
diff changeset
203 // Calling new or delete will result in fatal error.
a61af66fc99e Initial load
duke
parents:
diff changeset
204
a61af66fc99e Initial load
duke
parents:
diff changeset
205 class StackObj ALLOCATION_SUPER_CLASS_SPEC {
7434
32164d89fe9c 8004845: Catch incorrect usage of new and delete during compile time for value objects and stack objects
brutisso
parents: 7176
diff changeset
206 private:
0
a61af66fc99e Initial load
duke
parents:
diff changeset
207 void* operator new(size_t size);
a61af66fc99e Initial load
duke
parents:
diff changeset
208 void operator delete(void* p);
a61af66fc99e Initial load
duke
parents:
diff changeset
209 };
a61af66fc99e Initial load
duke
parents:
diff changeset
210
a61af66fc99e Initial load
duke
parents:
diff changeset
211 // Base class for objects used as value objects.
a61af66fc99e Initial load
duke
parents:
diff changeset
212 // Calling new or delete will result in fatal error.
a61af66fc99e Initial load
duke
parents:
diff changeset
213 //
a61af66fc99e Initial load
duke
parents:
diff changeset
214 // Portability note: Certain compilers (e.g. gcc) will
a61af66fc99e Initial load
duke
parents:
diff changeset
215 // always make classes bigger if it has a superclass, even
a61af66fc99e Initial load
duke
parents:
diff changeset
216 // if the superclass does not have any virtual methods or
a61af66fc99e Initial load
duke
parents:
diff changeset
217 // instance fields. The HotSpot implementation relies on this
a61af66fc99e Initial load
duke
parents:
diff changeset
218 // not to happen. So never make a ValueObj class a direct subclass
a61af66fc99e Initial load
duke
parents:
diff changeset
219 // of this object, but use the VALUE_OBJ_CLASS_SPEC class instead, e.g.,
a61af66fc99e Initial load
duke
parents:
diff changeset
220 // like this:
a61af66fc99e Initial load
duke
parents:
diff changeset
221 //
a61af66fc99e Initial load
duke
parents:
diff changeset
222 // class A VALUE_OBJ_CLASS_SPEC {
a61af66fc99e Initial load
duke
parents:
diff changeset
223 // ...
a61af66fc99e Initial load
duke
parents:
diff changeset
224 // }
a61af66fc99e Initial load
duke
parents:
diff changeset
225 //
a61af66fc99e Initial load
duke
parents:
diff changeset
226 // With gcc and possible other compilers the VALUE_OBJ_CLASS_SPEC can
a61af66fc99e Initial load
duke
parents:
diff changeset
227 // be defined as a an empty string "".
a61af66fc99e Initial load
duke
parents:
diff changeset
228 //
a61af66fc99e Initial load
duke
parents:
diff changeset
229 class _ValueObj {
7434
32164d89fe9c 8004845: Catch incorrect usage of new and delete during compile time for value objects and stack objects
brutisso
parents: 7176
diff changeset
230 private:
0
a61af66fc99e Initial load
duke
parents:
diff changeset
231 void* operator new(size_t size);
a61af66fc99e Initial load
duke
parents:
diff changeset
232 void operator delete(void* p);
a61af66fc99e Initial load
duke
parents:
diff changeset
233 };
a61af66fc99e Initial load
duke
parents:
diff changeset
234
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
235
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
236 // Base class for objects stored in Metaspace.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
237 // Calling delete will result in fatal error.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
238 //
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
239 // Do not inherit from something with a vptr because this class does
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
240 // not introduce one. This class is used to allocate both shared read-only
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
241 // and shared read-write classes.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
242 //
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
243
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
244 class ClassLoaderData;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
245
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
246 class MetaspaceObj {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
247 public:
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
248 bool is_metadata() const;
7176
59c790074993 8003635: NPG: AsynchGetCallTrace broken by Method* virtual call
coleenp
parents: 6882
diff changeset
249 bool is_metaspace_object() const; // more specific test but slower
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
250 bool is_shared() const;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
251 void print_address_on(outputStream* st) const; // nonvirtual address printing
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
252
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
253 void* operator new(size_t size, ClassLoaderData* loader_data,
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
254 size_t word_size, bool read_only, Thread* thread);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
255 // can't use TRAPS from this header file.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
256 void operator delete(void* p) { ShouldNotCallThis(); }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
257 };
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
258
0
a61af66fc99e Initial load
duke
parents:
diff changeset
259 // Base class for classes that constitute name spaces.
a61af66fc99e Initial load
duke
parents:
diff changeset
260
a61af66fc99e Initial load
duke
parents:
diff changeset
261 class AllStatic {
a61af66fc99e Initial load
duke
parents:
diff changeset
262 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
263 AllStatic() { ShouldNotCallThis(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
264 ~AllStatic() { ShouldNotCallThis(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
265 };
a61af66fc99e Initial load
duke
parents:
diff changeset
266
a61af66fc99e Initial load
duke
parents:
diff changeset
267
a61af66fc99e Initial load
duke
parents:
diff changeset
268 //------------------------------Chunk------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
269 // Linked list of raw memory chunks
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
270 class Chunk: CHeapObj<mtChunk> {
3939
f6f3bb0ee072 7088955: add C2 IR support to the SA
never
parents: 3302
diff changeset
271 friend class VMStructs;
f6f3bb0ee072 7088955: add C2 IR support to the SA
never
parents: 3302
diff changeset
272
0
a61af66fc99e Initial load
duke
parents:
diff changeset
273 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
274 Chunk* _next; // Next Chunk in list
a61af66fc99e Initial load
duke
parents:
diff changeset
275 const size_t _len; // Size of this Chunk
a61af66fc99e Initial load
duke
parents:
diff changeset
276 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
277 void* operator new(size_t size, size_t length);
a61af66fc99e Initial load
duke
parents:
diff changeset
278 void operator delete(void* p);
a61af66fc99e Initial load
duke
parents:
diff changeset
279 Chunk(size_t length);
a61af66fc99e Initial load
duke
parents:
diff changeset
280
a61af66fc99e Initial load
duke
parents:
diff changeset
281 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
282 // default sizes; make them slightly smaller than 2**k to guard against
a61af66fc99e Initial load
duke
parents:
diff changeset
283 // buddy-system style malloc implementations
a61af66fc99e Initial load
duke
parents:
diff changeset
284 #ifdef _LP64
a61af66fc99e Initial load
duke
parents:
diff changeset
285 slack = 40, // [RGV] Not sure if this is right, but make it
a61af66fc99e Initial load
duke
parents:
diff changeset
286 // a multiple of 8.
a61af66fc99e Initial load
duke
parents:
diff changeset
287 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
288 slack = 20, // suspected sizeof(Chunk) + internal malloc headers
a61af66fc99e Initial load
duke
parents:
diff changeset
289 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
290
a61af66fc99e Initial load
duke
parents:
diff changeset
291 init_size = 1*K - slack, // Size of first chunk
a61af66fc99e Initial load
duke
parents:
diff changeset
292 medium_size= 10*K - slack, // Size of medium-sized chunk
a61af66fc99e Initial load
duke
parents:
diff changeset
293 size = 32*K - slack, // Default size of an Arena chunk (following the first)
a61af66fc99e Initial load
duke
parents:
diff changeset
294 non_pool_size = init_size + 32 // An initial size which is not one of above
a61af66fc99e Initial load
duke
parents:
diff changeset
295 };
a61af66fc99e Initial load
duke
parents:
diff changeset
296
a61af66fc99e Initial load
duke
parents:
diff changeset
297 void chop(); // Chop this chunk
a61af66fc99e Initial load
duke
parents:
diff changeset
298 void next_chop(); // Chop next chunk
a61af66fc99e Initial load
duke
parents:
diff changeset
299 static size_t aligned_overhead_size(void) { return ARENA_ALIGN(sizeof(Chunk)); }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
300 static size_t aligned_overhead_size(size_t byte_size) { return ARENA_ALIGN(byte_size); }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
301
a61af66fc99e Initial load
duke
parents:
diff changeset
302 size_t length() const { return _len; }
a61af66fc99e Initial load
duke
parents:
diff changeset
303 Chunk* next() const { return _next; }
a61af66fc99e Initial load
duke
parents:
diff changeset
304 void set_next(Chunk* n) { _next = n; }
a61af66fc99e Initial load
duke
parents:
diff changeset
305 // Boundaries of data area (possibly unused)
a61af66fc99e Initial load
duke
parents:
diff changeset
306 char* bottom() const { return ((char*) this) + aligned_overhead_size(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
307 char* top() const { return bottom() + _len; }
a61af66fc99e Initial load
duke
parents:
diff changeset
308 bool contains(char* p) const { return bottom() <= p && p <= top(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
309
a61af66fc99e Initial load
duke
parents:
diff changeset
310 // Start the chunk_pool cleaner task
a61af66fc99e Initial load
duke
parents:
diff changeset
311 static void start_chunk_pool_cleaner_task();
1681
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
312
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
313 static void clean_chunk_pool();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
314 };
a61af66fc99e Initial load
duke
parents:
diff changeset
315
a61af66fc99e Initial load
duke
parents:
diff changeset
316 //------------------------------Arena------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
317 // Fast allocation of memory
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
318 class Arena : public CHeapObj<mtNone|otArena> {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
319 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
320 friend class ResourceMark;
a61af66fc99e Initial load
duke
parents:
diff changeset
321 friend class HandleMark;
a61af66fc99e Initial load
duke
parents:
diff changeset
322 friend class NoHandleMark;
3939
f6f3bb0ee072 7088955: add C2 IR support to the SA
never
parents: 3302
diff changeset
323 friend class VMStructs;
f6f3bb0ee072 7088955: add C2 IR support to the SA
never
parents: 3302
diff changeset
324
0
a61af66fc99e Initial load
duke
parents:
diff changeset
325 Chunk *_first; // First chunk
a61af66fc99e Initial load
duke
parents:
diff changeset
326 Chunk *_chunk; // current chunk
a61af66fc99e Initial load
duke
parents:
diff changeset
327 char *_hwm, *_max; // High water mark and max in current chunk
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
328 // Get a new Chunk of at least size x
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
329 void* grow(size_t x, AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM);
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
330 size_t _size_in_bytes; // Size of arena (used for native memory tracking)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
331
2250
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
332 NOT_PRODUCT(static julong _bytes_allocated;) // total #bytes allocated since start
0
a61af66fc99e Initial load
duke
parents:
diff changeset
333 friend class AllocStats;
a61af66fc99e Initial load
duke
parents:
diff changeset
334 debug_only(void* malloc(size_t size);)
a61af66fc99e Initial load
duke
parents:
diff changeset
335 debug_only(void* internal_malloc_4(size_t x);)
2250
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
336 NOT_PRODUCT(void inc_bytes_allocated(size_t x);)
2307
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
337
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
338 void signal_out_of_memory(size_t request, const char* whence) const;
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
339
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
340 void check_for_overflow(size_t request, const char* whence) const {
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
341 if (UINTPTR_MAX - request < (uintptr_t)_hwm) {
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
342 signal_out_of_memory(request, whence);
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
343 }
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
344 }
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
345
0
a61af66fc99e Initial load
duke
parents:
diff changeset
346 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
347 Arena();
a61af66fc99e Initial load
duke
parents:
diff changeset
348 Arena(size_t init_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
349 ~Arena();
a61af66fc99e Initial load
duke
parents:
diff changeset
350 void destruct_contents();
a61af66fc99e Initial load
duke
parents:
diff changeset
351 char* hwm() const { return _hwm; }
a61af66fc99e Initial load
duke
parents:
diff changeset
352
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
353 // new operators
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
354 void* operator new (size_t size);
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
355 void* operator new (size_t size, const std::nothrow_t& nothrow_constant);
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
356
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
357 // dynamic memory type tagging
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
358 void* operator new(size_t size, MEMFLAGS flags);
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
359 void* operator new(size_t size, const std::nothrow_t& nothrow_constant, MEMFLAGS flags);
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
360 void operator delete(void* p);
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
361
0
a61af66fc99e Initial load
duke
parents:
diff changeset
362 // Fast allocate in the arena. Common case is: pointer test + increment.
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
363 void* Amalloc(size_t x, AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
364 assert(is_power_of_2(ARENA_AMALLOC_ALIGNMENT) , "should be a power of 2");
a61af66fc99e Initial load
duke
parents:
diff changeset
365 x = ARENA_ALIGN(x);
a61af66fc99e Initial load
duke
parents:
diff changeset
366 debug_only(if (UseMallocOnly) return malloc(x);)
2307
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
367 check_for_overflow(x, "Arena::Amalloc");
2250
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
368 NOT_PRODUCT(inc_bytes_allocated(x);)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
369 if (_hwm + x > _max) {
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
370 return grow(x, alloc_failmode);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
371 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
372 char *old = _hwm;
a61af66fc99e Initial load
duke
parents:
diff changeset
373 _hwm += x;
a61af66fc99e Initial load
duke
parents:
diff changeset
374 return old;
a61af66fc99e Initial load
duke
parents:
diff changeset
375 }
a61af66fc99e Initial load
duke
parents:
diff changeset
376 }
a61af66fc99e Initial load
duke
parents:
diff changeset
377 // Further assume size is padded out to words
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
378 void *Amalloc_4(size_t x, AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
379 assert( (x&(sizeof(char*)-1)) == 0, "misaligned size" );
a61af66fc99e Initial load
duke
parents:
diff changeset
380 debug_only(if (UseMallocOnly) return malloc(x);)
2307
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
381 check_for_overflow(x, "Arena::Amalloc_4");
2250
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
382 NOT_PRODUCT(inc_bytes_allocated(x);)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
383 if (_hwm + x > _max) {
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
384 return grow(x, alloc_failmode);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
385 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
386 char *old = _hwm;
a61af66fc99e Initial load
duke
parents:
diff changeset
387 _hwm += x;
a61af66fc99e Initial load
duke
parents:
diff changeset
388 return old;
a61af66fc99e Initial load
duke
parents:
diff changeset
389 }
a61af66fc99e Initial load
duke
parents:
diff changeset
390 }
a61af66fc99e Initial load
duke
parents:
diff changeset
391
a61af66fc99e Initial load
duke
parents:
diff changeset
392 // Allocate with 'double' alignment. It is 8 bytes on sparc.
a61af66fc99e Initial load
duke
parents:
diff changeset
393 // In other cases Amalloc_D() should be the same as Amalloc_4().
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
394 void* Amalloc_D(size_t x, AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
395 assert( (x&(sizeof(char*)-1)) == 0, "misaligned size" );
a61af66fc99e Initial load
duke
parents:
diff changeset
396 debug_only(if (UseMallocOnly) return malloc(x);)
a61af66fc99e Initial load
duke
parents:
diff changeset
397 #if defined(SPARC) && !defined(_LP64)
a61af66fc99e Initial load
duke
parents:
diff changeset
398 #define DALIGN_M1 7
a61af66fc99e Initial load
duke
parents:
diff changeset
399 size_t delta = (((size_t)_hwm + DALIGN_M1) & ~DALIGN_M1) - (size_t)_hwm;
a61af66fc99e Initial load
duke
parents:
diff changeset
400 x += delta;
a61af66fc99e Initial load
duke
parents:
diff changeset
401 #endif
2307
4a9604cd7c5f 6878713: Verifier heap corruption, relating to backward jsrs
kamg
parents: 2250
diff changeset
402 check_for_overflow(x, "Arena::Amalloc_D");
2250
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
403 NOT_PRODUCT(inc_bytes_allocated(x);)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
404 if (_hwm + x > _max) {
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
405 return grow(x, alloc_failmode); // grow() returns a result aligned >= 8 bytes.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
406 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
407 char *old = _hwm;
a61af66fc99e Initial load
duke
parents:
diff changeset
408 _hwm += x;
a61af66fc99e Initial load
duke
parents:
diff changeset
409 #if defined(SPARC) && !defined(_LP64)
a61af66fc99e Initial load
duke
parents:
diff changeset
410 old += delta; // align to 8-bytes
a61af66fc99e Initial load
duke
parents:
diff changeset
411 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
412 return old;
a61af66fc99e Initial load
duke
parents:
diff changeset
413 }
a61af66fc99e Initial load
duke
parents:
diff changeset
414 }
a61af66fc99e Initial load
duke
parents:
diff changeset
415
a61af66fc99e Initial load
duke
parents:
diff changeset
416 // Fast delete in area. Common case is: NOP (except for storage reclaimed)
a61af66fc99e Initial load
duke
parents:
diff changeset
417 void Afree(void *ptr, size_t size) {
a61af66fc99e Initial load
duke
parents:
diff changeset
418 #ifdef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
419 if (ZapResourceArea) memset(ptr, badResourceValue, size); // zap freed memory
a61af66fc99e Initial load
duke
parents:
diff changeset
420 if (UseMallocOnly) return;
a61af66fc99e Initial load
duke
parents:
diff changeset
421 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
422 if (((char*)ptr) + size == _hwm) _hwm = (char*)ptr;
a61af66fc99e Initial load
duke
parents:
diff changeset
423 }
a61af66fc99e Initial load
duke
parents:
diff changeset
424
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
425 void *Arealloc( void *old_ptr, size_t old_size, size_t new_size,
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
426 AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
427
a61af66fc99e Initial load
duke
parents:
diff changeset
428 // Move contents of this arena into an empty arena
a61af66fc99e Initial load
duke
parents:
diff changeset
429 Arena *move_contents(Arena *empty_arena);
a61af66fc99e Initial load
duke
parents:
diff changeset
430
a61af66fc99e Initial load
duke
parents:
diff changeset
431 // Determine if pointer belongs to this Arena or not.
a61af66fc99e Initial load
duke
parents:
diff changeset
432 bool contains( const void *ptr ) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
433
a61af66fc99e Initial load
duke
parents:
diff changeset
434 // Total of all chunks in use (not thread-safe)
a61af66fc99e Initial load
duke
parents:
diff changeset
435 size_t used() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
436
a61af66fc99e Initial load
duke
parents:
diff changeset
437 // Total # of bytes used
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
438 size_t size_in_bytes() const { return _size_in_bytes; };
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
439 void set_size_in_bytes(size_t size);
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
440
0
a61af66fc99e Initial load
duke
parents:
diff changeset
441 static void free_malloced_objects(Chunk* chunk, char* hwm, char* max, char* hwm2) PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
442 static void free_all(char** start, char** end) PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
443
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
444 // how many arena instances
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
445 NOT_PRODUCT(static volatile jint _instance_count;)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
446 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
447 // Reset this Arena to empty, access will trigger grow if necessary
a61af66fc99e Initial load
duke
parents:
diff changeset
448 void reset(void) {
a61af66fc99e Initial load
duke
parents:
diff changeset
449 _first = _chunk = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
450 _hwm = _max = NULL;
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
451 set_size_in_bytes(0);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
452 }
a61af66fc99e Initial load
duke
parents:
diff changeset
453 };
a61af66fc99e Initial load
duke
parents:
diff changeset
454
a61af66fc99e Initial load
duke
parents:
diff changeset
455 // One of the following macros must be used when allocating
a61af66fc99e Initial load
duke
parents:
diff changeset
456 // an array or object from an arena
1836
894b1d7c7e01 6423256: GC stacks should use a better data structure
jcoomes
parents: 1689
diff changeset
457 #define NEW_ARENA_ARRAY(arena, type, size) \
894b1d7c7e01 6423256: GC stacks should use a better data structure
jcoomes
parents: 1689
diff changeset
458 (type*) (arena)->Amalloc((size) * sizeof(type))
0
a61af66fc99e Initial load
duke
parents:
diff changeset
459
1836
894b1d7c7e01 6423256: GC stacks should use a better data structure
jcoomes
parents: 1689
diff changeset
460 #define REALLOC_ARENA_ARRAY(arena, type, old, old_size, new_size) \
894b1d7c7e01 6423256: GC stacks should use a better data structure
jcoomes
parents: 1689
diff changeset
461 (type*) (arena)->Arealloc((char*)(old), (old_size) * sizeof(type), \
894b1d7c7e01 6423256: GC stacks should use a better data structure
jcoomes
parents: 1689
diff changeset
462 (new_size) * sizeof(type) )
0
a61af66fc99e Initial load
duke
parents:
diff changeset
463
1836
894b1d7c7e01 6423256: GC stacks should use a better data structure
jcoomes
parents: 1689
diff changeset
464 #define FREE_ARENA_ARRAY(arena, type, old, size) \
894b1d7c7e01 6423256: GC stacks should use a better data structure
jcoomes
parents: 1689
diff changeset
465 (arena)->Afree((char*)(old), (size) * sizeof(type))
0
a61af66fc99e Initial load
duke
parents:
diff changeset
466
1836
894b1d7c7e01 6423256: GC stacks should use a better data structure
jcoomes
parents: 1689
diff changeset
467 #define NEW_ARENA_OBJ(arena, type) \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
468 NEW_ARENA_ARRAY(arena, type, 1)
a61af66fc99e Initial load
duke
parents:
diff changeset
469
a61af66fc99e Initial load
duke
parents:
diff changeset
470
a61af66fc99e Initial load
duke
parents:
diff changeset
471 //%note allocation_1
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
472 extern char* resource_allocate_bytes(size_t size,
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
473 AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM);
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
474 extern char* resource_allocate_bytes(Thread* thread, size_t size,
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
475 AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM);
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
476 extern char* resource_reallocate_bytes( char *old, size_t old_size, size_t new_size,
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
477 AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
478 extern void resource_free_bytes( char *old, size_t size );
a61af66fc99e Initial load
duke
parents:
diff changeset
479
a61af66fc99e Initial load
duke
parents:
diff changeset
480 //----------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
481 // Base class for objects allocated in the resource area per default.
a61af66fc99e Initial load
duke
parents:
diff changeset
482 // Optionally, objects may be allocated on the C heap with
a61af66fc99e Initial load
duke
parents:
diff changeset
483 // new(ResourceObj::C_HEAP) Foo(...) or in an Arena with new (&arena)
a61af66fc99e Initial load
duke
parents:
diff changeset
484 // ResourceObj's can be allocated within other objects, but don't use
a61af66fc99e Initial load
duke
parents:
diff changeset
485 // new or delete (allocation_type is unknown). If new is used to allocate,
a61af66fc99e Initial load
duke
parents:
diff changeset
486 // use delete to deallocate.
a61af66fc99e Initial load
duke
parents:
diff changeset
487 class ResourceObj ALLOCATION_SUPER_CLASS_SPEC {
a61af66fc99e Initial load
duke
parents:
diff changeset
488 public:
1685
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
489 enum allocation_type { STACK_OR_EMBEDDED = 0, RESOURCE_AREA, C_HEAP, ARENA, allocation_mask = 0x3 };
1688
2dfd013a7465 6975078: assert(allocated_on_res_area() || allocated_on_C_heap() || allocated_on_arena()
kvn
parents: 1685
diff changeset
490 static void set_allocation_type(address res, allocation_type type) NOT_DEBUG_RETURN;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
491 #ifdef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
492 private:
1685
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
493 // When this object is allocated on stack the new() operator is not
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
494 // called but garbage on stack may look like a valid allocation_type.
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
495 // Store negated 'this' pointer when new() is called to distinguish cases.
2015
79d8657be916 6993125: runThese crashes with assert(Thread::current()->on_local_stack((address)this))
kvn
parents: 1972
diff changeset
496 // Use second array's element for verification value to distinguish garbage.
79d8657be916 6993125: runThese crashes with assert(Thread::current()->on_local_stack((address)this))
kvn
parents: 1972
diff changeset
497 uintptr_t _allocation_t[2];
79d8657be916 6993125: runThese crashes with assert(Thread::current()->on_local_stack((address)this))
kvn
parents: 1972
diff changeset
498 bool is_type_set() const;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
499 public:
1688
2dfd013a7465 6975078: assert(allocated_on_res_area() || allocated_on_C_heap() || allocated_on_arena()
kvn
parents: 1685
diff changeset
500 allocation_type get_allocation_type() const;
2dfd013a7465 6975078: assert(allocated_on_res_area() || allocated_on_C_heap() || allocated_on_arena()
kvn
parents: 1685
diff changeset
501 bool allocated_on_stack() const { return get_allocation_type() == STACK_OR_EMBEDDED; }
2dfd013a7465 6975078: assert(allocated_on_res_area() || allocated_on_C_heap() || allocated_on_arena()
kvn
parents: 1685
diff changeset
502 bool allocated_on_res_area() const { return get_allocation_type() == RESOURCE_AREA; }
2dfd013a7465 6975078: assert(allocated_on_res_area() || allocated_on_C_heap() || allocated_on_arena()
kvn
parents: 1685
diff changeset
503 bool allocated_on_C_heap() const { return get_allocation_type() == C_HEAP; }
2dfd013a7465 6975078: assert(allocated_on_res_area() || allocated_on_C_heap() || allocated_on_arena()
kvn
parents: 1685
diff changeset
504 bool allocated_on_arena() const { return get_allocation_type() == ARENA; }
1685
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
505 ResourceObj(); // default construtor
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
506 ResourceObj(const ResourceObj& r); // default copy construtor
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
507 ResourceObj& operator=(const ResourceObj& r); // default copy assignment
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
508 ~ResourceObj();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
509 #endif // ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
510
a61af66fc99e Initial load
duke
parents:
diff changeset
511 public:
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
512 void* operator new(size_t size, allocation_type type, MEMFLAGS flags);
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
513 void* operator new(size_t size, const std::nothrow_t& nothrow_constant,
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
514 allocation_type type, MEMFLAGS flags);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
515 void* operator new(size_t size, Arena *arena) {
a61af66fc99e Initial load
duke
parents:
diff changeset
516 address res = (address)arena->Amalloc(size);
1685
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
517 DEBUG_ONLY(set_allocation_type(res, ARENA);)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
518 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
519 }
a61af66fc99e Initial load
duke
parents:
diff changeset
520 void* operator new(size_t size) {
a61af66fc99e Initial load
duke
parents:
diff changeset
521 address res = (address)resource_allocate_bytes(size);
1685
0e35fa8ebccd 6973963: SEGV in ciBlock::start_bci() with EA
kvn
parents: 1552
diff changeset
522 DEBUG_ONLY(set_allocation_type(res, RESOURCE_AREA);)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
523 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
524 }
6872
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
525
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
526 void* operator new(size_t size, const std::nothrow_t& nothrow_constant) {
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
527 address res = (address)resource_allocate_bytes(size, AllocFailStrategy::RETURN_NULL);
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
528 DEBUG_ONLY(if (res != NULL) set_allocation_type(res, RESOURCE_AREA);)
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
529 return res;
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
530 }
7b5885dadbdc 8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents: 6854
diff changeset
531
0
a61af66fc99e Initial load
duke
parents:
diff changeset
532 void operator delete(void* p);
a61af66fc99e Initial load
duke
parents:
diff changeset
533 };
a61af66fc99e Initial load
duke
parents:
diff changeset
534
a61af66fc99e Initial load
duke
parents:
diff changeset
535 // One of the following macros must be used when allocating an array
a61af66fc99e Initial load
duke
parents:
diff changeset
536 // or object to determine whether it should reside in the C heap on in
a61af66fc99e Initial load
duke
parents:
diff changeset
537 // the resource area.
a61af66fc99e Initial load
duke
parents:
diff changeset
538
a61af66fc99e Initial load
duke
parents:
diff changeset
539 #define NEW_RESOURCE_ARRAY(type, size)\
a61af66fc99e Initial load
duke
parents:
diff changeset
540 (type*) resource_allocate_bytes((size) * sizeof(type))
a61af66fc99e Initial load
duke
parents:
diff changeset
541
a61af66fc99e Initial load
duke
parents:
diff changeset
542 #define NEW_RESOURCE_ARRAY_IN_THREAD(thread, type, size)\
a61af66fc99e Initial load
duke
parents:
diff changeset
543 (type*) resource_allocate_bytes(thread, (size) * sizeof(type))
a61af66fc99e Initial load
duke
parents:
diff changeset
544
a61af66fc99e Initial load
duke
parents:
diff changeset
545 #define REALLOC_RESOURCE_ARRAY(type, old, old_size, new_size)\
a61af66fc99e Initial load
duke
parents:
diff changeset
546 (type*) resource_reallocate_bytes((char*)(old), (old_size) * sizeof(type), (new_size) * sizeof(type) )
a61af66fc99e Initial load
duke
parents:
diff changeset
547
a61af66fc99e Initial load
duke
parents:
diff changeset
548 #define FREE_RESOURCE_ARRAY(type, old, size)\
a61af66fc99e Initial load
duke
parents:
diff changeset
549 resource_free_bytes((char*)(old), (size) * sizeof(type))
a61af66fc99e Initial load
duke
parents:
diff changeset
550
a61af66fc99e Initial load
duke
parents:
diff changeset
551 #define FREE_FAST(old)\
a61af66fc99e Initial load
duke
parents:
diff changeset
552 /* nop */
a61af66fc99e Initial load
duke
parents:
diff changeset
553
a61af66fc99e Initial load
duke
parents:
diff changeset
554 #define NEW_RESOURCE_OBJ(type)\
a61af66fc99e Initial load
duke
parents:
diff changeset
555 NEW_RESOURCE_ARRAY(type, 1)
a61af66fc99e Initial load
duke
parents:
diff changeset
556
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
557 #define NEW_C_HEAP_ARRAY(type, size, memflags)\
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
558 (type*) (AllocateHeap((size) * sizeof(type), memflags))
0
a61af66fc99e Initial load
duke
parents:
diff changeset
559
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
560 #define REALLOC_C_HEAP_ARRAY(type, old, size, memflags)\
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
561 (type*) (ReallocateHeap((char*)old, (size) * sizeof(type), memflags))
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
562
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
563 #define FREE_C_HEAP_ARRAY(type,old,memflags) \
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
564 FreeHeap((char*)(old), memflags)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
565
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
566 #define NEW_C_HEAP_OBJ(type, memflags)\
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
567 NEW_C_HEAP_ARRAY(type, 1, memflags)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
568
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
569
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
570 #define NEW_C_HEAP_ARRAY2(type, size, memflags, pc)\
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
571 (type*) (AllocateHeap((size) * sizeof(type), memflags, pc))
0
a61af66fc99e Initial load
duke
parents:
diff changeset
572
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
573 #define REALLOC_C_HEAP_ARRAY2(type, old, size, memflags, pc)\
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
574 (type*) (ReallocateHeap((char*)old, (size) * sizeof(type), memflags, pc))
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
575
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
576 #define NEW_C_HEAP_OBJ2(type, memflags, pc)\
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
577 NEW_C_HEAP_ARRAY2(type, 1, memflags, pc)
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 3939
diff changeset
578
0
a61af66fc99e Initial load
duke
parents:
diff changeset
579
a61af66fc99e Initial load
duke
parents:
diff changeset
580 extern bool warn_new_operator;
a61af66fc99e Initial load
duke
parents:
diff changeset
581
a61af66fc99e Initial load
duke
parents:
diff changeset
582 // for statistics
a61af66fc99e Initial load
duke
parents:
diff changeset
583 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
584 class AllocStats : StackObj {
2250
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
585 julong start_mallocs, start_frees;
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
586 julong start_malloc_bytes, start_mfree_bytes, start_res_bytes;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
587 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
588 AllocStats();
a61af66fc99e Initial load
duke
parents:
diff changeset
589
2250
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
590 julong num_mallocs(); // since creation of receiver
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
591 julong alloc_bytes();
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
592 julong num_frees();
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
593 julong free_bytes();
f7de3327c683 7017124: Fix some VM stats to avoid 32-bit overflow
kvn
parents: 2015
diff changeset
594 julong resource_bytes();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
595 void print();
a61af66fc99e Initial load
duke
parents:
diff changeset
596 };
a61af66fc99e Initial load
duke
parents:
diff changeset
597 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
598
a61af66fc99e Initial load
duke
parents:
diff changeset
599
a61af66fc99e Initial load
duke
parents:
diff changeset
600 //------------------------------ReallocMark---------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
601 // Code which uses REALLOC_RESOURCE_ARRAY should check an associated
a61af66fc99e Initial load
duke
parents:
diff changeset
602 // ReallocMark, which is declared in the same scope as the reallocated
a61af66fc99e Initial load
duke
parents:
diff changeset
603 // pointer. Any operation that could __potentially__ cause a reallocation
a61af66fc99e Initial load
duke
parents:
diff changeset
604 // should check the ReallocMark.
a61af66fc99e Initial load
duke
parents:
diff changeset
605 class ReallocMark: public StackObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
606 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
607 NOT_PRODUCT(int _nesting;)
a61af66fc99e Initial load
duke
parents:
diff changeset
608
a61af66fc99e Initial load
duke
parents:
diff changeset
609 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
610 ReallocMark() PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
611 void check() PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
612 };
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
613
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1836
diff changeset
614 #endif // SHARE_VM_MEMORY_ALLOCATION_HPP