clang mangling some static struct names?

Navdeep Parhar nparhar at gmail.com
Mon Nov 19 00:01:46 UTC 2012


On Sun, Nov 18, 2012 at 02:37:11PM +0100, Dimitry Andric wrote:
> On 2012-11-16 23:04, Navdeep Parhar wrote:
> >On 11/16/12 13:49, Roman Divacky wrote:
> >>Yes, it does that. iirc so that you can have things like
> >>
> >>void foo(int cond) {
> >>   if (cond) {
> >>     static int i = 7;
> >>   } else {
> >>     static int i = 8;
> >>   }
> >>}
> >>
> >>working correctly.
> >
> >It's not appending the .n everywhere.  And when it does, I don't see any
> >potential collision that it prevented by doing so.  Instead, it looks
> >like the .n symbol corresponds to the nth element in the structure (so
> >this is not name mangling in the true sense).  I just don't see the
> >point in doing things this way.  It is only making things harder for
> >debuggers.
> 
> I don't think the point is making things harder for debuggers, the point
> is optimization.  Since static variables and functions can be optimized
> away, or arbitrarily moved around, you cannot count on those symbols
> being there at all.

I'd (maybe) buy your argument if the symbol wasn't there at all.  But
it's there, just with a .0 appended to it.  It hasn't been moved around
or optimized away.  In fact, in the case of scsi_low_statics the
compiler added extra noise to the binary (in the form of multiple
scsi_low_statics.[0-4] symbols that no one except the compiler knows
about).

There doesn't seem to be *any* good reason for adding the .n to the
symbols.  What is the optimization being attempted here?  I lost the
ability to look up some symbols in kgdb and I'd like to know what I
gained in the process :-)

Regards,
Navdeep


More information about the freebsd-hackers mailing list