[dmd-internals] How to avoid 4-word padding for symbols?

Michel Fortin michel.fortin at michelf.com
Mon Nov 8 09:29:25 PST 2010


Turns out it doesn't work because those symbols refer to each other, so by coalescing them in one symbol I'm creating a self-referenced symbol and the backend doesn't like that.

I resorted to adding a 'noalign' flag to outdata() in the backend. It's a small change and it works, but it feels like a hack. Ideally there should be a way to specify the alignment per segment (there might already be one, but I can't figure it out). Since the Objective-C stuff belongs to separate segments it'd make things really easy.

I know there is the 'align' parameter in mach_getsegment(), but it doesn't seem to have any effect other than changing alignment value for the section in the object file.


Le 2010-11-07 à 21:05, Walter Bright a écrit :

> Symbols are aligned when written out to the data segment.
> 
> To defeat the alignment, symbols that should be adjacent should be merged into one symbol.
> 
> Michel Fortin wrote:
>> It's probably a small thing that I'm missing, but I have a small problem where the code below causes undesired padding to be added between two symbols in the object file. This code writes 5 words to the object file:
>> 
>>    symbol = symbol_name(sname, SCstatic, type_fake(TYnptr));
>>    symbol->Sdt = dt;
>>    symbol->Sseg = objc_getsegment(SEGprotocol);
>>    outdata(symbol);
>> 
>> If you call it 2 times, it generates 5*2 + 3 padding bytes between the two (added dashes to show padding):
>> 
>> [25] 002d2 0034 000da6    0 0f94   2 10000000 00 00 __protocol __OBJC
>> 0000:   0  0  0  0  6  3  0  0  0  0  0  0  0  0  0  0   ................
>> 0010:   0  0  0  0 -0--0--0--0--0--0--0--0--0--0--0--0   ................
>> 0020:   0  0  0  0 36  3  0  0  0  0  0  0  0  0  0  0   ....6...........
>> 0030:   0  0  0  0                     ....            
>> This padding is causing a crash when starting the Objective-C runtime because it expects the two to be contiguous.
>> 
>> What needs to be changed to remove this padding?
>> 
>>  
> _______________________________________________
> dmd-internals mailing list
> dmd-internals at puremagic.com
> http://lists.puremagic.com/mailman/listinfo/dmd-internals

-- 
Michel Fortin
michel.fortin at michelf.com
http://michelf.com/





More information about the dmd-internals mailing list