<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/107346>107346</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
lld-link not respecting /NODEFAULTLIB with a conflicting /DEFAULTLIB
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
Windows10CE
</td>
</tr>
</table>
<pre>
I'm trying to use lld-link to link [C# NativeAOT](https://learn.microsoft.com/en-us/dotnet/core/deploying/native-aot/) apps targeting Windows on Linux, the tooling for which generates an rsp for link.exe that looks something like this:
```
"obj/Release/net8.0/win-x64/native/Hello.obj"
/OUT:"bin/Release/net8.0/win-x64/native/Hello.exe"
/DEF:"obj/Release/net8.0/win-x64/native/Hello.def"
"/home/aaronr/.nuget/packages/runtime.win-x64.microsoft.dotnet.ilcompiler/8.0.7/sdk/bootstrapper.obj"
"/home/aaronr/.nuget/packages/runtime.win-x64.microsoft.dotnet.ilcompiler/8.0.7/sdk/Runtime.WorkstationGC.lib"
"/home/aaronr/.nuget/packages/runtime.win-x64.microsoft.dotnet.ilcompiler/8.0.7/sdk/eventpipe-disabled.lib"
"/home/aaronr/.nuget/packages/runtime.win-x64.microsoft.dotnet.ilcompiler/8.0.7/sdk/Runtime.VxsortEnabled.lib"
"/home/aaronr/.nuget/packages/runtime.win-x64.microsoft.dotnet.ilcompiler/8.0.7/sdk/System.Globalization.Native.Aot.lib"
"/home/aaronr/.nuget/packages/runtime.win-x64.microsoft.dotnet.ilcompiler/8.0.7/sdk/System.IO.Compression.Native.Aot.lib"
"advapi32.lib"
"bcrypt.lib"
"crypt32.lib"
"iphlpapi.lib"
"kernel32.lib"
"mswsock.lib"
"ncrypt.lib"
"normaliz.lib"
"ntdll.lib"
"ole32.lib"
"oleaut32.lib"
"secur32.lib"
"user32.lib"
"version.lib"
"ws2_32.lib"
/NOLOGO /MANIFEST:NO
/DEBUG
/INCREMENTAL:NO
/SUBSYSTEM:CONSOLE
/ENTRY:wmainCRTStartup /NOIMPLIB
/NATVIS:"/home/aaronr/.nuget/packages/microsoft.dotnet.ilcompiler/8.0.7/build/NativeAOT.natvis"
/NODEFAULTLIB:libucrt.lib
/DEFAULTLIB:ucrt.lib
/OPT:REF
/OPT:ICF
```
(all I do with this is pass it into lld-link with -flavor link and paths to the vctoolsdir and winsdkdir that I have locally)
Based on some debugging, lld-link seems to be ignoring the `/nodefaultlib:libucrt.lib` and linking it anyway due to dependencies on libcmt.lib, which contains the directive `/defaultlib:libucrt.lib` and "overrides" the nodefaultlib given in the rsp, contrary to what the docs for these parameters say should happen. This causes there to be duplicate symbols with an output that does not work.
Deleting/renaming libucrt.lib so it cannot be found to be linked solves the problem and makes everything work, but I would much prefer to not have to do that.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzEVt9v4j4S_2vMy4goNYXCAw-Ukh5SC6tCd7VPJyceEi-ObdlOKPfXn2zSX7B3392XXakq8sx4Ph_PTGaGOSdKhTglw1syvOuxxlfaTr8JxfXBXaXzRS_X_DhdEnpTg7dHoUrwGhqHICXvS6H24Rx_yfB2TugAVsyLFmfrLRneETquvDeODGaEZoRmEplVSS0Kq53e-aTQNaEZqn7jCM249go9oVmhLYYzGqkDKKGZim77TPvoaQLMGAee2RJ9oNWRBq3gQajmhdA5-ArBay2DfqctHCpRVFCiQss8OmAKrDNRFZ6Q4AuCr5gHqfXegdM1-ipclmIfNCI-JL0j6YyM0u7vdKRU5z8IzZ5QInOBvEI_TlJCs4NQ_ZfR9dsbCM3-hVLqJN6grw6y9fM2xonmQv2mJ3zBj57uFtnJ0-9z4rj74IkSmlW6DmrGrFaW0CxRTRmTZFixZyWGxNlGeVFj0rn9kOBTShMhC10bITF4GCdpckNo5vie0CzX2jtvmTFoz0LyJ-CfurvftN07z7zQ6n6eSJH_YR7YovJGGOxz4Vgukf8FEq_B-PritPUL9bd4bI7OY53cS50zKf4Ts5KcGksy0_7vMVquk7mujUXn_j8lxltmxICey_PCHs2FdRReGgtTScOMOJfv0SqUl_a1Ozhd7M_F6qeYSts6BPdC7rmU50It8RJOS2TNT2g7LBp7KW4c_kTaoo2hPBMfHP33hXG2Wj-s79dAaPY4Wy2zxSZ0zNX6Q-O7fb5_Oy1X86fF42K1nT18Nts8326-b7aLRzKYzderzfph8aZbrLZP38lgdqiZUPOn7cYz6xsDEX35-OVheftOZ7b9utycWu0v1uCv1VzeCMkDwOssTRTzrXCfY3G3yGbPD9vAaDCTIm8Ke8ryhznwbnChXX8J0XtaZGeS5Tz7HzNuzKSEJXANB-GrOBBBODDMORAehAq7wOteEE36O8nabrwCUxwM85ULO0OYzW0RprPjwkbdQSjH9-EUh_ASKtYiSF0wKY-ETjoa8f8tc8jDsA9DGjjmTVnGRWH-zsAh1hErRxCl0jauLxVCeBLNlOa4Y430ISifAzhKI6HgJdwRHpg6HtgReBM2CuBoUHFUhcC4cUiRF3X3hc27NaPQyjOhXETkwmIRctlh_xNy-LpatFbwUDU0-vjIF0rRogKhosY6E3ADomX2GBgeQgQjsi5c3HB8hQ7BMMtq9GgdOHYEV-lGcqjC9FUJbENGC9Y4jLQtdtHjjZGiYB7BHetcS3fKLlOgG28af0oY1-hAaQ8HbffJKU93KON-FtovKlaftqm394LTIboFU-FejrDTjeIdagg_cnBatic-YKzOJdYxRDXbowNs0R5PS1pADWHIm1A7h_iwuikqMBZ3aIPTABKLKuRQR9YJ9Ph0wCeDCevh9OqGDofpiI5pr5oOJ4MrNh7cIOJ4jKNJOsqv-HDE6dWIpTRPe2JKU3qdTtJhOrgapzQZ5OmkuJ5MJmmRp-OCkesUayZkImVbJ9qWPeFcg9Or9GZwPepJlqN0cfumVOEBojZ85MO7np2GS_28KR25TqVw3r278cJLnL5VeniXRWdCjakSzrpDl6xQHzsp3kzeDXqNldPPi3opfNXk3X4eYLufvrH6Bxahq0Wyoad1r2mn9L8BAAD__yhL9Nc">