On Sat, 2 Nov 2024 00:02:42 GMT, Vladimir Ivanov <vaiva...@openjdk.org> wrote:
>> This patch remove access to the shared variable to fix scalability issue in >> the multithread environment. According to testing by the >> specjvm2008::crypto.rsa the one thread performance reduced for less than 1% >> while the score for the multithread run increased in ~2x. For the 2 socket >> system with Xeon 8480+ numbers looks as: >> • 1 thread: 643.15 for original version vs 642.54 for patched one; >> • 224 threads: 22446.19 for original vs 46147.41 for patched. >> The RSABench microbenchmark reports no score changes for the 1 thread >> (average for all testcases) and 2.4% improvement for the 224 threads. > > Vladimir Ivanov has updated the pull request incrementally with one > additional commit since the last revision: > > 8317538: Potential bottleneck in Provider::getService: > specjvm2008::crypto.rsa have scalability issue for high vCPU numbers I tested the change and there was a problem with the change in the non-open source test repo. ServiceKey cannot be transient and needs to allow serialization. I think looking at doing a ThreadLocal solution may be best that this point. ------------- PR Comment: https://git.openjdk.org/jdk/pull/21719#issuecomment-2471258099