RFR(S): 8015237: Parallelize string table scanning during strong root processing

John Cuthbertson john.cuthbertson at oracle.com
Fri May 24 22:19:51 UTC 2013


Hi Everyone,

Can I have a couple of reviewers look over these changes - the webrev 
is: http://cr.openjdk.java.net/~johnc/8015237/webrev.0/

Summary:
On some workloads we are seeing that the scan of the intern string table 
(among others) can sometimes take quite a while. This showed up on some 
FMW workloads with G1 where the scan of the string table dominated the 
pause time for some pauses. G1 was particularly affected since it 
doesn't do class unloading (and hence pruning of the string table) 
except at full GCs. The solution was to change the string table from 
being considered a single root task and treat similarly to the Java 
thread stacks: each GC worker claims a given number of buckets and scans 
the entries in those buckets.

Testing
Kitchensink; jprt; GC test suite. With all collectors.

Overhead:
Not real performance numbers but I did some measurement of the 
synchronization overhead of using 1 GC worker thread. They are 
summarized here:


	0-threads (ms)
	1-thread-chunked (ms)
Min 	0.200
	0.300
Max 	6.900
	8.800
Avg 	0.658
	0.794


These were from 1 hour long runs of Kitchensink with around ~2800 GCs in 
each run.

Thanks,

JohnC
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.openjdk.org/pipermail/hotspot-gc-dev/attachments/20130524/3380d8c4/attachment.htm>


More information about the hotspot-gc-dev mailing list