<br><br><div class="gmail_quote">On Wed, May 5, 2010 at 2:52 PM, Eugene Toder <span dir="ltr"><<a href="mailto:eltoder@gmail.com">eltoder@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
Re having all fragments associated with some symbol -- this makes<br>
sense if you think in high level terms and assume all symbols to be<br>
some "objects". All data (fragments) you want to output is associated<br>
with some "object" (symbol). However, that's probably too high level<br>
thinking for MC interface. High level objects might not directly<br>
correspond to object-file level symbols.</blockquote><div><br></div><div>I agree with you one this, to me its a question of whose responsibility it is to determine the mapping, the compiler or the object file format. Another example would be labels, they are not high level objects in an of themselves, but must be represented as symbols in current object file formats.</div>
<div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;"> For example, module level<br>
inline assembler does not correspond to any symbol, or function may<br>
have more than one symbol when aliases are used.<br></blockquote><div><br></div><div>module level assembly could easily be dealt with as an unnamed symbol that the object file is free to not create a object-level symbol for (though the only context I can see a use for this I think it would still be useful to identity such code).</div>
<div> </div><div>When you say aliases, I assume you mean embedding object level symbol records pointing to the same high-level symbol. A high level symbol could easily report multiple names though its interface.</div><div>
<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<br>
Common is not .bss, it's an archaic concept inherited from Fortran. C<br>
language specifies that global uninitialized variables are put into<br>
common. This isn't for "programs that forget to use extern" -- you<br>
can't get the same behaviour with extern, common variables are glued<br>
together and with "normal" variables, so no object is exclusively owns<br>
the variable. There's also some subtle difference when linking<br>
archives.<br></blockquote><div><br></div><div>Thanks for the details of this, I will have to update my COFF writer to properly put these symbols into a COMDAT section, as I currently put them into .bss section with static linkage.</div>
<div><br></div><div>- Nathan</div></div>