-
Notifications
You must be signed in to change notification settings - Fork 2
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
Allow to filter/opt-in assemblies by name via MSBuild property #30
Comments
The optimizer will actually only transform methods in the main project assembly where the build task was imported, dependencies and cross-assembly opts are yet to happen. The There's currently the <DistilExtraArgs>--filter !ClassName::MethodName|MethodName2|get_*</DistilExtraArgs> Also, I think the SO (stack overflow?) crashes might be due to methods with stackallocs being inlined, there are no checks for these yet. (There are some weird gotchas with stackallocs that might lead to other codegen issues. I think it'd be best to completely skip parsing methods with them as a quick workaround, since there isn't much DistIL can do for them anyway atm.) |
Interestingly enough, the crash happens not in the application code itself but in the linker on project publish, which is why I assumed DistIL touches its code. Not sure how to go about troubleshooting it aside from examining IL. The next culprit is optimizations applied to source-generated System.Text.Json code. |
I'd be interested in taking a look if you have a repro available. I suppose the fuzzy bisect script would be very helpful in narrowing down to the methods leading to this issue, I guess it wouldn't be too hard to hack it around the csproj. |
Let me try to repro with a new update first :) |
It appears that the current way the build task works is somewhat "all or nothing" - either annotate individual methods with
[Optimize]
or press the big red button and add<DistilAllMethods>
.Turns out the latter completely breaks ILLink on Linux in an otherwise seemingly working application (with what is likely a runaway inlining scenario causing SO).
It would be nice to have a more granular way to choose what to optimize with opt-in and/or opt-out properties in csproj. Alternatively,
[Optimize]
could be made applicable toassembly
instead.The text was updated successfully, but these errors were encountered: