src/hotspot/share/memory/metaspace/spaceManager.cpp
author stuefe
Mon, 21 Oct 2019 16:43:06 +0200
branchstuefe-new-metaspace-branch
changeset 58716 960e372a6065
parent 58683 2d5dd194c65c
child 58840 7678903a348f
permissions -rw-r--r--
Fix error in chunk allocation strategy which caused small chunks to dominate
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
     1
/*
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 53970
diff changeset
     2
 * Copyright (c) 2018, 2019, Oracle and/or its affiliates. All rights reserved.
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
     3
 * Copyright (c) 2018, 2019 SAP SE. All rights reserved.
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
     4
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
     5
 *
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
     6
 * This code is free software; you can redistribute it and/or modify it
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
     7
 * under the terms of the GNU General Public License version 2 only, as
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
     8
 * published by the Free Software Foundation.
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
     9
 *
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    10
 * This code is distributed in the hope that it will be useful, but WITHOUT
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    11
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    12
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    13
 * version 2 for more details (a copy is included in the LICENSE file that
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    14
 * accompanied this code).
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    15
 *
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    16
 * You should have received a copy of the GNU General Public License version
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    17
 * 2 along with this work; if not, write to the Free Software Foundation,
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    18
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    19
 *
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    20
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    21
 * or visit www.oracle.com if you need additional information or have any
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    22
 * questions.
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    23
 *
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    24
 */
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    25
#include "precompiled.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    26
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    27
#include "logging/log.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    28
#include "logging/logStream.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    29
#include "memory/metaspace/chunkManager.hpp"
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    30
#include "memory/metaspace/internStat.hpp"
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    31
#include "memory/metaspace/metachunk.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    32
#include "memory/metaspace/metaDebug.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    33
#include "memory/metaspace/metaspaceCommon.hpp"
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    34
#include "memory/metaspace/metaspaceStatistics.hpp"
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    35
#include "memory/metaspace/smallBlocks.hpp"
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    36
#include "memory/metaspace/spaceManager.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    37
#include "memory/metaspace/virtualSpaceList.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    38
#include "runtime/atomic.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    39
#include "runtime/init.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    40
#include "services/memoryService.hpp"
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    41
#include "utilities/align.hpp"
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    42
#include "utilities/debug.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    43
#include "utilities/globalDefinitions.hpp"
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    44
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    45
namespace metaspace {
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    46
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    47
// Given a net allocation word size, return the raw word size
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    48
// we need to actually allocate in order to:
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    49
// 1) be able to deallocate the allocation - deallocated blocks are stored either in SmallBlocks
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    50
//    (an array of short lists) or, beyond a certain size, in a dictionary tree.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    51
//    For that to work the allocated block must be at least three words.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    52
// 2) be aligned to sizeof(void*)
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    53
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    54
// Note: externally visible for gtests.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    55
//static
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    56
size_t get_raw_allocation_word_size(size_t net_word_size) {
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    57
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    58
  size_t byte_size = net_word_size * BytesPerWord;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    59
  byte_size = MAX2(byte_size, (size_t)SmallBlocks::small_block_min_byte_size());
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    60
  byte_size = align_up(byte_size, Metachunk::allocation_alignment_bytes);
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    61
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    62
  size_t word_size = byte_size / BytesPerWord;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    63
  assert(word_size * BytesPerWord == byte_size, "Sanity");
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    64
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    65
  return word_size;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    66
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    67
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    68
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    69
static const size_t highest_possible_delta_between_raw_and_net_size = get_raw_allocation_word_size(1) - 1;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    70
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    71
// The inverse function to get_raw_allocation_word_size: Given a raw size, return the max net word size
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    72
// fitting into it.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    73
static size_t get_net_allocation_word_size(size_t raw_word_size) {
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    74
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    75
  size_t byte_size = raw_word_size * BytesPerWord;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    76
  byte_size = align_down(byte_size, Metachunk::allocation_alignment_bytes);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    77
  if (byte_size < SmallBlocks::small_block_min_byte_size()) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    78
    return 0;
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    79
  }
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    80
  return byte_size / BytesPerWord;
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    81
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    82
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    83
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    84
// Given a requested word size, will allocate a chunk large enough to at least fit that
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
    85
// size, but may be larger according to internal heuristics.
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
    86
//
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
    87
// On success, it will replace the current chunk with the newly allocated one, which will
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
    88
// become the current chunk. The old current chunk should be retired beforehand.
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
    89
//
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
    90
// May fail if we could not allocate a new chunk. In that case the current chunk remains
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
    91
// unchanged and false is returned.
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
    92
bool SpaceManager::allocate_new_current_chunk(size_t requested_word_size) {
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    93
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
    94
  assert_lock_strong(lock());
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    95
58228
6e61beb13680 Fix gc/class_unloading/.. tests
stuefe
parents: 58227
diff changeset
    96
  guarantee(requested_word_size <= chklvl::MAX_CHUNK_WORD_SIZE,
6e61beb13680 Fix gc/class_unloading/.. tests
stuefe
parents: 58227
diff changeset
    97
            "Requested size too large (" SIZE_FORMAT ") - max allowed size per allocation is " SIZE_FORMAT ".",
6e61beb13680 Fix gc/class_unloading/.. tests
stuefe
parents: 58227
diff changeset
    98
            requested_word_size, chklvl::MAX_CHUNK_WORD_SIZE);
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
    99
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   100
  // If we have a current chunk, it should have been retired (almost empty) beforehand.
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   101
  // See: retire_current_chunk().
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   102
  assert(current_chunk() == NULL || current_chunk()->free_below_committed_words() <= 10, "Must retire chunk beforehand");
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   103
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   104
  const chklvl_t min_level = chklvl::level_fitting_word_size(requested_word_size);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   105
  chklvl_t pref_level = _chunk_alloc_sequence->get_next_chunk_level(_chunks.size());
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   106
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   107
  if (pref_level > min_level) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   108
    pref_level = min_level;
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   109
  }
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   110
58716
960e372a6065 Fix error in chunk allocation strategy which caused small chunks to dominate
stuefe
parents: 58683
diff changeset
   111
  log_trace(metaspace)("SpaceManager %s: requested word size_ " SIZE_FORMAT ", num chunks so far: %d, preferred level: "
960e372a6065 Fix error in chunk allocation strategy which caused small chunks to dominate
stuefe
parents: 58683
diff changeset
   112
                       CHKLVL_FORMAT ", min level: " CHKLVL_FORMAT ".",
960e372a6065 Fix error in chunk allocation strategy which caused small chunks to dominate
stuefe
parents: 58683
diff changeset
   113
                       _name, requested_word_size, _chunks.size(), pref_level, min_level);
960e372a6065 Fix error in chunk allocation strategy which caused small chunks to dominate
stuefe
parents: 58683
diff changeset
   114
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   115
  Metachunk* c = _chunk_manager->get_chunk(min_level, pref_level);
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   116
  if (c == NULL) {
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   117
    log_debug(metaspace)("SpaceManager %s: failed to allocate new chunk for requested word size " SIZE_FORMAT ".",
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   118
                         _name, requested_word_size);
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   119
    return false;
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   120
  }
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   121
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   122
  assert(c->is_in_use(), "Wrong chunk state.");
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   123
  assert(c->level() <= min_level && c->level() >= pref_level, "Sanity");
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   124
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   125
  _chunks.add(c);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   126
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   127
  log_debug(metaspace)("SpaceManager %s: allocated new chunk " METACHUNK_FORMAT " for requested word size " SIZE_FORMAT ".",
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   128
                       _name, METACHUNK_FORMAT_ARGS(c), requested_word_size);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   129
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   130
  return c;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   131
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   132
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   133
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   134
void SpaceManager::create_block_freelist() {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   135
  assert(_block_freelist == NULL, "Only call once");
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   136
  _block_freelist = new BlockFreelist();
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   137
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   138
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   139
void SpaceManager::add_allocation_to_block_freelist(MetaWord* p, size_t word_size) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   140
  if (_block_freelist == NULL) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   141
    _block_freelist = new BlockFreelist(); // Create only on demand
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   142
  }
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   143
  _block_freelist->return_block(p, word_size);
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   144
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   145
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   146
SpaceManager::SpaceManager(ChunkManager* chunk_manager,
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   147
             const ChunkAllocSequence* alloc_sequence,
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   148
             Mutex* lock,
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   149
             SizeAtomicCounter* total_used_words_counter,
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   150
             const char* name)
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   151
: _lock(lock),
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   152
  _chunk_manager(chunk_manager),
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   153
  _chunk_alloc_sequence(alloc_sequence),
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   154
  _chunks(),
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   155
  _block_freelist(NULL),
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   156
  _total_used_words_counter(total_used_words_counter),
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   157
  _name(name)
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   158
{
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   159
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   160
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   161
SpaceManager::~SpaceManager() {
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   162
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   163
  MutexLocker fcl(lock(), Mutex::_no_safepoint_check_flag);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   164
  Metachunk* c = _chunks.first();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   165
  Metachunk* c2 = NULL;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   166
  while(c) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   167
    // c may become invalid. Take care while iterating.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   168
    c2 = c->next();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   169
    _total_used_words_counter->decrement_by(c->used_words());
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   170
    _chunks.remove(c);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   171
    _chunk_manager->return_chunk(c);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   172
    c = c2;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   173
  }
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   174
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   175
  DEBUG_ONLY(chunk_manager()->verify(true);)
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   176
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   177
  delete _block_freelist;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   178
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   179
}
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   180
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   181
// The remaining committed free space in the current chunk is chopped up and stored in the block
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   182
// free list for later use. As a result, the current chunk will remain current but completely
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   183
// used up. This is a preparation for calling allocate_new_current_chunk().
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   184
void SpaceManager::retire_current_chunk() {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   185
  assert_lock_strong(lock());
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   186
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   187
  Metachunk* c = current_chunk();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   188
  assert(c != NULL, "Sanity");
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   189
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   190
  log_debug(metaspace)("SpaceManager %s: retiring chunk " METACHUNK_FULL_FORMAT ".",
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   191
                       _name, METACHUNK_FULL_FORMAT_ARGS(c));
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   192
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   193
  // Side note:
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   194
  // In theory it could happen that we are asked to retire a completely empty chunk. This may be the
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   195
  // result of rolled back allocations (see deallocate in place) and a lot of luck.
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   196
  // But since these cases should be exceedingly rare, we do not handle them special in order to keep
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   197
  // the code simple.
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   198
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   199
  size_t raw_remaining_words = c->free_below_committed_words();
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   200
  size_t net_remaining_words = get_net_allocation_word_size(raw_remaining_words);
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   201
  if (net_remaining_words > 0) {
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   202
    bool did_hit_limit = false;
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   203
    MetaWord* ptr = c->allocate(net_remaining_words, &did_hit_limit);
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   204
    assert(ptr != NULL && did_hit_limit == false, "Should have worked");
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   205
    add_allocation_to_block_freelist(ptr, net_remaining_words);
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   206
    _total_used_words_counter->increment_by(net_remaining_words);
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   207
  }
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   208
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   209
  // After this operation: the current chunk should have (almost) no free committed space left.
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   210
  assert(current_chunk()->free_below_committed_words() <= highest_possible_delta_between_raw_and_net_size,
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   211
         "Chunk retiring did not work (current chunk " METACHUNK_FULL_FORMAT ").",
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   212
         METACHUNK_FULL_FORMAT_ARGS(current_chunk()));
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   213
58227
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   214
  DEBUG_ONLY(verify_locked();)
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   215
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   216
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   217
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   218
// Allocate memory from Metaspace.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   219
// 1) Attempt to allocate from the dictionary of deallocated blocks.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   220
// 2) Attempt to allocate from the current chunk.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   221
// 3) Attempt to enlarge the current chunk in place if it is too small.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   222
// 4) Attempt to get a new chunk and allocate from that chunk.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   223
// At any point, if we hit a commit limit, we return NULL.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   224
MetaWord* SpaceManager::allocate(size_t requested_word_size) {
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   225
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   226
  MutexLocker cl(lock(), Mutex::_no_safepoint_check_flag);
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   227
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   228
  const size_t raw_word_size = get_raw_allocation_word_size(requested_word_size);
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   229
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   230
  log_trace(metaspace)("SpaceManager %s: requested " SIZE_FORMAT " words, "
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   231
                       "raw word size: " SIZE_FORMAT ".",
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   232
                       _name, requested_word_size, raw_word_size);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   233
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   234
  MetaWord* p = NULL;
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   235
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   236
  bool did_hit_limit = false;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   237
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   238
  // Allocate first chunk if needed.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   239
  if (current_chunk() == NULL) {
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   240
    if (allocate_new_current_chunk(raw_word_size) == false) {
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   241
      did_hit_limit = true;
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   242
    } else {
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   243
      assert(current_chunk() != NULL && current_chunk()->free_words() >= raw_word_size, "Sanity");
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   244
    }
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   245
  }
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   246
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   247
  // 1) Attempt to allocate from the dictionary of deallocated blocks.
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   248
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   249
  // Allocation from the dictionary is expensive in the sense that
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   250
  // the dictionary has to be searched for a size.  Don't allocate
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   251
  // from the dictionary until it starts to get fat.  Is this
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   252
  // a reasonable policy?  Maybe an skinny dictionary is fast enough
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   253
  // for allocations.  Do some profiling.  JJJ
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   254
  if (_block_freelist != NULL && _block_freelist->total_size() > Settings::allocation_from_dictionary_limit()) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   255
    p = _block_freelist->get_block(raw_word_size);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   256
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   257
    if (p != NULL) {
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   258
      DEBUG_ONLY(InternalStats::inc_num_allocs_from_deallocated_blocks();)
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   259
      log_trace(metaspace)("SpaceManager %s: .. taken from freelist.", _name);
58475
e3aa9f95b85e Fix issue with statistics which caused Metaspace::used_words() to be too high
stuefe
parents: 58382
diff changeset
   260
      // Note: space in the freeblock dictionary counts as used (see retire_current_chunk()) -
e3aa9f95b85e Fix issue with statistics which caused Metaspace::used_words() to be too high
stuefe
parents: 58382
diff changeset
   261
      // that means that we must not increase the used counter again when allocating from the dictionary.
e3aa9f95b85e Fix issue with statistics which caused Metaspace::used_words() to be too high
stuefe
parents: 58382
diff changeset
   262
      // Therefore we return here.
e3aa9f95b85e Fix issue with statistics which caused Metaspace::used_words() to be too high
stuefe
parents: 58382
diff changeset
   263
      return p;
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   264
    }
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   265
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   266
  }
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   267
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   268
  // 2) Failing that, attempt to allocate from the current chunk. If we hit commit limit, return NULL.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   269
  if (p == NULL && !did_hit_limit) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   270
    p = current_chunk()->allocate(raw_word_size, &did_hit_limit);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   271
    log_trace(metaspace)("SpaceManager %s: .. taken from current chunk.", _name);
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   272
  }
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   273
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   274
  // 3) Failing that because the remaining chunk space is too small for the requested size
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   275
  //     (and not because commit limit), attempt to enlarge the chunk in place.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   276
  if (p == NULL && !did_hit_limit) {
53970
1ad7c590a6e7 8218988: Improve metaspace verifications
stuefe
parents: 51444
diff changeset
   277
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   278
    // Since we did not hit the commit limit, the current chunk must have been too small.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   279
    assert(current_chunk()->free_words() < raw_word_size, "Sanity");
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   280
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   281
    DEBUG_ONLY(InternalStats::inc_num_allocs_failed_chunk_too_small();)
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   282
58382
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   283
    // Under certain conditions we can just attempt to enlarge the chunk - fusing it with its follower
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   284
    // chunk to produce a chunk double the size (level decreased by 1).
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   285
    // 0) only if it is not switched off
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   286
    // 1) obviously, this only works for non-root chunks
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   287
    // 2) ... which are leader of their buddy pair.
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   288
    // 3) only if the requested allocation would fit into a thus enlarged chunk
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   289
    // 4) do not grow memory faster than what the chunk allocation strategy would allow
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   290
    // 5) as a safety feature, only below a certain limit
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   291
    if (Settings::enlarge_chunks_in_place() &&              // 0
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   292
        current_chunk()->is_root_chunk() == false &&        // 1
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   293
        current_chunk()->is_leader() &&                     // 2
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   294
        current_chunk()->word_size() + current_chunk()->free_words() >= requested_word_size &&      // 3
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   295
        _chunk_alloc_sequence->get_next_chunk_level(_chunks.size()) <= current_chunk()->level() &&  // 4
2e16658b7776 do not enlarge chunks faster than chunk alloc strategy would allow
stuefe
parents: 58228
diff changeset
   296
        current_chunk()->word_size() <= Settings::enlarge_chunks_in_place_max_word_size())          // 5
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   297
    {
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   298
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   299
      if (_chunk_manager->attempt_enlarge_chunk(current_chunk())) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   300
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   301
        // Re-attempt allocation.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   302
        p = current_chunk()->allocate(raw_word_size, &did_hit_limit);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   303
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   304
        if (p != NULL) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   305
          DEBUG_ONLY(InternalStats::inc_num_chunk_enlarged();)
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   306
          log_trace(metaspace)("SpaceManager %s: .. taken from current chunk (enlarged chunk).", _name);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   307
        }
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   308
      }
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   309
    }
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   310
  }
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   311
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   312
  // 4) Failing that, attempt to get a new chunk and allocate from that chunk. Again, we may hit a commit
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   313
  //    limit, in which case we return NULL.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   314
  if (p == NULL && !did_hit_limit) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   315
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   316
    // Since we did not hit the commit limit, the current chunk must have been too small.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   317
    assert(current_chunk()->free_words() < raw_word_size, "Sanity");
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   318
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   319
    // Before we allocate a new chunk we need to retire the old chunk, which is too small to serve our request
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   320
    // but may still have free committed words.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   321
    retire_current_chunk();
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   322
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   323
    DEBUG_ONLY(InternalStats::inc_num_chunks_retired();)
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   324
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   325
    // Allocate a new chunk.
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   326
    if (allocate_new_current_chunk(raw_word_size) == false) {
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   327
      did_hit_limit = true;
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   328
    } else {
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   329
      assert(current_chunk() != NULL && current_chunk()->free_words() >= raw_word_size, "Sanity");
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   330
      p = current_chunk()->allocate(raw_word_size, &did_hit_limit);
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   331
      log_trace(metaspace)("SpaceManager %s: .. allocated new chunk " CHKLVL_FORMAT " and taken from that.",
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   332
                           _name, current_chunk()->level());
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   333
    }
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   334
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   335
  }
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   336
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   337
  assert(p != NULL || (p == NULL && did_hit_limit), "Sanity");
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   338
58227
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   339
  SOMETIMES(verify_locked();)
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   340
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   341
  if (p == NULL) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   342
    DEBUG_ONLY(InternalStats::inc_num_allocs_failed_limit();)
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   343
  } else {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   344
    DEBUG_ONLY(InternalStats::inc_num_allocs();)
58085
a5f523f2ff91 Fix jtreg/vmTestbase/metaspace/shrink_grow/CompressedClassSpaceSize
stuefe
parents: 58063
diff changeset
   345
    _total_used_words_counter->increment_by(raw_word_size);
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   346
  }
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   347
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   348
  log_trace(metaspace)("SpaceManager %s: returned " PTR_FORMAT ".",
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   349
                       _name, p2i(p));
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   350
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   351
  return p;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   352
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   353
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   354
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   355
// Prematurely returns a metaspace allocation to the _block_freelists
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   356
// because it is not needed anymore (requires CLD lock to be active).
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   357
void SpaceManager::deallocate_locked(MetaWord* p, size_t word_size) {
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   358
  assert_lock_strong(lock());
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   359
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   360
  // Allocations and deallocations are in raw_word_size
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   361
  size_t raw_word_size = get_raw_allocation_word_size(word_size);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   362
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   363
  log_debug(metaspace)("SpaceManager %s: deallocating " PTR_FORMAT
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   364
                       ", word size: " SIZE_FORMAT ", raw size: " SIZE_FORMAT ".",
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   365
                       _name, p2i(p), word_size, raw_word_size);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   366
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   367
  assert(current_chunk() != NULL, "SpaceManager is empty.");
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   368
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   369
  assert(is_valid_area(p, word_size),
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   370
         "Pointer range not part of this SpaceManager and cannot be deallocated: (" PTR_FORMAT ".." PTR_FORMAT ").",
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   371
         p2i(p), p2i(p + word_size));
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   372
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   373
  // If this allocation has just been allocated from the current chunk, it may still be on the top of the
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   374
  // current chunk. In that case, just roll back the allocation.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   375
  if (current_chunk()->attempt_rollback_allocation(p, raw_word_size)) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   376
    log_trace(metaspace)("SpaceManager %s: ... rollback succeeded.", _name);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   377
    return;
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   378
  }
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   379
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   380
  add_allocation_to_block_freelist(p, raw_word_size);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   381
58227
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   382
  DEBUG_ONLY(verify_locked();)
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   383
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   384
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   385
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   386
// Prematurely returns a metaspace allocation to the _block_freelists because it is not
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   387
// needed anymore.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   388
void SpaceManager::deallocate(MetaWord* p, size_t word_size) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   389
  MutexLocker cl(lock(), Mutex::_no_safepoint_check_flag);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   390
  deallocate_locked(p, word_size);
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   391
}
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   392
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   393
// Update statistics. This walks all in-use chunks.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   394
void SpaceManager::add_to_statistics(sm_stats_t* out) const {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   395
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 53970
diff changeset
   396
  MutexLocker cl(lock(), Mutex::_no_safepoint_check_flag);
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   397
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   398
  for (const Metachunk* c = _chunks.first(); c != NULL; c = c->next()) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   399
    in_use_chunk_stats_t& ucs = out->stats[c->level()];
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   400
    ucs.num ++;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   401
    ucs.word_size += c->word_size();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   402
    ucs.committed_words += c->committed_words();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   403
    ucs.used_words += c->used_words();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   404
    // Note: for free and waste, we only count what's committed.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   405
    if (c == current_chunk()) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   406
      ucs.free_words += c->free_below_committed_words();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   407
    } else {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   408
      ucs.waste_words += c->free_below_committed_words();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   409
    }
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   410
  }
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   411
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   412
  if (block_freelist() != NULL) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   413
    out->free_blocks_num += block_freelist()->num_blocks();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   414
    out->free_blocks_word_size += block_freelist()->total_size();
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   415
  }
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   416
58227
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   417
  SOMETIMES(out->verify();)
58683
2d5dd194c65c Lessen verification costs
stuefe
parents: 58475
diff changeset
   418
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   419
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   420
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   421
#ifdef ASSERT
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   422
58227
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   423
void SpaceManager::verify_locked() const {
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   424
58227
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   425
  assert_lock_strong(lock());
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   426
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   427
  assert(_chunk_alloc_sequence != NULL && _chunk_manager != NULL, "Sanity");
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   428
58227
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   429
  _chunks.verify();
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   430
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   431
}
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   432
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   433
void SpaceManager::verify() const {
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   434
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   435
  MutexLocker cl(lock(), Mutex::_no_safepoint_check_flag);
0e7d9a23261e Fix various test issues.
stuefe
parents: 58085
diff changeset
   436
  verify_locked();
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   437
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   438
}
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   439
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   440
// Returns true if the area indicated by pointer and size have actually been allocated
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   441
// from this space manager.
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   442
bool SpaceManager::is_valid_area(MetaWord* p, size_t word_size) const {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   443
  assert(p != NULL && word_size > 0, "Sanity");
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   444
  for (const Metachunk* c = _chunks.first(); c != NULL; c = c->next()) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   445
    if (c->is_valid_pointer(p)) {
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   446
      assert(c->is_valid_pointer(p + word_size - 1), "Range partly oob");
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   447
      return true;
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   448
    }
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   449
  }
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   450
  return false;
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   451
}
58063
bdf136b8ae0e Initial changes for new metaspace. Only tested for Linux x64.
stuefe
parents: 54623
diff changeset
   452
50193
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   453
#endif // ASSERT
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   454
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   455
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   456
} // namespace metaspace
49c3e91c424f 8176808: Split up metaspace.cpp
stuefe
parents:
diff changeset
   457