RFR(s): 8077415: Remove duplicate variables holding the CollectedHeap

Stefan Karlsson stefan.karlsson at oracle.com
Wed Apr 15 08:39:28 UTC 2015



On 2015-04-15 10:13, Per Liden wrote:
> Hi Kim,
>
> On 2015-04-13 18:13, Kim Barrett wrote:
>> On Apr 13, 2015, at 11:55 AM, Per Liden <per.liden at oracle.com> wrote:
>>>
>>> Good point. I wouldn't mind using FakeRtti here, but I'd like us to 
>>> massage its interface a bit first. My main concern is that using it 
>>> today requires a fair bit of ceremony. But let me continue that 
>>> discussion in a separate mail thread, where I can expand a bit more 
>>> on what I'm thinking.
>>
>> Sure.  Some of the ceremony might be just to support some of the 
>> strangeness in current BarrierSet usage, some of which really ought 
>> to be done differently.  I’ll be interested to see what you suggest.
>>
>>> For now I'd like to just do the kind() check before the cast, to 
>>> avoid doing something with undefined behavior, like this:
>>>
>>> G1CollectedHeap* G1CollectedHeap::heap() {
>>>   CollectedHeap* heap = Universe::heap();
>>>   assert(heap != NULL, "Uninitialized access to 
>>> G1CollectedHeap::heap()");
>>>   assert(heap->kind() == CollectedHeap::G1CollectedHeap, "Not a 
>>> G1CollectedHeap");
>>>   return (G1CollectedHeap*)heap;
>>> }
>>>
>>> Ok?
>>
>> Yes.
>
> Great, here's an updated webrev:
> http://cr.openjdk.java.net/~pliden/8077415/webrev.1/
>
> And a diff against the initial webrev:
> http://cr.openjdk.java.net/~pliden/8077415/webrev.1-diff_0vs1/

Looks good.

StefanK

>
> cheers,
> /Per




More information about the hotspot-gc-dev mailing list