< prev index next >

src/hotspot/share/gc/shenandoah/shenandoahDegeneratedGC.hpp

Print this page
*** 26,19 ***
  #define SHARE_GC_SHENANDOAH_SHENANDOAHDEGENERATEDGC_HPP
  
  #include "gc/shenandoah/shenandoahGC.hpp"
  
  class VM_ShenandoahDegeneratedGC;
  
  class ShenandoahDegenGC : public ShenandoahGC {
    friend class VM_ShenandoahDegeneratedGC;
  private:
    const ShenandoahDegenPoint  _degen_point;
    bool _abbreviated;
  
  public:
!   ShenandoahDegenGC(ShenandoahDegenPoint degen_point);
    bool collect(GCCause::Cause cause);
  
  private:
    void vmop_degenerated();
    void entry_degenerated();
--- 26,21 ---
  #define SHARE_GC_SHENANDOAH_SHENANDOAHDEGENERATEDGC_HPP
  
  #include "gc/shenandoah/shenandoahGC.hpp"
  
  class VM_ShenandoahDegeneratedGC;
+ class ShenandoahGeneration;
  
  class ShenandoahDegenGC : public ShenandoahGC {
    friend class VM_ShenandoahDegeneratedGC;
  private:
    const ShenandoahDegenPoint  _degen_point;
+   ShenandoahGeneration* _generation;
    bool _abbreviated;
  
  public:
!   ShenandoahDegenGC(ShenandoahDegenPoint degen_point, ShenandoahGeneration* generation);
    bool collect(GCCause::Cause cause);
  
  private:
    void vmop_degenerated();
    void entry_degenerated();

*** 54,10 ***
--- 56,13 ---
    void op_init_updaterefs();
    void op_updaterefs();
    void op_update_roots();
    void op_cleanup_complete();
  
+   // This will rebuild card offsets, which is necessary if classes were unloaded
+   void op_global_coalesce_and_fill();
+ 
    // Fail handling
    void op_degenerated_futile();
    void op_degenerated_fail();
  
    // Turns this degenerated cycle into a full gc without leaving the safepoint
< prev index next >