<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Thu, Sep 28, 2017 at 9:43 AM, Joerg Sonnenberger via cfe-dev <span dir="ltr"><<a href="mailto:cfe-dev@lists.llvm.org" target="_blank">cfe-dev@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hello all,<br>
I've been discussing this topic on #llvm with some of the regulars, but<br>
this merrits a wider audience. As you some of you might know, NetBSD<br>
allows doing a full release build with GCC in a reproducable way,<br>
including variations of the source locations. This is currently not<br>
possible with clang and I want to fix that. There are four identified<br>
primary points where absolute path names leak into the output:<br>
<br>
(1) .file<br>
(2) DWARF<br>
(3) __FILE__<br>
(4) __PRETTY_FUNCTION__ for lambdas etc<br>
<br>
We have -fdebug-prefix-map [-fdpm from here] for (2) with some<br>
limitations. I've created -iremap for GCC for (3) years ago, the patch<br>
is still in review limbo.  We don't have anything for (1) and (4) right<br>
now in clangland. I've started to write patches for that, but this is a<br>
bit messy as it tends to duplicate code. This made me want to step back<br>
and review whether we need/want many different switches in first place.<br>
I couldn't come up with a very good reason, but it has been mentioned<br>
that Facebook is using -fdpm for speakable hacks to get space into the<br>
binaries for patching in real patches. That seems to be abusive for me,<br>
even when I can somewhat understand the motivation.<br>
<br>
My proposal forward is:<br>
(1) Tighten the definition of -fdpm to mean prefix paths, i.e. the next<br>
character must be a path separator:<br>
  -fdebug-prefix-map=/foo=/bar should not change /foobar into /barbar<br>
(2) Introduce a new option -frewrite-path=src=dst and make -fdpm an<br>
alias of it. The translation applies to all four points above.<br>
</blockquote><div><br></div><div>These two SGTM. I also don't see why you'd want different path translations for the different kinds of data. Controlling it all with one flag seems like a very reasonable proposal. Suggestion: "-frewrite-source-path" may be a clearer name for the flag.</div><div><br></div><div><div>I'd also like to point out the (proposed, but not accepted) patch to GCC here to do something similar:</div><div><a href="https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00513.html">https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00513.html</a></div><div>Note that the discussion does continue in some of the later months too. If we decide to go for this, it would be nice to respond to the gcc thread saying what we're planning to do, in case they'd like to be compatible with it.</div><div> </div></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">(3) Introduce a new -gdwarf-path-padding=$n option to prefix all path<br>
names encoded in DWARF with $n path separators.</blockquote><div><br></div><div>This part sounds pretty horrible. =)</div><div><br></div><div>Even after the discussion on #llvm earlier, I still don't really understand why Facebook has a need to mangle dwarf paths in-place, instead of using a debugger source mapping feature.<br></div></div></div></div>