libgcrypt: Add hardware acceleration for gcry_sha512

Enable hardware acceleration for the gcry_sha512 module when building
for the x86_64 EFI target.

Signed-off-by: Gary Lin <glin@suse.com>
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
This commit is contained in:
Gary Lin 2025-10-22 09:28:59 +08:00 committed by Daniel Kiper
parent 70b2f5f08d
commit f8f68f14ae
2 changed files with 36 additions and 0 deletions

View File

@ -50,6 +50,7 @@ EXTRA_DIST += grub-core/lib/libgcrypt-patches/12-kdf-use-grub_divmod64.patch
EXTRA_DIST += grub-core/lib/libgcrypt-patches/13_add_hwfeatures.patch
EXTRA_DIST += grub-core/lib/libgcrypt-patches/14_fix_build_shaext.patch
EXTRA_DIST += grub-core/lib/libgcrypt-patches/15_build_sha256_x86_64_efi_opt_code.patch
EXTRA_DIST += grub-core/lib/libgcrypt-patches/16_build_sha512_x86_64_efi_opt_code.patch
EXTRA_DIST += grub-core/lib/libtasn1-patches/0001-libtasn1-disable-code-not-needed-in-grub.patch
EXTRA_DIST += grub-core/lib/libtasn1-patches/0002-libtasn1-replace-strcat-with-strcpy-in-_asn1_str_cat.patch

View File

@ -0,0 +1,35 @@
From f62c2c7565237bbf059220e90d3f1f8c8d6eebd5 Mon Sep 17 00:00:00 2001
From: Gary Lin <glin@suse.com>
Date: Wed, 3 Sep 2025 16:26:55 +0800
Subject: [PATCH 4/4] libgcrypt: Add hardware acceleration for gcry_sha512
Enable hardware acceleration for the gcry_sha512 module when building
for the x86_64 EFI target.
Signed-off-by: Gary Lin <glin@suse.com>
---
grub-core/Makefile.gcry.def | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/grub-core/Makefile.gcry.def b/grub-core/Makefile.gcry.def
index ac1d9a088..64ea5ee24 100644
--- a/grub-core/Makefile.gcry.def
+++ b/grub-core/Makefile.gcry.def
@@ -186,8 +186,13 @@ module = {
name = gcry_sha512;
common = lib/libgcrypt-grub/cipher/sha512.c;
common = lib/libgcrypt-grub/cipher/hash-common.c;
+ x86_64_efi = lib/libgcrypt-grub/cipher/sha512-ssse3-amd64.S;
+ x86_64_efi = lib/libgcrypt-grub/cipher/sha512-avx-amd64.S;
+ x86_64_efi = lib/libgcrypt-grub/cipher/sha512-avx2-bmi2-amd64.S;
+ x86_64_efi = lib/libgcrypt-grub/cipher/sha512-avx512-amd64.S;
+
cflags = '$(CFLAGS_GCRY) -Wno-cast-align';
- cppflags = '$(CPPFLAGS_GCRY)';
+ cppflags = '$(CPPFLAGS_GCRY) -DUSE_SHA512 $(CPPFLAGS_GCRY_ASM)';
};
module = {
--
2.51.0