src/hotspot/share/gc/cms/compactibleFreeListSpace.cpp
author chegar
Thu, 17 Oct 2019 20:54:25 +0100
branchdatagramsocketimpl-branch
changeset 58679 9c3209ff7550
parent 58678 9cf78a70fa4f
parent 57782 ca133d5ea78a
permissions -rw-r--r--
datagramsocketimpl-branch: merge with default
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
     2
 * Copyright (c) 2001, 2019, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5434
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5434
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5434
diff changeset
    21
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    25
#include "precompiled.hpp"
47622
817f2a7019e4 8179387: Factor out CMS specific code from GenCollectedHeap into its own subclass
rkennke
parents: 47216
diff changeset
    26
#include "gc/cms/cmsHeap.hpp"
30764
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 30581
diff changeset
    27
#include "gc/cms/cmsLockVerifier.hpp"
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 30581
diff changeset
    28
#include "gc/cms/compactibleFreeListSpace.hpp"
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 30581
diff changeset
    29
#include "gc/cms/concurrentMarkSweepGeneration.inline.hpp"
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 30581
diff changeset
    30
#include "gc/cms/concurrentMarkSweepThread.hpp"
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 30581
diff changeset
    31
#include "gc/shared/blockOffsetTable.inline.hpp"
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 30581
diff changeset
    32
#include "gc/shared/collectedHeap.inline.hpp"
50752
9d62da00bf15 8204540: Automatic oop closure devirtualization
stefank
parents: 50429
diff changeset
    33
#include "gc/shared/genOopClosures.inline.hpp"
30764
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 30581
diff changeset
    34
#include "gc/shared/space.inline.hpp"
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 30581
diff changeset
    35
#include "gc/shared/spaceDecorator.hpp"
46701
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46683
diff changeset
    36
#include "logging/log.hpp"
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46683
diff changeset
    37
#include "logging/logStream.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    38
#include "memory/allocation.inline.hpp"
49708
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    39
#include "memory/binaryTreeDictionary.inline.hpp"
50752
9d62da00bf15 8204540: Automatic oop closure devirtualization
stefank
parents: 50429
diff changeset
    40
#include "memory/iterator.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    41
#include "memory/resourceArea.hpp"
49359
59f6547e151f 8199264: Remove universe.inline.hpp to simplify include dependencies
stefank
parents: 49164
diff changeset
    42
#include "memory/universe.hpp"
49592
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49359
diff changeset
    43
#include "oops/access.inline.hpp"
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49359
diff changeset
    44
#include "oops/compressedOops.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    45
#include "oops/oop.inline.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    46
#include "runtime/globals.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    47
#include "runtime/handles.inline.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    48
#include "runtime/init.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    49
#include "runtime/java.hpp"
50429
83aec1d357d4 8204301: Make OrderAccess functions available to hpp rather than inline.hpp files
coleenp
parents: 50034
diff changeset
    50
#include "runtime/orderAccess.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    51
#include "runtime/vmThread.hpp"
46625
edefffab74e2 8183552: Move align functions to align.hpp
stefank
parents: 46620
diff changeset
    52
#include "utilities/align.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7384
diff changeset
    53
#include "utilities/copy.hpp"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
49708
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    55
// Specialize for AdaptiveFreeList which tries to avoid
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    56
// splitting a chunk of a size that is under populated in favor of
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    57
// an over populated size.  The general get_better_list() just returns
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    58
// the current list.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    59
template <>
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    60
TreeList<FreeChunk, AdaptiveFreeList<FreeChunk> >*
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    61
TreeList<FreeChunk, AdaptiveFreeList<FreeChunk> >::get_better_list(
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    62
  BinaryTreeDictionary<FreeChunk, ::AdaptiveFreeList<FreeChunk> >* dictionary) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    63
  // A candidate chunk has been found.  If it is already under
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    64
  // populated, get a chunk associated with the hint for this
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    65
  // chunk.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    66
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    67
  TreeList<FreeChunk, ::AdaptiveFreeList<FreeChunk> >* curTL = this;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    68
  if (curTL->surplus() <= 0) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    69
    /* Use the hint to find a size with a surplus, and reset the hint. */
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    70
    TreeList<FreeChunk, ::AdaptiveFreeList<FreeChunk> >* hintTL = this;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    71
    while (hintTL->hint() != 0) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    72
      assert(hintTL->hint() > hintTL->size(),
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    73
        "hint points in the wrong direction");
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    74
      hintTL = dictionary->find_list(hintTL->hint());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    75
      assert(curTL != hintTL, "Infinite loop");
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    76
      if (hintTL == NULL ||
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    77
          hintTL == curTL /* Should not happen but protect against it */ ) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    78
        // No useful hint.  Set the hint to NULL and go on.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    79
        curTL->set_hint(0);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    80
        break;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    81
      }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    82
      assert(hintTL->size() > curTL->size(), "hint is inconsistent");
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    83
      if (hintTL->surplus() > 0) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    84
        // The hint led to a list that has a surplus.  Use it.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    85
        // Set the hint for the candidate to an overpopulated
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    86
        // size.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    87
        curTL->set_hint(hintTL->size());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    88
        // Change the candidate.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    89
        curTL = hintTL;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    90
        break;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    91
      }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    92
    }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    93
  }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    94
  return curTL;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    95
}
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    96
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    97
void AFLBinaryTreeDictionary::dict_census_update(size_t size, bool split, bool birth) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    98
  TreeList<FreeChunk, AdaptiveFreeList<FreeChunk> >* nd = find_list(size);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
    99
  if (nd) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   100
    if (split) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   101
      if (birth) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   102
        nd->increment_split_births();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   103
        nd->increment_surplus();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   104
      }  else {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   105
        nd->increment_split_deaths();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   106
        nd->decrement_surplus();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   107
      }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   108
    } else {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   109
      if (birth) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   110
        nd->increment_coal_births();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   111
        nd->increment_surplus();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   112
      } else {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   113
        nd->increment_coal_deaths();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   114
        nd->decrement_surplus();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   115
      }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   116
    }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   117
  }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   118
  // A list for this size may not be found (nd == 0) if
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   119
  //   This is a death where the appropriate list is now
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   120
  //     empty and has been removed from the list.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   121
  //   This is a birth associated with a LinAB.  The chunk
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   122
  //     for the LinAB is not in the dictionary.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   123
}
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   124
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   125
bool AFLBinaryTreeDictionary::coal_dict_over_populated(size_t size) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   126
  if (FLSAlwaysCoalesceLarge) return true;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   127
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   128
  TreeList<FreeChunk, AdaptiveFreeList<FreeChunk> >* list_of_size = find_list(size);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   129
  // None of requested size implies overpopulated.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   130
  return list_of_size == NULL || list_of_size->coal_desired() <= 0 ||
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   131
         list_of_size->count() > list_of_size->coal_desired();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   132
}
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   133
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   134
// For each list in the tree, calculate the desired, desired
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   135
// coalesce, count before sweep, and surplus before sweep.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   136
class BeginSweepClosure : public AscendTreeCensusClosure<FreeChunk, AdaptiveFreeList<FreeChunk> > {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   137
  double _percentage;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   138
  float _inter_sweep_current;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   139
  float _inter_sweep_estimate;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   140
  float _intra_sweep_estimate;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   141
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   142
 public:
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   143
  BeginSweepClosure(double p, float inter_sweep_current,
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   144
                              float inter_sweep_estimate,
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   145
                              float intra_sweep_estimate) :
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   146
   _percentage(p),
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   147
   _inter_sweep_current(inter_sweep_current),
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   148
   _inter_sweep_estimate(inter_sweep_estimate),
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   149
   _intra_sweep_estimate(intra_sweep_estimate) { }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   150
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   151
  void do_list(AdaptiveFreeList<FreeChunk>* fl) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   152
    double coalSurplusPercent = _percentage;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   153
    fl->compute_desired(_inter_sweep_current, _inter_sweep_estimate, _intra_sweep_estimate);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   154
    fl->set_coal_desired((ssize_t)((double)fl->desired() * coalSurplusPercent));
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   155
    fl->set_before_sweep(fl->count());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   156
    fl->set_bfr_surp(fl->surplus());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   157
  }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   158
};
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   159
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   160
void AFLBinaryTreeDictionary::begin_sweep_dict_census(double coalSurplusPercent,
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   161
  float inter_sweep_current, float inter_sweep_estimate, float intra_sweep_estimate) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   162
  BeginSweepClosure bsc(coalSurplusPercent, inter_sweep_current,
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   163
                        inter_sweep_estimate,
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   164
                        intra_sweep_estimate);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   165
  bsc.do_tree(root());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   166
}
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   167
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   168
// Calculate surpluses for the lists in the tree.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   169
class setTreeSurplusClosure : public AscendTreeCensusClosure<FreeChunk, AdaptiveFreeList<FreeChunk> > {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   170
  double percentage;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   171
 public:
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   172
  setTreeSurplusClosure(double v) { percentage = v; }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   173
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   174
  void do_list(AdaptiveFreeList<FreeChunk>* fl) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   175
    double splitSurplusPercent = percentage;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   176
    fl->set_surplus(fl->count() -
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   177
                   (ssize_t)((double)fl->desired() * splitSurplusPercent));
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   178
  }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   179
};
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   180
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   181
void AFLBinaryTreeDictionary::set_tree_surplus(double splitSurplusPercent) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   182
  setTreeSurplusClosure sts(splitSurplusPercent);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   183
  sts.do_tree(root());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   184
}
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   185
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   186
// Set hints for the lists in the tree.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   187
class setTreeHintsClosure : public DescendTreeCensusClosure<FreeChunk, AdaptiveFreeList<FreeChunk> > {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   188
  size_t hint;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   189
 public:
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   190
  setTreeHintsClosure(size_t v) { hint = v; }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   191
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   192
  void do_list(AdaptiveFreeList<FreeChunk>* fl) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   193
    fl->set_hint(hint);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   194
    assert(fl->hint() == 0 || fl->hint() > fl->size(),
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   195
      "Current hint is inconsistent");
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   196
    if (fl->surplus() > 0) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   197
      hint = fl->size();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   198
    }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   199
  }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   200
};
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   201
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   202
void AFLBinaryTreeDictionary::set_tree_hints(void) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   203
  setTreeHintsClosure sth(0);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   204
  sth.do_tree(root());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   205
}
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   206
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   207
// Save count before previous sweep and splits and coalesces.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   208
class clearTreeCensusClosure : public AscendTreeCensusClosure<FreeChunk, AdaptiveFreeList<FreeChunk> > {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   209
  void do_list(AdaptiveFreeList<FreeChunk>* fl) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   210
    fl->set_prev_sweep(fl->count());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   211
    fl->set_coal_births(0);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   212
    fl->set_coal_deaths(0);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   213
    fl->set_split_births(0);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   214
    fl->set_split_deaths(0);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   215
  }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   216
};
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   217
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   218
void AFLBinaryTreeDictionary::clear_tree_census(void) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   219
  clearTreeCensusClosure ctc;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   220
  ctc.do_tree(root());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   221
}
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   222
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   223
// Do reporting and post sweep clean up.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   224
void AFLBinaryTreeDictionary::end_sweep_dict_census(double splitSurplusPercent) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   225
  // Does walking the tree 3 times hurt?
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   226
  set_tree_surplus(splitSurplusPercent);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   227
  set_tree_hints();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   228
  LogTarget(Trace, gc, freelist, stats) log;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   229
  if (log.is_enabled()) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   230
    LogStream out(log);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   231
    report_statistics(&out);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   232
  }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   233
  clear_tree_census();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   234
}
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   235
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   236
// Print census information - counts, births, deaths, etc.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   237
// for each list in the tree.  Also print some summary
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   238
// information.
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   239
class PrintTreeCensusClosure : public AscendTreeCensusClosure<FreeChunk, AdaptiveFreeList<FreeChunk> > {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   240
  int _print_line;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   241
  size_t _total_free;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   242
  AdaptiveFreeList<FreeChunk> _total;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   243
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   244
 public:
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   245
  PrintTreeCensusClosure() {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   246
    _print_line = 0;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   247
    _total_free = 0;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   248
  }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   249
  AdaptiveFreeList<FreeChunk>* total() { return &_total; }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   250
  size_t total_free() { return _total_free; }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   251
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   252
  void do_list(AdaptiveFreeList<FreeChunk>* fl) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   253
    LogStreamHandle(Debug, gc, freelist, census) out;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   254
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   255
    if (++_print_line >= 40) {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   256
      AdaptiveFreeList<FreeChunk>::print_labels_on(&out, "size");
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   257
      _print_line = 0;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   258
    }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   259
    fl->print_on(&out);
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   260
    _total_free +=           fl->count()             * fl->size()        ;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   261
    total()->set_count(      total()->count()        + fl->count()      );
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   262
    total()->set_bfr_surp(   total()->bfr_surp()     + fl->bfr_surp()    );
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   263
    total()->set_surplus(    total()->split_deaths() + fl->surplus()    );
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   264
    total()->set_desired(    total()->desired()      + fl->desired()    );
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   265
    total()->set_prev_sweep(  total()->prev_sweep()   + fl->prev_sweep()  );
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   266
    total()->set_before_sweep(total()->before_sweep() + fl->before_sweep());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   267
    total()->set_coal_births( total()->coal_births()  + fl->coal_births() );
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   268
    total()->set_coal_deaths( total()->coal_deaths()  + fl->coal_deaths() );
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   269
    total()->set_split_births(total()->split_births() + fl->split_births());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   270
    total()->set_split_deaths(total()->split_deaths() + fl->split_deaths());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   271
  }
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   272
};
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   273
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   274
void AFLBinaryTreeDictionary::print_dict_census(outputStream* st) const {
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   275
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   276
  st->print_cr("BinaryTree");
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   277
  AdaptiveFreeList<FreeChunk>::print_labels_on(st, "size");
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   278
  PrintTreeCensusClosure ptc;
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   279
  ptc.do_tree(root());
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   280
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   281
  AdaptiveFreeList<FreeChunk>* total = ptc.total();
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   282
  AdaptiveFreeList<FreeChunk>::print_labels_on(st, " ");
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   283
  total->print_on(st, "TOTAL\t");
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   284
  st->print_cr("total_free(words): " SIZE_FORMAT_W(16) " growth: %8.5f  deficit: %8.5f",
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   285
               ptc.total_free(),
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   286
               (double)(total->split_births() + total->coal_births()
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   287
                      - total->split_deaths() - total->coal_deaths())
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   288
               /(total->prev_sweep() != 0 ? (double)total->prev_sweep() : 1.0),
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   289
              (double)(total->desired() - total->count())
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   290
              /(total->desired() != 0 ? (double)total->desired() : 1.0));
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   291
}
6709f13dccd3 8200735: Move CMS specific code from binaryTreeDictionary and freeList to CMS files
stefank
parents: 49592
diff changeset
   292
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   293
/////////////////////////////////////////////////////////////////////////
489c9b5090e2 Initial load
duke
parents:
diff changeset
   294
//// CompactibleFreeListSpace
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
/////////////////////////////////////////////////////////////////////////
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
// highest ranked  free list lock rank
489c9b5090e2 Initial load
duke
parents:
diff changeset
   298
int CompactibleFreeListSpace::_lockRank = Mutex::leaf + 3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
5694
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   300
// Defaults are 0 so things will break badly if incorrectly initialized.
10992
b998c6b89fa2 7105163: CMS: some mentions of MinChunkSize should be IndexSetStart
ysr
parents: 10771
diff changeset
   301
size_t CompactibleFreeListSpace::IndexSetStart  = 0;
b998c6b89fa2 7105163: CMS: some mentions of MinChunkSize should be IndexSetStart
ysr
parents: 10771
diff changeset
   302
size_t CompactibleFreeListSpace::IndexSetStride = 0;
47816
ac0af7750da9 8189798: SA cleanup - part 1
jgeorge
parents: 47622
diff changeset
   303
size_t CompactibleFreeListSpace::_min_chunk_size_in_bytes = 0;
5694
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   304
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   305
size_t MinChunkSize = 0;
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   306
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   307
void CompactibleFreeListSpace::set_cms_values() {
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   308
  // Set CMS global values
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   309
  assert(MinChunkSize == 0, "already set");
12776
468772366db9 7169062: CMS: Assertion failed with -XX:+ObjectAlignmentInBytes=64
brutisso
parents: 12509
diff changeset
   310
468772366db9 7169062: CMS: Assertion failed with -XX:+ObjectAlignmentInBytes=64
brutisso
parents: 12509
diff changeset
   311
  // MinChunkSize should be a multiple of MinObjAlignment and be large enough
468772366db9 7169062: CMS: Assertion failed with -XX:+ObjectAlignmentInBytes=64
brutisso
parents: 12509
diff changeset
   312
  // for chunks to contain a FreeChunk.
47816
ac0af7750da9 8189798: SA cleanup - part 1
jgeorge
parents: 47622
diff changeset
   313
  _min_chunk_size_in_bytes = align_up(sizeof(FreeChunk), MinObjAlignmentInBytes);
ac0af7750da9 8189798: SA cleanup - part 1
jgeorge
parents: 47622
diff changeset
   314
  MinChunkSize = _min_chunk_size_in_bytes / BytesPerWord;
5694
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   315
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   316
  assert(IndexSetStart == 0 && IndexSetStride == 0, "already set");
10992
b998c6b89fa2 7105163: CMS: some mentions of MinChunkSize should be IndexSetStart
ysr
parents: 10771
diff changeset
   317
  IndexSetStart  = MinChunkSize;
5694
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   318
  IndexSetStride = MinObjAlignment;
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   319
}
1e0532a6abff 6916623: Align object to 16 bytes to use Compressed Oops with java heap up to 64Gb
kvn
parents: 5434
diff changeset
   320
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   321
// Constructor
33587
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   322
CompactibleFreeListSpace::CompactibleFreeListSpace(BlockOffsetSharedArray* bs, MemRegion mr) :
51332
c25572739e7c 8208669: GC changes to allow enabling -Wreorder
tschatzl
parents: 51268
diff changeset
   323
  _rescan_task_size(CardTable::card_size_in_words * BitsPerWord *
c25572739e7c 8208669: GC changes to allow enabling -Wreorder
tschatzl
parents: 51268
diff changeset
   324
                    CMSRescanMultiple),
c25572739e7c 8208669: GC changes to allow enabling -Wreorder
tschatzl
parents: 51268
diff changeset
   325
  _marking_task_size(CardTable::card_size_in_words * BitsPerWord *
c25572739e7c 8208669: GC changes to allow enabling -Wreorder
tschatzl
parents: 51268
diff changeset
   326
                    CMSConcMarkMultiple),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   327
  _bt(bs, mr),
51332
c25572739e7c 8208669: GC changes to allow enabling -Wreorder
tschatzl
parents: 51268
diff changeset
   328
  _collector(NULL),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   329
  // free list locks are in the range of values taken by _lockRank
489c9b5090e2 Initial load
duke
parents:
diff changeset
   330
  // This range currently is [_leaf+2, _leaf+3]
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
  // Note: this requires that CFLspace c'tors
489c9b5090e2 Initial load
duke
parents:
diff changeset
   332
  // are called serially in the order in which the locks are
489c9b5090e2 Initial load
duke
parents:
diff changeset
   333
  // are acquired in the program text. This is true today.
54663
f03d5a093093 8074355: make MutexLocker smarter about non-JavaThreads
coleenp
parents: 54623
diff changeset
   334
  _freelistLock(_lockRank--, "CompactibleFreeListSpace_lock", true,
f03d5a093093 8074355: make MutexLocker smarter about non-JavaThreads
coleenp
parents: 54623
diff changeset
   335
                Monitor::_safepoint_check_never),
51332
c25572739e7c 8208669: GC changes to allow enabling -Wreorder
tschatzl
parents: 51268
diff changeset
   336
  _preconsumptionDirtyCardClosure(NULL),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   337
  _parDictionaryAllocLock(Mutex::leaf - 1,  // == rank(ExpandHeap_lock) - 1
54663
f03d5a093093 8074355: make MutexLocker smarter about non-JavaThreads
coleenp
parents: 54623
diff changeset
   338
                          "CompactibleFreeListSpace_dict_par_lock", true,
51332
c25572739e7c 8208669: GC changes to allow enabling -Wreorder
tschatzl
parents: 51268
diff changeset
   339
                          Monitor::_safepoint_check_never)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   340
{
12507
6182ca66bc7b 7131629: Generalize the CMS free list code
jmasa
parents: 12379
diff changeset
   341
  assert(sizeof(FreeChunk) / BytesPerWord <= MinChunkSize,
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
   342
         "FreeChunk is larger than expected");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   343
  _bt.set_space(this);
971
f0b20be4165d 6672698: mangle_unused_area() should not remangle the entire heap at each collection.
jmasa
parents: 613
diff changeset
   344
  initialize(mr, SpaceDecorator::Clear, SpaceDecorator::Mangle);
33587
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   345
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   346
  _dictionary = new AFLBinaryTreeDictionary(mr);
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   347
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   348
  assert(_dictionary != NULL, "CMS dictionary initialization");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   349
  // The indexed free lists are initially all empty and are lazily
489c9b5090e2 Initial load
duke
parents:
diff changeset
   350
  // filled in on demand. Initialize the array elements to NULL.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   351
  initializeIndexedFreeListArray();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   352
33587
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   353
  _smallLinearAllocBlock.set(0, 0, 1024*SmallForLinearAlloc,
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   354
                             SmallForLinearAlloc);
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   355
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   356
  // CMSIndexedFreeListReplenish should be at least 1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   357
  CMSIndexedFreeListReplenish = MAX2((uintx)1, CMSIndexedFreeListReplenish);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   358
  _promoInfo.setSpace(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   359
  if (UseCMSBestFit) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   360
    _fitStrategy = FreeBlockBestFitFirst;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   361
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   362
    _fitStrategy = FreeBlockStrategyNone;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   363
  }
10771
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
   364
  check_free_list_consistency();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   365
489c9b5090e2 Initial load
duke
parents:
diff changeset
   366
  // Initialize locks for parallel case.
27251
7d667f91ec8d 6979279: remove special-case code for ParallelGCThreads==0
mlarsson
parents: 26150
diff changeset
   367
  for (size_t i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
7d667f91ec8d 6979279: remove special-case code for ParallelGCThreads==0
mlarsson
parents: 26150
diff changeset
   368
    _indexedFreeListParLocks[i] = new Mutex(Mutex::leaf - 1, // == ExpandHeap_lock - 1
54663
f03d5a093093 8074355: make MutexLocker smarter about non-JavaThreads
coleenp
parents: 54623
diff changeset
   369
                                            "a freelist par lock", true, Mutex::_safepoint_check_never);
27251
7d667f91ec8d 6979279: remove special-case code for ParallelGCThreads==0
mlarsson
parents: 26150
diff changeset
   370
    DEBUG_ONLY(
7d667f91ec8d 6979279: remove special-case code for ParallelGCThreads==0
mlarsson
parents: 26150
diff changeset
   371
      _indexedFreeList[i].set_protecting_lock(_indexedFreeListParLocks[i]);
7d667f91ec8d 6979279: remove special-case code for ParallelGCThreads==0
mlarsson
parents: 26150
diff changeset
   372
    )
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   373
  }
27251
7d667f91ec8d 6979279: remove special-case code for ParallelGCThreads==0
mlarsson
parents: 26150
diff changeset
   374
  _dictionary->set_par_lock(&_parDictionaryAllocLock);
57782
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   375
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   376
  _used_stable = 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   378
489c9b5090e2 Initial load
duke
parents:
diff changeset
   379
// Like CompactibleSpace forward() but always calls cross_threshold() to
489c9b5090e2 Initial load
duke
parents:
diff changeset
   380
// update the block offset table.  Removed initialize_threshold call because
489c9b5090e2 Initial load
duke
parents:
diff changeset
   381
// CFLS does not use a block offset array for contiguous spaces.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   382
HeapWord* CompactibleFreeListSpace::forward(oop q, size_t size,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   383
                                    CompactPoint* cp, HeapWord* compact_top) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   384
  // q is alive
489c9b5090e2 Initial load
duke
parents:
diff changeset
   385
  // First check if we should switch compaction space
489c9b5090e2 Initial load
duke
parents:
diff changeset
   386
  assert(this == cp->space, "'this' should be current compaction space.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   387
  size_t compaction_max_size = pointer_delta(end(), compact_top);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   388
  assert(adjustObjectSize(size) == cp->space->adjust_object_size_v(size),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   389
    "virtual adjustObjectSize_v() method is not correct");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   390
  size_t adjusted_size = adjustObjectSize(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   391
  assert(compaction_max_size >= MinChunkSize || compaction_max_size == 0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   392
         "no small fragments allowed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   393
  assert(minimum_free_block_size() == MinChunkSize,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   394
         "for de-virtualized reference below");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   395
  // Can't leave a nonzero size, residual fragment smaller than MinChunkSize
489c9b5090e2 Initial load
duke
parents:
diff changeset
   396
  if (adjusted_size + MinChunkSize > compaction_max_size &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
   397
      adjusted_size != compaction_max_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   398
    do {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   399
      // switch to next compaction space
489c9b5090e2 Initial load
duke
parents:
diff changeset
   400
      cp->space->set_compaction_top(compact_top);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   401
      cp->space = cp->space->next_compaction_space();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   402
      if (cp->space == NULL) {
47622
817f2a7019e4 8179387: Factor out CMS specific code from GenCollectedHeap into its own subclass
rkennke
parents: 47216
diff changeset
   403
        cp->gen = CMSHeap::heap()->young_gen();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   404
        assert(cp->gen != NULL, "compaction must succeed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   405
        cp->space = cp->gen->first_compaction_space();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   406
        assert(cp->space != NULL, "generation must have a first compaction space");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   407
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   408
      compact_top = cp->space->bottom();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   409
      cp->space->set_compaction_top(compact_top);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   410
      // The correct adjusted_size may not be the same as that for this method
489c9b5090e2 Initial load
duke
parents:
diff changeset
   411
      // (i.e., cp->space may no longer be "this" so adjust the size again.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   412
      // Use the virtual method which is not used above to save the virtual
489c9b5090e2 Initial load
duke
parents:
diff changeset
   413
      // dispatch.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   414
      adjusted_size = cp->space->adjust_object_size_v(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   415
      compaction_max_size = pointer_delta(cp->space->end(), compact_top);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   416
      assert(cp->space->minimum_free_block_size() == 0, "just checking");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   417
    } while (adjusted_size > compaction_max_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   418
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   419
489c9b5090e2 Initial load
duke
parents:
diff changeset
   420
  // store the forwarding pointer into the mark word
489c9b5090e2 Initial load
duke
parents:
diff changeset
   421
  if ((HeapWord*)q != compact_top) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   422
    q->forward_to(oop(compact_top));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
    assert(q->is_gc_marked(), "encoding the pointer should preserve the mark");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   424
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   425
    // if the object isn't moving we can just set the mark to the default
489c9b5090e2 Initial load
duke
parents:
diff changeset
   426
    // mark and handle it specially later on.
49722
a47d1e21b3f1 8199735: Mark word updates need to use Access API
rkennke
parents: 49708
diff changeset
   427
    q->init_mark_raw();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   428
    assert(q->forwardee() == NULL, "should be forwarded to NULL");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   429
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   430
489c9b5090e2 Initial load
duke
parents:
diff changeset
   431
  compact_top += adjusted_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   432
489c9b5090e2 Initial load
duke
parents:
diff changeset
   433
  // we need to update the offset table so that the beginnings of objects can be
489c9b5090e2 Initial load
duke
parents:
diff changeset
   434
  // found during scavenge.  Note that we are updating the offset table based on
489c9b5090e2 Initial load
duke
parents:
diff changeset
   435
  // where the object will be once the compaction phase finishes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   436
489c9b5090e2 Initial load
duke
parents:
diff changeset
   437
  // Always call cross_threshold().  A contiguous space can only call it when
489c9b5090e2 Initial load
duke
parents:
diff changeset
   438
  // the compaction_top exceeds the current threshold but not for an
489c9b5090e2 Initial load
duke
parents:
diff changeset
   439
  // non-contiguous space.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   440
  cp->threshold =
489c9b5090e2 Initial load
duke
parents:
diff changeset
   441
    cp->space->cross_threshold(compact_top - adjusted_size, compact_top);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   442
  return compact_top;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   443
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   444
489c9b5090e2 Initial load
duke
parents:
diff changeset
   445
// A modified copy of OffsetTableContigSpace::cross_threshold() with _offsets -> _bt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   446
// and use of single_block instead of alloc_block.  The name here is not really
489c9b5090e2 Initial load
duke
parents:
diff changeset
   447
// appropriate - maybe a more general name could be invented for both the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   448
// contiguous and noncontiguous spaces.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   449
489c9b5090e2 Initial load
duke
parents:
diff changeset
   450
HeapWord* CompactibleFreeListSpace::cross_threshold(HeapWord* start, HeapWord* the_end) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   451
  _bt.single_block(start, the_end);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   452
  return end();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   453
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   454
489c9b5090e2 Initial load
duke
parents:
diff changeset
   455
// Initialize them to NULL.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   456
void CompactibleFreeListSpace::initializeIndexedFreeListArray() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   457
  for (size_t i = 0; i < IndexSetSize; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   458
    // Note that on platforms where objects are double word aligned,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   459
    // the odd array elements are not used.  It is convenient, however,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   460
    // to map directly from the object size to the array element.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   461
    _indexedFreeList[i].reset(IndexSetSize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   462
    _indexedFreeList[i].set_size(i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   463
    assert(_indexedFreeList[i].count() == 0, "reset check failed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   464
    assert(_indexedFreeList[i].head() == NULL, "reset check failed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   465
    assert(_indexedFreeList[i].tail() == NULL, "reset check failed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   466
    assert(_indexedFreeList[i].hint() == IndexSetSize, "reset check failed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   467
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   468
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   469
35862
411842d0c882 8146395: Add inline qualifier in oop.hpp and fix inlining in gc files
goetz
parents: 35492
diff changeset
   470
size_t CompactibleFreeListSpace::obj_size(const HeapWord* addr) const {
411842d0c882 8146395: Add inline qualifier in oop.hpp and fix inlining in gc files
goetz
parents: 35492
diff changeset
   471
  return adjustObjectSize(oop(addr)->size());
411842d0c882 8146395: Add inline qualifier in oop.hpp and fix inlining in gc files
goetz
parents: 35492
diff changeset
   472
}
411842d0c882 8146395: Add inline qualifier in oop.hpp and fix inlining in gc files
goetz
parents: 35492
diff changeset
   473
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   474
void CompactibleFreeListSpace::resetIndexedFreeListArray() {
10992
b998c6b89fa2 7105163: CMS: some mentions of MinChunkSize should be IndexSetStart
ysr
parents: 10771
diff changeset
   475
  for (size_t i = 1; i < IndexSetSize; i++) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   476
    assert(_indexedFreeList[i].size() == (size_t) i,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   477
      "Indexed free list sizes are incorrect");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   478
    _indexedFreeList[i].reset(IndexSetSize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   479
    assert(_indexedFreeList[i].count() == 0, "reset check failed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   480
    assert(_indexedFreeList[i].head() == NULL, "reset check failed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   481
    assert(_indexedFreeList[i].tail() == NULL, "reset check failed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   482
    assert(_indexedFreeList[i].hint() == IndexSetSize, "reset check failed");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   483
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   484
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   485
489c9b5090e2 Initial load
duke
parents:
diff changeset
   486
void CompactibleFreeListSpace::reset(MemRegion mr) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   487
  resetIndexedFreeListArray();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   488
  dictionary()->reset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   489
  if (BlockOffsetArrayUseUnallocatedBlock) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   490
    assert(end() == mr.end(), "We are compacting to the bottom of CMS gen");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   491
    // Everything's allocated until proven otherwise.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   492
    _bt.set_unallocated_block(end());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   493
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   494
  if (!mr.is_empty()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   495
    assert(mr.word_size() >= MinChunkSize, "Chunk size is too small");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   496
    _bt.single_block(mr.start(), mr.word_size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   497
    FreeChunk* fc = (FreeChunk*) mr.start();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   498
    fc->set_size(mr.word_size());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   499
    if (mr.word_size() >= IndexSetSize ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   500
      returnChunkToDictionary(fc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   501
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   502
      _bt.verify_not_unallocated((HeapWord*)fc, fc->size());
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   503
      _indexedFreeList[mr.word_size()].return_chunk_at_head(fc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   504
    }
17629
505d50bbe0fa 7066063: CMS: "Conservation Principle" assert failed
brutisso
parents: 15429
diff changeset
   505
    coalBirth(mr.word_size());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   506
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   507
  _promoInfo.reset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   508
  _smallLinearAllocBlock._ptr = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   509
  _smallLinearAllocBlock._word_size = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   510
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   511
489c9b5090e2 Initial load
duke
parents:
diff changeset
   512
void CompactibleFreeListSpace::reset_after_compaction() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   513
  // Reset the space to the new reality - one free chunk.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   514
  MemRegion mr(compaction_top(), end());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   515
  reset(mr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   516
  // Now refill the linear allocation block(s) if possible.
33587
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   517
  refillLinearAllocBlocksIfNeeded();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   518
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   519
489c9b5090e2 Initial load
duke
parents:
diff changeset
   520
// Walks the entire dictionary, returning a coterminal
489c9b5090e2 Initial load
duke
parents:
diff changeset
   521
// chunk, if it exists. Use with caution since it involves
489c9b5090e2 Initial load
duke
parents:
diff changeset
   522
// a potentially complete walk of a potentially large tree.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   523
FreeChunk* CompactibleFreeListSpace::find_chunk_at_end() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   524
489c9b5090e2 Initial load
duke
parents:
diff changeset
   525
  assert_lock_strong(&_freelistLock);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   526
489c9b5090e2 Initial load
duke
parents:
diff changeset
   527
  return dictionary()->find_chunk_ends_at(end());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   528
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   529
489c9b5090e2 Initial load
duke
parents:
diff changeset
   530
489c9b5090e2 Initial load
duke
parents:
diff changeset
   531
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   532
void CompactibleFreeListSpace::initializeIndexedFreeListArrayReturnedBytes() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   533
  for (size_t i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   534
    _indexedFreeList[i].allocation_stats()->set_returned_bytes(0);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   535
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   536
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   537
489c9b5090e2 Initial load
duke
parents:
diff changeset
   538
size_t CompactibleFreeListSpace::sumIndexedFreeListArrayReturnedBytes() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   539
  size_t sum = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   540
  for (size_t i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   541
    sum += _indexedFreeList[i].allocation_stats()->returned_bytes();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   542
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   543
  return sum;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   544
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   545
489c9b5090e2 Initial load
duke
parents:
diff changeset
   546
size_t CompactibleFreeListSpace::totalCountInIndexedFreeLists() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   547
  size_t count = 0;
10992
b998c6b89fa2 7105163: CMS: some mentions of MinChunkSize should be IndexSetStart
ysr
parents: 10771
diff changeset
   548
  for (size_t i = IndexSetStart; i < IndexSetSize; i++) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   549
    debug_only(
489c9b5090e2 Initial load
duke
parents:
diff changeset
   550
      ssize_t total_list_count = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   551
      for (FreeChunk* fc = _indexedFreeList[i].head(); fc != NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   552
         fc = fc->next()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   553
        total_list_count++;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   554
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   555
      assert(total_list_count ==  _indexedFreeList[i].count(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   556
        "Count in list is incorrect");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   557
    )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   558
    count += _indexedFreeList[i].count();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   559
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   560
  return count;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   561
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   562
489c9b5090e2 Initial load
duke
parents:
diff changeset
   563
size_t CompactibleFreeListSpace::totalCount() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   564
  size_t num = totalCountInIndexedFreeLists();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   565
  num +=  dictionary()->total_count();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   566
  if (_smallLinearAllocBlock._word_size != 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   567
    num++;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   568
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   569
  return num;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   570
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   571
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   572
489c9b5090e2 Initial load
duke
parents:
diff changeset
   573
bool CompactibleFreeListSpace::is_free_block(const HeapWord* p) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   574
  FreeChunk* fc = (FreeChunk*) p;
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   575
  return fc->is_free();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   576
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   577
489c9b5090e2 Initial load
duke
parents:
diff changeset
   578
size_t CompactibleFreeListSpace::used() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   579
  return capacity() - free();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   580
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   581
57782
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   582
size_t CompactibleFreeListSpace::used_stable() const {
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   583
  return _used_stable;
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   584
}
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   585
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   586
void CompactibleFreeListSpace::recalculate_used_stable() {
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   587
  _used_stable = used();
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   588
}
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
   589
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   590
size_t CompactibleFreeListSpace::free() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   591
  // "MT-safe, but not MT-precise"(TM), if you will: i.e.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   592
  // if you do this while the structures are in flux you
489c9b5090e2 Initial load
duke
parents:
diff changeset
   593
  // may get an approximate answer only; for instance
489c9b5090e2 Initial load
duke
parents:
diff changeset
   594
  // because there is concurrent allocation either
489c9b5090e2 Initial load
duke
parents:
diff changeset
   595
  // directly by mutators or for promotion during a GC.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   596
  // It's "MT-safe", however, in the sense that you are guaranteed
489c9b5090e2 Initial load
duke
parents:
diff changeset
   597
  // not to crash and burn, for instance, because of walking
489c9b5090e2 Initial load
duke
parents:
diff changeset
   598
  // pointers that could disappear as you were walking them.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   599
  // The approximation is because the various components
489c9b5090e2 Initial load
duke
parents:
diff changeset
   600
  // that are read below are not read atomically (and
489c9b5090e2 Initial load
duke
parents:
diff changeset
   601
  // further the computation of totalSizeInIndexedFreeLists()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   602
  // is itself a non-atomic computation. The normal use of
489c9b5090e2 Initial load
duke
parents:
diff changeset
   603
  // this is during a resize operation at the end of GC
489c9b5090e2 Initial load
duke
parents:
diff changeset
   604
  // and at that time you are guaranteed to get the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   605
  // correct actual value. However, for instance, this is
489c9b5090e2 Initial load
duke
parents:
diff changeset
   606
  // also read completely asynchronously by the "perf-sampler"
489c9b5090e2 Initial load
duke
parents:
diff changeset
   607
  // that supports jvmstat, and you are apt to see the values
489c9b5090e2 Initial load
duke
parents:
diff changeset
   608
  // flicker in such cases.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   609
  assert(_dictionary != NULL, "No _dictionary?");
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   610
  return (_dictionary->total_chunk_size(DEBUG_ONLY(freelistLock())) +
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   611
          totalSizeInIndexedFreeLists() +
489c9b5090e2 Initial load
duke
parents:
diff changeset
   612
          _smallLinearAllocBlock._word_size) * HeapWordSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   613
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   614
489c9b5090e2 Initial load
duke
parents:
diff changeset
   615
size_t CompactibleFreeListSpace::max_alloc_in_words() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   616
  assert(_dictionary != NULL, "No _dictionary?");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   617
  assert_locked();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   618
  size_t res = _dictionary->max_chunk_size();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   619
  res = MAX2(res, MIN2(_smallLinearAllocBlock._word_size,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   620
                       (size_t) SmallForLinearAlloc - 1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   621
  // XXX the following could potentially be pretty slow;
22551
9bf46d16dcc6 8025856: Fix typos in the GC code
jwilhelm
parents: 18687
diff changeset
   622
  // should one, pessimistically for the rare cases when res
9bf46d16dcc6 8025856: Fix typos in the GC code
jwilhelm
parents: 18687
diff changeset
   623
  // calculated above is less than IndexSetSize,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   624
  // just return res calculated above? My reasoning was that
489c9b5090e2 Initial load
duke
parents:
diff changeset
   625
  // those cases will be so rare that the extra time spent doesn't
489c9b5090e2 Initial load
duke
parents:
diff changeset
   626
  // really matter....
489c9b5090e2 Initial load
duke
parents:
diff changeset
   627
  // Note: do not change the loop test i >= res + IndexSetStride
489c9b5090e2 Initial load
duke
parents:
diff changeset
   628
  // to i > res below, because i is unsigned and res may be zero.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   629
  for (size_t i = IndexSetSize - 1; i >= res + IndexSetStride;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   630
       i -= IndexSetStride) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   631
    if (_indexedFreeList[i].head() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   632
      assert(_indexedFreeList[i].count() != 0, "Inconsistent FreeList");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   633
      return i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   634
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   635
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   636
  return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   637
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   638
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   639
void LinearAllocBlock::print_on(outputStream* st) const {
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   640
  st->print_cr(" LinearAllocBlock: ptr = " PTR_FORMAT ", word_size = " SIZE_FORMAT
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   641
            ", refillsize = " SIZE_FORMAT ", allocation_size_limit = " SIZE_FORMAT,
24424
2658d7834c6e 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 24351
diff changeset
   642
            p2i(_ptr), _word_size, _refillSize, _allocation_size_limit);
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   643
}
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   644
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   645
void CompactibleFreeListSpace::print_on(outputStream* st) const {
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   646
  st->print_cr("COMPACTIBLE FREELIST SPACE");
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   647
  st->print_cr(" Space:");
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   648
  Space::print_on(st);
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   649
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   650
  st->print_cr("promoInfo:");
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   651
  _promoInfo.print_on(st);
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   652
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   653
  st->print_cr("_smallLinearAllocBlock");
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   654
  _smallLinearAllocBlock.print_on(st);
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   655
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   656
  // dump_memory_block(_smallLinearAllocBlock->_ptr, 128);
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   657
33587
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   658
  st->print_cr(" _fitStrategy = %s", BOOL_TO_STR(_fitStrategy));
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   659
}
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   660
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   661
void CompactibleFreeListSpace::print_indexed_free_lists(outputStream* st)
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   662
const {
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   663
  reportIndexedFreeListStatistics(st);
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   664
  st->print_cr("Layout of Indexed Freelists");
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   665
  st->print_cr("---------------------------");
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
   666
  AdaptiveFreeList<FreeChunk>::print_labels_on(st, "size");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   667
  for (size_t i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   668
    _indexedFreeList[i].print_on(st);
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   669
    for (FreeChunk* fc = _indexedFreeList[i].head(); fc != NULL; fc = fc->next()) {
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   670
      st->print_cr("\t[" PTR_FORMAT "," PTR_FORMAT ")  %s",
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   671
                   p2i(fc), p2i((HeapWord*)fc + i),
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   672
                   fc->cantCoalesce() ? "\t CC" : "");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   673
    }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   674
  }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   675
}
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   676
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   677
void CompactibleFreeListSpace::print_promo_info_blocks(outputStream* st)
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   678
const {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   679
  _promoInfo.print_on(st);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   680
}
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   681
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   682
void CompactibleFreeListSpace::print_dictionary_free_lists(outputStream* st)
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   683
const {
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   684
  _dictionary->report_statistics(st);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   685
  st->print_cr("Layout of Freelists in Tree");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   686
  st->print_cr("---------------------------");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   687
  _dictionary->print_free_lists(st);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   688
}
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   689
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   690
class BlkPrintingClosure: public BlkClosure {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   691
  const CMSCollector*             _collector;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   692
  const CompactibleFreeListSpace* _sp;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   693
  const CMSBitMap*                _live_bit_map;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   694
  const bool                      _post_remark;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   695
  outputStream*                   _st;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   696
public:
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   697
  BlkPrintingClosure(const CMSCollector* collector,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   698
                     const CompactibleFreeListSpace* sp,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   699
                     const CMSBitMap* live_bit_map,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   700
                     outputStream* st):
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   701
    _collector(collector),
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   702
    _sp(sp),
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   703
    _live_bit_map(live_bit_map),
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   704
    _post_remark(collector->abstract_state() > CMSCollector::FinalMarking),
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   705
    _st(st) { }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   706
  size_t do_blk(HeapWord* addr);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   707
};
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   708
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   709
size_t BlkPrintingClosure::do_blk(HeapWord* addr) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   710
  size_t sz = _sp->block_size_no_stall(addr, _collector);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   711
  assert(sz != 0, "Should always be able to compute a size");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   712
  if (_sp->block_is_obj(addr)) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   713
    const bool dead = _post_remark && !_live_bit_map->isMarked(addr);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   714
    _st->print_cr(PTR_FORMAT ": %s object of size " SIZE_FORMAT "%s",
24424
2658d7834c6e 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 24351
diff changeset
   715
      p2i(addr),
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   716
      dead ? "dead" : "live",
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   717
      sz,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   718
      (!dead && CMSPrintObjectsInDump) ? ":" : ".");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   719
    if (CMSPrintObjectsInDump && !dead) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   720
      oop(addr)->print_on(_st);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   721
      _st->print_cr("--------------------------------------");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   722
    }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   723
  } else { // free block
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   724
    _st->print_cr(PTR_FORMAT ": free block of size " SIZE_FORMAT "%s",
24424
2658d7834c6e 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 24351
diff changeset
   725
      p2i(addr), sz, CMSPrintChunksInDump ? ":" : ".");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   726
    if (CMSPrintChunksInDump) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   727
      ((FreeChunk*)addr)->print_on(_st);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   728
      _st->print_cr("--------------------------------------");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   729
    }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   730
  }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   731
  return sz;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   732
}
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   733
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   734
void CompactibleFreeListSpace::dump_at_safepoint_with_locks(CMSCollector* c, outputStream* st) {
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   735
  st->print_cr("=========================");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   736
  st->print_cr("Block layout in CMS Heap:");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   737
  st->print_cr("=========================");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   738
  BlkPrintingClosure  bpcl(c, this, c->markBitMap(), st);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   739
  blk_iterate(&bpcl);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   740
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   741
  st->print_cr("=======================================");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   742
  st->print_cr("Order & Layout of Promotion Info Blocks");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   743
  st->print_cr("=======================================");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   744
  print_promo_info_blocks(st);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   745
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   746
  st->print_cr("===========================");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   747
  st->print_cr("Order of Indexed Free Lists");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   748
  st->print_cr("=========================");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   749
  print_indexed_free_lists(st);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   750
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   751
  st->print_cr("=================================");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   752
  st->print_cr("Order of Free Lists in Dictionary");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   753
  st->print_cr("=================================");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   754
  print_dictionary_free_lists(st);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   755
}
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   756
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   757
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   758
void CompactibleFreeListSpace::reportFreeListStatistics(const char* title) const {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   759
  assert_lock_strong(&_freelistLock);
37242
91e5f98fff6f 8152632: Rename LogHandle(...) to Log(...)
stefank
parents: 37194
diff changeset
   760
  Log(gc, freelist, stats) log;
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   761
  if (!log.is_debug()) {
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   762
    return;
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   763
  }
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   764
  log.debug("%s", title);
37457
79f4b6032f9e 8152639: ResourceMark missing in reportFreeListStatistics
stefank
parents: 37433
diff changeset
   765
79f4b6032f9e 8152639: ResourceMark missing in reportFreeListStatistics
stefank
parents: 37433
diff changeset
   766
  LogStream out(log.debug());
79f4b6032f9e 8152639: ResourceMark missing in reportFreeListStatistics
stefank
parents: 37433
diff changeset
   767
  _dictionary->report_statistics(&out);
79f4b6032f9e 8152639: ResourceMark missing in reportFreeListStatistics
stefank
parents: 37433
diff changeset
   768
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   769
  if (log.is_trace()) {
37457
79f4b6032f9e 8152639: ResourceMark missing in reportFreeListStatistics
stefank
parents: 37433
diff changeset
   770
    LogStream trace_out(log.trace());
79f4b6032f9e 8152639: ResourceMark missing in reportFreeListStatistics
stefank
parents: 37433
diff changeset
   771
    reportIndexedFreeListStatistics(&trace_out);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   772
    size_t total_size = totalSizeInIndexedFreeLists() +
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   773
                       _dictionary->total_chunk_size(DEBUG_ONLY(freelistLock()));
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   774
    log.trace(" free=" SIZE_FORMAT " frag=%1.4f", total_size, flsFrag());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   775
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   776
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   777
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   778
void CompactibleFreeListSpace::reportIndexedFreeListStatistics(outputStream* st) const {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   779
  assert_lock_strong(&_freelistLock);
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   780
  st->print_cr("Statistics for IndexedFreeLists:");
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   781
  st->print_cr("--------------------------------");
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   782
  size_t total_size = totalSizeInIndexedFreeLists();
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   783
  size_t free_blocks = numFreeBlocksInIndexedFreeLists();
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   784
  st->print_cr("Total Free Space: " SIZE_FORMAT, total_size);
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   785
  st->print_cr("Max   Chunk Size: " SIZE_FORMAT, maxChunkSizeInIndexedFreeLists());
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   786
  st->print_cr("Number of Blocks: " SIZE_FORMAT, free_blocks);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
   787
  if (free_blocks != 0) {
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
   788
    st->print_cr("Av.  Block  Size: " SIZE_FORMAT, total_size/free_blocks);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   789
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   790
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   791
489c9b5090e2 Initial load
duke
parents:
diff changeset
   792
size_t CompactibleFreeListSpace::numFreeBlocksInIndexedFreeLists() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   793
  size_t res = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   794
  for (size_t i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   795
    debug_only(
489c9b5090e2 Initial load
duke
parents:
diff changeset
   796
      ssize_t recount = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   797
      for (FreeChunk* fc = _indexedFreeList[i].head(); fc != NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   798
         fc = fc->next()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   799
        recount += 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   800
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   801
      assert(recount == _indexedFreeList[i].count(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   802
        "Incorrect count in list");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   803
    )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   804
    res += _indexedFreeList[i].count();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   805
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   806
  return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   807
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   808
489c9b5090e2 Initial load
duke
parents:
diff changeset
   809
size_t CompactibleFreeListSpace::maxChunkSizeInIndexedFreeLists() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   810
  for (size_t i = IndexSetSize - 1; i != 0; i -= IndexSetStride) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   811
    if (_indexedFreeList[i].head() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   812
      assert(_indexedFreeList[i].count() != 0, "Inconsistent FreeList");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   813
      return (size_t)i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   814
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   815
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   816
  return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   817
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   818
489c9b5090e2 Initial load
duke
parents:
diff changeset
   819
void CompactibleFreeListSpace::set_end(HeapWord* value) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   820
  HeapWord* prevEnd = end();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   821
  assert(prevEnd != value, "unnecessary set_end call");
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   822
  assert(prevEnd == NULL || !BlockOffsetArrayUseUnallocatedBlock || value >= unallocated_block(),
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   823
        "New end is below unallocated block");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   824
  _end = value;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   825
  if (prevEnd != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   826
    // Resize the underlying block offset table.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   827
    _bt.resize(pointer_delta(value, bottom()));
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   828
    if (value <= prevEnd) {
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   829
      assert(!BlockOffsetArrayUseUnallocatedBlock || value >= unallocated_block(),
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
   830
             "New end is below unallocated block");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   831
    } else {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   832
      // Now, take this new chunk and add it to the free blocks.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   833
      // Note that the BOT has not yet been updated for this block.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
   834
      size_t newFcSize = pointer_delta(value, prevEnd);
33587
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   835
      // Add the block to the free lists, if possible coalescing it
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   836
      // with the last free block, and update the BOT and census data.
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
   837
      addChunkToFreeListsAtEndRecordingStats(prevEnd, newFcSize);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   838
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   839
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   840
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   841
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   842
class FreeListSpaceDCTOC : public FilteringDCTOC {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   843
  CompactibleFreeListSpace* _cfls;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   844
  CMSCollector* _collector;
30870
3050fdcdc60b 8080112: Replace and remove the last usages of CollectedHeap::n_par_threads()
stefank
parents: 30764
diff changeset
   845
  bool _parallel;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   846
protected:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   847
  // Override.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   848
#define walk_mem_region_with_cl_DECL(ClosureType)                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   849
  virtual void walk_mem_region_with_cl(MemRegion mr,                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   850
                                       HeapWord* bottom, HeapWord* top, \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   851
                                       ClosureType* cl);                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   852
      void walk_mem_region_with_cl_par(MemRegion mr,                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   853
                                       HeapWord* bottom, HeapWord* top, \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   854
                                       ClosureType* cl);                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   855
    void walk_mem_region_with_cl_nopar(MemRegion mr,                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   856
                                       HeapWord* bottom, HeapWord* top, \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   857
                                       ClosureType* cl)
50752
9d62da00bf15 8204540: Automatic oop closure devirtualization
stefank
parents: 50429
diff changeset
   858
  walk_mem_region_with_cl_DECL(OopIterateClosure);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   859
  walk_mem_region_with_cl_DECL(FilteringClosure);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   860
489c9b5090e2 Initial load
duke
parents:
diff changeset
   861
public:
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   862
  FreeListSpaceDCTOC(CompactibleFreeListSpace* sp,
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   863
                     CMSCollector* collector,
50752
9d62da00bf15 8204540: Automatic oop closure devirtualization
stefank
parents: 50429
diff changeset
   864
                     OopIterateClosure* cl,
49164
7e958a8ebcd3 8195142: Refactor out card table from CardTableModRefBS to flatten the BarrierSet hierarchy
eosterlund
parents: 47816
diff changeset
   865
                     CardTable::PrecisionStyle precision,
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   866
                     HeapWord* boundary,
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   867
                     bool parallel) :
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   868
    FilteringDCTOC(sp, cl, precision, boundary),
30870
3050fdcdc60b 8080112: Replace and remove the last usages of CollectedHeap::n_par_threads()
stefank
parents: 30764
diff changeset
   869
    _cfls(sp), _collector(collector), _parallel(parallel) {}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   870
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   871
489c9b5090e2 Initial load
duke
parents:
diff changeset
   872
// We de-virtualize the block-related calls below, since we know that our
489c9b5090e2 Initial load
duke
parents:
diff changeset
   873
// space is a CompactibleFreeListSpace.
11174
fccee5238e70 6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents: 10992
diff changeset
   874
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   875
#define FreeListSpaceDCTOC__walk_mem_region_with_cl_DEFN(ClosureType)           \
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   876
void FreeListSpaceDCTOC::walk_mem_region_with_cl(MemRegion mr,                  \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   877
                                                 HeapWord* bottom,              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   878
                                                 HeapWord* top,                 \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   879
                                                 ClosureType* cl) {             \
30870
3050fdcdc60b 8080112: Replace and remove the last usages of CollectedHeap::n_par_threads()
stefank
parents: 30764
diff changeset
   880
   if (_parallel) {                                                             \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   881
     walk_mem_region_with_cl_par(mr, bottom, top, cl);                          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   882
   } else {                                                                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   883
     walk_mem_region_with_cl_nopar(mr, bottom, top, cl);                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   884
   }                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   885
}                                                                               \
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   886
void FreeListSpaceDCTOC::walk_mem_region_with_cl_par(MemRegion mr,              \
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   887
                                                     HeapWord* bottom,          \
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   888
                                                     HeapWord* top,             \
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   889
                                                     ClosureType* cl) {         \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   890
  /* Skip parts that are before "mr", in case "block_start" sent us             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   891
     back too far. */                                                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   892
  HeapWord* mr_start = mr.start();                                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   893
  size_t bot_size = _cfls->CompactibleFreeListSpace::block_size(bottom);        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   894
  HeapWord* next = bottom + bot_size;                                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   895
  while (next < mr_start) {                                                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   896
    bottom = next;                                                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   897
    bot_size = _cfls->CompactibleFreeListSpace::block_size(bottom);             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   898
    next = bottom + bot_size;                                                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   899
  }                                                                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   900
                                                                                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   901
  while (bottom < top) {                                                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   902
    if (_cfls->CompactibleFreeListSpace::block_is_obj(bottom) &&                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   903
        !_cfls->CompactibleFreeListSpace::obj_allocated_since_save_marks(       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   904
                    oop(bottom)) &&                                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   905
        !_collector->CMSCollector::is_dead_obj(oop(bottom))) {                  \
32606
fdaa30d06ada 8129417: Oop iteration clean-up to remove oop_ms_follow_contents
sjohanss
parents: 30870
diff changeset
   906
      size_t word_sz = oop(bottom)->oop_iterate_size(cl, mr);                   \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   907
      bottom += _cfls->adjustObjectSize(word_sz);                               \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   908
    } else {                                                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   909
      bottom += _cfls->CompactibleFreeListSpace::block_size(bottom);            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   910
    }                                                                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   911
  }                                                                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   912
}                                                                               \
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   913
void FreeListSpaceDCTOC::walk_mem_region_with_cl_nopar(MemRegion mr,            \
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   914
                                                       HeapWord* bottom,        \
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   915
                                                       HeapWord* top,           \
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   916
                                                       ClosureType* cl) {       \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   917
  /* Skip parts that are before "mr", in case "block_start" sent us             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   918
     back too far. */                                                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   919
  HeapWord* mr_start = mr.start();                                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   920
  size_t bot_size = _cfls->CompactibleFreeListSpace::block_size_nopar(bottom);  \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   921
  HeapWord* next = bottom + bot_size;                                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   922
  while (next < mr_start) {                                                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   923
    bottom = next;                                                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   924
    bot_size = _cfls->CompactibleFreeListSpace::block_size_nopar(bottom);       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   925
    next = bottom + bot_size;                                                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   926
  }                                                                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   927
                                                                                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   928
  while (bottom < top) {                                                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   929
    if (_cfls->CompactibleFreeListSpace::block_is_obj_nopar(bottom) &&          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   930
        !_cfls->CompactibleFreeListSpace::obj_allocated_since_save_marks(       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   931
                    oop(bottom)) &&                                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   932
        !_collector->CMSCollector::is_dead_obj(oop(bottom))) {                  \
32606
fdaa30d06ada 8129417: Oop iteration clean-up to remove oop_ms_follow_contents
sjohanss
parents: 30870
diff changeset
   933
      size_t word_sz = oop(bottom)->oop_iterate_size(cl, mr);                   \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   934
      bottom += _cfls->adjustObjectSize(word_sz);                               \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   935
    } else {                                                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   936
      bottom += _cfls->CompactibleFreeListSpace::block_size_nopar(bottom);      \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   937
    }                                                                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   938
  }                                                                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   939
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   940
489c9b5090e2 Initial load
duke
parents:
diff changeset
   941
// (There are only two of these, rather than N, because the split is due
489c9b5090e2 Initial load
duke
parents:
diff changeset
   942
// only to the introduction of the FilteringClosure, a local part of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   943
// impl of this abstraction.)
50752
9d62da00bf15 8204540: Automatic oop closure devirtualization
stefank
parents: 50429
diff changeset
   944
FreeListSpaceDCTOC__walk_mem_region_with_cl_DEFN(OopIterateClosure)
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   945
FreeListSpaceDCTOC__walk_mem_region_with_cl_DEFN(FilteringClosure)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   946
489c9b5090e2 Initial load
duke
parents:
diff changeset
   947
DirtyCardToOopClosure*
50752
9d62da00bf15 8204540: Automatic oop closure devirtualization
stefank
parents: 50429
diff changeset
   948
CompactibleFreeListSpace::new_dcto_cl(OopIterateClosure* cl,
49164
7e958a8ebcd3 8195142: Refactor out card table from CardTableModRefBS to flatten the BarrierSet hierarchy
eosterlund
parents: 47816
diff changeset
   949
                                      CardTable::PrecisionStyle precision,
30870
3050fdcdc60b 8080112: Replace and remove the last usages of CollectedHeap::n_par_threads()
stefank
parents: 30764
diff changeset
   950
                                      HeapWord* boundary,
3050fdcdc60b 8080112: Replace and remove the last usages of CollectedHeap::n_par_threads()
stefank
parents: 30764
diff changeset
   951
                                      bool parallel) {
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
   952
  return new FreeListSpaceDCTOC(this, _collector, cl, precision, boundary, parallel);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   953
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   954
489c9b5090e2 Initial load
duke
parents:
diff changeset
   955
489c9b5090e2 Initial load
duke
parents:
diff changeset
   956
// Note on locking for the space iteration functions:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   957
// since the collector's iteration activities are concurrent with
489c9b5090e2 Initial load
duke
parents:
diff changeset
   958
// allocation activities by mutators, absent a suitable mutual exclusion
22551
9bf46d16dcc6 8025856: Fix typos in the GC code
jwilhelm
parents: 18687
diff changeset
   959
// mechanism the iterators may go awry. For instance a block being iterated
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   960
// may suddenly be allocated or divided up and part of it allocated and
489c9b5090e2 Initial load
duke
parents:
diff changeset
   961
// so on.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   962
489c9b5090e2 Initial load
duke
parents:
diff changeset
   963
// Apply the given closure to each block in the space.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   964
void CompactibleFreeListSpace::blk_iterate_careful(BlkClosureCareful* cl) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   965
  assert_lock_strong(freelistLock());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   966
  HeapWord *cur, *limit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   967
  for (cur = bottom(), limit = end(); cur < limit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   968
       cur += cl->do_blk_careful(cur));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   969
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   970
489c9b5090e2 Initial load
duke
parents:
diff changeset
   971
// Apply the given closure to each block in the space.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   972
void CompactibleFreeListSpace::blk_iterate(BlkClosure* cl) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   973
  assert_lock_strong(freelistLock());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   974
  HeapWord *cur, *limit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   975
  for (cur = bottom(), limit = end(); cur < limit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   976
       cur += cl->do_blk(cur));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   977
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   978
489c9b5090e2 Initial load
duke
parents:
diff changeset
   979
// Apply the given closure to each oop in the space.
50752
9d62da00bf15 8204540: Automatic oop closure devirtualization
stefank
parents: 50429
diff changeset
   980
void CompactibleFreeListSpace::oop_iterate(OopIterateClosure* cl) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   981
  assert_lock_strong(freelistLock());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   982
  HeapWord *cur, *limit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   983
  size_t curSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   984
  for (cur = bottom(), limit = end(); cur < limit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   985
       cur += curSize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   986
    curSize = block_size(cur);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   987
    if (block_is_obj(cur)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   988
      oop(cur)->oop_iterate(cl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   989
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   990
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   991
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   992
489c9b5090e2 Initial load
duke
parents:
diff changeset
   993
// NOTE: In the following methods, in order to safely be able to
489c9b5090e2 Initial load
duke
parents:
diff changeset
   994
// apply the closure to an object, we need to be sure that the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   995
// object has been initialized. We are guaranteed that an object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   996
// is initialized if we are holding the Heap_lock with the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   997
// world stopped.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   998
void CompactibleFreeListSpace::verify_objects_initialized() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   999
  if (is_init_completed()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1000
    assert_locked_or_safepoint(Heap_lock);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1001
    if (Universe::is_fully_initialized()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1002
      guarantee(SafepointSynchronize::is_at_safepoint(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1003
                "Required for objects to be initialized");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1004
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1005
  } // else make a concession at vm start-up
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1006
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1007
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1008
// Apply the given closure to each object in the space
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1009
void CompactibleFreeListSpace::object_iterate(ObjectClosure* blk) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1010
  assert_lock_strong(freelistLock());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1011
  NOT_PRODUCT(verify_objects_initialized());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1012
  HeapWord *cur, *limit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1013
  size_t curSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1014
  for (cur = bottom(), limit = end(); cur < limit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1015
       cur += curSize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1016
    curSize = block_size(cur);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1017
    if (block_is_obj(cur)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1018
      blk->do_object(oop(cur));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1019
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1020
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1021
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1022
1893
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1023
// Apply the given closure to each live object in the space
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1024
//   The usage of CompactibleFreeListSpace
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1025
// by the ConcurrentMarkSweepGeneration for concurrent GC's allows
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1026
// objects in the space with references to objects that are no longer
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1027
// valid.  For example, an object may reference another object
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1028
// that has already been sweep up (collected).  This method uses
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1029
// obj_is_alive() to determine whether it is safe to apply the closure to
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1030
// an object.  See obj_is_alive() for details on how liveness of an
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1031
// object is decided.
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1032
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1033
void CompactibleFreeListSpace::safe_object_iterate(ObjectClosure* blk) {
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1034
  assert_lock_strong(freelistLock());
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1035
  NOT_PRODUCT(verify_objects_initialized());
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1036
  HeapWord *cur, *limit;
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1037
  size_t curSize;
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1038
  for (cur = bottom(), limit = end(); cur < limit;
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1039
       cur += curSize) {
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1040
    curSize = block_size(cur);
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1041
    if (block_is_obj(cur) && obj_is_alive(cur)) {
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1042
      blk->do_object(oop(cur));
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1043
    }
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1044
  }
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1045
}
c82e388e17c5 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 1392
diff changeset
  1046
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1047
void CompactibleFreeListSpace::object_iterate_mem(MemRegion mr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1048
                                                  UpwardsObjectClosure* cl) {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1049
  assert_locked(freelistLock());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1050
  NOT_PRODUCT(verify_objects_initialized());
23535
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1051
  assert(!mr.is_empty(), "Should be non-empty");
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1052
  // We use MemRegion(bottom(), end()) rather than used_region() below
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1053
  // because the two are not necessarily equal for some kinds of
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1054
  // spaces, in particular, certain kinds of free list spaces.
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1055
  // We could use the more complicated but more precise:
46620
750c6edff33b 8178500: Replace usages of round_to and round_down with align_up and align_down
stefank
parents: 46619
diff changeset
  1056
  // MemRegion(used_region().start(), align_up(used_region().end(), CardSize))
23535
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1057
  // but the slight imprecision seems acceptable in the assertion check.
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1058
  assert(MemRegion(bottom(), end()).contains(mr),
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1059
         "Should be within used space");
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1060
  HeapWord* prev = cl->previous();   // max address from last time
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1061
  if (prev >= mr.end()) { // nothing to do
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1062
    return;
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1063
  }
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1064
  // This assert will not work when we go from cms space to perm
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1065
  // space, and use same closure. Easy fix deferred for later. XXX YSR
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1066
  // assert(prev == NULL || contains(prev), "Should be within space");
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1067
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1068
  bool last_was_obj_array = false;
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1069
  HeapWord *blk_start_addr, *region_start_addr;
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1070
  if (prev > mr.start()) {
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1071
    region_start_addr = prev;
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1072
    blk_start_addr    = prev;
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1073
    // The previous invocation may have pushed "prev" beyond the
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1074
    // last allocated block yet there may be still be blocks
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1075
    // in this region due to a particular coalescing policy.
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1076
    // Relax the assertion so that the case where the unallocated
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1077
    // block is maintained and "prev" is beyond the unallocated
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1078
    // block does not cause the assertion to fire.
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1079
    assert((BlockOffsetArrayUseUnallocatedBlock &&
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1080
            (!is_in(prev))) ||
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1081
           (blk_start_addr == block_start(region_start_addr)), "invariant");
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1082
  } else {
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1083
    region_start_addr = mr.start();
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1084
    blk_start_addr    = block_start(region_start_addr);
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1085
  }
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1086
  HeapWord* region_end_addr = mr.end();
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1087
  MemRegion derived_mr(region_start_addr, region_end_addr);
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1088
  while (blk_start_addr < region_end_addr) {
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1089
    const size_t size = block_size(blk_start_addr);
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1090
    if (block_is_obj(blk_start_addr)) {
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1091
      last_was_obj_array = cl->do_object_bm(oop(blk_start_addr), derived_mr);
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1092
    } else {
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1093
      last_was_obj_array = false;
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1094
    }
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1095
    blk_start_addr += size;
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1096
  }
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1097
  if (!last_was_obj_array) {
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1098
    assert((bottom() <= blk_start_addr) && (blk_start_addr <= end()),
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1099
           "Should be within (closed) used space");
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1100
    assert(blk_start_addr > prev, "Invariant");
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1101
    cl->set_previous(blk_start_addr); // min address for next time
6306204d22a9 8038404: Move object_iterate_mem from Space to CMS since it is only ever used by CMS
mgerdin
parents: 23508
diff changeset
  1102
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1103
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1104
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1105
// Callers of this iterator beware: The closure application should
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1106
// be robust in the face of uninitialized objects and should (always)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1107
// return a correct size so that the next addr + size below gives us a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1108
// valid block boundary. [See for instance,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1109
// ScanMarkedObjectsAgainCarefullyClosure::do_object_careful()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1110
// in ConcurrentMarkSweepGeneration.cpp.]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1111
HeapWord*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1112
CompactibleFreeListSpace::object_iterate_careful_m(MemRegion mr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1113
  ObjectClosureCareful* cl) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1114
  assert_lock_strong(freelistLock());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1115
  // Can't use used_region() below because it may not necessarily
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1116
  // be the same as [bottom(),end()); although we could
46620
750c6edff33b 8178500: Replace usages of round_to and round_down with align_up and align_down
stefank
parents: 46619
diff changeset
  1117
  // use [used_region().start(),align_up(used_region().end(),CardSize)),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1118
  // that appears too cumbersome, so we just do the simpler check
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1119
  // in the assertion below.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1120
  assert(!mr.is_empty() && MemRegion(bottom(),end()).contains(mr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1121
         "mr should be non-empty and within used space");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1122
  HeapWord *addr, *end;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1123
  size_t size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1124
  for (addr = block_start_careful(mr.start()), end  = mr.end();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1125
       addr < end; addr += size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1126
    FreeChunk* fc = (FreeChunk*)addr;
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1127
    if (fc->is_free()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1128
      // Since we hold the free list lock, which protects direct
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1129
      // allocation in this generation by mutators, a free object
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1130
      // will remain free throughout this iteration code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1131
      size = fc->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1132
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1133
      // Note that the object need not necessarily be initialized,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1134
      // because (for instance) the free list lock does NOT protect
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1135
      // object initialization. The closure application below must
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1136
      // therefore be correct in the face of uninitialized objects.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1137
      size = cl->do_object_careful_m(oop(addr), mr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1138
      if (size == 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1139
        // An unparsable object found. Signal early termination.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1140
        return addr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1141
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1142
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1143
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1144
  return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1145
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1146
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1147
1374
4c24294029a9 6711316: Open source the Garbage-First garbage collector
ysr
parents: 360
diff changeset
  1148
HeapWord* CompactibleFreeListSpace::block_start_const(const void* p) const {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1149
  NOT_PRODUCT(verify_objects_initialized());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1150
  return _bt.block_start(p);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1151
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1152
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1153
HeapWord* CompactibleFreeListSpace::block_start_careful(const void* p) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1154
  return _bt.block_start_careful(p);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1155
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1156
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1157
size_t CompactibleFreeListSpace::block_size(const HeapWord* p) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1158
  NOT_PRODUCT(verify_objects_initialized());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1159
  // This must be volatile, or else there is a danger that the compiler
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1160
  // will compile the code below into a sometimes-infinite loop, by keeping
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1161
  // the value read the first time in a register.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1162
  while (true) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1163
    // We must do this until we get a consistent view of the object.
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1164
    if (FreeChunk::indicatesFreeChunk(p)) {
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1165
      volatile FreeChunk* fc = (volatile FreeChunk*)p;
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1166
      size_t res = fc->size();
22859
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1167
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1168
      // Bugfix for systems with weak memory model (PPC64/IA64). The
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1169
      // block's free bit was set and we have read the size of the
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1170
      // block. Acquire and check the free bit again. If the block is
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1171
      // still free, the read size is correct.
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1172
      OrderAccess::acquire();
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1173
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1174
      // If the object is still a free chunk, return the size, else it
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1175
      // has been allocated so try again.
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1176
      if (FreeChunk::indicatesFreeChunk(p)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1177
        assert(res != 0, "Block size should not be 0");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1178
        return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1179
      }
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1180
    } else {
42043
bf17eb48ea3f 8166862: CMS needs klass_or_null_acquire
kbarrett
parents: 37457
diff changeset
  1181
      // Ensure klass read before size.
bf17eb48ea3f 8166862: CMS needs klass_or_null_acquire
kbarrett
parents: 37457
diff changeset
  1182
      Klass* k = oop(p)->klass_or_null_acquire();
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1183
      if (k != NULL) {
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 12776
diff changeset
  1184
        assert(k->is_klass(), "Should really be klass oop.");
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1185
        oop o = (oop)p;
46968
9119841280f4 8160399: is_oop_or_null involves undefined behavior
coleenp
parents: 46701
diff changeset
  1186
        assert(oopDesc::is_oop(o, true /* ignore mark word */), "Should be an oop.");
22859
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1187
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 12776
diff changeset
  1188
        size_t res = o->size_given_klass(k);
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1189
        res = adjustObjectSize(res);
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1190
        assert(res != 0, "Block size should not be 0");
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1191
        return res;
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1192
      }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1193
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1194
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1195
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1196
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 12776
diff changeset
  1197
// TODO: Now that is_parsable is gone, we should combine these two functions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1198
// A variant of the above that uses the Printezis bits for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1199
// unparsable but allocated objects. This avoids any possible
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1200
// stalls waiting for mutators to initialize objects, and is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1201
// thus potentially faster than the variant above. However,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1202
// this variant may return a zero size for a block that is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1203
// under mutation and for which a consistent size cannot be
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1204
// inferred without stalling; see CMSCollector::block_size_if_printezis_bits().
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1205
size_t CompactibleFreeListSpace::block_size_no_stall(HeapWord* p,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1206
                                                     const CMSCollector* c)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1207
const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1208
  assert(MemRegion(bottom(), end()).contains(p), "p not in space");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1209
  // This must be volatile, or else there is a danger that the compiler
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1210
  // will compile the code below into a sometimes-infinite loop, by keeping
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1211
  // the value read the first time in a register.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1212
  DEBUG_ONLY(uint loops = 0;)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1213
  while (true) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1214
    // We must do this until we get a consistent view of the object.
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1215
    if (FreeChunk::indicatesFreeChunk(p)) {
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1216
      volatile FreeChunk* fc = (volatile FreeChunk*)p;
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1217
      size_t res = fc->size();
22859
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1218
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1219
      // Bugfix for systems with weak memory model (PPC64/IA64). The
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1220
      // free bit of the block was set and we have read the size of
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1221
      // the block. Acquire and check the free bit again. If the
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1222
      // block is still free, the read size is correct.
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1223
      OrderAccess::acquire();
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1224
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1225
      if (FreeChunk::indicatesFreeChunk(p)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1226
        assert(res != 0, "Block size should not be 0");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1227
        assert(loops == 0, "Should be 0");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1228
        return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1229
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1230
    } else {
42043
bf17eb48ea3f 8166862: CMS needs klass_or_null_acquire
kbarrett
parents: 37457
diff changeset
  1231
      // Ensure klass read before size.
bf17eb48ea3f 8166862: CMS needs klass_or_null_acquire
kbarrett
parents: 37457
diff changeset
  1232
      Klass* k = oop(p)->klass_or_null_acquire();
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 12776
diff changeset
  1233
      if (k != NULL) {
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 12776
diff changeset
  1234
        assert(k->is_klass(), "Should really be klass oop.");
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1235
        oop o = (oop)p;
46968
9119841280f4 8160399: is_oop_or_null involves undefined behavior
coleenp
parents: 46701
diff changeset
  1236
        assert(oopDesc::is_oop(o), "Should be an oop");
22859
7b88983393b7 8029396: PPC64 (part 212): Several memory ordering fixes in C-code.
goetz
parents: 18687
diff changeset
  1237
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 12776
diff changeset
  1238
        size_t res = o->size_given_klass(k);
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1239
        res = adjustObjectSize(res);
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1240
        assert(res != 0, "Block size should not be 0");
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1241
        return res;
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1242
      } else {
8296
b1c2163e4e59 6912621: iCMS: Error: assert(_markBitMap.isMarked(addr + 1),"Missing Printezis bit?")
ysr
parents: 7397
diff changeset
  1243
        // May return 0 if P-bits not present.
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1244
        return c->block_size_if_printezis_bits(p);
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1245
      }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1246
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1247
    assert(loops == 0, "Can loop at most once");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1248
    DEBUG_ONLY(loops++;)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1249
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1250
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1251
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1252
size_t CompactibleFreeListSpace::block_size_nopar(const HeapWord* p) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1253
  NOT_PRODUCT(verify_objects_initialized());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1254
  assert(MemRegion(bottom(), end()).contains(p), "p not in space");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1255
  FreeChunk* fc = (FreeChunk*)p;
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1256
  if (fc->is_free()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1257
    return fc->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1258
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1259
    // Ignore mark word because this may be a recently promoted
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1260
    // object whose mark word is used to chain together grey
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1261
    // objects (the last one would have a null value).
46968
9119841280f4 8160399: is_oop_or_null involves undefined behavior
coleenp
parents: 46701
diff changeset
  1262
    assert(oopDesc::is_oop(oop(p), true), "Should be an oop");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1263
    return adjustObjectSize(oop(p)->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1264
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1265
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1266
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1267
// This implementation assumes that the property of "being an object" is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1268
// stable.  But being a free chunk may not be (because of parallel
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1269
// promotion.)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1270
bool CompactibleFreeListSpace::block_is_obj(const HeapWord* p) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1271
  FreeChunk* fc = (FreeChunk*)p;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1272
  assert(is_in_reserved(p), "Should be in space");
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1273
  if (FreeChunk::indicatesFreeChunk(p)) return false;
42043
bf17eb48ea3f 8166862: CMS needs klass_or_null_acquire
kbarrett
parents: 37457
diff changeset
  1274
  Klass* k = oop(p)->klass_or_null_acquire();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1275
  if (k != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1276
    // Ignore mark word because it may have been used to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1277
    // chain together promoted objects (the last one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1278
    // would have a null value).
46968
9119841280f4 8160399: is_oop_or_null involves undefined behavior
coleenp
parents: 46701
diff changeset
  1279
    assert(oopDesc::is_oop(oop(p), true), "Should be an oop");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1280
    return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1281
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1282
    return false;  // Was not an object at the start of collection.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1283
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1284
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1285
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1286
// Check if the object is alive. This fact is checked either by consulting
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1287
// the main marking bitmap in the sweeping phase or, if it's a permanent
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1288
// generation and we're not in the sweeping phase, by checking the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1289
// perm_gen_verify_bit_map where we store the "deadness" information if
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1290
// we did not sweep the perm gen in the most recent previous GC cycle.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1291
bool CompactibleFreeListSpace::obj_is_alive(const HeapWord* p) const {
7384
71eebb634028 7000578: CMS: assert(SafepointSynchronize::is_at_safepoint()) failed: Else races are possible
ysr
parents: 7377
diff changeset
  1292
  assert(SafepointSynchronize::is_at_safepoint() || !is_init_completed(),
71eebb634028 7000578: CMS: assert(SafepointSynchronize::is_at_safepoint()) failed: Else races are possible
ysr
parents: 7377
diff changeset
  1293
         "Else races are possible");
7376
d6f7fff9da94 6997298: fatal error: must own lock CMS_markBitMap_lock during heap dump
ysr
parents: 6759
diff changeset
  1294
  assert(block_is_obj(p), "The address should point to an object");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1295
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1296
  // If we're sweeping, we use object liveness information from the main bit map
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1297
  // for both perm gen and old gen.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1298
  // We don't need to lock the bitmap (live_map or dead_map below), because
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1299
  // EITHER we are in the middle of the sweeping phase, and the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1300
  // main marking bit map (live_map below) is locked,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1301
  // OR we're in other phases and perm_gen_verify_bit_map (dead_map below)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1302
  // is stable, because it's mutated only in the sweeping phase.
7376
d6f7fff9da94 6997298: fatal error: must own lock CMS_markBitMap_lock during heap dump
ysr
parents: 6759
diff changeset
  1303
  // NOTE: This method is also used by jmap where, if class unloading is
d6f7fff9da94 6997298: fatal error: must own lock CMS_markBitMap_lock during heap dump
ysr
parents: 6759
diff changeset
  1304
  // off, the results can return "false" for legitimate perm objects,
d6f7fff9da94 6997298: fatal error: must own lock CMS_markBitMap_lock during heap dump
ysr
parents: 6759
diff changeset
  1305
  // when we are not in the midst of a sweeping phase, which can result
d6f7fff9da94 6997298: fatal error: must own lock CMS_markBitMap_lock during heap dump
ysr
parents: 6759
diff changeset
  1306
  // in jmap not reporting certain perm gen objects. This will be moot
d6f7fff9da94 6997298: fatal error: must own lock CMS_markBitMap_lock during heap dump
ysr
parents: 6759
diff changeset
  1307
  // if/when the perm gen goes away in the future.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1308
  if (_collector->abstract_state() == CMSCollector::Sweeping) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1309
    CMSBitMap* live_map = _collector->markBitMap();
7376
d6f7fff9da94 6997298: fatal error: must own lock CMS_markBitMap_lock during heap dump
ysr
parents: 6759
diff changeset
  1310
    return live_map->par_isMarked((HeapWord*) p);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1311
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1312
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1313
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1314
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1315
bool CompactibleFreeListSpace::block_is_obj_nopar(const HeapWord* p) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1316
  FreeChunk* fc = (FreeChunk*)p;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1317
  assert(is_in_reserved(p), "Should be in space");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1318
  assert(_bt.block_start(p) == p, "Should be a block boundary");
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1319
  if (!fc->is_free()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1320
    // Ignore mark word because it may have been used to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1321
    // chain together promoted objects (the last one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1322
    // would have a null value).
46968
9119841280f4 8160399: is_oop_or_null involves undefined behavior
coleenp
parents: 46701
diff changeset
  1323
    assert(oopDesc::is_oop(oop(p), true), "Should be an oop");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1324
    return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1325
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1326
  return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1327
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1328
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1329
// "MT-safe but not guaranteed MT-precise" (TM); you may get an
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1330
// approximate answer if you don't hold the freelistlock when you call this.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1331
size_t CompactibleFreeListSpace::totalSizeInIndexedFreeLists() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1332
  size_t size = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1333
  for (size_t i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1334
    debug_only(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1335
      // We may be calling here without the lock in which case we
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1336
      // won't do this modest sanity check.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1337
      if (freelistLock()->owned_by_self()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1338
        size_t total_list_size = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1339
        for (FreeChunk* fc = _indexedFreeList[i].head(); fc != NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1340
          fc = fc->next()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1341
          total_list_size += i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1342
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1343
        assert(total_list_size == i * _indexedFreeList[i].count(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1344
               "Count in list is incorrect");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1345
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1346
    )
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1347
    size += i * _indexedFreeList[i].count();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1348
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1349
  return size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1350
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1351
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1352
HeapWord* CompactibleFreeListSpace::par_allocate(size_t size) {
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  1353
  MutexLocker x(freelistLock(), Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1354
  return allocate(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1355
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1356
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1357
HeapWord*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1358
CompactibleFreeListSpace::getChunkFromSmallLinearAllocBlockRemainder(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1359
  return getChunkFromLinearAllocBlockRemainder(&_smallLinearAllocBlock, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1360
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1361
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1362
HeapWord* CompactibleFreeListSpace::allocate(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1363
  assert_lock_strong(freelistLock());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1364
  HeapWord* res = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1365
  assert(size == adjustObjectSize(size),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1366
         "use adjustObjectSize() before calling into allocate()");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1367
33587
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
  1368
  res = allocate_adaptive_freelists(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1369
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1370
  if (res != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1371
    // check that res does lie in this space!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1372
    assert(is_in_reserved(res), "Not in this space!");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1373
    assert(is_aligned((void*)res), "alignment check");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1374
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1375
    FreeChunk* fc = (FreeChunk*)res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1376
    fc->markNotFree();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1377
    assert(!fc->is_free(), "shouldn't be marked free");
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  1378
    assert(oop(fc)->klass_or_null() == NULL, "should look uninitialized");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1379
    // Verify that the block offset table shows this to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1380
    // be a single block, but not one which is unallocated.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1381
    _bt.verify_single_block(res, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1382
    _bt.verify_not_unallocated(res, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1383
    // mangle a just allocated object with a distinct pattern.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1384
    debug_only(fc->mangleAllocated(size));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1385
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1386
57782
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
  1387
  // During GC we do not need to recalculate the stable used value for
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
  1388
  // every allocation in old gen. It is done once at the end of GC instead
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
  1389
  // for performance reasons.
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
  1390
  if (!CMSHeap::heap()->is_gc_active()) {
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
  1391
    recalculate_used_stable();
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
  1392
  }
ca133d5ea78a 8229420: [Redo] jstat reports incorrect values for OU for CMS GC
poonam
parents: 55557
diff changeset
  1393
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1394
  return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1395
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1396
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1397
HeapWord* CompactibleFreeListSpace::allocate_adaptive_freelists(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1398
  assert_lock_strong(freelistLock());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1399
  HeapWord* res = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1400
  assert(size == adjustObjectSize(size),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1401
         "use adjustObjectSize() before calling into allocate()");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1402
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1403
  // Strategy
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1404
  //   if small
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1405
  //     exact size from small object indexed list if small
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1406
  //     small or large linear allocation block (linAB) as appropriate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1407
  //     take from lists of greater sized chunks
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1408
  //   else
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1409
  //     dictionary
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1410
  //     small or large linear allocation block if it has the space
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1411
  // Try allocating exact size from indexTable first
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1412
  if (size < IndexSetSize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1413
    res = (HeapWord*) getChunkFromIndexedFreeList(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1414
    if(res != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1415
      assert(res != (HeapWord*)_indexedFreeList[size].head(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1416
        "Not removed from free list");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1417
      // no block offset table adjustment is necessary on blocks in
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1418
      // the indexed lists.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1419
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1420
    // Try allocating from the small LinAB
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1421
    } else if (size < _smallLinearAllocBlock._allocation_size_limit &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1422
        (res = getChunkFromSmallLinearAllocBlock(size)) != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1423
        // if successful, the above also adjusts block offset table
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1424
        // Note that this call will refill the LinAB to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1425
        // satisfy the request.  This is different that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1426
        // evm.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1427
        // Don't record chunk off a LinAB?  smallSplitBirth(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1428
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1429
      // Raid the exact free lists larger than size, even if they are not
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1430
      // overpopulated.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1431
      res = (HeapWord*) getChunkFromGreater(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1432
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1433
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1434
    // Big objects get allocated directly from the dictionary.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1435
    res = (HeapWord*) getChunkFromDictionaryExact(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1436
    if (res == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1437
      // Try hard not to fail since an allocation failure will likely
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1438
      // trigger a synchronous GC.  Try to get the space from the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1439
      // allocation blocks.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1440
      res = getChunkFromSmallLinearAllocBlockRemainder(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1441
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1442
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1443
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1444
  return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1445
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1446
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1447
// A worst-case estimate of the space required (in HeapWords) to expand the heap
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1448
// when promoting obj.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1449
size_t CompactibleFreeListSpace::expansionSpaceRequired(size_t obj_size) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1450
  // Depending on the object size, expansion may require refilling either a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1451
  // bigLAB or a smallLAB plus refilling a PromotionInfo object.  MinChunkSize
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1452
  // is added because the dictionary may over-allocate to avoid fragmentation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1453
  size_t space = obj_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1454
  space += _promoInfo.refillSize() + 2 * MinChunkSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1455
  return space;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1456
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1457
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1458
FreeChunk* CompactibleFreeListSpace::getChunkFromGreater(size_t numWords) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1459
  FreeChunk* ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1460
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1461
  assert(numWords >= MinChunkSize, "Size is less than minimum");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1462
  assert(linearAllocationWouldFail() || bestFitFirst(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1463
    "Should not be here");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1464
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1465
  size_t i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1466
  size_t currSize = numWords + MinChunkSize;
46683
33808f7eadd5 8184753: Asserts against MinObjectAlignment should avoid integer division
shade
parents: 46674
diff changeset
  1467
  assert(is_object_aligned(currSize), "currSize should be aligned");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1468
  for (i = currSize; i < IndexSetSize; i += IndexSetStride) {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  1469
    AdaptiveFreeList<FreeChunk>* fl = &_indexedFreeList[i];
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1470
    if (fl->head()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1471
      ret = getFromListGreater(fl, numWords);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1472
      assert(ret == NULL || ret->is_free(), "Should be returning a free chunk");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1473
      return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1474
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1475
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1476
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1477
  currSize = MAX2((size_t)SmallForDictionary,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1478
                  (size_t)(numWords + MinChunkSize));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1479
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1480
  /* Try to get a chunk that satisfies request, while avoiding
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1481
     fragmentation that can't be handled. */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1482
  {
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1483
    ret =  dictionary()->get_chunk(currSize);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1484
    if (ret != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1485
      assert(ret->size() - numWords >= MinChunkSize,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1486
             "Chunk is too small");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1487
      _bt.allocated((HeapWord*)ret, ret->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1488
      /* Carve returned chunk. */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1489
      (void) splitChunkAndReturnRemainder(ret, numWords);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1490
      /* Label this as no longer a free chunk. */
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1491
      assert(ret->is_free(), "This chunk should be free");
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1492
      ret->link_prev(NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1493
    }
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1494
    assert(ret == NULL || ret->is_free(), "Should be returning a free chunk");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1495
    return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1496
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1497
  ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1498
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1499
10771
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1500
bool CompactibleFreeListSpace::verifyChunkInIndexedFreeLists(FreeChunk* fc) const {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1501
  assert(fc->size() < IndexSetSize, "Size of chunk is too large");
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1502
  return _indexedFreeList[fc->size()].verify_chunk_in_free_list(fc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1503
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1504
10771
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1505
bool CompactibleFreeListSpace::verify_chunk_is_linear_alloc_block(FreeChunk* fc) const {
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1506
  assert((_smallLinearAllocBlock._ptr != (HeapWord*)fc) ||
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1507
         (_smallLinearAllocBlock._word_size == fc->size()),
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1508
         "Linear allocation block shows incorrect size");
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1509
  return ((_smallLinearAllocBlock._ptr == (HeapWord*)fc) &&
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1510
          (_smallLinearAllocBlock._word_size == fc->size()));
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1511
}
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1512
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1513
// Check if the purported free chunk is present either as a linear
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1514
// allocation block, the size-indexed table of (smaller) free blocks,
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1515
// or the larger free blocks kept in the binary tree dictionary.
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1516
bool CompactibleFreeListSpace::verify_chunk_in_free_list(FreeChunk* fc) const {
10771
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1517
  if (verify_chunk_is_linear_alloc_block(fc)) {
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1518
    return true;
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1519
  } else if (fc->size() < IndexSetSize) {
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1520
    return verifyChunkInIndexedFreeLists(fc);
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  1521
  } else {
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1522
    return dictionary()->verify_chunk_in_free_list(fc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1523
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1524
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1525
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1526
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1527
void CompactibleFreeListSpace::assert_locked() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1528
  CMSLockVerifier::assert_locked(freelistLock(), parDictionaryAllocLock());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1529
}
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1530
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1531
void CompactibleFreeListSpace::assert_locked(const Mutex* lock) const {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1532
  CMSLockVerifier::assert_locked(lock);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1533
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1534
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1535
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1536
FreeChunk* CompactibleFreeListSpace::allocateScratch(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1537
  // In the parallel case, the main thread holds the free list lock
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1538
  // on behalf the parallel threads.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1539
  FreeChunk* fc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1540
  {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1541
    // If GC is parallel, this might be called by several threads.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1542
    // This should be rare enough that the locking overhead won't affect
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1543
    // the sequential code.
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  1544
    MutexLocker x(parDictionaryAllocLock(),
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  1545
                  Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1546
    fc = getChunkFromDictionary(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1547
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1548
  if (fc != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1549
    fc->dontCoalesce();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1550
    assert(fc->is_free(), "Should be free, but not coalescable");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1551
    // Verify that the block offset table shows this to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1552
    // be a single block, but not one which is unallocated.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1553
    _bt.verify_single_block((HeapWord*)fc, fc->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1554
    _bt.verify_not_unallocated((HeapWord*)fc, fc->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1555
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1556
  return fc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1557
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1558
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  1559
oop CompactibleFreeListSpace::promote(oop obj, size_t obj_size) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1560
  assert(obj_size == (size_t)obj->size(), "bad obj_size passed in");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1561
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1562
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1563
  // if we are tracking promotions, then first ensure space for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1564
  // promotion (including spooling space for saving header if necessary).
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1565
  // then allocate and copy, then track promoted info if needed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1566
  // When tracking (see PromotionInfo::track()), the mark word may
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1567
  // be displaced and in this case restoration of the mark word
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1568
  // occurs in the (oop_since_save_marks_)iterate phase.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1569
  if (_promoInfo.tracking() && !_promoInfo.ensure_spooling_space()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1570
    return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1571
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1572
  // Call the allocate(size_t, bool) form directly to avoid the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1573
  // additional call through the allocate(size_t) form.  Having
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1574
  // the compile inline the call is problematic because allocate(size_t)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1575
  // is a virtual method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1576
  HeapWord* res = allocate(adjustObjectSize(obj_size));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1577
  if (res != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1578
    Copy::aligned_disjoint_words((HeapWord*)obj, res, obj_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1579
    // if we should be tracking promotions, do so.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1580
    if (_promoInfo.tracking()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1581
        _promoInfo.track((PromotedObject*)res);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1582
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1583
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1584
  return oop(res);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1585
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1586
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1587
HeapWord*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1588
CompactibleFreeListSpace::getChunkFromSmallLinearAllocBlock(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1589
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1590
  assert(size >= MinChunkSize, "minimum chunk size");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1591
  assert(size <  _smallLinearAllocBlock._allocation_size_limit,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1592
    "maximum from smallLinearAllocBlock");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1593
  return getChunkFromLinearAllocBlock(&_smallLinearAllocBlock, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1594
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1595
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1596
HeapWord*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1597
CompactibleFreeListSpace::getChunkFromLinearAllocBlock(LinearAllocBlock *blk,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1598
                                                       size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1599
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1600
  assert(size >= MinChunkSize, "too small");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1601
  HeapWord* res = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1602
  // Try to do linear allocation from blk, making sure that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1603
  if (blk->_word_size == 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1604
    // We have probably been unable to fill this either in the prologue or
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1605
    // when it was exhausted at the last linear allocation. Bail out until
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1606
    // next time.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1607
    assert(blk->_ptr == NULL, "consistency check");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1608
    return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1609
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1610
  assert(blk->_word_size != 0 && blk->_ptr != NULL, "consistency check");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1611
  res = getChunkFromLinearAllocBlockRemainder(blk, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1612
  if (res != NULL) return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1613
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1614
  // about to exhaust this linear allocation block
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1615
  if (blk->_word_size == size) { // exactly satisfied
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1616
    res = blk->_ptr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1617
    _bt.allocated(res, blk->_word_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1618
  } else if (size + MinChunkSize <= blk->_refillSize) {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1619
    size_t sz = blk->_word_size;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1620
    // Update _unallocated_block if the size is such that chunk would be
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1621
    // returned to the indexed free list.  All other chunks in the indexed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1622
    // free lists are allocated from the dictionary so that _unallocated_block
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1623
    // has already been adjusted for them.  Do it here so that the cost
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1624
    // for all chunks added back to the indexed free lists.
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1625
    if (sz < SmallForDictionary) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1626
      _bt.allocated(blk->_ptr, sz);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1627
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1628
    // Return the chunk that isn't big enough, and then refill below.
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1629
    addChunkToFreeLists(blk->_ptr, sz);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1630
    split_birth(sz);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1631
    // Don't keep statistics on adding back chunk from a LinAB.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1632
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1633
    // A refilled block would not satisfy the request.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1634
    return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1635
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1636
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1637
  blk->_ptr = NULL; blk->_word_size = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1638
  refillLinearAllocBlock(blk);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1639
  assert(blk->_ptr == NULL || blk->_word_size >= size + MinChunkSize,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1640
         "block was replenished");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1641
  if (res != NULL) {
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1642
    split_birth(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1643
    repairLinearAllocBlock(blk);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1644
  } else if (blk->_ptr != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1645
    res = blk->_ptr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1646
    size_t blk_size = blk->_word_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1647
    blk->_word_size -= size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1648
    blk->_ptr  += size;
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1649
    split_birth(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1650
    repairLinearAllocBlock(blk);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1651
    // Update BOT last so that other (parallel) GC threads see a consistent
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1652
    // view of the BOT and free blocks.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1653
    // Above must occur before BOT is updated below.
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  1654
    OrderAccess::storestore();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1655
    _bt.split_block(res, blk_size, size);  // adjust block offset table
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1656
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1657
  return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1658
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1659
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1660
HeapWord*  CompactibleFreeListSpace::getChunkFromLinearAllocBlockRemainder(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1661
                                        LinearAllocBlock* blk,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1662
                                        size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1663
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1664
  assert(size >= MinChunkSize, "too small");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1665
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1666
  HeapWord* res = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1667
  // This is the common case.  Keep it simple.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1668
  if (blk->_word_size >= size + MinChunkSize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1669
    assert(blk->_ptr != NULL, "consistency check");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1670
    res = blk->_ptr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1671
    // Note that the BOT is up-to-date for the linAB before allocation.  It
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1672
    // indicates the start of the linAB.  The split_block() updates the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1673
    // BOT for the linAB after the allocation (indicates the start of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1674
    // next chunk to be allocated).
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1675
    size_t blk_size = blk->_word_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1676
    blk->_word_size -= size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1677
    blk->_ptr  += size;
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1678
    split_birth(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1679
    repairLinearAllocBlock(blk);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1680
    // Update BOT last so that other (parallel) GC threads see a consistent
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1681
    // view of the BOT and free blocks.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1682
    // Above must occur before BOT is updated below.
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  1683
    OrderAccess::storestore();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1684
    _bt.split_block(res, blk_size, size);  // adjust block offset table
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1685
    _bt.allocated(res, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1686
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1687
  return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1688
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1689
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1690
FreeChunk*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1691
CompactibleFreeListSpace::getChunkFromIndexedFreeList(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1692
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1693
  assert(size < SmallForDictionary, "just checking");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1694
  FreeChunk* res;
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1695
  res = _indexedFreeList[size].get_chunk_at_head();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1696
  if (res == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1697
    res = getChunkFromIndexedFreeListHelper(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1698
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1699
  _bt.verify_not_unallocated((HeapWord*) res, size);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1700
  assert(res == NULL || res->size() == size, "Incorrect block size");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1701
  return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1702
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1703
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1704
FreeChunk*
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1705
CompactibleFreeListSpace::getChunkFromIndexedFreeListHelper(size_t size,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1706
  bool replenish) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1707
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1708
  FreeChunk* fc = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1709
  if (size < SmallForDictionary) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1710
    assert(_indexedFreeList[size].head() == NULL ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1711
      _indexedFreeList[size].surplus() <= 0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1712
      "List for this size should be empty or under populated");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1713
    // Try best fit in exact lists before replenishing the list
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1714
    if (!bestFitFirst() || (fc = bestFitSmall(size)) == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1715
      // Replenish list.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1716
      //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1717
      // Things tried that failed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1718
      //   Tried allocating out of the two LinAB's first before
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1719
      // replenishing lists.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1720
      //   Tried small linAB of size 256 (size in indexed list)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1721
      // and replenishing indexed lists from the small linAB.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1722
      //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1723
      FreeChunk* newFc = NULL;
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1724
      const size_t replenish_size = CMSIndexedFreeListReplenish * size;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1725
      if (replenish_size < SmallForDictionary) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1726
        // Do not replenish from an underpopulated size.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1727
        if (_indexedFreeList[replenish_size].surplus() > 0 &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1728
            _indexedFreeList[replenish_size].head() != NULL) {
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1729
          newFc = _indexedFreeList[replenish_size].get_chunk_at_head();
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1730
        } else if (bestFitFirst()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1731
          newFc = bestFitSmall(replenish_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1732
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1733
      }
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1734
      if (newFc == NULL && replenish_size > size) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1735
        assert(CMSIndexedFreeListReplenish > 1, "ctl pt invariant");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1736
        newFc = getChunkFromIndexedFreeListHelper(replenish_size, false);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1737
      }
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1738
      // Note: The stats update re split-death of block obtained above
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1739
      // will be recorded below precisely when we know we are going to
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1740
      // be actually splitting it into more than one pieces below.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1741
      if (newFc != NULL) {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1742
        if  (replenish || CMSReplenishIntermediate) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1743
          // Replenish this list and return one block to caller.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1744
          size_t i;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1745
          FreeChunk *curFc, *nextFc;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1746
          size_t num_blk = newFc->size() / size;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1747
          assert(num_blk >= 1, "Smaller than requested?");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1748
          assert(newFc->size() % size == 0, "Should be integral multiple of request");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1749
          if (num_blk > 1) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1750
            // we are sure we will be splitting the block just obtained
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1751
            // into multiple pieces; record the split-death of the original
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1752
            splitDeath(replenish_size);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1753
          }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1754
          // carve up and link blocks 0, ..., num_blk - 2
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1755
          // The last chunk is not added to the lists but is returned as the
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1756
          // free chunk.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1757
          for (curFc = newFc, nextFc = (FreeChunk*)((HeapWord*)curFc + size),
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1758
               i = 0;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1759
               i < (num_blk - 1);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1760
               curFc = nextFc, nextFc = (FreeChunk*)((HeapWord*)nextFc + size),
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1761
               i++) {
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1762
            curFc->set_size(size);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1763
            // Don't record this as a return in order to try and
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1764
            // determine the "returns" from a GC.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1765
            _bt.verify_not_unallocated((HeapWord*) fc, size);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1766
            _indexedFreeList[size].return_chunk_at_tail(curFc, false);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1767
            _bt.mark_block((HeapWord*)curFc, size);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1768
            split_birth(size);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1769
            // Don't record the initial population of the indexed list
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1770
            // as a split birth.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1771
          }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1772
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1773
          // check that the arithmetic was OK above
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1774
          assert((HeapWord*)nextFc == (HeapWord*)newFc + num_blk*size,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1775
            "inconsistency in carving newFc");
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1776
          curFc->set_size(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1777
          _bt.mark_block((HeapWord*)curFc, size);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1778
          split_birth(size);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1779
          fc = curFc;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1780
        } else {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1781
          // Return entire block to caller
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1782
          fc = newFc;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1783
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1784
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1785
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1786
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1787
    // Get a free chunk from the free chunk dictionary to be returned to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1788
    // replenish the indexed free list.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1789
    fc = getChunkFromDictionaryExact(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1790
  }
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1791
  // assert(fc == NULL || fc->is_free(), "Should be returning a free chunk");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1792
  return fc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1793
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1794
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1795
FreeChunk*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1796
CompactibleFreeListSpace::getChunkFromDictionary(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1797
  assert_locked();
46674
a9e42ff6158f 8183923: Get rid of FreeBlockDictionary and dithering
mgerdin
parents: 46625
diff changeset
  1798
  FreeChunk* fc = _dictionary->get_chunk(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1799
  if (fc == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1800
    return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1801
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1802
  _bt.allocated((HeapWord*)fc, fc->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1803
  if (fc->size() >= size + MinChunkSize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1804
    fc = splitChunkAndReturnRemainder(fc, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1805
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1806
  assert(fc->size() >= size, "chunk too small");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1807
  assert(fc->size() < size + MinChunkSize, "chunk too big");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1808
  _bt.verify_single_block((HeapWord*)fc, fc->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1809
  return fc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1810
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1811
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1812
FreeChunk*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1813
CompactibleFreeListSpace::getChunkFromDictionaryExact(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1814
  assert_locked();
46674
a9e42ff6158f 8183923: Get rid of FreeBlockDictionary and dithering
mgerdin
parents: 46625
diff changeset
  1815
  FreeChunk* fc = _dictionary->get_chunk(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1816
  if (fc == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1817
    return fc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1818
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1819
  _bt.allocated((HeapWord*)fc, fc->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1820
  if (fc->size() == size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1821
    _bt.verify_single_block((HeapWord*)fc, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1822
    return fc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1823
  }
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1824
  assert(fc->size() > size, "get_chunk() guarantee");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1825
  if (fc->size() < size + MinChunkSize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1826
    // Return the chunk to the dictionary and go get a bigger one.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1827
    returnChunkToDictionary(fc);
46674
a9e42ff6158f 8183923: Get rid of FreeBlockDictionary and dithering
mgerdin
parents: 46625
diff changeset
  1828
    fc = _dictionary->get_chunk(size + MinChunkSize);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1829
    if (fc == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1830
      return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1831
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1832
    _bt.allocated((HeapWord*)fc, fc->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1833
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1834
  assert(fc->size() >= size + MinChunkSize, "tautology");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1835
  fc = splitChunkAndReturnRemainder(fc, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1836
  assert(fc->size() == size, "chunk is wrong size");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1837
  _bt.verify_single_block((HeapWord*)fc, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1838
  return fc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1839
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1840
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1841
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1842
CompactibleFreeListSpace::returnChunkToDictionary(FreeChunk* chunk) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1843
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1844
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1845
  size_t size = chunk->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1846
  _bt.verify_single_block((HeapWord*)chunk, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1847
  // adjust _unallocated_block downward, as necessary
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1848
  _bt.freed((HeapWord*)chunk, size);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1849
  _dictionary->return_chunk(chunk);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1850
#ifndef PRODUCT
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1851
  if (CMSCollector::abstract_state() != CMSCollector::Sweeping) {
22884
5cadaf2c3f32 8034171: Remove use of template template parameters from binaryTreeDictionary.
goetz
parents: 22551
diff changeset
  1852
    TreeChunk<FreeChunk, AdaptiveFreeList<FreeChunk> >* tc = TreeChunk<FreeChunk, AdaptiveFreeList<FreeChunk> >::as_TreeChunk(chunk);
5cadaf2c3f32 8034171: Remove use of template template parameters from binaryTreeDictionary.
goetz
parents: 22551
diff changeset
  1853
    TreeList<FreeChunk, AdaptiveFreeList<FreeChunk> >* tl = tc->list();
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  1854
    tl->verify_stats();
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1855
  }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1856
#endif // PRODUCT
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1857
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1858
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1859
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1860
CompactibleFreeListSpace::returnChunkToFreeList(FreeChunk* fc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1861
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1862
  size_t size = fc->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1863
  _bt.verify_single_block((HeapWord*) fc, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1864
  _bt.verify_not_unallocated((HeapWord*) fc, size);
33587
c04a7462b0e6 8139952: Remove UseCMSAdaptiveFreeLists, UseAsyncConcMarkSweepGC, CMSDictionaryChoice, CMSOverflowEarlyRestoration and CMSTestInFreeList
david
parents: 33105
diff changeset
  1865
  _indexedFreeList[size].return_chunk_at_tail(fc);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1866
#ifndef PRODUCT
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1867
  if (CMSCollector::abstract_state() != CMSCollector::Sweeping) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1868
     _indexedFreeList[size].verify_stats();
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1869
  }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  1870
#endif // PRODUCT
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1871
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1872
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1873
// Add chunk to end of last block -- if it's the largest
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1874
// block -- and update BOT and census data. We would
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1875
// of course have preferred to coalesce it with the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1876
// last block, but it's currently less expensive to find the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1877
// largest block than it is to find the last.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1878
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1879
CompactibleFreeListSpace::addChunkToFreeListsAtEndRecordingStats(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1880
  HeapWord* chunk, size_t     size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1881
  // check that the chunk does lie in this space!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1882
  assert(chunk != NULL && is_in_reserved(chunk), "Not in this space!");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1883
  // One of the parallel gc task threads may be here
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1884
  // whilst others are allocating.
27251
7d667f91ec8d 6979279: remove special-case code for ParallelGCThreads==0
mlarsson
parents: 26150
diff changeset
  1885
  Mutex* lock = &_parDictionaryAllocLock;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1886
  FreeChunk* ec;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1887
  {
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  1888
    MutexLocker x(lock, Mutex::_no_safepoint_check_flag);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1889
    ec = dictionary()->find_largest_dict();  // get largest block
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  1890
    if (ec != NULL && ec->end() == (uintptr_t*) chunk) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1891
      // It's a coterminal block - we can coalesce.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1892
      size_t old_size = ec->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1893
      coalDeath(old_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1894
      removeChunkFromDictionary(ec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1895
      size += old_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1896
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1897
      ec = (FreeChunk*)chunk;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1898
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1899
  }
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1900
  ec->set_size(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1901
  debug_only(ec->mangleFreed(size));
27251
7d667f91ec8d 6979279: remove special-case code for ParallelGCThreads==0
mlarsson
parents: 26150
diff changeset
  1902
  if (size < SmallForDictionary) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1903
    lock = _indexedFreeListParLocks[size];
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1904
  }
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  1905
  MutexLocker x(lock, Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1906
  addChunkAndRepairOffsetTable((HeapWord*)ec, size, true);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1907
  // record the birth under the lock since the recording involves
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1908
  // manipulation of the list on which the chunk lives and
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1909
  // if the chunk is allocated and is the last on the list,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1910
  // the list can go away.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1911
  coalBirth(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1912
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1913
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1914
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1915
CompactibleFreeListSpace::addChunkToFreeLists(HeapWord* chunk,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1916
                                              size_t     size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1917
  // check that the chunk does lie in this space!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1918
  assert(chunk != NULL && is_in_reserved(chunk), "Not in this space!");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1919
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1920
  _bt.verify_single_block(chunk, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1921
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1922
  FreeChunk* fc = (FreeChunk*) chunk;
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1923
  fc->set_size(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1924
  debug_only(fc->mangleFreed(size));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1925
  if (size < SmallForDictionary) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1926
    returnChunkToFreeList(fc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1927
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1928
    returnChunkToDictionary(fc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1929
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1930
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1931
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1932
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1933
CompactibleFreeListSpace::addChunkAndRepairOffsetTable(HeapWord* chunk,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1934
  size_t size, bool coalesced) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1935
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1936
  assert(chunk != NULL, "null chunk");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1937
  if (coalesced) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1938
    // repair BOT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1939
    _bt.single_block(chunk, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1940
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1941
  addChunkToFreeLists(chunk, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1942
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1943
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1944
// We _must_ find the purported chunk on our free lists;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1945
// we assert if we don't.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1946
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1947
CompactibleFreeListSpace::removeFreeChunkFromFreeLists(FreeChunk* fc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1948
  size_t size = fc->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1949
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1950
  debug_only(verifyFreeLists());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1951
  if (size < SmallForDictionary) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1952
    removeChunkFromIndexedFreeList(fc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1953
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1954
    removeChunkFromDictionary(fc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1955
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1956
  _bt.verify_single_block((HeapWord*)fc, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1957
  debug_only(verifyFreeLists());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1958
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1959
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1960
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1961
CompactibleFreeListSpace::removeChunkFromDictionary(FreeChunk* fc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1962
  size_t size = fc->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1963
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1964
  assert(fc != NULL, "null chunk");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1965
  _bt.verify_single_block((HeapWord*)fc, size);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1966
  _dictionary->remove_chunk(fc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1967
  // adjust _unallocated_block upward, as necessary
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1968
  _bt.allocated((HeapWord*)fc, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1969
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1970
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1971
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1972
CompactibleFreeListSpace::removeChunkFromIndexedFreeList(FreeChunk* fc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1973
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1974
  size_t size = fc->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1975
  _bt.verify_single_block((HeapWord*)fc, size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1976
  NOT_PRODUCT(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1977
    if (FLSVerifyIndexTable) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1978
      verifyIndexedFreeList(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1979
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1980
  )
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  1981
  _indexedFreeList[size].remove_chunk(fc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1982
  NOT_PRODUCT(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1983
    if (FLSVerifyIndexTable) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1984
      verifyIndexedFreeList(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1985
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1986
  )
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1987
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1988
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1989
FreeChunk* CompactibleFreeListSpace::bestFitSmall(size_t numWords) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1990
  /* A hint is the next larger size that has a surplus.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1991
     Start search at a size large enough to guarantee that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1992
     the excess is >= MIN_CHUNK. */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1993
  size_t start = align_object_size(numWords + MinChunkSize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1994
  if (start < IndexSetSize) {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  1995
    AdaptiveFreeList<FreeChunk>* it   = _indexedFreeList;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1996
    size_t    hint = _indexedFreeList[start].hint();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1997
    while (hint < IndexSetSize) {
46683
33808f7eadd5 8184753: Asserts against MinObjectAlignment should avoid integer division
shade
parents: 46674
diff changeset
  1998
      assert(is_object_aligned(hint), "hint should be aligned");
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  1999
      AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[hint];
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2000
      if (fl->surplus() > 0 && fl->head() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2001
        // Found a list with surplus, reset original hint
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2002
        // and split out a free chunk which is returned.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2003
        _indexedFreeList[start].set_hint(hint);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2004
        FreeChunk* res = getFromListGreater(fl, numWords);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2005
        assert(res == NULL || res->is_free(),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2006
          "Should be returning a free chunk");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2007
        return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2008
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2009
      hint = fl->hint(); /* keep looking */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2010
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2011
    /* None found. */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2012
    it[start].set_hint(IndexSetSize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2013
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2014
  return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2015
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2016
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2017
/* Requires fl->size >= numWords + MinChunkSize */
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2018
FreeChunk* CompactibleFreeListSpace::getFromListGreater(AdaptiveFreeList<FreeChunk>* fl,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2019
  size_t numWords) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2020
  FreeChunk *curr = fl->head();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2021
  size_t oldNumWords = curr->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2022
  assert(numWords >= MinChunkSize, "Word size is too small");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2023
  assert(curr != NULL, "List is empty");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2024
  assert(oldNumWords >= numWords + MinChunkSize,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2025
        "Size of chunks in the list is too small");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2026
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2027
  fl->remove_chunk(curr);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2028
  // recorded indirectly by splitChunkAndReturnRemainder -
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2029
  // smallSplit(oldNumWords, numWords);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2030
  FreeChunk* new_chunk = splitChunkAndReturnRemainder(curr, numWords);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2031
  // Does anything have to be done for the remainder in terms of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2032
  // fixing the card table?
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2033
  assert(new_chunk == NULL || new_chunk->is_free(),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2034
    "Should be returning a free chunk");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2035
  return new_chunk;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2036
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2037
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2038
FreeChunk*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2039
CompactibleFreeListSpace::splitChunkAndReturnRemainder(FreeChunk* chunk,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2040
  size_t new_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2041
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2042
  size_t size = chunk->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2043
  assert(size > new_size, "Split from a smaller block?");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2044
  assert(is_aligned(chunk), "alignment problem");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2045
  assert(size == adjustObjectSize(size), "alignment problem");
25725
5d6da524725b 8050228: Rename 'rem_size' in compactibleFreeListSpace.cpp because of name clashes on AIX
simonis
parents: 24487
diff changeset
  2046
  size_t rem_sz = size - new_size;
5d6da524725b 8050228: Rename 'rem_size' in compactibleFreeListSpace.cpp because of name clashes on AIX
simonis
parents: 24487
diff changeset
  2047
  assert(rem_sz == adjustObjectSize(rem_sz), "alignment problem");
5d6da524725b 8050228: Rename 'rem_size' in compactibleFreeListSpace.cpp because of name clashes on AIX
simonis
parents: 24487
diff changeset
  2048
  assert(rem_sz >= MinChunkSize, "Free chunk smaller than minimum");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2049
  FreeChunk* ffc = (FreeChunk*)((HeapWord*)chunk + new_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2050
  assert(is_aligned(ffc), "alignment problem");
25725
5d6da524725b 8050228: Rename 'rem_size' in compactibleFreeListSpace.cpp because of name clashes on AIX
simonis
parents: 24487
diff changeset
  2051
  ffc->set_size(rem_sz);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2052
  ffc->link_next(NULL);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2053
  ffc->link_prev(NULL); // Mark as a free block for other (parallel) GC threads.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2054
  // Above must occur before BOT is updated below.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2055
  // adjust block offset table
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2056
  OrderAccess::storestore();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2057
  assert(chunk->is_free() && ffc->is_free(), "Error");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2058
  _bt.split_block((HeapWord*)chunk, chunk->size(), new_size);
25725
5d6da524725b 8050228: Rename 'rem_size' in compactibleFreeListSpace.cpp because of name clashes on AIX
simonis
parents: 24487
diff changeset
  2059
  if (rem_sz < SmallForDictionary) {
30870
3050fdcdc60b 8080112: Replace and remove the last usages of CollectedHeap::n_par_threads()
stefank
parents: 30764
diff changeset
  2060
    // The freeList lock is held, but multiple GC task threads might be executing in parallel.
3050fdcdc60b 8080112: Replace and remove the last usages of CollectedHeap::n_par_threads()
stefank
parents: 30764
diff changeset
  2061
    bool is_par = Thread::current()->is_GC_task_thread();
54663
f03d5a093093 8074355: make MutexLocker smarter about non-JavaThreads
coleenp
parents: 54623
diff changeset
  2062
    if (is_par) _indexedFreeListParLocks[rem_sz]->lock_without_safepoint_check();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2063
    returnChunkToFreeList(ffc);
25725
5d6da524725b 8050228: Rename 'rem_size' in compactibleFreeListSpace.cpp because of name clashes on AIX
simonis
parents: 24487
diff changeset
  2064
    split(size, rem_sz);
5d6da524725b 8050228: Rename 'rem_size' in compactibleFreeListSpace.cpp because of name clashes on AIX
simonis
parents: 24487
diff changeset
  2065
    if (is_par) _indexedFreeListParLocks[rem_sz]->unlock();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2066
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2067
    returnChunkToDictionary(ffc);
25725
5d6da524725b 8050228: Rename 'rem_size' in compactibleFreeListSpace.cpp because of name clashes on AIX
simonis
parents: 24487
diff changeset
  2068
    split(size, rem_sz);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2069
  }
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2070
  chunk->set_size(new_size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2071
  return chunk;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2072
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2073
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2074
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2075
CompactibleFreeListSpace::sweep_completed() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2076
  // Now that space is probably plentiful, refill linear
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2077
  // allocation blocks as needed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2078
  refillLinearAllocBlocksIfNeeded();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2079
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2080
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2081
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2082
CompactibleFreeListSpace::gc_prologue() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2083
  assert_locked();
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2084
  reportFreeListStatistics("Before GC:");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2085
  refillLinearAllocBlocksIfNeeded();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2086
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2087
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2088
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2089
CompactibleFreeListSpace::gc_epilogue() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2090
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2091
  assert(_promoInfo.noPromotions(), "_promoInfo inconsistency");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2092
  _promoInfo.stopTrackingPromotions();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2093
  repairLinearAllocationBlocks();
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2094
  reportFreeListStatistics("After GC:");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2095
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2096
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2097
// Iteration support, mostly delegated from a CMS generation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2098
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2099
void CompactibleFreeListSpace::save_marks() {
9342
456b8d0486b5 7039089: G1: changeset for 7037276 broke heap verification, and related cleanups
ysr
parents: 8921
diff changeset
  2100
  assert(Thread::current()->is_VM_thread(),
456b8d0486b5 7039089: G1: changeset for 7037276 broke heap verification, and related cleanups
ysr
parents: 8921
diff changeset
  2101
         "Global variable should only be set when single-threaded");
456b8d0486b5 7039089: G1: changeset for 7037276 broke heap verification, and related cleanups
ysr
parents: 8921
diff changeset
  2102
  // Mark the "end" of the used space at the time of this call;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2103
  // note, however, that promoted objects from this point
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2104
  // on are tracked in the _promoInfo below.
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2105
  set_saved_mark_word(unallocated_block());
9342
456b8d0486b5 7039089: G1: changeset for 7037276 broke heap verification, and related cleanups
ysr
parents: 8921
diff changeset
  2106
#ifdef ASSERT
456b8d0486b5 7039089: G1: changeset for 7037276 broke heap verification, and related cleanups
ysr
parents: 8921
diff changeset
  2107
  // Check the sanity of save_marks() etc.
456b8d0486b5 7039089: G1: changeset for 7037276 broke heap verification, and related cleanups
ysr
parents: 8921
diff changeset
  2108
  MemRegion ur    = used_region();
456b8d0486b5 7039089: G1: changeset for 7037276 broke heap verification, and related cleanups
ysr
parents: 8921
diff changeset
  2109
  MemRegion urasm = used_region_at_save_marks();
456b8d0486b5 7039089: G1: changeset for 7037276 broke heap verification, and related cleanups
ysr
parents: 8921
diff changeset
  2110
  assert(ur.contains(urasm),
33105
294e48b4f704 8080775: Better argument formatting for assert() and friends
david
parents: 32623
diff changeset
  2111
         " Error at save_marks(): [" PTR_FORMAT "," PTR_FORMAT ")"
294e48b4f704 8080775: Better argument formatting for assert() and friends
david
parents: 32623
diff changeset
  2112
         " should contain [" PTR_FORMAT "," PTR_FORMAT ")",
294e48b4f704 8080775: Better argument formatting for assert() and friends
david
parents: 32623
diff changeset
  2113
         p2i(ur.start()), p2i(ur.end()), p2i(urasm.start()), p2i(urasm.end()));
9342
456b8d0486b5 7039089: G1: changeset for 7037276 broke heap verification, and related cleanups
ysr
parents: 8921
diff changeset
  2114
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2115
  // inform allocator that promotions should be tracked.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2116
  assert(_promoInfo.noPromotions(), "_promoInfo inconsistency");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2117
  _promoInfo.startTrackingPromotions();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2118
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2119
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2120
bool CompactibleFreeListSpace::no_allocs_since_save_marks() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2121
  assert(_promoInfo.tracking(), "No preceding save_marks?");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2122
  return _promoInfo.noPromotions();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2123
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2124
185
cda2a1eb4be5 6668743: CMS: Consolidate block statistics reporting code
ysr
parents: 1
diff changeset
  2125
bool CompactibleFreeListSpace::linearAllocationWouldFail() const {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2126
  return _smallLinearAllocBlock._word_size == 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2127
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2128
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2129
void CompactibleFreeListSpace::repairLinearAllocationBlocks() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2130
  // Fix up linear allocation blocks to look like free blocks
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2131
  repairLinearAllocBlock(&_smallLinearAllocBlock);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2132
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2133
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2134
void CompactibleFreeListSpace::repairLinearAllocBlock(LinearAllocBlock* blk) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2135
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2136
  if (blk->_ptr != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2137
    assert(blk->_word_size != 0 && blk->_word_size >= MinChunkSize,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2138
           "Minimum block size requirement");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2139
    FreeChunk* fc = (FreeChunk*)(blk->_ptr);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2140
    fc->set_size(blk->_word_size);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2141
    fc->link_prev(NULL);   // mark as free
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2142
    fc->dontCoalesce();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2143
    assert(fc->is_free(), "just marked it free");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2144
    assert(fc->cantCoalesce(), "just marked it uncoalescable");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2145
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2146
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2147
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2148
void CompactibleFreeListSpace::refillLinearAllocBlocksIfNeeded() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2149
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2150
  if (_smallLinearAllocBlock._ptr == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2151
    assert(_smallLinearAllocBlock._word_size == 0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2152
      "Size of linAB should be zero if the ptr is NULL");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2153
    // Reset the linAB refill and allocation size limit.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2154
    _smallLinearAllocBlock.set(0, 0, 1024*SmallForLinearAlloc, SmallForLinearAlloc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2155
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2156
  refillLinearAllocBlockIfNeeded(&_smallLinearAllocBlock);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2157
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2158
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2159
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2160
CompactibleFreeListSpace::refillLinearAllocBlockIfNeeded(LinearAllocBlock* blk) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2161
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2162
  assert((blk->_ptr == NULL && blk->_word_size == 0) ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2163
         (blk->_ptr != NULL && blk->_word_size >= MinChunkSize),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2164
         "blk invariant");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2165
  if (blk->_ptr == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2166
    refillLinearAllocBlock(blk);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2167
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2168
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2169
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2170
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2171
CompactibleFreeListSpace::refillLinearAllocBlock(LinearAllocBlock* blk) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2172
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2173
  assert(blk->_word_size == 0 && blk->_ptr == NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2174
         "linear allocation block should be empty");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2175
  FreeChunk* fc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2176
  if (blk->_refillSize < SmallForDictionary &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2177
      (fc = getChunkFromIndexedFreeList(blk->_refillSize)) != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2178
    // A linAB's strategy might be to use small sizes to reduce
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2179
    // fragmentation but still get the benefits of allocation from a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2180
    // linAB.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2181
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2182
    fc = getChunkFromDictionary(blk->_refillSize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2183
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2184
  if (fc != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2185
    blk->_ptr  = (HeapWord*)fc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2186
    blk->_word_size = fc->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2187
    fc->dontCoalesce();   // to prevent sweeper from sweeping us up
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2188
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2189
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2190
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2191
// Support for compaction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2192
void CompactibleFreeListSpace::prepare_for_compaction(CompactPoint* cp) {
27624
fe43edc5046d 8043243: convert SCAN_AND_FORWARD, SCAN_AND_ADJUST_POINTERS, SCAN_AND_COMPACT macros to methods
mlarsson
parents: 27251
diff changeset
  2193
  scan_and_forward(this, cp);
22551
9bf46d16dcc6 8025856: Fix typos in the GC code
jwilhelm
parents: 18687
diff changeset
  2194
  // Prepare_for_compaction() uses the space between live objects
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2195
  // so that later phase can skip dead space quickly.  So verification
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2196
  // of the free lists doesn't work after.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2197
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2198
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2199
void CompactibleFreeListSpace::adjust_pointers() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2200
  // In other versions of adjust_pointers(), a bail out
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2201
  // based on the amount of live data in the generation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2202
  // (i.e., if 0, bail out) may be used.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2203
  // Cannot test used() == 0 here because the free lists have already
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2204
  // been mangled by the compaction.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2205
27624
fe43edc5046d 8043243: convert SCAN_AND_FORWARD, SCAN_AND_ADJUST_POINTERS, SCAN_AND_COMPACT macros to methods
mlarsson
parents: 27251
diff changeset
  2206
  scan_and_adjust_pointers(this);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2207
  // See note about verification in prepare_for_compaction().
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2208
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2209
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2210
void CompactibleFreeListSpace::compact() {
27624
fe43edc5046d 8043243: convert SCAN_AND_FORWARD, SCAN_AND_ADJUST_POINTERS, SCAN_AND_COMPACT macros to methods
mlarsson
parents: 27251
diff changeset
  2211
  scan_and_compact(this);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2212
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2213
22551
9bf46d16dcc6 8025856: Fix typos in the GC code
jwilhelm
parents: 18687
diff changeset
  2214
// Fragmentation metric = 1 - [sum of (fbs**2) / (sum of fbs)**2]
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2215
// where fbs is free block sizes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2216
double CompactibleFreeListSpace::flsFrag() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2217
  size_t itabFree = totalSizeInIndexedFreeLists();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2218
  double frag = 0.0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2219
  size_t i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2220
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2221
  for (i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2222
    double sz  = i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2223
    frag      += _indexedFreeList[i].count() * (sz * sz);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2224
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2225
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2226
  double totFree = itabFree +
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2227
                   _dictionary->total_chunk_size(DEBUG_ONLY(freelistLock()));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2228
  if (totFree > 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2229
    frag = ((frag + _dictionary->sum_of_squared_block_sizes()) /
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2230
            (totFree * totFree));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2231
    frag = (double)1.0  - frag;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2232
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2233
    assert(frag == 0.0, "Follows from totFree == 0");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2234
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2235
  return frag;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2236
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2237
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2238
void CompactibleFreeListSpace::beginSweepFLCensus(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2239
  float inter_sweep_current,
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2240
  float inter_sweep_estimate,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2241
  float intra_sweep_estimate) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2242
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2243
  size_t i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2244
  for (i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2245
    AdaptiveFreeList<FreeChunk>* fl    = &_indexedFreeList[i];
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2246
    log_trace(gc, freelist)("size[" SIZE_FORMAT "] : ", i);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2247
    fl->compute_desired(inter_sweep_current, inter_sweep_estimate, intra_sweep_estimate);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2248
    fl->set_coal_desired((ssize_t)((double)fl->desired() * CMSSmallCoalSurplusPercent));
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2249
    fl->set_before_sweep(fl->count());
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2250
    fl->set_bfr_surp(fl->surplus());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2251
  }
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2252
  _dictionary->begin_sweep_dict_census(CMSLargeCoalSurplusPercent,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2253
                                    inter_sweep_current,
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2254
                                    inter_sweep_estimate,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2255
                                    intra_sweep_estimate);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2256
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2257
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2258
void CompactibleFreeListSpace::setFLSurplus() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2259
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2260
  size_t i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2261
  for (i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2262
    AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[i];
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2263
    fl->set_surplus(fl->count() -
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2264
                    (ssize_t)((double)fl->desired() * CMSSmallSplitSurplusPercent));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2265
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2266
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2267
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2268
void CompactibleFreeListSpace::setFLHints() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2269
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2270
  size_t i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2271
  size_t h = IndexSetSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2272
  for (i = IndexSetSize - 1; i != 0; i -= IndexSetStride) {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2273
    AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[i];
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2274
    fl->set_hint(h);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2275
    if (fl->surplus() > 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2276
      h = i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2277
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2278
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2279
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2280
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2281
void CompactibleFreeListSpace::clearFLCensus() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2282
  assert_locked();
10992
b998c6b89fa2 7105163: CMS: some mentions of MinChunkSize should be IndexSetStart
ysr
parents: 10771
diff changeset
  2283
  size_t i;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2284
  for (i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2285
    AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[i];
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2286
    fl->set_prev_sweep(fl->count());
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2287
    fl->set_coal_births(0);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2288
    fl->set_coal_deaths(0);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2289
    fl->set_split_births(0);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2290
    fl->set_split_deaths(0);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2291
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2292
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2293
185
cda2a1eb4be5 6668743: CMS: Consolidate block statistics reporting code
ysr
parents: 1
diff changeset
  2294
void CompactibleFreeListSpace::endSweepFLCensus(size_t sweep_count) {
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2295
  log_debug(gc, freelist)("CMS: Large block " PTR_FORMAT, p2i(dictionary()->find_largest_dict()));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2296
  setFLSurplus();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2297
  setFLHints();
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2298
  printFLCensus(sweep_count);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2299
  clearFLCensus();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2300
  assert_locked();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2301
  _dictionary->end_sweep_dict_census(CMSLargeSplitSurplusPercent);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2302
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2303
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2304
bool CompactibleFreeListSpace::coalOverPopulated(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2305
  if (size < SmallForDictionary) {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2306
    AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[size];
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2307
    return (fl->coal_desired() < 0) ||
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2308
           ((int)fl->count() > fl->coal_desired());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2309
  } else {
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2310
    return dictionary()->coal_dict_over_populated(size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2311
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2312
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2313
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2314
void CompactibleFreeListSpace::smallCoalBirth(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2315
  assert(size < SmallForDictionary, "Size too large for indexed list");
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2316
  AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[size];
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2317
  fl->increment_coal_births();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2318
  fl->increment_surplus();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2319
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2320
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2321
void CompactibleFreeListSpace::smallCoalDeath(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2322
  assert(size < SmallForDictionary, "Size too large for indexed list");
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2323
  AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[size];
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2324
  fl->increment_coal_deaths();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2325
  fl->decrement_surplus();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2326
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2327
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2328
void CompactibleFreeListSpace::coalBirth(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2329
  if (size  < SmallForDictionary) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2330
    smallCoalBirth(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2331
  } else {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2332
    dictionary()->dict_census_update(size,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2333
                                   false /* split */,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2334
                                   true /* birth */);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2335
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2336
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2337
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2338
void CompactibleFreeListSpace::coalDeath(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2339
  if(size  < SmallForDictionary) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2340
    smallCoalDeath(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2341
  } else {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2342
    dictionary()->dict_census_update(size,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2343
                                   false /* split */,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2344
                                   false /* birth */);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2345
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2346
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2347
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2348
void CompactibleFreeListSpace::smallSplitBirth(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2349
  assert(size < SmallForDictionary, "Size too large for indexed list");
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2350
  AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[size];
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2351
  fl->increment_split_births();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2352
  fl->increment_surplus();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2353
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2354
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2355
void CompactibleFreeListSpace::smallSplitDeath(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2356
  assert(size < SmallForDictionary, "Size too large for indexed list");
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2357
  AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[size];
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2358
  fl->increment_split_deaths();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2359
  fl->decrement_surplus();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2360
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2361
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2362
void CompactibleFreeListSpace::split_birth(size_t size) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2363
  if (size  < SmallForDictionary) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2364
    smallSplitBirth(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2365
  } else {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2366
    dictionary()->dict_census_update(size,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2367
                                   true /* split */,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2368
                                   true /* birth */);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2369
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2370
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2371
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2372
void CompactibleFreeListSpace::splitDeath(size_t size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2373
  if (size  < SmallForDictionary) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2374
    smallSplitDeath(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2375
  } else {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2376
    dictionary()->dict_census_update(size,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2377
                                   true /* split */,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2378
                                   false /* birth */);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2379
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2380
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2381
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2382
void CompactibleFreeListSpace::split(size_t from, size_t to1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2383
  size_t to2 = from - to1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2384
  splitDeath(from);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2385
  split_birth(to1);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2386
  split_birth(to2);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2387
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2388
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2389
void CompactibleFreeListSpace::print() const {
7377
92108ee83d52 6996613: CompactibleFreeListSpace::print should call CompactibleFreeListSpace::print_on, not Space::print_on
ysr
parents: 7376
diff changeset
  2390
  print_on(tty);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2391
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2392
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2393
void CompactibleFreeListSpace::prepare_for_verify() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2394
  assert_locked();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2395
  repairLinearAllocationBlocks();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2396
  // Verify that the SpoolBlocks look like free blocks of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2397
  // appropriate sizes... To be done ...
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2398
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2399
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2400
class VerifyAllBlksClosure: public BlkClosure {
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2401
 private:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2402
  const CompactibleFreeListSpace* _sp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2403
  const MemRegion                 _span;
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2404
  HeapWord*                       _last_addr;
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2405
  size_t                          _last_size;
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2406
  bool                            _last_was_obj;
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2407
  bool                            _last_was_live;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2408
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2409
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2410
  VerifyAllBlksClosure(const CompactibleFreeListSpace* sp,
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2411
    MemRegion span) :  _sp(sp), _span(span),
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2412
                       _last_addr(NULL), _last_size(0),
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2413
                       _last_was_obj(false), _last_was_live(false) { }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2414
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2415
  virtual size_t do_blk(HeapWord* addr) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2416
    size_t res;
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2417
    bool   was_obj  = false;
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2418
    bool   was_live = false;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2419
    if (_sp->block_is_obj(addr)) {
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2420
      was_obj = true;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2421
      oop p = oop(addr);
46968
9119841280f4 8160399: is_oop_or_null involves undefined behavior
coleenp
parents: 46701
diff changeset
  2422
      guarantee(oopDesc::is_oop(p), "Should be an oop");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2423
      res = _sp->adjustObjectSize(p->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2424
      if (_sp->obj_is_alive(addr)) {
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2425
        was_live = true;
51268
4ac20e5f96ce 8202171: Some oopDesc functions compare this with NULL
hseigel
parents: 50800
diff changeset
  2426
        oopDesc::verify(p);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2427
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2428
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2429
      FreeChunk* fc = (FreeChunk*)addr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2430
      res = fc->size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2431
      if (FLSVerifyLists && !fc->cantCoalesce()) {
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2432
        guarantee(_sp->verify_chunk_in_free_list(fc),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2433
                  "Chunk should be on a free list");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2434
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2435
    }
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2436
    if (res == 0) {
37242
91e5f98fff6f 8152632: Rename LogHandle(...) to Log(...)
stefank
parents: 37194
diff changeset
  2437
      Log(gc, verify) log;
36090
cffc1dd98258 8149541: Use log_error() instead of log_info() when verification reports a problem
brutisso
parents: 35862
diff changeset
  2438
      log.error("Livelock: no rank reduction!");
cffc1dd98258 8149541: Use log_error() instead of log_info() when verification reports a problem
brutisso
parents: 35862
diff changeset
  2439
      log.error(" Current:  addr = " PTR_FORMAT ", size = " SIZE_FORMAT ", obj = %s, live = %s \n"
cffc1dd98258 8149541: Use log_error() instead of log_info() when verification reports a problem
brutisso
parents: 35862
diff changeset
  2440
                " Previous: addr = " PTR_FORMAT ", size = " SIZE_FORMAT ", obj = %s, live = %s \n",
24424
2658d7834c6e 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 24351
diff changeset
  2441
        p2i(addr),       res,        was_obj      ?"true":"false", was_live      ?"true":"false",
2658d7834c6e 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 24351
diff changeset
  2442
        p2i(_last_addr), _last_size, _last_was_obj?"true":"false", _last_was_live?"true":"false");
46701
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46683
diff changeset
  2443
      LogStream ls(log.error());
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46683
diff changeset
  2444
      _sp->print_on(&ls);
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2445
      guarantee(false, "Verification failed.");
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2446
    }
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2447
    _last_addr = addr;
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2448
    _last_size = res;
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2449
    _last_was_obj  = was_obj;
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2450
    _last_was_live = was_live;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2451
    return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2452
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2453
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2454
50800
6da12aa23b88 8205607: Use oop_iterate instead of oop_iterate_no_header
stefank
parents: 50752
diff changeset
  2455
class VerifyAllOopsClosure: public BasicOopIterateClosure {
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2456
 private:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2457
  const CMSCollector*             _collector;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2458
  const CompactibleFreeListSpace* _sp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2459
  const MemRegion                 _span;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2460
  const bool                      _past_remark;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2461
  const CMSBitMap*                _bit_map;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2462
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2463
 protected:
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2464
  void do_oop(void* p, oop obj) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2465
    if (_span.contains(obj)) { // the interior oop points into CMS heap
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2466
      if (!_span.contains(p)) { // reference from outside CMS heap
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2467
        // Should be a valid object; the first disjunct below allows
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2468
        // us to sidestep an assertion in block_is_obj() that insists
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2469
        // that p be in _sp. Note that several generations (and spaces)
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2470
        // are spanned by _span (CMS heap) above.
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2471
        guarantee(!_sp->is_in_reserved(obj) ||
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2472
                  _sp->block_is_obj((HeapWord*)obj),
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2473
                  "Should be an object");
46968
9119841280f4 8160399: is_oop_or_null involves undefined behavior
coleenp
parents: 46701
diff changeset
  2474
        guarantee(oopDesc::is_oop(obj), "Should be an oop");
51268
4ac20e5f96ce 8202171: Some oopDesc functions compare this with NULL
hseigel
parents: 50800
diff changeset
  2475
        oopDesc::verify(obj);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2476
        if (_past_remark) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2477
          // Remark has been completed, the object should be marked
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2478
          _bit_map->isMarked((HeapWord*)obj);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2479
        }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2480
      } else { // reference within CMS heap
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2481
        if (_past_remark) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2482
          // Remark has been completed -- so the referent should have
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2483
          // been marked, if referring object is.
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2484
          if (_bit_map->isMarked(_collector->block_start(p))) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2485
            guarantee(_bit_map->isMarked((HeapWord*)obj), "Marking error?");
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2486
          }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2487
        }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2488
      }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2489
    } else if (_sp->is_in_reserved(p)) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2490
      // the reference is from FLS, and points out of FLS
46968
9119841280f4 8160399: is_oop_or_null involves undefined behavior
coleenp
parents: 46701
diff changeset
  2491
      guarantee(oopDesc::is_oop(obj), "Should be an oop");
51268
4ac20e5f96ce 8202171: Some oopDesc functions compare this with NULL
hseigel
parents: 50800
diff changeset
  2492
      oopDesc::verify(obj);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2493
    }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2494
  }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2495
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2496
  template <class T> void do_oop_work(T* p) {
49592
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49359
diff changeset
  2497
    T heap_oop = RawAccess<>::oop_load(p);
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49359
diff changeset
  2498
    if (!CompressedOops::is_null(heap_oop)) {
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49359
diff changeset
  2499
      oop obj = CompressedOops::decode_not_null(heap_oop);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2500
      do_oop(p, obj);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2501
    }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2502
  }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2503
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2504
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2505
  VerifyAllOopsClosure(const CMSCollector* collector,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2506
    const CompactibleFreeListSpace* sp, MemRegion span,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2507
    bool past_remark, CMSBitMap* bit_map) :
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 12776
diff changeset
  2508
    _collector(collector), _sp(sp), _span(span),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2509
    _past_remark(past_remark), _bit_map(bit_map) { }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2510
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2511
  virtual void do_oop(oop* p)       { VerifyAllOopsClosure::do_oop_work(p); }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 185
diff changeset
  2512
  virtual void do_oop(narrowOop* p) { VerifyAllOopsClosure::do_oop_work(p); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2513
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2514
12379
2cf45b79ce3a 4988100: oop_verify_old_oop appears to be dead
brutisso
parents: 11396
diff changeset
  2515
void CompactibleFreeListSpace::verify() const {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2516
  assert_lock_strong(&_freelistLock);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2517
  verify_objects_initialized();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2518
  MemRegion span = _collector->_span;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2519
  bool past_remark = (_collector->abstract_state() ==
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2520
                      CMSCollector::Sweeping);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2521
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2522
  ResourceMark rm;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2523
  HandleMark  hm;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2524
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2525
  // Check integrity of CFL data structures
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2526
  _promoInfo.verify();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2527
  _dictionary->verify();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2528
  if (FLSVerifyIndexTable) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2529
    verifyIndexedFreeLists();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2530
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2531
  // Check integrity of all objects and free blocks in space
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2532
  {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2533
    VerifyAllBlksClosure cl(this, span);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2534
    ((CompactibleFreeListSpace*)this)->blk_iterate(&cl);  // cast off const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2535
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2536
  // Check that all references in the heap to FLS
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2537
  // are to valid objects in FLS or that references in
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2538
  // FLS are to valid objects elsewhere in the heap
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2539
  if (FLSVerifyAllHeapReferences)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2540
  {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2541
    VerifyAllOopsClosure cl(_collector, this, span, past_remark,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2542
      _collector->markBitMap());
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 12776
diff changeset
  2543
50800
6da12aa23b88 8205607: Use oop_iterate instead of oop_iterate_no_header
stefank
parents: 50752
diff changeset
  2544
    // Iterate over all oops in the heap.
6da12aa23b88 8205607: Use oop_iterate instead of oop_iterate_no_header
stefank
parents: 50752
diff changeset
  2545
    CMSHeap::heap()->oop_iterate(&cl);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2546
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2547
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2548
  if (VerifyObjectStartArray) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2549
    // Verify the block offset table
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2550
    _bt.verify();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2551
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2552
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2553
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2554
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2555
void CompactibleFreeListSpace::verifyFreeLists() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2556
  if (FLSVerifyLists) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2557
    _dictionary->verify();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2558
    verifyIndexedFreeLists();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2559
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2560
    if (FLSVerifyDictionary) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2561
      _dictionary->verify();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2562
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2563
    if (FLSVerifyIndexTable) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2564
      verifyIndexedFreeLists();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2565
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2566
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2567
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2568
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2569
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2570
void CompactibleFreeListSpace::verifyIndexedFreeLists() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2571
  size_t i = 0;
10992
b998c6b89fa2 7105163: CMS: some mentions of MinChunkSize should be IndexSetStart
ysr
parents: 10771
diff changeset
  2572
  for (; i < IndexSetStart; i++) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2573
    guarantee(_indexedFreeList[i].head() == NULL, "should be NULL");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2574
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2575
  for (; i < IndexSetSize; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2576
    verifyIndexedFreeList(i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2577
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2578
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2579
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2580
void CompactibleFreeListSpace::verifyIndexedFreeList(size_t size) const {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2581
  FreeChunk* fc   =  _indexedFreeList[size].head();
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2582
  FreeChunk* tail =  _indexedFreeList[size].tail();
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2583
  size_t    num = _indexedFreeList[size].count();
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2584
  size_t      n = 0;
10992
b998c6b89fa2 7105163: CMS: some mentions of MinChunkSize should be IndexSetStart
ysr
parents: 10771
diff changeset
  2585
  guarantee(((size >= IndexSetStart) && (size % IndexSetStride == 0)) || fc == NULL,
10771
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  2586
            "Slot should have been empty");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2587
  for (; fc != NULL; fc = fc->next(), n++) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2588
    guarantee(fc->size() == size, "Size inconsistency");
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2589
    guarantee(fc->is_free(), "!free?");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2590
    guarantee(fc->next() == NULL || fc->next()->prev() == fc, "Broken list");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2591
    guarantee((fc->next() == NULL) == (fc == tail), "Incorrect tail");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2592
  }
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2593
  guarantee(n == num, "Incorrect count");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2594
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2595
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2596
#ifndef PRODUCT
10771
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  2597
void CompactibleFreeListSpace::check_free_list_consistency() const {
22884
5cadaf2c3f32 8034171: Remove use of template template parameters from binaryTreeDictionary.
goetz
parents: 22551
diff changeset
  2598
  assert((TreeChunk<FreeChunk, AdaptiveFreeList<FreeChunk> >::min_size() <= IndexSetSize),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2599
    "Some sizes can't be allocated without recourse to"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2600
    " linear allocation buffers");
22884
5cadaf2c3f32 8034171: Remove use of template template parameters from binaryTreeDictionary.
goetz
parents: 22551
diff changeset
  2601
  assert((TreeChunk<FreeChunk, AdaptiveFreeList<FreeChunk> >::min_size()*HeapWordSize == sizeof(TreeChunk<FreeChunk, AdaptiveFreeList<FreeChunk> >)),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2602
    "else MIN_TREE_CHUNK_SIZE is wrong");
12776
468772366db9 7169062: CMS: Assertion failed with -XX:+ObjectAlignmentInBytes=64
brutisso
parents: 12509
diff changeset
  2603
  assert(IndexSetStart != 0, "IndexSetStart not initialized");
468772366db9 7169062: CMS: Assertion failed with -XX:+ObjectAlignmentInBytes=64
brutisso
parents: 12509
diff changeset
  2604
  assert(IndexSetStride != 0, "IndexSetStride not initialized");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2605
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2606
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2607
185
cda2a1eb4be5 6668743: CMS: Consolidate block statistics reporting code
ysr
parents: 1
diff changeset
  2608
void CompactibleFreeListSpace::printFLCensus(size_t sweep_count) const {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2609
  assert_lock_strong(&_freelistLock);
37245
70413a0266d4 8152635: Create a UL class to represent a Log + Level combination
stefank
parents: 37243
diff changeset
  2610
  LogTarget(Debug, gc, freelist, census) log;
70413a0266d4 8152635: Create a UL class to represent a Log + Level combination
stefank
parents: 37243
diff changeset
  2611
  if (!log.is_enabled()) {
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2612
    return;
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2613
  }
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2614
  AdaptiveFreeList<FreeChunk> total;
37245
70413a0266d4 8152635: Create a UL class to represent a Log + Level combination
stefank
parents: 37243
diff changeset
  2615
  log.print("end sweep# " SIZE_FORMAT, sweep_count);
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2616
  ResourceMark rm;
46701
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46683
diff changeset
  2617
  LogStream ls(log);
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46683
diff changeset
  2618
  outputStream* out = &ls;
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2619
  AdaptiveFreeList<FreeChunk>::print_labels_on(out, "size");
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2620
  size_t total_free = 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2621
  for (size_t i = IndexSetStart; i < IndexSetSize; i += IndexSetStride) {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2622
    const AdaptiveFreeList<FreeChunk> *fl = &_indexedFreeList[i];
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2623
    total_free += fl->count() * fl->size();
185
cda2a1eb4be5 6668743: CMS: Consolidate block statistics reporting code
ysr
parents: 1
diff changeset
  2624
    if (i % (40*IndexSetStride) == 0) {
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2625
      AdaptiveFreeList<FreeChunk>::print_labels_on(out, "size");
185
cda2a1eb4be5 6668743: CMS: Consolidate block statistics reporting code
ysr
parents: 1
diff changeset
  2626
    }
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2627
    fl->print_on(out);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2628
    total.set_bfr_surp(    total.bfr_surp()     + fl->bfr_surp()    );
185
cda2a1eb4be5 6668743: CMS: Consolidate block statistics reporting code
ysr
parents: 1
diff changeset
  2629
    total.set_surplus(    total.surplus()     + fl->surplus()    );
cda2a1eb4be5 6668743: CMS: Consolidate block statistics reporting code
ysr
parents: 1
diff changeset
  2630
    total.set_desired(    total.desired()     + fl->desired()    );
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2631
    total.set_prev_sweep(  total.prev_sweep()   + fl->prev_sweep()  );
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2632
    total.set_before_sweep(total.before_sweep() + fl->before_sweep());
185
cda2a1eb4be5 6668743: CMS: Consolidate block statistics reporting code
ysr
parents: 1
diff changeset
  2633
    total.set_count(      total.count()       + fl->count()      );
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2634
    total.set_coal_births( total.coal_births()  + fl->coal_births() );
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2635
    total.set_coal_deaths( total.coal_deaths()  + fl->coal_deaths() );
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2636
    total.set_split_births(total.split_births() + fl->split_births());
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2637
    total.set_split_deaths(total.split_deaths() + fl->split_deaths());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2638
  }
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2639
  total.print_on(out, "TOTAL");
37245
70413a0266d4 8152635: Create a UL class to represent a Log + Level combination
stefank
parents: 37243
diff changeset
  2640
  log.print("Total free in indexed lists " SIZE_FORMAT " words", total_free);
70413a0266d4 8152635: Create a UL class to represent a Log + Level combination
stefank
parents: 37243
diff changeset
  2641
  log.print("growth: %8.5f  deficit: %8.5f",
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2642
            (double)(total.split_births()+total.coal_births()-total.split_deaths()-total.coal_deaths())/
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2643
                    (total.prev_sweep() != 0 ? (double)total.prev_sweep() : 1.0),
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2644
            (double)(total.desired() - total.count())/(total.desired() != 0 ? (double)total.desired() : 1.0));
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2645
  _dictionary->print_dict_census(out);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2646
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2647
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2648
///////////////////////////////////////////////////////////////////////////
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2649
// CompactibleFreeListSpaceLAB
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2650
///////////////////////////////////////////////////////////////////////////
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2651
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2652
#define VECTOR_257(x)                                                                                  \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2653
  /* 1  2  3  4  5  6  7  8  9 1x 11 12 13 14 15 16 17 18 19 2x 21 22 23 24 25 26 27 28 29 3x 31 32 */ \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2654
  {  x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x,   \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2655
     x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x,   \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2656
     x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x,   \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2657
     x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x,   \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2658
     x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x,   \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2659
     x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x,   \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2660
     x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x,   \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2661
     x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x, x,   \
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2662
     x }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2663
28206
98aac9173d5f 8061611: Remove deprecated command line flags
drwhite
parents: 27888
diff changeset
  2664
// Initialize with default setting for CMS, _not_
98aac9173d5f 8061611: Remove deprecated command line flags
drwhite
parents: 27888
diff changeset
  2665
// generic OldPLABSize, whose static default is different; if overridden at the
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2666
// command-line, this will get reinitialized via a call to
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2667
// modify_initialization() below.
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2668
AdaptiveWeightedAverage CompactibleFreeListSpaceLAB::_blocks_to_claim[]    =
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2669
  VECTOR_257(AdaptiveWeightedAverage(OldPLABWeight, (float)CompactibleFreeListSpaceLAB::_default_dynamic_old_plab_size));
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2670
size_t CompactibleFreeListSpaceLAB::_global_num_blocks[]  = VECTOR_257(0);
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2671
uint   CompactibleFreeListSpaceLAB::_global_num_workers[] = VECTOR_257(0);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2672
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2673
CompactibleFreeListSpaceLAB::CompactibleFreeListSpaceLAB(CompactibleFreeListSpace* cfls) :
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2674
  _cfls(cfls)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2675
{
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2676
  assert(CompactibleFreeListSpace::IndexSetSize == 257, "Modify VECTOR_257() macro above");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2677
  for (size_t i = CompactibleFreeListSpace::IndexSetStart;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2678
       i < CompactibleFreeListSpace::IndexSetSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2679
       i += CompactibleFreeListSpace::IndexSetStride) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2680
    _indexedFreeList[i].set_size(i);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2681
    _num_blocks[i] = 0;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2682
  }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2683
}
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2684
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2685
static bool _CFLS_LAB_modified = false;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2686
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2687
void CompactibleFreeListSpaceLAB::modify_initialization(size_t n, unsigned wt) {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2688
  assert(!_CFLS_LAB_modified, "Call only once");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2689
  _CFLS_LAB_modified = true;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2690
  for (size_t i = CompactibleFreeListSpace::IndexSetStart;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2691
       i < CompactibleFreeListSpace::IndexSetSize;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2692
       i += CompactibleFreeListSpace::IndexSetStride) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2693
    _blocks_to_claim[i].modify(n, wt, true /* force */);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2694
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2695
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2696
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2697
HeapWord* CompactibleFreeListSpaceLAB::alloc(size_t word_sz) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2698
  FreeChunk* res;
6447
32cc5cad7fa6 6983930: CMS: Various small cleanups ca September 2010
ysr
parents: 6258
diff changeset
  2699
  assert(word_sz == _cfls->adjustObjectSize(word_sz), "Error");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2700
  if (word_sz >=  CompactibleFreeListSpace::IndexSetSize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2701
    // This locking manages sync with other large object allocations.
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2702
    MutexLocker x(_cfls->parDictionaryAllocLock(),
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2703
                  Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2704
    res = _cfls->getChunkFromDictionaryExact(word_sz);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2705
    if (res == NULL) return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2706
  } else {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2707
    AdaptiveFreeList<FreeChunk>* fl = &_indexedFreeList[word_sz];
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2708
    if (fl->count() == 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2709
      // Attempt to refill this local free list.
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2710
      get_from_global_pool(word_sz, fl);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2711
      // If it didn't work, give up.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2712
      if (fl->count() == 0) return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2713
    }
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2714
    res = fl->get_chunk_at_head();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2715
    assert(res != NULL, "Why was count non-zero?");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2716
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2717
  res->markNotFree();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2718
  assert(!res->is_free(), "shouldn't be marked free");
613
2aa2b913106c 6687581: Make CMS work with compressed oops
coleenp
parents: 360
diff changeset
  2719
  assert(oop(res)->klass_or_null() == NULL, "should look uninitialized");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2720
  // mangle a just allocated object with a distinct pattern.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2721
  debug_only(res->mangleAllocated(word_sz));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2722
  return (HeapWord*)res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2723
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2724
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2725
// Get a chunk of blocks of the right size and update related
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2726
// book-keeping stats
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2727
void CompactibleFreeListSpaceLAB::get_from_global_pool(size_t word_sz, AdaptiveFreeList<FreeChunk>* fl) {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2728
  // Get the #blocks we want to claim
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2729
  size_t n_blks = (size_t)_blocks_to_claim[word_sz].average();
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2730
  assert(n_blks > 0, "Error");
27633
e15ba904574e 8060467: CMS: small OldPLABSize and -XX:-ResizePLAB cause assert(ResizePLAB || n_blks == OldPLABSize) failed: Error
jcoomes
parents: 27624
diff changeset
  2731
  assert(ResizeOldPLAB || n_blks == OldPLABSize, "Error");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2732
  // In some cases, when the application has a phase change,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2733
  // there may be a sudden and sharp shift in the object survival
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2734
  // profile, and updating the counts at the end of a scavenge
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2735
  // may not be quick enough, giving rise to large scavenge pauses
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2736
  // during these phase changes. It is beneficial to detect such
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2737
  // changes on-the-fly during a scavenge and avoid such a phase-change
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2738
  // pothole. The following code is a heuristic attempt to do that.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2739
  // It is protected by a product flag until we have gained
22551
9bf46d16dcc6 8025856: Fix typos in the GC code
jwilhelm
parents: 18687
diff changeset
  2740
  // enough experience with this heuristic and fine-tuned its behavior.
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2741
  // WARNING: This might increase fragmentation if we overreact to
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2742
  // small spikes, so some kind of historical smoothing based on
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2743
  // previous experience with the greater reactivity might be useful.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2744
  // Lacking sufficient experience, CMSOldPLABResizeQuicker is disabled by
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2745
  // default.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2746
  if (ResizeOldPLAB && CMSOldPLABResizeQuicker) {
35168
927833845cf6 8139768: Running with -XX:CMSOldPLABNumRefills=2147483648 causes EXCEPTION_INT_DIVIDE_BY_ZERO on Windows i586
jprovino
parents: 33587
diff changeset
  2747
    //
927833845cf6 8139768: Running with -XX:CMSOldPLABNumRefills=2147483648 causes EXCEPTION_INT_DIVIDE_BY_ZERO on Windows i586
jprovino
parents: 33587
diff changeset
  2748
    // On a 32-bit VM, the denominator can become zero because of integer overflow,
927833845cf6 8139768: Running with -XX:CMSOldPLABNumRefills=2147483648 causes EXCEPTION_INT_DIVIDE_BY_ZERO on Windows i586
jprovino
parents: 33587
diff changeset
  2749
    // which is why there is a cast to double.
927833845cf6 8139768: Running with -XX:CMSOldPLABNumRefills=2147483648 causes EXCEPTION_INT_DIVIDE_BY_ZERO on Windows i586
jprovino
parents: 33587
diff changeset
  2750
    //
927833845cf6 8139768: Running with -XX:CMSOldPLABNumRefills=2147483648 causes EXCEPTION_INT_DIVIDE_BY_ZERO on Windows i586
jprovino
parents: 33587
diff changeset
  2751
    size_t multiple = (size_t) (_num_blocks[word_sz]/(((double)CMSOldPLABToleranceFactor)*CMSOldPLABNumRefills*n_blks));
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2752
    n_blks +=  CMSOldPLABReactivityFactor*multiple*n_blks;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2753
    n_blks = MIN2(n_blks, CMSOldPLABMax);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2754
  }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2755
  assert(n_blks > 0, "Error");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2756
  _cfls->par_get_chunk_of_blocks(word_sz, n_blks, fl);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2757
  // Update stats table entry for this block size
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2758
  _num_blocks[word_sz] += fl->count();
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2759
}
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2760
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2761
void CompactibleFreeListSpaceLAB::compute_desired_plab_size() {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2762
  for (size_t i =  CompactibleFreeListSpace::IndexSetStart;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2763
       i < CompactibleFreeListSpace::IndexSetSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2764
       i += CompactibleFreeListSpace::IndexSetStride) {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2765
    assert((_global_num_workers[i] == 0) == (_global_num_blocks[i] == 0),
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2766
           "Counter inconsistency");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2767
    if (_global_num_workers[i] > 0) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2768
      // Need to smooth wrt historical average
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2769
      if (ResizeOldPLAB) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2770
        _blocks_to_claim[i].sample(
29697
92501504191b 8074459: Flags handling memory sizes should be of type size_t
jwilhelm
parents: 29684
diff changeset
  2771
          MAX2(CMSOldPLABMin,
92501504191b 8074459: Flags handling memory sizes should be of type size_t
jwilhelm
parents: 29684
diff changeset
  2772
          MIN2(CMSOldPLABMax,
37194
96cc74bd293b 8152160: SIGFPE in CompactibleFreeListSpaceLAB::compute_desired_plab_size
sangheki
parents: 37072
diff changeset
  2773
               _global_num_blocks[i]/_global_num_workers[i]/CMSOldPLABNumRefills)));
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2774
      }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2775
      // Reset counters for next round
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2776
      _global_num_workers[i] = 0;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2777
      _global_num_blocks[i] = 0;
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2778
      log_trace(gc, plab)("[" SIZE_FORMAT "]: " SIZE_FORMAT, i, (size_t)_blocks_to_claim[i].average());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2779
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2780
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2781
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2782
10771
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  2783
// If this is changed in the future to allow parallel
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  2784
// access, one would need to take the FL locks and,
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  2785
// depending on how it is used, stagger access from
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  2786
// parallel threads to reduce contention.
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35169
diff changeset
  2787
void CompactibleFreeListSpaceLAB::retire(int tid) {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2788
  // We run this single threaded with the world stopped;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2789
  // so no need for locks and such.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2790
  NOT_PRODUCT(Thread* t = Thread::current();)
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2791
  assert(Thread::current()->is_VM_thread(), "Error");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2792
  for (size_t i =  CompactibleFreeListSpace::IndexSetStart;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2793
       i < CompactibleFreeListSpace::IndexSetSize;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2794
       i += CompactibleFreeListSpace::IndexSetStride) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2795
    assert(_num_blocks[i] >= (size_t)_indexedFreeList[i].count(),
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2796
           "Can't retire more than what we obtained");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2797
    if (_num_blocks[i] > 0) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2798
      size_t num_retire =  _indexedFreeList[i].count();
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2799
      assert(_num_blocks[i] > num_retire, "Should have used at least one");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2800
      {
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2801
        // MutexLocker x(_cfls->_indexedFreeListParLocks[i],
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2802
        //               Mutex::_no_safepoint_check_flag);
10771
68e4b84cfa28 7099817: CMS: +FLSVerifyLists +FLSVerifyIndexTable asserts: odd slot non-empty, chunk not on free list
ysr
parents: 9984
diff changeset
  2803
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2804
        // Update globals stats for num_blocks used
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2805
        _global_num_blocks[i] += (_num_blocks[i] - num_retire);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2806
        _global_num_workers[i]++;
11396
917d8673b5ef 7121618: Change type of number of GC workers to unsigned int.
jmasa
parents: 11174
diff changeset
  2807
        assert(_global_num_workers[i] <= ParallelGCThreads, "Too big");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2808
        if (num_retire > 0) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2809
          _cfls->_indexedFreeList[i].prepend(&_indexedFreeList[i]);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2810
          // Reset this list.
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2811
          _indexedFreeList[i] = AdaptiveFreeList<FreeChunk>();
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2812
          _indexedFreeList[i].set_size(i);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2813
        }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2814
      }
35061
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2815
      log_trace(gc, plab)("%d[" SIZE_FORMAT "]: " SIZE_FORMAT "/" SIZE_FORMAT "/" SIZE_FORMAT,
be6025ebffea 8145092: Use Unified Logging for the GC logging
brutisso
parents: 33587
diff changeset
  2816
                          tid, i, num_retire, _num_blocks[i], (size_t)_blocks_to_claim[i].average());
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2817
      // Reset stats for next round
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2818
      _num_blocks[i]         = 0;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2819
    }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2820
  }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2821
}
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2822
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2823
// Used by par_get_chunk_of_blocks() for the chunks from the
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2824
// indexed_free_lists.  Looks for a chunk with size that is a multiple
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2825
// of "word_sz" and if found, splits it into "word_sz" chunks and add
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2826
// to the free list "fl".  "n" is the maximum number of chunks to
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2827
// be added to "fl".
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2828
bool CompactibleFreeListSpace:: par_get_chunk_of_blocks_IFL(size_t word_sz, size_t n, AdaptiveFreeList<FreeChunk>* fl) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2829
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2830
  // We'll try all multiples of word_sz in the indexed set, starting with
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2831
  // word_sz itself and, if CMSSplitIndexedFreeListBlocks, try larger multiples,
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2832
  // then try getting a big chunk and splitting it.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2833
  {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2834
    bool found;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2835
    int  k;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2836
    size_t cur_sz;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2837
    for (k = 1, cur_sz = k * word_sz, found = false;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2838
         (cur_sz < CompactibleFreeListSpace::IndexSetSize) &&
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2839
         (CMSSplitIndexedFreeListBlocks || k <= 1);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2840
         k++, cur_sz = k * word_sz) {
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2841
      AdaptiveFreeList<FreeChunk> fl_for_cur_sz;  // Empty.
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2842
      fl_for_cur_sz.set_size(cur_sz);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2843
      {
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2844
        MutexLocker x(_indexedFreeListParLocks[cur_sz],
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2845
                      Mutex::_no_safepoint_check_flag);
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2846
        AdaptiveFreeList<FreeChunk>* gfl = &_indexedFreeList[cur_sz];
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2847
        if (gfl->count() != 0) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2848
          // nn is the number of chunks of size cur_sz that
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2849
          // we'd need to split k-ways each, in order to create
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2850
          // "n" chunks of size word_sz each.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2851
          const size_t nn = MAX2(n/k, (size_t)1);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2852
          gfl->getFirstNChunksFromList(nn, &fl_for_cur_sz);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2853
          found = true;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2854
          if (k > 1) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2855
            // Update split death stats for the cur_sz-size blocks list:
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2856
            // we increment the split death count by the number of blocks
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2857
            // we just took from the cur_sz-size blocks list and which
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2858
            // we will be splitting below.
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2859
            ssize_t deaths = gfl->split_deaths() +
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2860
                             fl_for_cur_sz.count();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2861
            gfl->set_split_deaths(deaths);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2862
          }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2863
        }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2864
      }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2865
      // Now transfer fl_for_cur_sz to fl.  Common case, we hope, is k = 1.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2866
      if (found) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2867
        if (k == 1) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2868
          fl->prepend(&fl_for_cur_sz);
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2869
        } else {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2870
          // Divide each block on fl_for_cur_sz up k ways.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2871
          FreeChunk* fc;
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2872
          while ((fc = fl_for_cur_sz.get_chunk_at_head()) != NULL) {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2873
            // Must do this in reverse order, so that anybody attempting to
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2874
            // access the main chunk sees it as a single free block until we
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2875
            // change it.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2876
            size_t fc_size = fc->size();
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2877
            assert(fc->is_free(), "Error");
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2878
            for (int i = k-1; i >= 0; i--) {
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2879
              FreeChunk* ffc = (FreeChunk*)((HeapWord*)fc + i * word_sz);
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2880
              assert((i != 0) ||
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2881
                        ((fc == ffc) && ffc->is_free() &&
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2882
                         (ffc->size() == k*word_sz) && (fc_size == word_sz)),
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2883
                        "Counting error");
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2884
              ffc->set_size(word_sz);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2885
              ffc->link_prev(NULL); // Mark as a free block for other (parallel) GC threads.
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2886
              ffc->link_next(NULL);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2887
              // Above must occur before BOT is updated below.
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2888
              OrderAccess::storestore();
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2889
              // splitting from the right, fc_size == i * word_sz
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2890
              _bt.mark_block((HeapWord*)ffc, word_sz, true /* reducing */);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2891
              fc_size -= word_sz;
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2892
              assert(fc_size == i*word_sz, "Error");
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2893
              _bt.verify_not_unallocated((HeapWord*)ffc, word_sz);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2894
              _bt.verify_single_block((HeapWord*)fc, fc_size);
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2895
              _bt.verify_single_block((HeapWord*)ffc, word_sz);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2896
              // Push this on "fl".
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2897
              fl->return_chunk_at_head(ffc);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2898
            }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2899
            // TRAP
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2900
            assert(fl->tail()->next() == NULL, "List invariant.");
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2901
          }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2902
        }
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2903
        // Update birth stats for this block size.
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2904
        size_t num = fl->count();
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2905
        MutexLocker x(_indexedFreeListParLocks[word_sz],
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2906
                      Mutex::_no_safepoint_check_flag);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2907
        ssize_t births = _indexedFreeList[word_sz].split_births() + num;
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2908
        _indexedFreeList[word_sz].set_split_births(births);
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2909
        return true;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2910
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2911
    }
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2912
    return found;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2913
  }
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2914
}
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2915
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2916
FreeChunk* CompactibleFreeListSpace::get_n_way_chunk_to_split(size_t word_sz, size_t n) {
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2917
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2918
  FreeChunk* fc = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2919
  FreeChunk* rem_fc = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2920
  size_t rem;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2921
  {
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2922
    MutexLocker x(parDictionaryAllocLock(),
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2923
                  Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2924
    while (n > 0) {
46674
a9e42ff6158f 8183923: Get rid of FreeBlockDictionary and dithering
mgerdin
parents: 46625
diff changeset
  2925
      fc = dictionary()->get_chunk(MAX2(n * word_sz, _dictionary->min_size()));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2926
      if (fc != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2927
        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2928
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2929
        n--;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2930
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2931
    }
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2932
    if (fc == NULL) return NULL;
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2933
    // Otherwise, split up that block.
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2934
    assert((ssize_t)n >= 1, "Control point invariant");
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2935
    assert(fc->is_free(), "Error: should be a free block");
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2936
    _bt.verify_single_block((HeapWord*)fc, fc->size());
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2937
    const size_t nn = fc->size() / word_sz;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2938
    n = MIN2(nn, n);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2939
    assert((ssize_t)n >= 1, "Control point invariant");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2940
    rem = fc->size() - n * word_sz;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2941
    // If there is a remainder, and it's too small, allocate one fewer.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2942
    if (rem > 0 && rem < MinChunkSize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2943
      n--; rem += word_sz;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2944
    }
4577
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2945
    // Note that at this point we may have n == 0.
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2946
    assert((ssize_t)n >= 0, "Control point invariant");
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2947
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2948
    // If n is 0, the chunk fc that was found is not large
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2949
    // enough to leave a viable remainder.  We are unable to
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2950
    // allocate even one block.  Return fc to the
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2951
    // dictionary and return, leaving "fl" empty.
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2952
    if (n == 0) {
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2953
      returnChunkToDictionary(fc);
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2954
      return NULL;
4577
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2955
    }
18d854d28d4e 6912018: CMS: guarantee(head() != 0,"The head of the list cannot be NULL")
jmasa
parents: 4574
diff changeset
  2956
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2957
    _bt.allocated((HeapWord*)fc, fc->size(), true /* reducing */);  // update _unallocated_blk
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2958
    dictionary()->dict_census_update(fc->size(),
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2959
                                     true /*split*/,
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2960
                                     false /*birth*/);
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2961
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2962
    // First return the remainder, if any.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2963
    // Note that we hold the lock until we decide if we're going to give
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2964
    // back the remainder to the dictionary, since a concurrent allocation
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2965
    // may otherwise see the heap as empty.  (We're willing to take that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2966
    // hit if the block is a small block.)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2967
    if (rem > 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2968
      size_t prefix_size = n * word_sz;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2969
      rem_fc = (FreeChunk*)((HeapWord*)fc + prefix_size);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2970
      rem_fc->set_size(rem);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2971
      rem_fc->link_prev(NULL); // Mark as a free block for other (parallel) GC threads.
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2972
      rem_fc->link_next(NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2973
      // Above must occur before BOT is updated below.
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  2974
      assert((ssize_t)n > 0 && prefix_size > 0 && rem_fc > fc, "Error");
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  2975
      OrderAccess::storestore();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2976
      _bt.split_block((HeapWord*)fc, fc->size(), prefix_size);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2977
      assert(fc->is_free(), "Error");
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2978
      fc->set_size(prefix_size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2979
      if (rem >= IndexSetSize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2980
        returnChunkToDictionary(rem_fc);
14123
944e56f74fba 7045397: NPG: Add freelists to class loader arenas.
jmasa
parents: 13728
diff changeset
  2981
        dictionary()->dict_census_update(rem, true /*split*/, true /*birth*/);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2982
        rem_fc = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2983
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2984
      // Otherwise, return it to the small list below.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2985
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2986
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2987
  if (rem_fc != NULL) {
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2988
    MutexLocker x(_indexedFreeListParLocks[rem],
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  2989
                  Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2990
    _bt.verify_not_unallocated((HeapWord*)rem_fc, rem_fc->size());
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  2991
    _indexedFreeList[rem].return_chunk_at_head(rem_fc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2992
    smallSplitBirth(rem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2993
  }
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2994
  assert(n * word_sz == fc->size(),
33105
294e48b4f704 8080775: Better argument formatting for assert() and friends
david
parents: 32623
diff changeset
  2995
         "Chunk size " SIZE_FORMAT " is not exactly splittable by "
294e48b4f704 8080775: Better argument formatting for assert() and friends
david
parents: 32623
diff changeset
  2996
         SIZE_FORMAT " sized chunks of size " SIZE_FORMAT,
294e48b4f704 8080775: Better argument formatting for assert() and friends
david
parents: 32623
diff changeset
  2997
         fc->size(), n, word_sz);
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2998
  return fc;
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  2999
}
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3000
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3001
void CompactibleFreeListSpace:: par_get_chunk_of_blocks_dictionary(size_t word_sz, size_t targetted_number_of_chunks, AdaptiveFreeList<FreeChunk>* fl) {
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3002
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3003
  FreeChunk* fc = get_n_way_chunk_to_split(word_sz, targetted_number_of_chunks);
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3004
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3005
  if (fc == NULL) {
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3006
    return;
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3007
  }
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3008
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3009
  size_t n = fc->size() / word_sz;
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3010
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3011
  assert((ssize_t)n > 0, "Consistency");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3012
  // Now do the splitting up.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3013
  // Must do this in reverse order, so that anybody attempting to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3014
  // access the main chunk sees it as a single free block until we
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3015
  // change it.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3016
  size_t fc_size = n * word_sz;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3017
  // All but first chunk in this loop
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3018
  for (ssize_t i = n-1; i > 0; i--) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3019
    FreeChunk* ffc = (FreeChunk*)((HeapWord*)fc + i * word_sz);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3020
    ffc->set_size(word_sz);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3021
    ffc->link_prev(NULL); // Mark as a free block for other (parallel) GC threads.
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3022
    ffc->link_next(NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3023
    // Above must occur before BOT is updated below.
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  3024
    OrderAccess::storestore();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3025
    // splitting from the right, fc_size == (n - i + 1) * wordsize
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  3026
    _bt.mark_block((HeapWord*)ffc, word_sz, true /* reducing */);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3027
    fc_size -= word_sz;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3028
    _bt.verify_not_unallocated((HeapWord*)ffc, ffc->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3029
    _bt.verify_single_block((HeapWord*)ffc, ffc->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3030
    _bt.verify_single_block((HeapWord*)fc, fc_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3031
    // Push this on "fl".
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3032
    fl->return_chunk_at_head(ffc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3033
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3034
  // First chunk
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3035
  assert(fc->is_free() && fc->size() == n*word_sz, "Error: should still be a free block");
6258
68f252c6e825 6948538: CMS: BOT walkers can fall into object allocation and initialization cracks
ysr
parents: 5702
diff changeset
  3036
  // The blocks above should show their new sizes before the first block below
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3037
  fc->set_size(word_sz);
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3038
  fc->link_prev(NULL);    // idempotent wrt free-ness, see assert above
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3039
  fc->link_next(NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3040
  _bt.verify_not_unallocated((HeapWord*)fc, fc->size());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3041
  _bt.verify_single_block((HeapWord*)fc, fc->size());
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3042
  fl->return_chunk_at_head(fc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3043
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  3044
  assert((ssize_t)n > 0 && (ssize_t)n == fl->count(), "Incorrect number of blocks");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3045
  {
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  3046
    // Update the stats for this block size.
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  3047
    MutexLocker x(_indexedFreeListParLocks[word_sz],
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 51332
diff changeset
  3048
                  Mutex::_no_safepoint_check_flag);
12509
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3049
    const ssize_t births = _indexedFreeList[word_sz].split_births() + n;
6228e2085074 7164144: Fix variable naming style in freeBlockDictionary.* and binaryTreeDictionary*
jmasa
parents: 12507
diff changeset
  3050
    _indexedFreeList[word_sz].set_split_births(births);
4574
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  3051
    // ssize_t new_surplus = _indexedFreeList[word_sz].surplus() + n;
b2d5b0975515 6631166: CMS: better heuristics when combatting fragmentation
ysr
parents: 2105
diff changeset
  3052
    // _indexedFreeList[word_sz].set_surplus(new_surplus);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3053
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3054
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3055
  // TRAP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3056
  assert(fl->tail()->next() == NULL, "List invariant.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3057
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3058
26150
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3059
void CompactibleFreeListSpace:: par_get_chunk_of_blocks(size_t word_sz, size_t n, AdaptiveFreeList<FreeChunk>* fl) {
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3060
  assert(fl->count() == 0, "Precondition.");
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3061
  assert(word_sz < CompactibleFreeListSpace::IndexSetSize,
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3062
         "Precondition");
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3063
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3064
  if (par_get_chunk_of_blocks_IFL(word_sz, n, fl)) {
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3065
    // Got it
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3066
    return;
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3067
  }
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3068
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3069
  // Otherwise, we'll split a block from the dictionary.
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3070
  par_get_chunk_of_blocks_dictionary(word_sz, n, fl);
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3071
}
6186fcfeb5ae 8026303: CMS: JVM intermittently crashes with "FreeList of size 258 violates Conservation Principle" assert
jmasa
parents: 25725
diff changeset
  3072
37433
f8fd0bcc60af 8152182: Possible overflow in initialzation of _rescan_task_size and _marking_task_size
sangheki
parents: 37245
diff changeset
  3073
const size_t CompactibleFreeListSpace::max_flag_size_for_task_size() const {
49164
7e958a8ebcd3 8195142: Refactor out card table from CardTableModRefBS to flatten the BarrierSet hierarchy
eosterlund
parents: 47816
diff changeset
  3074
  const size_t ergo_max = _old_gen->reserved().word_size() / (CardTable::card_size_in_words * BitsPerWord);
37433
f8fd0bcc60af 8152182: Possible overflow in initialzation of _rescan_task_size and _marking_task_size
sangheki
parents: 37245
diff changeset
  3075
  return ergo_max;
f8fd0bcc60af 8152182: Possible overflow in initialzation of _rescan_task_size and _marking_task_size
sangheki
parents: 37245
diff changeset
  3076
}
f8fd0bcc60af 8152182: Possible overflow in initialzation of _rescan_task_size and _marking_task_size
sangheki
parents: 37245
diff changeset
  3077
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3078
// Set up the space's par_seq_tasks structure for work claiming
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3079
// for parallel rescan. See CMSParRemarkTask where this is currently used.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3080
// XXX Need to suitably abstract and generalize this and the next
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3081
// method into one.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3082
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3083
CompactibleFreeListSpace::
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3084
initialize_sequential_subtasks_for_rescan(int n_threads) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3085
  // The "size" of each task is fixed according to rescan_task_size.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3086
  assert(n_threads > 0, "Unexpected n_threads argument");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3087
  const size_t task_size = rescan_task_size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3088
  size_t n_tasks = (used_region().word_size() + task_size - 1)/task_size;
1372
654bcf7839bc 6722116: CMS: Incorrect overflow handling when using parallel concurrent marking
ysr
parents: 977
diff changeset
  3089
  assert((n_tasks == 0) == used_region().is_empty(), "n_tasks incorrect");
654bcf7839bc 6722116: CMS: Incorrect overflow handling when using parallel concurrent marking
ysr
parents: 977
diff changeset
  3090
  assert(n_tasks == 0 ||
654bcf7839bc 6722116: CMS: Incorrect overflow handling when using parallel concurrent marking
ysr
parents: 977
diff changeset
  3091
         ((used_region().start() + (n_tasks - 1)*task_size < used_region().end()) &&
654bcf7839bc 6722116: CMS: Incorrect overflow handling when using parallel concurrent marking
ysr
parents: 977
diff changeset
  3092
          (used_region().start() + n_tasks*task_size >= used_region().end())),
654bcf7839bc 6722116: CMS: Incorrect overflow handling when using parallel concurrent marking
ysr
parents: 977
diff changeset
  3093
         "n_tasks calculation incorrect");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3094
  SequentialSubTasksDone* pst = conc_par_seq_tasks();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3095
  assert(!pst->valid(), "Clobbering existing data?");
6759
67b1a69ef5aa 6984287: Regularize how GC parallel workers are specified.
jmasa
parents: 6447
diff changeset
  3096
  // Sets the condition for completion of the subtask (how many threads
67b1a69ef5aa 6984287: Regularize how GC parallel workers are specified.
jmasa
parents: 6447
diff changeset
  3097
  // need to finish in order to be done).
67b1a69ef5aa 6984287: Regularize how GC parallel workers are specified.
jmasa
parents: 6447
diff changeset
  3098
  pst->set_n_threads(n_threads);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3099
  pst->set_n_tasks((int)n_tasks);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3100
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3102
// Set up the space's par_seq_tasks structure for work claiming
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3103
// for parallel concurrent marking. See CMSConcMarkTask where this is currently used.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3104
void
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3105
CompactibleFreeListSpace::
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3106
initialize_sequential_subtasks_for_marking(int n_threads,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3107
                                           HeapWord* low) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3108
  // The "size" of each task is fixed according to rescan_task_size.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3109
  assert(n_threads > 0, "Unexpected n_threads argument");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3110
  const size_t task_size = marking_task_size();
49164
7e958a8ebcd3 8195142: Refactor out card table from CardTableModRefBS to flatten the BarrierSet hierarchy
eosterlund
parents: 47816
diff changeset
  3111
  assert(task_size > CardTable::card_size_in_words &&
7e958a8ebcd3 8195142: Refactor out card table from CardTableModRefBS to flatten the BarrierSet hierarchy
eosterlund
parents: 47816
diff changeset
  3112
         (task_size %  CardTable::card_size_in_words == 0),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3113
         "Otherwise arithmetic below would be incorrect");
32623
390a27af5657 8134626: Misc cleanups after generation array removal
jwilhelm
parents: 32606
diff changeset
  3114
  MemRegion span = _old_gen->reserved();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3115
  if (low != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3116
    if (span.contains(low)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3117
      // Align low down to  a card boundary so that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3118
      // we can use block_offset_careful() on span boundaries.
49164
7e958a8ebcd3 8195142: Refactor out card table from CardTableModRefBS to flatten the BarrierSet hierarchy
eosterlund
parents: 47816
diff changeset
  3119
      HeapWord* aligned_low = align_down(low, CardTable::card_size);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3120
      // Clip span prefix at aligned_low
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3121
      span = span.intersection(MemRegion(aligned_low, span.end()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3122
    } else if (low > span.end()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3123
      span = MemRegion(low, low);  // Null region
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3124
    } // else use entire span
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3125
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3126
  assert(span.is_empty() ||
49164
7e958a8ebcd3 8195142: Refactor out card table from CardTableModRefBS to flatten the BarrierSet hierarchy
eosterlund
parents: 47816
diff changeset
  3127
         ((uintptr_t)span.start() %  CardTable::card_size == 0),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3128
        "span should start at a card boundary");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3129
  size_t n_tasks = (span.word_size() + task_size - 1)/task_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3130
  assert((n_tasks == 0) == span.is_empty(), "Inconsistency");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3131
  assert(n_tasks == 0 ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3132
         ((span.start() + (n_tasks - 1)*task_size < span.end()) &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3133
          (span.start() + n_tasks*task_size >= span.end())),
1372
654bcf7839bc 6722116: CMS: Incorrect overflow handling when using parallel concurrent marking
ysr
parents: 977
diff changeset
  3134
         "n_tasks calculation incorrect");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3135
  SequentialSubTasksDone* pst = conc_par_seq_tasks();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3136
  assert(!pst->valid(), "Clobbering existing data?");
6759
67b1a69ef5aa 6984287: Regularize how GC parallel workers are specified.
jmasa
parents: 6447
diff changeset
  3137
  // Sets the condition for completion of the subtask (how many threads
67b1a69ef5aa 6984287: Regularize how GC parallel workers are specified.
jmasa
parents: 6447
diff changeset
  3138
  // need to finish in order to be done).
67b1a69ef5aa 6984287: Regularize how GC parallel workers are specified.
jmasa
parents: 6447
diff changeset
  3139
  pst->set_n_threads(n_threads);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3140
  pst->set_n_tasks((int)n_tasks);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3141
}