-
Notifications
You must be signed in to change notification settings - Fork 4.8k
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
Fix GetModuleFileName in GetProcessPath #110888
Conversation
Ideally, we would have a test for this. Unfortunately, it is not easy to build one because of other issues in the end-to-end handling of longs paths (#58492). Have you done ad-hoc testing for this? Does the API return the path with or without |
Does there need to be a bound to prevent integer overflow? It would cause infinite loop again if path length exceeds 2^30, which is unlikely to happen in any situation. |
I do not think it would lead to infinite loop. |
That's interesting, in my manual test in #110800 using PInvoke to call |
Seems like there is an opportunity for consolidation here, as logically the control wouldn't reach this point if the runtime/corehost initialization had this logic flawed; so corehost (and only corehost) is doing it right. Maybe it's better to delete calls from all these places:
(there maybe others) in favor of runtime/src/native/minipal/getexepath.h Line 67 in 2eb59bf
hostmisc/pal.windows.cpp . After that, use this minipal_getexepath() as we do on unix repo-wide (and windows+unix on mono).
|
I think that all shipping code is fine, except
Note that some of these places want paths for arbitrary modules. For managed implementations on Windows, we tend to avoid the native shims and call the OS APIs directly from C#, even if it means a bit of duplication. This change LGTM. Number of end-to-end scenarios with process long paths do not work, but that's tracked by other issues. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks!
/ba-g DeadLetterered linux-arm32 Helix queue, testing not relevant to this change. |
Fixes #110800