Blame SOURCES/gnutls-3.7.6-drbg-reseed.patch

cd0318
From 3035e884b3abc68bcebff5adec5bd8819bbc6d7b Mon Sep 17 00:00:00 2001
cd0318
From: rpm-build <rpm-build>
cd0318
Date: Fri, 5 Aug 2022 16:16:42 +0900
cd0318
Subject: [PATCH] gnutls-3.7.6-drbg-reseed.patch
cd0318
cd0318
Signed-off-by: rpm-build <rpm-build>
cd0318
---
cd0318
 lib/nettle/sysrng-linux.c | 10 +++++++++-
cd0318
 1 file changed, 9 insertions(+), 1 deletion(-)
cd0318
cd0318
diff --git a/lib/nettle/sysrng-linux.c b/lib/nettle/sysrng-linux.c
cd0318
index 6b3971c..dae9061 100644
cd0318
--- a/lib/nettle/sysrng-linux.c
cd0318
+++ b/lib/nettle/sysrng-linux.c
cd0318
@@ -31,6 +31,9 @@
cd0318
 # include <num.h>
cd0318
 # include <errno.h>
cd0318
 # include <rnd-common.h>
cd0318
+# include "fips.h"
cd0318
+#else
cd0318
+# define _gnutls_fips_mode_enabled() 0
cd0318
 #endif
cd0318
 
cd0318
 #include <sys/types.h>
cd0318
@@ -103,7 +106,12 @@ static int force_getrandom(void *buf, size_t buflen, unsigned int flags)
cd0318
 static int _rnd_get_system_entropy_getrandom(void* _rnd, size_t size)
cd0318
 {
cd0318
 	int ret;
cd0318
-	ret = force_getrandom(_rnd, size, 0);
cd0318
+	unsigned int flags = 0;
cd0318
+
cd0318
+	if (_gnutls_fips_mode_enabled()) {
cd0318
+		flags |= 2/*GRND_RANDOM*/;
cd0318
+	}
cd0318
+	ret = force_getrandom(_rnd, size, flags);
cd0318
 	if (ret == -1) {
cd0318
 		int e = errno;
cd0318
 		gnutls_assert();
cd0318
-- 
cd0318
2.37.1
cd0318