]> git.ipfire.org Git - thirdparty/strongswan.git/commitdiff
eap-mschapv2: Fix length check for Failure Request packets on the client
authorTobias Brunner <tobias@strongswan.org>
Thu, 9 Oct 2025 09:33:45 +0000 (11:33 +0200)
committerAndreas Steffen <andreas.steffen@strongswan.org>
Mon, 27 Oct 2025 13:02:59 +0000 (14:02 +0100)
For message lengths between 6 and 8, subtracting HEADER_LEN (9) causes
`message_len` to become negative, which is then used in calls to malloc()
and memcpy() that both take size_t arguments, causing an integer
underflow.

For 6 and 7, the huge size requested from malloc() will fail (it exceeds
PTRDIFF_MAX) and the returned NULL pointer will cause a segmentation
fault in memcpy().

However, for 8, the allocation is 0, which succeeds.  But then the -1
passed to memcpy() causes a heap-based buffer overflow (and possibly a
segmentation fault when attempting to read/write that much data).
Fortunately, if compiled with -D_FORTIFY_SOURCE=3 (the default on e.g.
Ubuntu), the compiler will use __memcpy_chk(), which prevents that buffer
overflow and causes the daemon to get aborted immediately instead.

Fixes: f98cdf7a4765 ("adding plugin for EAP-MS-CHAPv2")
Fixes: CVE-2025-62291
src/libcharon/plugins/eap_mschapv2/eap_mschapv2.c

index 21cc95a6a360513a791e44c99ac0508ad066c4be..35faad2e0bb52375ee4b7e2c3ce05d595d549c53 100644 (file)
@@ -974,7 +974,7 @@ static status_t process_peer_failure(private_eap_mschapv2_t *this,
        data = in->get_data(in);
        eap = (eap_mschapv2_header_t*)data.ptr;
 
-       if (data.len < 3) /* we want at least an error code: E=e */
+       if (data.len < HEADER_LEN + 3) /* we want at least an error code: E=e */
        {
                DBG1(DBG_IKE, "received invalid EAP-MS-CHAPv2 message: too short");
                return FAILED;