<html><head><meta http-equiv="Content-Type" content="text/html charset=windows-1252"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">On Aug 27, 2013, at 11:35 AM, Shankar Easwaran <<a href="mailto:shankare@codeaurora.org">shankare@codeaurora.org</a>> wrote:<br><div><blockquote type="cite"><div bgcolor="#FFFFFF" text="#000000" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><div class="moz-cite-prefix">On 8/27/2013 12:45 AM, Nick Kledzik wrote:<br></div><blockquote cite="mid:C3178FDB-A019-4276-900A-489BE2C0C0C6@apple.com" type="cite"><pre wrap="">On Aug 26, 2013, at 10:20 PM, Shankar Easwaran wrote:
</pre><blockquote type="cite"><pre wrap="">Can we add deadStrip() to undefinedAtoms as well ?
This will enable to choose whether we want to set the property deadStripNormal or deadStripNever on them.
Also I think it will be cleaner for atoms to be added to deadStripRoot set using a single API.
</pre></blockquote><pre wrap="">Can you give more more background on this? When would you want and undef that causes the whatever defined atom replaces it to be never dead stripped?</pre></blockquote>We have these options<br><br>a) -entry <symbolname><br>b) -init <symbolname><br>c) -fini <symbolname><br><br>The atoms created for this shouldnot be dead stripped, as there is an explicit reference from the command line.<br></div></blockquote><div>Those should be added to LinkingContext’s initialUndefinedSymbols. Then we should change Resolver::deadStripOptimize() to add all initial undefines (along with deadStripRoots) to the dead strip roots. InitialUndefines are atom names that need to have an implementation, that means they should not be dead stripped. With that change in place, this half of your issue is solved.</div><br><blockquote type="cite"><div bgcolor="#FFFFFF" text="#000000" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><br>The other options such as<br><br>a) --defsym newsymbol = oldsymbol + 100<br>b) --wrap newsymbol<br><br>have the other effect that if there is no reference to the symbols<span class="Apple-converted-space"> </span><i>newsymbol, and __wrap_newsymbol,<span class="Apple-converted-space"> </span></i>the atoms are removed.<br></div></blockquote>Off hand, I’m not sure how to support —wrap in general. I can see having the command line object create an alias atom (scope=linkageunit) which is named newsymbol and references __wrap_newsymbol. But I don’t know how to model uses of __real_newsymbol. But there is nothing to dead strip here. Alias are zero size and making it scopeLinkageUnit means it won’t escape. So, I don’t see anything deadStrip wise that needs to handling here.</div><div><br><blockquote type="cite" dir="auto"><div bgcolor="#FFFFFF" text="#000000" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><br>Also rather than having the symbols seperately considered in the Driver, on whether we want to add to the deadStripRoot set or not, we can just use the attributes on the atom to place<span class="Apple-converted-space"> </span><br>them in the deadStripRoot set / not.<span class="Apple-converted-space"> </span><br><br>On the similiar lines, I think it should become an atom property itself (having absoluteAtoms also have this property set) ?</div></blockquote>Like aliases, AbsoluteAtoms have no size, so I don’t see what dead stripping them would gain.</div><div><br></div><div>-Nick</div><div><br></div></body></html>