RFR: 8293416: ZGC: Set mark bit with unconditional atomic ops [v2]

hev duke at openjdk.org
Tue Sep 6 11:01:08 UTC 2022


> **Summary**
> Support to set ZGC mark bit with unconditional atomic ops.
> 
> **Motivation**
> ZGC currently modify mark-bitmap by a conditional atomic operation (cmpxchg). This way is not optimal, which will retry the loop when cmpxchg fails.
> 
> **Description**
> First, This patch-set add an new unconditional atomic operation: Atomic::fetch_and_or, which is implemented in different ways for different CPU architectures:
> 
> * Exclusive access: Non-nested loop
> 
> 
> retry:
>   ll old_val, addr
>   or new_val, old_val, set_val
>   sc new_val, addr
>   beq retry
> 
> 
> * Atomic access: One instruction
> 
> 
> ldset old_val, set_val, addr
> 
> 
> * Generic: Fallback to cmpxchg or use c++ __atomic_fetch_or
> 
> **Testing**
> * jtreg tests
> * benchmark tests

hev has refreshed the contents of this pull request, and previous commits have been removed. The incremental views will show differences compared to the previous content of the PR. The pull request contains one new commit since the last revision:

  8293416: ZGC: Set mark bit with unconditional atomic ops

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

Changes:
  - all: https://git.openjdk.org/jdk/pull/10182/files
  - new: https://git.openjdk.org/jdk/pull/10182/files/5e580f44..016ee1f1

Webrevs:
 - full: https://webrevs.openjdk.org/?repo=jdk&pr=10182&range=01
 - incr: https://webrevs.openjdk.org/?repo=jdk&pr=10182&range=00-01

  Stats: 2 lines in 1 file changed: 0 ins; 0 del; 2 mod
  Patch: https://git.openjdk.org/jdk/pull/10182.diff
  Fetch: git fetch https://git.openjdk.org/jdk pull/10182/head:pull/10182

PR: https://git.openjdk.org/jdk/pull/10182


More information about the hotspot-dev mailing list