allocation.inline.hpp 3.8 KB
Newer Older
D
duke 已提交
1
/*
2
 * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
D
duke 已提交
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
19 20 21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
D
duke 已提交
22 23 24
 *
 */

25 26 27 28 29
#ifndef SHARE_VM_MEMORY_ALLOCATION_INLINE_HPP
#define SHARE_VM_MEMORY_ALLOCATION_INLINE_HPP

#include "runtime/os.hpp"

D
duke 已提交
30 31 32 33 34
// Explicit C-heap memory management

void trace_heap_malloc(size_t size, const char* name, void *p);
void trace_heap_free(void *p);

35
#ifndef PRODUCT
36 37
// Increments unsigned long value for statistics (not atomic on MP).
inline void inc_stat_counter(volatile julong* dest, julong add_value) {
38 39
#if defined(SPARC) || defined(X86)
  // Sparc and X86 have atomic jlong (8 bytes) instructions
40 41 42
  julong value = Atomic::load((volatile jlong*)dest);
  value += add_value;
  Atomic::store((jlong)value, (volatile jlong*)dest);
43 44 45 46
#else
  // possible word-tearing during load/store
  *dest += add_value;
#endif
47
}
48
#endif
D
duke 已提交
49 50

// allocate using malloc; will fail if no memory available
51 52
inline char* AllocateHeap(size_t size, MEMFLAGS flags, address pc = 0,
    AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM) {
Z
zgu 已提交
53 54 55 56
  if (pc == 0) {
    pc = CURRENT_PC;
  }
  char* p = (char*) os::malloc(size, flags, pc);
D
duke 已提交
57
  #ifdef ASSERT
Z
zgu 已提交
58
  if (PrintMallocFree) trace_heap_malloc(size, "AllocateHeap", p);
D
duke 已提交
59
  #endif
60
  if (p == NULL && alloc_failmode == AllocFailStrategy::EXIT_OOM) vm_exit_out_of_memory(size, "AllocateHeap");
D
duke 已提交
61 62 63
  return p;
}

64 65
inline char* ReallocateHeap(char *old, size_t size, MEMFLAGS flags,
    AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM) {
Z
zgu 已提交
66
  char* p = (char*) os::realloc(old, size, flags, CURRENT_PC);
D
duke 已提交
67
  #ifdef ASSERT
Z
zgu 已提交
68
  if (PrintMallocFree) trace_heap_malloc(size, "ReallocateHeap", p);
D
duke 已提交
69
  #endif
70
  if (p == NULL && alloc_failmode == AllocFailStrategy::EXIT_OOM) vm_exit_out_of_memory(size, "ReallocateHeap");
D
duke 已提交
71 72 73
  return p;
}

Z
zgu 已提交
74
inline void FreeHeap(void* p, MEMFLAGS memflags = mtInternal) {
D
duke 已提交
75 76 77
  #ifdef ASSERT
  if (PrintMallocFree) trace_heap_free(p);
  #endif
Z
zgu 已提交
78
  os::free(p, memflags);
D
duke 已提交
79
}
80

Z
zgu 已提交
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95

template <MEMFLAGS F> void* CHeapObj<F>::operator new(size_t size,
      address caller_pc){
#ifdef ASSERT
    void* p = (void*)AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC));
    if (PrintMallocFree) trace_heap_malloc(size, "CHeapObj-new", p);
    return p;
#else
    return (void *) AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC));
#endif
  }

template <MEMFLAGS F> void* CHeapObj<F>::operator new (size_t size,
  const std::nothrow_t&  nothrow_constant, address caller_pc) {
#ifdef ASSERT
96 97
  void* p = (void*)AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC),
      AllocFailStrategy::RETURN_NULL);
Z
zgu 已提交
98 99 100
    if (PrintMallocFree) trace_heap_malloc(size, "CHeapObj-new", p);
    return p;
#else
101 102
  return (void *) AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC),
      AllocFailStrategy::RETURN_NULL);
Z
zgu 已提交
103 104 105 106 107 108 109 110
#endif
}

template <MEMFLAGS F> void CHeapObj<F>::operator delete(void* p){
   FreeHeap(p, F);
}


111
#endif // SHARE_VM_MEMORY_ALLOCATION_INLINE_HPP