On 2019-01-18 3:45 a.m., Richard Biener wrote:
> On Thu, Jan 17, 2019 at 8:16 PM Michael Ploujnikov
> <michael.ploujni...@oracle.com> wrote:
>>
>> Hi,
>>
>> I've been doing some investigations that required using a bitmap to keep 
>> track of decl IDs and I ran into segmentation fault after my bitmap has been 
>> loaded from a PCH. Attached is a short patch that can reliably reproduce my 
>> problem. Looks like head->current is set to point to uninitialized memory 
>> for some reason. Could someone with a strong understanding of GGC take a 
>> look and let me know what I might be doing wrong and how to fix this?
> 
> If you're just doing investigation why do you care about PCH?

My idea is to write a patch that does something similar to this, but not 
exactly (obviously not storing all of the object IDs for example). It's very 
preliminary and I don't know about the feasibility of what I'm trying to do, 
but I do know that I need a bitmap/hash_set for the full duration of 
toplev::main which inevitably involves PCH. However because of this segfault I 
haven't been able to actually try my idea yet!

> 
> In any event I guess that bimaps are not supported by PCH because of
> GTY(skip)ing the bitmap_head current member (so that's not saved).
> I guess PCH writers/readers need to ignore skipping.

Why is the current member not saved? I know the documentation says that another 
pointer in the chain already points to the same thing, but what's the harm in 
not skipping it?


- Michael

Attachment: signature.asc
Description: OpenPGP digital signature

Reply via email to