src/hotspot/share/gc/shared/parallelCleaning.hpp
author kvn
Wed, 01 May 2019 12:31:29 -0700
changeset 54669 ad45b3802d4e
parent 53536 482109fae02b
child 57510 4db4d0d14390
permissions -rw-r--r--
8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library Reviewed-by: dnsimon, never, stefank, rehn, neliasso, dholmes, kbarrett, coleenp
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
     1
/*
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 52448
diff changeset
     2
 * Copyright (c) 2018, 2019, Oracle and/or its affiliates. All rights reserved.
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
     4
 *
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
     7
 * published by the Free Software Foundation.
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
     8
 *
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    13
 * accompanied this code).
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    14
 *
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    18
 *
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    21
 * questions.
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    22
 *
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    23
 */
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    24
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 52448
diff changeset
    25
#ifndef SHARE_GC_SHARED_PARALLELCLEANING_HPP
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 52448
diff changeset
    26
#define SHARE_GC_SHARED_PARALLELCLEANING_HPP
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    27
53361
4a59f7042325 8217203: Some more includes to .inline.hpp files in gc header files
tschatzl
parents: 53244
diff changeset
    28
#include "classfile/classLoaderDataGraph.hpp"
4a59f7042325 8217203: Some more includes to .inline.hpp files in gc header files
tschatzl
parents: 53244
diff changeset
    29
#include "code/codeCache.hpp"
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    30
#include "gc/shared/oopStorageParState.hpp"
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    31
#include "gc/shared/stringdedup/stringDedup.hpp"
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    32
#include "gc/shared/workgroup.hpp"
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    33
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    34
class ParallelCleaningTask;
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    35
53536
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
    36
class StringDedupCleaningTask : public AbstractGangTask {
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
    37
  StringDedupUnlinkOrOopsDoClosure _dedup_closure;
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    38
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    39
public:
53536
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
    40
  StringDedupCleaningTask(BoolObjectClosure* is_alive, OopClosure* keep_alive, bool resize_table);
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
    41
  ~StringDedupCleaningTask();
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    42
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    43
  void work(uint worker_id);
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    44
};
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    45
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    46
class CodeCacheUnloadingTask {
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    47
52385
5c679ec60888 8209189: Make CompiledMethod::do_unloading more concurrent
eosterlund
parents: 51959
diff changeset
    48
  CodeCache::UnloadingScope _unloading_scope;
5c679ec60888 8209189: Make CompiledMethod::do_unloading more concurrent
eosterlund
parents: 51959
diff changeset
    49
  const bool                _unloading_occurred;
5c679ec60888 8209189: Make CompiledMethod::do_unloading more concurrent
eosterlund
parents: 51959
diff changeset
    50
  const uint                _num_workers;
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    51
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    52
  // Variables used to claim nmethods.
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    53
  CompiledMethod* _first_nmethod;
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    54
  CompiledMethod* volatile _claimed_nmethod;
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    55
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    56
public:
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    57
  CodeCacheUnloadingTask(uint num_workers, BoolObjectClosure* is_alive, bool unloading_occurred);
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    58
  ~CodeCacheUnloadingTask();
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    59
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    60
private:
52385
5c679ec60888 8209189: Make CompiledMethod::do_unloading more concurrent
eosterlund
parents: 51959
diff changeset
    61
  static const int MaxClaimNmethods = 16;
5c679ec60888 8209189: Make CompiledMethod::do_unloading more concurrent
eosterlund
parents: 51959
diff changeset
    62
  void claim_nmethods(CompiledMethod** claimed_nmethods, int *num_claimed_nmethods);
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    63
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    64
public:
52385
5c679ec60888 8209189: Make CompiledMethod::do_unloading more concurrent
eosterlund
parents: 51959
diff changeset
    65
  // Cleaning and unloading of nmethods.
5c679ec60888 8209189: Make CompiledMethod::do_unloading more concurrent
eosterlund
parents: 51959
diff changeset
    66
  void work(uint worker_id);
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    67
};
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    68
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    69
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    70
class KlassCleaningTask : public StackObj {
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    71
  volatile int                            _clean_klass_tree_claimed;
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    72
  ClassLoaderDataGraphKlassIteratorAtomic _klass_iterator;
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    73
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    74
public:
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    75
  KlassCleaningTask();
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    76
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    77
private:
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    78
  bool claim_clean_klass_tree_task();
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    79
  InstanceKlass* claim_next_klass();
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    80
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    81
public:
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    82
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    83
  void clean_klass(InstanceKlass* ik) {
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    84
    ik->clean_weak_instanceklass_links();
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    85
  }
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    86
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    87
  void work();
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    88
};
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
    89
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    90
#if INCLUDE_JVMCI
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    91
class JVMCICleaningTask : public StackObj {
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    92
  volatile int       _cleaning_claimed;
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    93
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    94
public:
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    95
  JVMCICleaningTask();
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    96
  // Clean JVMCI metadata handles.
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    97
  void work(bool unloading_occurred);
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    98
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
    99
private:
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
   100
  bool claim_cleaning_task();
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
   101
};
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
   102
#endif
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
   103
53536
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   104
// Do cleanup of some weakly held data in the same parallel task.
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   105
// Assumes a non-moving context.
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
   106
class ParallelCleaningTask : public AbstractGangTask {
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
   107
private:
53536
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   108
  bool                    _unloading_occurred;
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   109
  StringDedupCleaningTask _string_dedup_task;
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   110
  CodeCacheUnloadingTask  _code_cache_task;
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
   111
#if INCLUDE_JVMCI
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
   112
  JVMCICleaningTask       _jvmci_cleaning_task;
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 53536
diff changeset
   113
#endif
53536
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   114
  KlassCleaningTask       _klass_cleaning_task;
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
   115
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
   116
public:
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
   117
  // The constructor is run in the VMThread.
53536
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   118
  ParallelCleaningTask(BoolObjectClosure* is_alive,
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   119
                       uint num_workers,
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   120
                       bool unloading_occurred,
482109fae02b 8213229: Investigate treating StringTable as weak in young collections
tschatzl
parents: 53361
diff changeset
   121
                       bool resize_dedup_table);
51524
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
   122
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
   123
  void work(uint worker_id);
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
   124
};
9d01ad46daef 8209841: [REDO] Refactor G1ParallelCleaningTask into shared
zgu
parents:
diff changeset
   125
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 52448
diff changeset
   126
#endif // SHARE_GC_SHARED_PARALLELCLEANING_HPP