<html>
    <head>
      <base href="https://bugs.llvm.org/">
    </head>
    <body><table border="1" cellspacing="0" cellpadding="8">
        <tr>
          <th>Bug ID</th>
          <td><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - lld needs to set the link timeStamp on Windows builds, probably to a hash of the binary"
   href="https://bugs.llvm.org/show_bug.cgi?id=35914">35914</a>
          </td>
        </tr>

        <tr>
          <th>Summary</th>
          <td>lld needs to set the link timeStamp on Windows builds, probably to a hash of the binary
          </td>
        </tr>

        <tr>
          <th>Product</th>
          <td>lld
          </td>
        </tr>

        <tr>
          <th>Version</th>
          <td>unspecified
          </td>
        </tr>

        <tr>
          <th>Hardware</th>
          <td>PC
          </td>
        </tr>

        <tr>
          <th>OS</th>
          <td>Windows NT
          </td>
        </tr>

        <tr>
          <th>Status</th>
          <td>NEW
          </td>
        </tr>

        <tr>
          <th>Severity</th>
          <td>release blocker
          </td>
        </tr>

        <tr>
          <th>Priority</th>
          <td>P
          </td>
        </tr>

        <tr>
          <th>Component</th>
          <td>COFF
          </td>
        </tr>

        <tr>
          <th>Assignee</th>
          <td>unassignedbugs@nondot.org
          </td>
        </tr>

        <tr>
          <th>Reporter</th>
          <td>brucedawson@chromium.org
          </td>
        </tr>

        <tr>
          <th>CC</th>
          <td>llvm-bugs@lists.llvm.org
          </td>
        </tr></table>
      <p>
        <div>
        <pre>lld currently sets the link-time-stamp to zero, rather than to the link time,
in order to support reproducible builds (builds where the results depend only
on the inputs, not on the time or machine used to do the build).

This is a worthy goal but this solution to the reproducible build problem is
*not* practical. It will completely break symbol servers.

Symbol servers are a vital tool for Windows developers and they are used not
just to archive PDB files but also to archive PE files (.exe and .dll). The
format of the paths used is documented here:

<a href="https://randomascii.wordpress.com/2013/03/09/symbols-the-microsoft-way/">https://randomascii.wordpress.com/2013/03/09/symbols-the-microsoft-way/</a>

In particular note that the path for a PE file on a symbol server is generated
like this:

    ā€œ%s\%s\%s%s\%sā€ % (serverName, peName, timeStamp, imageSize, peName)

The peName and serverName can be considered to be unchanging which leaves the
timeStamp and imageSize to identify a particular binary. The imageSize is often
rounded to a page size so there are likely to be many similar builds which have
exactly the same page size.

So that leaves timeStamp as often the *only* differentiator between builds.
Therefore, setting the timeStamp field to a constant (zero or anything else) is
simply not tenable.

Starting with Windows 10 Microsoft has been creating reproducible builds which
is why the timeStamp field in Windows 10 binaries shows dates from seemingly
random years. The new implementation of this field is discussed here:

<a href="https://blogs.msdn.microsoft.com/oldnewthing/20180103-00/?p=97705">https://blogs.msdn.microsoft.com/oldnewthing/20180103-00/?p=97705</a>

Roughly speaking the timeStamp field now contains some sort of hash of the
binary. This needs to be a reasonably good hash in order to reduce the odds of
collisions. A cryptographically secure hash would be overkill, especially given
that the result has to be packed down into a 32-bit value.

It should be possible to use the same idea to generate the GUID/age field for
identifying the PDB, in order to avoid this source of non-determinism in
builds.

Using a hash for the timeStamp and GUID/age would be compatible with the
buildID concept on Linux.



Any versions of lld that ignore this are incompatible with symbol servers and
therefore incompatible with "real" Windows development.</pre>
        </div>
      </p>


      <hr>
      <span>You are receiving this mail because:</span>

      <ul>
          <li>You are on the CC list for the bug.</li>
      </ul>
    </body>
</html>