new file mode 100644
@@ -0,0 +1,61 @@
+From ad3004ec8731730e93fcfbbc824e67eadc1c1bae Mon Sep 17 00:00:00 2001
+From: Frank Denis <github@pureftpd.org>
+Date: Mon, 29 Dec 2025 23:22:15 +0100
+Subject: [PATCH] core_ed25519_is_valid_point: check Y==Z in addition to X==0
+
+CVE: CVE-2025-69277
+Upstream-Status: Backport [https://github.com/jedisct1/libsodium/commit/ad3004ec8731730e93fcfbbc824e67eadc1c1bae]
+Signed-off-by: Peter Marko <peter.marko@siemens.com>
+---
+ src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c | 5 ++++-
+ test/default/core_ed25519.c | 7 ++++++-
+ 2 files changed, 10 insertions(+), 2 deletions(-)
+
+diff --git a/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c b/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c
+index d3020132..4b824f6d 100644
+--- a/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c
++++ b/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c
+@@ -992,10 +992,13 @@ int
+ ge25519_is_on_main_subgroup(const ge25519_p3 *p)
+ {
+ ge25519_p3 pl;
++ fe25519 t;
+
+ ge25519_mul_l(&pl, p);
+
+- return fe25519_iszero(pl.X);
++ fe25519_sub(t, pl.Y, pl.Z);
++
++ return fe25519_iszero(pl.X) & fe25519_iszero(t);
+ }
+
+ int
+diff --git a/test/default/core_ed25519.c b/test/default/core_ed25519.c
+index bc457493..02f72bd6 100644
+--- a/test/default/core_ed25519.c
++++ b/test/default/core_ed25519.c
+@@ -13,6 +13,10 @@ static const unsigned char max_canonical_p[32] = {
+ 0xe4, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x7f
+ };
++static const unsigned char not_main_subgroup_p[32] = {
++ 0x95, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99,
++ 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99, 0x99
++};
+
+ static void
+ add_P(unsigned char * const S)
+@@ -130,11 +134,12 @@ main(void)
+ assert(crypto_core_ed25519_is_valid_point(p) == 0);
+
+ p[0] = 9;
+- assert(crypto_core_ed25519_is_valid_point(p) == 1);
++ assert(crypto_core_ed25519_is_valid_point(p) == 0);
+
+ assert(crypto_core_ed25519_is_valid_point(max_canonical_p) == 1);
+ assert(crypto_core_ed25519_is_valid_point(non_canonical_invalid_p) == 0);
+ assert(crypto_core_ed25519_is_valid_point(non_canonical_p) == 0);
++ assert(crypto_core_ed25519_is_valid_point(not_main_subgroup_p) == 0);
+
+ memcpy(p2, p, crypto_core_ed25519_BYTES);
+ add_P(p2);
@@ -8,6 +8,8 @@ SRC_URI = "https://download.libsodium.org/libsodium/releases/${BPN}-${PV}.tar.gz
SRC_URI[md5sum] = "3ca9ebc13b6b4735acae0a6a4c4f9a95"
SRC_URI[sha256sum] = "6f504490b342a4f8a4c4a02fc9b866cbef8622d5df4e5452b46be121e46636c1"
+SRC_URI += "file://CVE-2025-69277.patch"
+
inherit autotools
BBCLASSEXTEND = "native nativesdk"