RFR: 8253064: monitor list simplifications and getting rid of TSM [v6]

Coleen Phillimore coleenp at openjdk.java.net
Wed Nov 11 13:53:08 UTC 2020


On Wed, 11 Nov 2020 05:11:10 GMT, David Holmes <dholmes at openjdk.org> wrote:

>> Daniel D. Daugherty has updated the pull request incrementally with one additional commit since the last revision:
>> 
>>   resolve more robehn and coleenp comments.
>
> src/hotspot/share/runtime/synchronizer.cpp line 246:
> 
>> 244: //
>> 245: // Start the ceiling with the estimate for one thread:
>> 246: jint _in_use_list_ceiling = AvgMonitorsPerThreadEstimate;
> 
> Why is this a jint when you use size_t for its accessor and all the other sizes that you compare with the ceiling are also size_t?
> I'm not sure size_t is right to use in these cases (do we really expect different maximums on 32-bit versus 64-bit?) but it should be all or none IMO.

Our int types are really confused.  AvgMonitorsPerThreadEstimate is defined as an intx which is intptr_t and the range of it is 0..max_jint which is 0 .. 0x7fffffff . jint is long on windows (the problematic type) and int on unix.  Since this is a new declaration, it probably should be something other than jint but what?
At any rate, it should be declared as 'static'.

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

PR: https://git.openjdk.java.net/jdk/pull/642


More information about the hotspot-dev mailing list