does C1+CMS miss a storestore membar in jdk8u-shenandoah?
Doerr, Martin
martin.doerr at sap.com
Thu Dec 12 09:36:51 UTC 2019
Hi lx,
seems like the following issue should get backported:
https://bugs.openjdk.java.net/browse/JDK-8135018
Btw. I believe PPC is fine because C1 is not supported in 8u (at least not in the official repo).
Best regards,
Martin
> -----Original Message-----
> From: jdk8u-dev <jdk8u-dev-bounces at openjdk.java.net> On Behalf Of Liu
> Xin
> Sent: Donnerstag, 12. Dezember 2019 08:40
> To: aarch64-port-dev at openjdk.java.net; ppc-aix-port-
> dev at openjdk.java.net; jdk8u-dev at openjdk.java.net
> Subject: does C1+CMS miss a storestore membar in jdk8u-shenandoah?
>
> Hi, Aarch64 & PowerPC community,
>
> I think this is only for arm and ppc because only they are use relaxed
> memory ordering. x86 and sparc use TSO so storestore membar doesn't
> matter
> for them. please correct me if I am wrong.
>
> I feel that C1's
> LIRGenerator::CardTableModRef_post_barrier(c1_LIRGenerator.cpp) misses
> a
> storestore membar for CMS on jdk8u. Could you review my observation? If I
> am right, I'd like to file a bug and fix it.
>
> One reference is oop.inline.hpp. CMS uses the following function:
> template <class T> inline void oop_store(volatile T* p, oop v)
> It will emit a write_mem_barrier before cardTable updates.
>
> Another reference is C2 code. GraphKit::write_barrier_post generates
> storeCM for CMS.
> // Smash zero into card
> if( !UseConcMarkSweepGC ) {
> __ store(__ ctrl(), card_adr, zero, bt, adr_type, MemNode::release);
> } else {
> // Specialized path for CM store barrier
> __ storeCM(__ ctrl(), card_adr, zero, oop_store, adr_idx, bt, adr_type);
> }
>
> Actually, it's not only C1 has this bug. Template interpreter has this
> problem too. It only happens for aarch64. do_oop_store in
> templateTable_aarch64.cpp doesn't have any membar for CMS. By contrast,
> ppc64 does have a membar(StoreStore).
>
> (macroAssembly_ppc.cpp)
>
> // Write the card table byte.
> void MacroAssembler::card_table_write(jbyte* byte_map_base, Register
> Rtmp,
> Register Robj) {
> assert_different_registers(Robj, Rtmp, R0);
> load_const_optimized(Rtmp, (address)byte_map_base, R0);
> srdi(Robj, Robj, CardTableModRefBS::card_shift);
> li(R0, 0); // dirty
> if (UseConcMarkSweepGC) membar(Assembler::StoreStore);
> stbx(R0, Rtmp, Robj);
> }
>
> I also check the jdk11 and jdk14, c1 and template interpreter both
> consider concurrent_scanning case. please check out the following
> functions. so only jdk8u is at risk.
> CardTableBarrierSetC1::post_barrier
> CardTableBarrierSetAssembler::store_check
>
> thanks,
> --lx
More information about the jdk8u-dev
mailing list