Skip to content
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

Debug build crashing with 0xc0000374 (STATUS_HEAP_CORRUPTION) since update to WinAppSdk 1.5.X #9902

Closed
AMArostegui opened this issue Aug 13, 2024 · 5 comments
Labels
area-MRT This area only covers the usage of MRT inside of a WinUI 3 app area-Resources closed-Won'tFix Described behavior will not be fixed. needs-triage Issue needs to be triaged by the area owners team-Markup Issue for the Markup team

Comments

@AMArostegui
Copy link

AMArostegui commented Aug 13, 2024

Describe the bug

Since updating to WinAppSdk 1.5.X our application crashes with the above exception. As soon as I revert back to WinAppSdk 1.4.X or lower, it stops happening. We're on .NET 6 if that's important.

I've never seen it crashing on a release build so our customers won't be impacted, but it's a time sink since it happens very often for the developers. Out of 3 developers, one is not experiencing the problem.

Visual Studio won't trap the exception and the process suddenly stops, but I get a Windows event viewer entry and the excepction is logged in the output window. The debug build crashes no matter if Visual Studio is attached, or I run the executable on its own.

I've run the program with WinDbg and I'm sharing the callstack below. I've edited four frames for privacy reasons, the line that triggers the problem seems to be:

public const string ColorsDictionaryPath = "ms-resource:///Files/Styles/Colors.xaml";
(...)
ColorsDictionary = new ResourceDictionary { Source = new Uri(ColorsDictionaryPath, UriKind.RelativeOrAbsolute) };

If I click 'continue' WinDbg is able to swallow the exception and keep running, but it seems I cannot catch such exception in VS, it doesn't show in the exception list.

Steps to reproduce the bug

Not applicable

Expected behavior

Debug build should not crash

Screenshots

No response

NuGet package version

Windows App SDK 1.5.5: 1.5.240627000

Packaging type

Unpackaged

Windows version

Windows 11 version 22H2 (22621, 2022 Update), Windows 10 version 22H2 (19045, 2022 Update)

IDE

Visual Studio 2022

Additional context

WinDbg Callstack edited.txt

@microsoft-github-policy-service microsoft-github-policy-service bot added the needs-triage Issue needs to be triaged by the area owners label Aug 13, 2024
@codendone codendone transferred this issue from microsoft/WindowsAppSDK Aug 16, 2024
@codendone codendone added team-Markup Issue for the Markup team area-Resources area-MRT This area only covers the usage of MRT inside of a WinUI 3 app and removed needs-triage Issue needs to be triaged by the area owners labels Aug 16, 2024
@AMArostegui
Copy link
Author

Another example of a different situation when the program is crashing:

WinDbg Callstack edited 2.txt

I think localization might have something to do, since the developer who isn't getting the crashes is not using a translated operating system.

@AMArostegui
Copy link
Author

Turns out, the repository name I'm using is quite long.

If I rename the repository folder to a shorter name, the problem suddenly disappears

@lhak
Copy link

lhak commented Aug 24, 2024

I actually observed the same issue (but in a different configuration) and moving the output folder also helps in my case. Still, the path is far shorter than MAX_PATH (not even talking about long path support), so I guess there is a bug somewhere in the winui code.

@llongley llongley closed this as not planned Won't fix, can't repro, duplicate, stale Oct 17, 2024
@llongley llongley added the closed-Won'tFix Described behavior will not be fixed. label Oct 17, 2024
@lhak
Copy link

lhak commented Nov 3, 2024

I do not think that this should be closed as it still reproduces with path lengths smaller than MAX_PATH even with the latest appsdk release.

@microsoft-github-policy-service microsoft-github-policy-service bot added the needs-triage Issue needs to be triaged by the area owners label Nov 3, 2024
@SWB54
Copy link

SWB54 commented Jan 2, 2025

Just to note that I also encountered this issue today. Currently mulling how to work around it in my case, since I can't easily move my project to a different path. (I can, just not easily.) This occurred after updating my project to .NET 9 and WindowsAppSDK 1.6.241114003.

From a WinDbg analysis, it looks like the crash occurred in my case when trying to access the resources.pri file. The length of the absolute path to my resources.pri is 146 characters (including the terminating null), or 292 bytes in UTF-16. The error message is, "Heap block at 000001C682694190 modified at 000001C6826942C4 past requested size of 124."


Edited to add: In case this helps someone else, I was able to work around the issue in my case by adding the following to my .csproj file, as mentioned here:

<PropertyGroup>
  <AppendTargetFrameworkToOutputPath>false</AppendTargetFrameworkToOutputPath>
  <AppendRuntimeIdentifierToOutputPath>false</AppendRuntimeIdentifierToOutputPath>
</PropertyGroup>

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area-MRT This area only covers the usage of MRT inside of a WinUI 3 app area-Resources closed-Won'tFix Described behavior will not be fixed. needs-triage Issue needs to be triaged by the area owners team-Markup Issue for the Markup team
Projects
None yet
Development

No branches or pull requests

5 participants