RFR: 8260309: Shenandoah: Clean up ShenandoahBarrierSet [v3]

Roman Kennke rkennke at openjdk.java.net
Mon Feb 1 11:00:59 UTC 2021


> We collected some cruft in ShenandoahBarrierSet. Time to clean it up. 
> 
> This fixes/removes a number of includes, fixes some comments and it also removes is_a() and is_aligned() which look like leftovers/requirements from earlier incarnations of the superclass BarrierSet. Using the override keyword would be useful for such situations (btw, are we ok to start using override, nullptr, auto etc in Shenandoah, or do we want to keep it C++ for backporting ease?)
> 
> One thing I was not sure about is the ShenandoahHeap* _heap field. Making it const will likely help the compiler avoid repeated access (e.g. in a number of perf-critical paths like the LRB impl). However, maybe we should get rid of the field altogether and make it explicitely using ShenandoahHeap::heap() and avoid repeated access instead of helping the compiler and hoping for the best?
> 
> Testing:
>  - [x] hotspot_gc_shenandoah release, fastdebug

Roman Kennke has updated the pull request incrementally with one additional commit since the last revision:

  Include accessBarrierSupport.inline.hpp instead of accessBarrierSupport.hpp

-------------

Changes:
  - all: https://git.openjdk.java.net/jdk/pull/2202/files
  - new: https://git.openjdk.java.net/jdk/pull/2202/files/bd7da1e2..5f68a73b

Webrevs:
 - full: https://webrevs.openjdk.java.net/?repo=jdk&pr=2202&range=02
 - incr: https://webrevs.openjdk.java.net/?repo=jdk&pr=2202&range=01-02

  Stats: 1 line in 1 file changed: 0 ins; 0 del; 1 mod
  Patch: https://git.openjdk.java.net/jdk/pull/2202.diff
  Fetch: git fetch https://git.openjdk.java.net/jdk pull/2202/head:pull/2202

PR: https://git.openjdk.java.net/jdk/pull/2202



More information about the hotspot-gc-dev mailing list