<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/65855>65855</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[lld-link] Failures/crashes due to dropping referenced empty sections for x86_64-pc-windows-msvc
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
danielframpton
</td>
</tr>
</table>
<pre>
Linking the object compiled from `zst.ll` (see IR below) with `libcmt.lib` for the `x86_64-pc-windows-msvc` target fails with:
```
lld-link: error: relocation against symbol in discarded section: nothing
>>> referenced by zst.o:(pointer_to_nothing)
```
This is because we drop empty sections (as necessary for a valid PE) but do not handle the case where there are references into that section.
This is a minimized reproduction from a Rust program that hit this issue when an array constructed using linker sections was empty. In that case the only reference (after `/opt:ref`) was from debug info and so the linker crashes writing debug information where we were trying to compute the offset of a global and the section was null:
```
lld-link: llvm-project/lld/COFF/PDB.cpp:1145: llvm::pdb::BulkPublic createPublic(lld::coff::COFFLinkerContext&, lld::coff::Defined*): Assertion `os && "all publics should be in final image"' failed.
...
#9 0x00007f32c4984e96 (/lib/x86_64-linux-gnu/libc.so.6+0x39e96)
#10 0x00005622018608a0 createPublic(lld::coff::COFFLinkerContext&, lld::coff::Defined*) llvm-project/lld/COFF/PDB.cpp:1145:27
#11 0x0000562201860ef1 (anonymous namespace)::PDBLinker::addPublicsToPDB()::'lambda'(lld::coff::Symbol*)::operator()(lld::coff::Symbol*) const llvm-project/lld/COFF/PDB.cpp:1224:24
#12 0x0000562201865dbc void lld::coff::SymbolTable::forEachSymbol<(anonymous namespace)::PDBLinker::addPublicsToPDB()::'lambda'(lld::coff::Symbol*)>((anonymous namespace)::PDBLinker::addPublicsToPDB()::'lambda'(lld::coff::Symbol*)) llvm-project/lld/COFF/SymbolTable.h:119:5
#13 0x0000562201860fb2 (anonymous namespace)::PDBLinker::addPublicsToPDB() llvm-project/lld/COFF/PDB.cpp:1228:21
#14 0x00005622018639e9 lld::coff::createPDB(lld::coff::COFFLinkerContext&, llvm::ArrayRef<unsigned char>, llvm::codeview::DebugInfo*) llvm-project/lld/COFF/PDB.cpp:1610:22
#15 0x00005622017c49fb (anonymous namespace)::Writer::run() llvm-project/lld/COFF/Writer.cpp:694:15
#16 0x00005622017c2d88 lld::coff::writeResult(lld::coff::COFFLinkerContext&) llvm-project/lld/COFF/Writer.cpp:323:55
#17 0x000056220173d7df lld::coff::LinkerDriver::linkerMain(llvm::ArrayRef<char const*>) llvm-project/lld/COFF/Driver.cpp:2532:17
#18 0x000056220172a077 lld::coff::link(llvm::ArrayRef<char const*>, llvm::raw_ostream&, llvm::raw_ostream&, bool, bool) llvm-project/lld/COFF/Driver.cpp:77:20
#19 0x00005622016fc19f lld::unsafeLldMain(llvm::ArrayRef<char const*>, llvm::raw_ostream&, llvm::raw_ostream&, llvm::ArrayRef<lld::DriverDef>, bool) llvm-project/lld/Common/DriverDispatcher.cpp:164:11
#20 0x00005622015d08dc lld_main(int, char**, llvm::ToolContext const&) llvm-project/lld/tools/lld/lld.cpp:92:27
...
```
`zst.ll`:
```
target triple = "x86_64-pc-windows-msvc"
@nothing = internal constant <{}> zeroinitializer, section ".nothing", align 1
@pointer_to_nothing = internal constant <{ ptr }> <{ ptr @nothing }>, align 8
define dso_local i32 @main() {
start:
ret i32 0
}
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzEWNFv274R_mvol0MMibJk6cEPTpwABTos6ArsMaDIk8WVIgWSiuP-9QMp2bFddWmGDb_CaCzpePfddx9PPDPn5F4jbkh-T_Ldgg2-NXYjmJaoGsu63hu9qI04br5K_UPqPfgWwdT_Qu6Bm66XCgU01nRAiuSn80ulSJEAoaVDhC_foEZlDoRWcJC-DUZK1rzzSyXrYNgYG12SInkri5diddfzu4PUwhzcXedeeTDyzO7RQ8OkctEPybYk2ZFkS4pk-sRLpcSdkvoHybaA1hobvlhUhjMvjQa2Z1I7D-7Y1UaB1CCk48wKFOCQB5uwQhvfSr2fQmSP4wcsNmhRcxRQHyEkawIQWvZGao_2xZuX01JazQL83koH0kGNnA0O4YAgrOkBu94fTxBcoI850MjROWaPkSUGr0xJAc-Pgc168CBMQAot00JhZJGz4LNFGy8tArP4DtuB1N6Ab5k_hVpOKK_AMeiklp38iQIs9taIIRqPdWbwbXAeemv2lnWjt1Z68ONqN0QEGpgGZi07AjfaeTtwjwIGFzQUSoT2Pd0DcyMDS_iiR48xk6g1rY7vKURmGo82CIbQJ9N7km0tNvGyip4iSoH1sAepGwNMC3AmOpsCc8tciw4OVvqA593YdqNQRg4P4RO4tMcofRMlP_gJWdM49GAaYLBXpmYqhgqPpswiHD0o9a7Xj1Sr1Gt311sTNhihT0oJQp8e_v70ROjT8-5-yfueZNs0XeUn6-A72_aiHr_cD-rH81AryYFbZB7HC0LL4CuacNM047fg-Gvk5MFoj2-e0ILQB5gx3WEjNQpCt0Hb2Ra2zqGNWZIiMUGzBaEFEEqZUtDHqA5cawYloMaw2RqpmQLZsT0SSgldxy2N4kqFcP63XC5vbxGaVZC8JUmSrJuM8lVVrrAKUcvAlqwJfZr6iJJ6eLvb62F8wJfOLAtC75O3rMKqOO_QK-dpMnnPC0qTtCySkiX_RyI_V2-6noOc3kLGJo37RBt97MzgQLMOXc84jqUj2fZ5dz_CHS-ZEGN27rt53t1HNidLQteKdbVghK7nc_9HbKZnYZBsa3q0zBs7-flw1dgi_pQLSleBi9UcF_SGi1zUHF6NFHOVGCF8Z7XC8UZj7CPj7QQte_jLSHyMi_-a4B-I8oK0ZRulGcLkc8XIboXZ1PR_Icw_F0oZhJLOYVvdYAs9YU4j09aPoT-170-NeRvegd-wIdnDoONpSwBvmY1FvjTkRuCrxMOpS9TD_otuzOf6RJEmIWU6pRwyza8yXfNV1dQfVeGfVvpTCeyg_4D2ccUEo6jCDk1nRVHcwKGiLOeID-9m_IZuUP4z1H8CZUazoNxZlOtrlJlYi2YO5QhgZ-Xria7xiPE3JnWEPSODUP2x44XaZo8fgR69T6BpntHA7eyboLxGTVmyXs-hjoeNP0Z3KVLLDi_GeYus-0Xpvz6rTegqp7-fyHK9DqkmFyqurlIrGp5WFwUZtGMNflXic7z_95nNBjjDGXPZhZuPH-dvus7oMwM76XrmeXvmIi3iZprrYvT6tJKLpBQ8sPLSjTxI7UP82G9CH9leY_9ujJo2z4mY328hb4xy5yulxISvopcnk_OZ7eaMe755nhF_N8NNw563slcIJNuFI-VvZsNTo5v-XyXT-BWXxZksHDhjakx7CK_09T1Z78I09xOtkVp6yZT8iTYwczq2E0qX50GOhidMyb2G9Bzn14nvP4aE3luY4l7euQAcH76HKi8TE_HICMKZlzDKKpAZDYunKoeShbyirfPM-jO3ABZ9ND_VYb1biE0mqqxiC9ykRbWiJU2yfNFual4Xab5ieZlWGS0FY7xMaJ3xhGZpneJCbmhCs6RKqnSdZ3m-rFdC5JSXWFTY8JKRVYIdk2oZFLQ0dr-IA-GmyMs8XyhWo3LxtwZKNR7GaTEwnO8WdhNVVw97R1aJks67dy9eehV_pDiPSvkOnphUg8WgydNAJwYMU1oYqfvA6sXEfjNhh4l6XlSLwapN633v4tkp9Ka99O1QL7npovJfT38u9khMJUCJqf47AAD__5KgNj8">