Mercurial > hg > truffle
annotate src/share/vm/memory/allocation.inline.hpp @ 7090:05ce1defa4f9
Common out some parts of UnsafeLoad/Store in UnsafeAccess
author | Gilles Duboscq <duboscq@ssw.jku.at> |
---|---|
date | Thu, 29 Nov 2012 13:24:08 +0100 |
parents | 7b5885dadbdc |
children | 63e54c37ac64 |
rev | line source |
---|---|
0 | 1 /* |
6842
b9a9ed0f8eeb
7197424: update copyright year to match last edit in jdk8 hotspot repository
mikael
parents:
6197
diff
changeset
|
2 * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. |
0 | 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 * | |
1552
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
0
diff
changeset
|
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
0
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:
0
diff
changeset
|
21 * questions. |
0 | 22 * |
23 */ | |
24 | |
1972 | 25 #ifndef SHARE_VM_MEMORY_ALLOCATION_INLINE_HPP |
26 #define SHARE_VM_MEMORY_ALLOCATION_INLINE_HPP | |
27 | |
28 #include "runtime/os.hpp" | |
29 | |
0 | 30 // Explicit C-heap memory management |
31 | |
32 void trace_heap_malloc(size_t size, const char* name, void *p); | |
33 void trace_heap_free(void *p); | |
34 | |
2255 | 35 #ifndef PRODUCT |
2250 | 36 // Increments unsigned long value for statistics (not atomic on MP). |
37 inline void inc_stat_counter(volatile julong* dest, julong add_value) { | |
2255 | 38 #if defined(SPARC) || defined(X86) |
39 // Sparc and X86 have atomic jlong (8 bytes) instructions | |
2250 | 40 julong value = Atomic::load((volatile jlong*)dest); |
41 value += add_value; | |
42 Atomic::store((jlong)value, (volatile jlong*)dest); | |
2255 | 43 #else |
44 // possible word-tearing during load/store | |
45 *dest += add_value; | |
46 #endif | |
2250 | 47 } |
2255 | 48 #endif |
0 | 49 |
50 // allocate using malloc; will fail if no memory available | |
6872
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
51 inline char* AllocateHeap(size_t size, MEMFLAGS flags, address pc = 0, |
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
52 AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM) { |
6197 | 53 if (pc == 0) { |
54 pc = CURRENT_PC; | |
55 } | |
56 char* p = (char*) os::malloc(size, flags, pc); | |
0 | 57 #ifdef ASSERT |
6197 | 58 if (PrintMallocFree) trace_heap_malloc(size, "AllocateHeap", p); |
0 | 59 #endif |
6872
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
60 if (p == NULL && alloc_failmode == AllocFailStrategy::EXIT_OOM) vm_exit_out_of_memory(size, "AllocateHeap"); |
6197 | 61 return p; |
62 } | |
63 | |
6872
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
64 inline char* ReallocateHeap(char *old, size_t size, MEMFLAGS flags, |
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
65 AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM) { |
6197 | 66 char* p = (char*) os::realloc(old, size, flags, CURRENT_PC); |
67 #ifdef ASSERT | |
68 if (PrintMallocFree) trace_heap_malloc(size, "ReallocateHeap", p); | |
69 #endif | |
6872
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
70 if (p == NULL && alloc_failmode == AllocFailStrategy::EXIT_OOM) vm_exit_out_of_memory(size, "ReallocateHeap"); |
0 | 71 return p; |
72 } | |
73 | |
6197 | 74 inline void FreeHeap(void* p, MEMFLAGS memflags = mtInternal) { |
0 | 75 #ifdef ASSERT |
76 if (PrintMallocFree) trace_heap_free(p); | |
77 #endif | |
6197 | 78 os::free(p, memflags); |
0 | 79 } |
1972 | 80 |
6197 | 81 |
82 template <MEMFLAGS F> void* CHeapObj<F>::operator new(size_t size, | |
83 address caller_pc){ | |
84 #ifdef ASSERT | |
85 void* p = (void*)AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC)); | |
86 if (PrintMallocFree) trace_heap_malloc(size, "CHeapObj-new", p); | |
87 return p; | |
88 #else | |
89 return (void *) AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC)); | |
90 #endif | |
91 } | |
92 | |
93 template <MEMFLAGS F> void* CHeapObj<F>::operator new (size_t size, | |
94 const std::nothrow_t& nothrow_constant, address caller_pc) { | |
95 #ifdef ASSERT | |
6872
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
96 void* p = (void*)AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC), |
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
97 AllocFailStrategy::RETURN_NULL); |
6197 | 98 if (PrintMallocFree) trace_heap_malloc(size, "CHeapObj-new", p); |
99 return p; | |
100 #else | |
6872
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
101 return (void *) AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC), |
7b5885dadbdc
8000617: It should be possible to allocate memory without the VM dying.
nloodin
parents:
6842
diff
changeset
|
102 AllocFailStrategy::RETURN_NULL); |
6197 | 103 #endif |
104 } | |
105 | |
106 template <MEMFLAGS F> void CHeapObj<F>::operator delete(void* p){ | |
107 FreeHeap(p, F); | |
108 } | |
109 | |
110 | |
1972 | 111 #endif // SHARE_VM_MEMORY_ALLOCATION_INLINE_HPP |