]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
public_key: move common functions to public key helper
authorRaymond Mao <raymond.mao@linaro.org>
Thu, 3 Oct 2024 21:50:25 +0000 (14:50 -0700)
committerTom Rini <trini@konsulko.com>
Mon, 14 Oct 2024 23:58:40 +0000 (17:58 -0600)
Move public_key_free and public_key_signature_free as helper
functions that can be shared by legacy crypto lib and MbedTLS
implementation.

Signed-off-by: Raymond Mao <raymond.mao@linaro.org>
Reviewed-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
lib/crypto/Makefile
lib/crypto/public_key.c
lib/crypto/public_key_helper.c [new file with mode: 0644]

index bec1bc95a65864fb3a6c935f1efd3eb2ec9fdc99..4ad1849040da150ab044d8bddab496523ac3fb51 100644 (file)
@@ -7,7 +7,9 @@ obj-$(CONFIG_$(SPL_)ASYMMETRIC_KEY_TYPE) += asymmetric_keys.o
 
 asymmetric_keys-y := asymmetric_type.o
 
-obj-$(CONFIG_$(SPL_)ASYMMETRIC_PUBLIC_KEY_SUBTYPE) += public_key.o
+obj-$(CONFIG_$(SPL_)ASYMMETRIC_PUBLIC_KEY_SUBTYPE) += \
+       public_key_helper.o \
+       public_key.o
 
 #
 # RSA public key parser
index 6efe951c057c8834921306243fa579784c91cc94..408742907f183c8ada820d472dbbaa78d1fd8483 100644 (file)
@@ -51,38 +51,7 @@ static void public_key_describe(const struct key *asymmetric_key,
 }
 #endif
 
-/*
- * Destroy a public key algorithm key.
- */
-void public_key_free(struct public_key *key)
-{
-       if (key) {
-               kfree(key->key);
-               kfree(key->params);
-               kfree(key);
-       }
-}
-EXPORT_SYMBOL_GPL(public_key_free);
-
 #ifdef __UBOOT__
-/*
- * from <linux>/crypto/asymmetric_keys/signature.c
- *
- * Destroy a public key signature.
- */
-void public_key_signature_free(struct public_key_signature *sig)
-{
-       int i;
-
-       if (sig) {
-               for (i = 0; i < ARRAY_SIZE(sig->auth_ids); i++)
-                       free(sig->auth_ids[i]);
-               free(sig->s);
-               free(sig->digest);
-               free(sig);
-       }
-}
-EXPORT_SYMBOL_GPL(public_key_signature_free);
 
 /**
  * public_key_verify_signature - Verify a signature using a public key.
diff --git a/lib/crypto/public_key_helper.c b/lib/crypto/public_key_helper.c
new file mode 100644 (file)
index 0000000..2c55922
--- /dev/null
@@ -0,0 +1,39 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * X509 helper functions
+ *
+ * Copyright (c) 2012 Red Hat, Inc. All Rights Reserved.
+ * Written by David Howells (dhowells@redhat.com)
+ */
+#include <linux/compat.h>
+#include <crypto/public_key.h>
+
+/*
+ * Destroy a public key algorithm key.
+ */
+void public_key_free(struct public_key *key)
+{
+       if (key) {
+               kfree(key->key);
+               kfree(key->params);
+               kfree(key);
+       }
+}
+
+/*
+ * from <linux>/crypto/asymmetric_keys/signature.c
+ *
+ * Destroy a public key signature.
+ */
+void public_key_signature_free(struct public_key_signature *sig)
+{
+       int i;
+
+       if (sig) {
+               for (i = 0; i < ARRAY_SIZE(sig->auth_ids); i++)
+                       kfree(sig->auth_ids[i]);
+               kfree(sig->s);
+               kfree(sig->digest);
+               kfree(sig);
+       }
+}