From: Thomas Perale via buildroot <buildroot@buildroot.org>
To: Thomas Perale <thomas.perale@mind.be>
Cc: buildroot@buildroot.org
Subject: Re: [Buildroot] [PATCH] package/botan: add patch for CVE-2024-50382 & CVE-2024-50383
Date: Fri, 6 Mar 2026 20:53:08 +0100 [thread overview]
Message-ID: <20260306195308.7643-1-thomas.perale@mind.be> (raw)
In-Reply-To: <20260227084404.35563-1-thomas.perale@mind.be>
In reply of:
> Fixes the following vulnerabilities:
>
> - CVE-2024-50382:
> Botan before 3.6.0, when certain LLVM versions are used, has compiler-
> induced secret-dependent control flow in lib/utils/ghash/ghash.cpp in
> GHASH in AES-GCM. There is a branch instead of an XOR with carry. This
> was observed for Clang in LLVM 15 on RISC-V.
>
> For more information, see:
> - https://www.cve.org/CVERecord?id=CVE-2024-50382
> - https://github.com/randombit/botan/commit/53b0cfde580e86b03d0d27a488b6c134f662e957
>
> - CVE-2024-50383:
> Botan before 3.6.0, when certain GCC versions are used, has a
> compiler-induced secret-dependent operation in lib/utils/donna128.h in
> donna128 (used in Chacha-Poly1305 and x25519). An addition can be
> skipped if a carry is not set. This was observed for GCC 11.3.0 with
> -O2 on MIPS, and GCC on x86-i386. (Only 32-bit processors can be
> affected.)
>
> For more information, see:
> - https://www.cve.org/CVERecord?id=CVE-2024-50383
> - https://github.com/randombit/botan/commit/53b0cfde580e86b03d0d27a488b6c134f662e957
>
> Signed-off-by: Thomas Perale <thomas.perale@mind.be>
Applied to 2025.02.x & 2025.11.x. Thanks
> ---
> ...avoid-compiler-induced-side-channels.patch | 65 +++++++++++++++++++
> package/botan/botan.mk | 3 +
> 2 files changed, 68 insertions(+)
> create mode 100644 package/botan/0001-Add-more-value-barriers-to-avoid-compiler-induced-side-channels.patch
>
> diff --git a/package/botan/0001-Add-more-value-barriers-to-avoid-compiler-induced-side-channels.patch b/package/botan/0001-Add-more-value-barriers-to-avoid-compiler-induced-side-channels.patch
> new file mode 100644
> index 0000000000..22f64be1b9
> --- /dev/null
> +++ b/package/botan/0001-Add-more-value-barriers-to-avoid-compiler-induced-side-channels.patch
> @@ -0,0 +1,65 @@
> +From 53b0cfde580e86b03d0d27a488b6c134f662e957 Mon Sep 17 00:00:00 2001
> +From: Jack Lloyd <jack@randombit.net>
> +Date: Sat, 19 Oct 2024 07:43:18 -0400
> +Subject: [PATCH] Add more value barriers to avoid compiler induced side
> + channels
> +
> +The paper https://arxiv.org/pdf/2410.13489 claims that on specific
> +architectures Clang and GCC may introduce jumps here. The donna128
> +issues only affect 32-bit processors, which explains why we would not
> +see it in the x86-64 valgrind runs.
> +
> +The GHASH leak would seem to be generic but the authors only observed
> +it on RISC-V.
> +
> +CVE: CVE-2024-50382
> +CVE: CVE-2024-50383
> +Upstream: https://github.com/randombit/botan/commit/53b0cfde580e86b03d0d27a488b6c134f662e957
> +Signed-off-by: Thomas Perale <thomas.perale@mind.be>
> +---
> + src/lib/utils/donna128.h | 5 +++--
> + src/lib/utils/ghash/ghash.cpp | 2 +-
> + 2 files changed, 4 insertions(+), 3 deletions(-)
> +
> +diff --git a/src/lib/utils/donna128.h b/src/lib/utils/donna128.h
> +index 8212bd349e0..7adf54546df 100644
> +--- a/src/lib/utils/donna128.h
> ++++ b/src/lib/utils/donna128.h
> +@@ -8,6 +8,7 @@
> + #ifndef BOTAN_CURVE25519_DONNA128_H_
> + #define BOTAN_CURVE25519_DONNA128_H_
> +
> ++#include <botan/internal/ct_utils.h>
> + #include <botan/internal/mul128.h>
> + #include <type_traits>
> +
> +@@ -73,14 +74,14 @@ class donna128 final {
> + l += x.l;
> + h += x.h;
> +
> +- const uint64_t carry = (l < x.l);
> ++ const uint64_t carry = CT::Mask<uint64_t>::is_lt(l, x.l).if_set_return(1);
> + h += carry;
> + return *this;
> + }
> +
> + constexpr donna128& operator+=(uint64_t x) {
> + l += x;
> +- const uint64_t carry = (l < x);
> ++ const uint64_t carry = CT::Mask<uint64_t>::is_lt(l, x).if_set_return(1);
> + h += carry;
> + return *this;
> + }
> +diff --git a/src/lib/utils/ghash/ghash.cpp b/src/lib/utils/ghash/ghash.cpp
> +index 8c3b1ed6c2a..61b28590002 100644
> +--- a/src/lib/utils/ghash/ghash.cpp
> ++++ b/src/lib/utils/ghash/ghash.cpp
> +@@ -131,7 +131,7 @@ void GHASH::key_schedule(std::span<const uint8_t> key) {
> + m_HM[4 * j + 2 * i + 1] = H1;
> +
> + // GCM's bit ops are reversed so we carry out of the bottom
> +- const uint64_t carry = R * (H1 & 1);
> ++ const uint64_t carry = CT::Mask<uint64_t>::expand(H1 & 1).if_set_return(R);
> + H1 = (H1 >> 1) | (H0 << 63);
> + H0 = (H0 >> 1) ^ carry;
> + }
> diff --git a/package/botan/botan.mk b/package/botan/botan.mk
> index 561e7bf702..38948f0184 100644
> --- a/package/botan/botan.mk
> +++ b/package/botan/botan.mk
> @@ -11,6 +11,9 @@ BOTAN_LICENSE = BSD-2-Clause
> BOTAN_LICENSE_FILES = license.txt
> BOTAN_CPE_ID_VALID = YES
>
> +# 0001-Add-more-value-barriers-to-avoid-compiler-induced-side-channels.patch
> +BOTAN_IGNORE_CVES += CVE-2024-50382 CVE-2024-50383
> +
> BOTAN_INSTALL_STAGING = YES
>
> BOTAN_DEPENDENCIES = host-python3
> --
> 2.53.0
>
> _______________________________________________
> buildroot mailing list
> buildroot@buildroot.org
> https://lists.buildroot.org/mailman/listinfo/buildroot
_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot
prev parent reply other threads:[~2026-03-06 19:53 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-02-27 8:44 [Buildroot] [PATCH] package/botan: add patch for CVE-2024-50382 & CVE-2024-50383 Thomas Perale via buildroot
2026-02-27 18:13 ` Julien Olivain via buildroot
2026-03-06 19:53 ` Thomas Perale via buildroot [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260306195308.7643-1-thomas.perale@mind.be \
--to=buildroot@buildroot.org \
--cc=thomas.perale@mind.be \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox