<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/90956>90956</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
ld.lld rejects a pass plugin's command line options before loading the plugin
</td>
</tr>
<tr>
<th>Labels</th>
<td>
lld
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
byron-hawkins
</td>
</tr>
</table>
<pre>
In the `lld` ELF driver, command line options parsing completes before pass plugins are loaded. It is impossible to even run the provided [`Bye.cpp`](https://github.com/llvm/llvm-project/blob/main/llvm/examples/Bye/Bye.cpp) pass, because there is no way to provide its activation option `--wave-goodbye`.
The ELF driver parses the command line [early in `LinkerDriver::linkerMain`](https://github.com/llvm/llvm-project/blob/2933ef2da9103122a52066a1c680046d1bdacaed/lld/ELF/Driver.cpp#L630C3-L630C10), but does not load plugins until the LTO backend, invoked [at the end of `LinkerDriver::linkerMain`](https://github.com/llvm/llvm-project/blob/2933ef2da9103122a52066a1c680046d1bdacaed/lld/ELF/Driver.cpp#L658C5-L658C15). So command line options provided by plugins ([such as in the provided example](https://github.com/llvm/llvm-project/blob/bcdbd0bf50a3845130c5db9e3284f056233f12d7/llvm/examples/Bye/Bye.cpp#L11)) can never be taken into account.
There are several possible resolutions, such as loading plugins earlier (while perhaps still invoking the plugin API later), or saving unrecognized command line options and waiting for plugins to load before concluding that an option is invalid.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzUlV-P6yYTxj8NuRklwmA78YUv9s-JtFJevZV6vsAA44QuAQtwtumnryC72XPUU6nVueoNSPZgnvnNM2NMyR490ci6R9Y9r3DJpxBHdY3Br0_49mp9WqlgruOLh3wiYD13zrCew5fDHky0F4pMPIEO5zN6A856gjBnG3yCGWOy_lhezo4yJVA0hUgwY0owu-VofQKMBC6gIbOBlww2gT3PISWrHEEOQBfyEJfb_XMMF2vIQBHc88crbfQ8s56z7pmJ3SnnOTH5wMSeif3R5tOiNjqcmdg7d_nY1nMMv5HOTOyVC4qJ_Rmt_4yh37EITkzsH690W-s1YqjSS8KKNC6JiqhIRbQP8IbXIvhdI9icAHW2Fyw43qkUguv1G15ofQzBqCuxnm-A8WfGH27r1xN9Q7dSpFSz_44y6x4Jo7uCrR89WP9K8flWEfnA5IOrT_5XUvtZPmKQkiZhcGi4bITATvC-x0b3O87b3jTKoEYy9QNl_XIoF9zU3NDJQy_5k1zXreFMDBXjksEEKvhydcHdFovP1tWsD1__Dwr1K3lTjlh_Ca83B2CuAeQNhOk_AqHbPXXrujUdE8MGfg1_0z0fVlfXOxQmdqx7TIs-AaZS-O964t23P5el0kYZrqaOo9y1XSO57owaSIpdO_GuF1JOjTDbf9Iu8tA0tdADaPTgqfhZEWR8JQ_W5wCodVh8_ksHRKqDIZUj6OA-ECKl4JZKqJjhA0WxThk1H6BKZ1iKBdjbyTqCmeIJ5wQpW-duHirxlV89Aw-_vIDDXOZZtWaIkPBSghYfSYejt3-Q-XGtyoM3tLlETyHeZeRwM_X73NPBa7eY28WYAe9ToUw9f0FnzWZlRmkGOeCKxmbbtFvZdtt2dRr7SXcksd8207QVsjVaT53aDZ3cciO3uLKj4KLlHZdNwwfRb7p2EnrgQu8GIfl2YC2nM1q3KZXbhHhc2ZQWGgc-dP3KoSKX6q9AiOpgUf4JcaxGUcsxsZY7m3L6PJ9tdjQ6s3HOQKRipQT47YBnYpt-DO0dykfpPkuxWqIb_7V_ayrFhDWbPwMAAP__X91ApA">