aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNIIBE Yutaka <[email protected]>2021-10-08 13:07:14 +0000
committerNIIBE Yutaka <[email protected]>2021-10-08 13:07:14 +0000
commitf2b54b3309519c693cc8e7a1d2008722a34a1e3c (patch)
tree8b9f917c28ac339f6cc8740b7a68ee2f3c5496d5
parentgpg: Support MPI(0) by sos_read and mpi_print. (diff)
downloadgnupg-f2b54b3309519c693cc8e7a1d2008722a34a1e3c.tar.gz
gnupg-f2b54b3309519c693cc8e7a1d2008722a34a1e3c.zip
experiment: Add forgotten open-misc.c.
Signed-off-by: NIIBE Yutaka <[email protected]>
-rw-r--r--common/openpgp-misc.c61
1 files changed, 61 insertions, 0 deletions
diff --git a/common/openpgp-misc.c b/common/openpgp-misc.c
new file mode 100644
index 000000000..7c6c56a69
--- /dev/null
+++ b/common/openpgp-misc.c
@@ -0,0 +1,61 @@
+#include <config.h>
+#include <stdlib.h>
+#include <errno.h>
+#include <ctype.h>
+#include <assert.h>
+
+#include "util.h"
+#include "openpgpdefs.h"
+
+gcry_mpi_t
+openpgp_ecc_parse_pubkey (pubkey_algo_t pkalgo, const char *curve_oid,
+ gcry_mpi_t pubkey)
+{
+ unsigned int nbits = 0;
+ unsigned char *buf = NULL;
+ const char *curve = openpgp_oid_to_curve (curve_oid, 1);
+
+ if (curve == NULL)
+ curve = curve_oid;
+
+ if ((pkalgo == PUBKEY_ALGO_EDDSA && !strcmp (curve, "Ed448"))
+ || (pkalgo == PUBKEY_ALGO_ECDH && !strcmp (curve, "X448")))
+ buf = gcry_mpi_get_opaque (pubkey, &nbits);
+
+ if (nbits == 0
+ || (pkalgo == PUBKEY_ALGO_EDDSA && (nbits+7)/8 == (448 + 8)/8)
+ || (pkalgo == PUBKEY_ALGO_ECDH && (nbits+7)/8 == 448/8))
+ return gcry_mpi_copy (pubkey);
+
+ if (pkalgo == PUBKEY_ALGO_EDDSA)
+ return gcry_mpi_set_opaque_copy (NULL, buf+1, 8 + 448);
+ else
+ return gcry_mpi_set_opaque_copy (NULL, buf+1, 448);
+}
+
+
+gcry_mpi_t
+openpgp_ecc_parse_seckey (pubkey_algo_t pkalgo, const char *curve_oid,
+ gcry_mpi_t seckey)
+{
+ unsigned int nbits = 0;
+ unsigned char *buf = NULL;
+ const char *curve = openpgp_oid_to_curve (curve_oid, 1);
+
+ if (curve == NULL)
+ curve = curve_oid;
+
+ if ((pkalgo == PUBKEY_ALGO_EDDSA && !strcmp (curve, "Ed448"))
+ || (pkalgo == PUBKEY_ALGO_ECDH && !strcmp (curve, "X448")))
+ buf = gcry_mpi_get_opaque (seckey, &nbits);
+
+ if (nbits == 0
+ || (pkalgo == PUBKEY_ALGO_EDDSA && (nbits+7)/8 == (448 + 8)/8)
+ || (pkalgo == PUBKEY_ALGO_ECDH && (nbits+7)/8 == 448/8))
+ return gcry_mpi_copy (seckey);
+
+ if (pkalgo == PUBKEY_ALGO_EDDSA)
+ return gcry_mpi_set_opaque_copy (NULL, buf+1, 8 + 448);
+ else
+ return gcry_mpi_set_opaque_copy (NULL, buf+1, 448);
+}