Russh is a Rust SSH client & server library. Allocating an untrusted amount of memory allows any unauthenticated user to OOM a russh server. An SSH packet consists of a 4-byte big-endian length, followed by a byte stream of this length.
After parsing and potentially decrypting the 4-byte length, russh allocates enough memory for this bytestream, as a performance optimization to avoid reallocations later. But this length is entirely untrusted and can be set to any value by the client, causing this much memory to be allocated, which will cause the process to OOM within a few such requests. This vulnerability is fixed in 0.44.1.
References
Configurations
No configuration.
History
21 Aug 2024, 17:25
Type | Values Removed | Values Added |
---|---|---|
New CVE |
Information
Published : 2024-08-21 16:15
Updated : 2024-08-21 17:25
NVD link : CVE-2024-43410
Mitre link : CVE-2024-43410
CVE.ORG link : CVE-2024-43410
JSON object : View
Products Affected
No product.
CWE
CWE-770
Allocation of Resources Without Limits or Throttling