hotspot/src/share/vm/gc/parallel/psMarkSweepDecorator.hpp
author tschatzl
Thu, 28 Jan 2016 13:30:12 +0100
changeset 35877 a2a62511d0f8
parent 30764 fec48bf5a827
permissions -rw-r--r--
8146987: Improve Parallel GC Full GC by caching results of live_words_in_range() Summary: A large part of time in the parallel scavenge collector is spent finding out the amount of live words within memory ranges to find out where to move an object to. Try to incrementally calculate this value. Reviewed-by: tschatzl, mgerdin, jmasa Contributed-by: ray alex <sky1young@gmail.com>
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
30764
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 13728
diff changeset
     2
 * Copyright (c) 2001, 2015, 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: 1623
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1623
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: 1623
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
30764
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 13728
diff changeset
    25
#ifndef SHARE_VM_GC_PARALLEL_PSMARKSWEEPDECORATOR_HPP
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 13728
diff changeset
    26
#define SHARE_VM_GC_PARALLEL_PSMARKSWEEPDECORATOR_HPP
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    27
30764
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 13728
diff changeset
    28
#include "gc/parallel/mutableSpace.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    29
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    30
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    31
// A PSMarkSweepDecorator is used to add "ParallelScavenge" style mark sweep operations
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
// to a MutableSpace.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
class ObjectStartArray;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
13195
be27e1b6a4b9 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 7397
diff changeset
    37
class PSMarkSweepDecorator: public CHeapObj<mtGC> {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
  static PSMarkSweepDecorator* _destination_decorator;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
 protected:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
  MutableSpace* _space;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
  ObjectStartArray* _start_array;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
  HeapWord* _first_dead;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
  HeapWord* _end_of_live;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
  HeapWord* _compaction_top;
1557
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    47
  size_t _allowed_dead_ratio;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
1557
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    49
  bool insert_deadspace(size_t& allowed_deadspace_words, HeapWord* q,
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    50
                        size_t word_len);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
  PSMarkSweepDecorator(MutableSpace* space, ObjectStartArray* start_array,
1557
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    54
                       size_t allowed_dead_ratio) :
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    55
    _space(space), _start_array(start_array),
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    56
    _allowed_dead_ratio(allowed_dead_ratio) { }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
  // During a compacting collection, we need to collapse objects into
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
  // spaces in a given order. We want to fill space A, space B, and so
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
  // on. The code that controls that order is in the following methods.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
  static void set_destination_decorator_tenured();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
  static void advance_destination_decorator();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
  static PSMarkSweepDecorator* destination_decorator();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
  // Accessors
1557
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    66
  MutableSpace* space()                     { return _space; }
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    67
  ObjectStartArray* start_array()           { return _start_array; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
1557
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    69
  HeapWord* compaction_top()                { return _compaction_top; }
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    70
  void set_compaction_top(HeapWord* value)  { _compaction_top = value; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
1557
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    72
  size_t allowed_dead_ratio()               { return _allowed_dead_ratio; }
13878a2edfef 6765804: GC "dead ratios" should be unsigned
jcoomes
parents: 1
diff changeset
    73
  void set_allowed_dead_ratio(size_t value) { _allowed_dead_ratio = value; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
  // Work methods
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
  void adjust_pointers();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
  void precompact();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
  void compact(bool mangle_free_space);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
};
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    80
30764
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 13728
diff changeset
    81
#endif // SHARE_VM_GC_PARALLEL_PSMARKSWEEPDECORATOR_HPP