-
Enhancement
-
Resolution: Fixed
-
P4
-
17, 18, 19
-
b21
Issue | Fix Version | Assignee | Priority | Status | Resolution | Resolved In Build |
---|---|---|---|---|---|---|
JDK-8286898 | 18u-cpu | Aleksey Shipilev | P4 | Resolved | Fixed | master |
JDK-8286591 | 18.0.2 | Aleksey Shipilev | P4 | Resolved | Fixed | b07 |
JDK-8286880 | 17.0.5-oracle | Tobias Hartmann | P4 | Resolved | Fixed | b01 |
JDK-8286592 | 17.0.4 | Aleksey Shipilev | P4 | Resolved | Fixed | b03 |
@Warmup(iterations = 5, time = 1, timeUnit = TimeUnit.SECONDS)
@Measurement(iterations = 5, time = 1, timeUnit = TimeUnit.SECONDS)
@Fork(1)
@BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS)
@State(Scope.Benchmark)
public class Synchronization {
@Benchmark
public Object blackhole() {
Object o = new Object();
synchronized (o) {}
return o;
}
}
...with JMH that enables compiler blackholes, shows that the synchronization for the object is eliminated by EA, because the object is deemed non-escaping. Blackholes do prevent scalar replacement, but not other optimizations made available by EA.
While this is not exactly a bug in compiler blackhole implementation, this diverts from the status quo of plain Java JMH blackholes: they were fully opaque for EA, that is the arguments were globally escaping. We should probably match that behavior to avoid surprises for users. See the real world sighting of the related EA-enabled optimization -- eliding constructor storestore barriers -- here: https://mail.openjdk.java.net/pipermail/jmh-dev/2022-April/003428.html
One can still get current compiler blackhole behavior by doing the non-inlined empty method like:
@Benchmark
public void dontinline() {
Object o = new Object();
synchronized (o) {}
sink(o);
}
@CompilerControl(CompilerControl.Mode.DONT_INLINE)
public void sink(Object o) {}
- backported by
-
JDK-8286591 C2: Compiler blackhole arguments should be treated as globally escaping
- Resolved
-
JDK-8286592 C2: Compiler blackhole arguments should be treated as globally escaping
- Resolved
-
JDK-8286880 C2: Compiler blackhole arguments should be treated as globally escaping
- Resolved
-
JDK-8286898 C2: Compiler blackhole arguments should be treated as globally escaping
- Resolved
- relates to
-
JDK-8259316 [REDO] C1/C2 compiler support for blackholes
- Resolved
- links to
-
Commit openjdk/jdk17u-dev/31eefe5e
-
Commit openjdk/jdk18u/15776b5b
-
Commit openjdk/jdk/5629c755
-
Review openjdk/jdk17u-dev/379
-
Review openjdk/jdk18u/118
-
Review openjdk/jdk/8228