1a4330d2a2
When performing a "fat" LTO the compiler has a whole mess of codegen units that it links together. To do this it needs to select one module as a "base" module and then link everything else into this module. Previously LTO passes assume that there's at least one module in-memory to link into, but nowadays that's not always true! With incremental compilation modules may actually largely be cached and it may be possible that there's no in-memory modules to work with. This commit updates the logic of the LTO backend to handle modules a bit more uniformly during a fat LTO. This commit immediately splits them into two lists, one serialized and one in-memory. The in-memory list is then searched for the largest module and failing that we simply deserialize the first serialized module and link into that. This refactoring avoids juggling three lists, two of which are serialized modules and one of which is half serialized and half in-memory. Closes #63349
7 lines
174 B
Plaintext
7 lines
174 B
Plaintext
warning: Linking globals named 'foo': symbol multiply defined!
|
|
|
|
error: failed to load bc of "lto_duplicate_symbols2.3a1fbbbh-cgu.0":
|
|
|
|
error: aborting due to previous error
|
|
|