-
Notifications
You must be signed in to change notification settings - Fork 128
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ILLinker removes type forwarders when they are still needed #628
Comments
cc @sbomer |
Here's what the linker is doing that causes this. During the sweep phase:
It's generally expected that "copyused" assemblies will end up with references to removed types in other assemblies. However what's unexpected here is that the "copyused" assembly itself has exports removed. At least IMO "copyused" should mean that all exports are kept (even to types in removed assemblies). On the other hand, we already remove assemblyrefs from "copy" assemblies (but not "copyused" assemblies, I think - this seems like a bug), so maybe we should also remove unused exports. I'd like to be more clear about what we want "copy" and "copyused" to mean. Clearly we are already modifying such assemblies in some cases. We need to modify used typerefs to removed forwarders at least. @marek-safar:
|
How we handle various combinations of AssemblyAction's is kind of a mess. If you start writing tests with various combinations of code behaviors and assembly actions is not hard to run into results that make you as "does this make sense? Or is this a bug?
I don't recall exactly why the linker does this. I can say that for our use cases, after linking, we don't want any missing things. No references to assemblies that are gone or types that don't resolve. The current behaviors do help us achieve this. What if instead of keeping around references to assemblies that are gone, or exported types that won't resolved, we
|
I think this would be confusing - for .NET Core at least we are trying to reduce size and number of files, and seeing empty shells for unused assemblies wouldn't be great.
I think marking them might be too much. I'd expect that rooting an assembly would mark all TypeForwards in it, but to me it seems useful to have the ability to set the action to "copy" and have it keep the assembly (with the TypeForwards) without necessarily marking all of them. |
I cleaned up the copy/save handling with forwarders but they are not enough to control the process. We also have |
To repro:
Crossgen will emit warnings. They are due to missing types. Here's an example:
System.Console.dll has a type SyncTextReader. The base type for it is TextReader, which is declared as a forwarded type in System.Runtime.Extensions.dll, and really lives in System.Private.Corelib.dll
After linking, the linked System.Runtime.Extensions.dll doesn't have the TextReader forwarder anymore, causing crossgen to fail to compile type SyncTextReader when compiling System.Console.dll, because it can't find type TextReader.
Note: crossgen will emit a warning and move on when it fails to compile a type/method. At runtime, if we hit a codepath that causes the typeloader to load a type through these type forwarders, it would most likely throw exceptions)
The text was updated successfully, but these errors were encountered: