Microsoft is releasing this security advisory to provide information about a vulnerability in .NET 8.0, .NET 9.0, and .NET 10.0. This advisory also provides guidance on what developers can do to update their applications to remove this vulnerability.
Loop with unreachable exit condition ('infinite loop') in ASP.NET Core allows an unauthorized attacker to deny service over a network.
Announcement for this issue can be found at https://github.com/dotnet/announcements/issues/397
The vulnerability affects any Microsoft .NET project if it uses any of affected package versions listed below
| Package name | Affected version | Patched version |
|---|---|---|
| Microsoft.AspNetCore.App.Runtime.win-arm | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.win-arm64 | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.win-x64 | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.win-x86 | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.linux-arm | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.linux-arm64 | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.linux-musl-arm | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.linux-musl-arm64 | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.linux-musl-x64 | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.linux-x64 | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.osx-arm64 | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Microsoft.AspNetCore.App.Runtime.osx-x64 | >= 10.0.0, <= 10.0.7 | 10.0.8 |
| Package name | Affected version | Patched version |
|---|---|---|
| Microsoft.AspNetCore.App.Runtime.win-arm | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.win-arm64 | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.win-x64 | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.win-x86 | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.linux-arm | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.linux-arm64 | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.linux-musl-arm | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.linux-musl-arm64 | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.linux-musl-x64 | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.linux-x64 | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.osx-arm64 | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Microsoft.AspNetCore.App.Runtime.osx-x64 | >= 9.0.0, <= 9.0.15 | 9.0.16 |
| Package name | Affected version | Patched version |
|---|---|---|
| Microsoft.AspNetCore.App.Runtime.win-arm | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.win-arm64 | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.win-x64 | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.win-x86 | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.linux-arm | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.linux-arm64 | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.linux-musl-arm | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.linux-musl-arm64 | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.linux-musl-x64 | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.linux-x64 | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.osx-arm64 | >= 8.0.0, <= 8.0.26 | 8.0.27 |
| Microsoft.AspNetCore.App.Runtime.osx-x64 | >= 8.0.0, <= 8.0.26 | 8.0.27 |
If using a package listed in affected packages, an application is exposed to the vulnerability.
dotnet --info command. Once developers have installed the updated runtime or SDK, they should restart their apps for the update to take effect.
Additionally, if developers have deployed self-contained applications targeting any of the impacted versions, these applications are also vulnerable and must be recompiled and redeployed.
If a potential security issue has been found in a supported version of .NET, please report it to the Microsoft Security Response Center (MSRC) via the MSRC Researcher Portal. Further information can be found in the MSRC Report an Issue FAQ.
Security reports made through MSRC may qualify for the Microsoft .NET Bounty. Details of the Microsoft .NET Bounty Program including terms and conditions are at https://aka.ms/corebounty.
Questions about this issue can be submitted to the .NET GitHub organization. The main repos are located at https://github.com/dotnet/runtime. The Announcements repo (https://github.com/dotnet/Announcements) will contain this bulletin as an issue and will include a link to a discussion issue. Questions can be submitted through the linked discussion issue.
The information provided in this advisory is provided "as is" without warranty of any kind. Microsoft disclaims all warranties, either express or implied, including the warranties of merchantability and fitness for a particular purpose. In no event shall Microsoft Corporation or its suppliers be liable for any damages whatsoever including direct, indirect, incidental, consequential, loss of business profits or special damages, even if Microsoft Corporation or its suppliers have been advised of the possibility of such damages. Some states do not allow the exclusion or limitation of liability for consequential or incidental damages so the foregoing limitation may not apply.
hamayanhamayan Muhammad Abdul Rehman
V1.0 (May 12, 2026): Advisory published.
| Score | Percentile |
|---|---|
| 0.04% | 12.10% |
| Base score | Version | Severity | Vector |
|---|---|---|---|
| 7.5 | 3.1 | — |
|
| Type | Value |
|---|---|
| GHSA | GHSA-9v76-4qcc-frgh ↗ |
| CVE | CVE-2026-42899 ↗ |
| CWE id | Name |
|---|---|
| CWE-835 | Loop with Unreachable Exit Condition ('Infinite Loop') |
Vulnerable version ranges and first patched releases as published by GitHub.
| Ecosystem | Package | Vulnerable range | First patched | Vulnerable functions |
|---|---|---|---|---|
| nuget | Microsoft.AspNetCore.App.Runtime.win-arm | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-arm64 | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-x64 | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-x86 | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-arm | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-arm64 | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-musl-arm | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-musl-arm64 | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-musl-x64 | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-x64 | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.osx-arm64 | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.osx-x64 | >= 8.0.0, <= 8.0.26 | 8.0.27 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-arm | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-arm | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-arm64 | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-arm64 | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-x64 | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-x64 | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-x86 | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.win-x86 | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-arm | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-arm | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-arm64 | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-arm64 | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-musl-arm | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-musl-arm | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-musl-arm64 | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-musl-arm64 | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-musl-x64 | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-musl-x64 | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-x64 | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.linux-x64 | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.osx-arm64 | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.osx-arm64 | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.osx-x64 | >= 9.0.0, <= 9.0.15 | 9.0.16 | — |
| nuget | Microsoft.AspNetCore.App.Runtime.osx-x64 | >= 10.0.0, <= 10.0.7 | 10.0.8 | — |