Move X9.62 signature decoding out of the ecdsa driver and into a template (patch [4/5]). This allows introduction of P1363 signature decoding as another template (patch [5/5]), which is needed by the upcoming SPDM library (Security Protocol and Data Model) for PCI device authentication. Drop usage of sglists for signature verification and use kernel buffers instead (patch [2/5]) to avoid the overhead of extracting from sglists into kernel buffers both in the templates and in the ecdsa driver. This builds on Herbert's elimination of sglists from the akcipher API with commit 63ba4d67594a ("KEYS: asymmetric: Use new crypto interface without scatterlists"). I realize that P1363 support (patch [5/5]) might not be acceptable standalone, but I'm hoping to get an ack for it so that I may upstream the patch as part of PCI device authentication. Patches [1/5] to [4/5] will hopefully be acceptable standalone. Note that I've duplicated the ecdsa test vectors in their entirety in patch [4/5]. If that is considered overzealous, I can reduce them to one or a few for testing the "raw" internal encoding. In patch [5/5] I've included just a single test vector for P1363. I can add more if desired. Link to Herbert's suggestion to use templates for X9.62 and P1363: https://lore.kernel.org/all/ZoHXyGwRzVvYkcTP@xxxxxxxxxxxxxxxxxxx/ Link to PCI device authentication v2 patches: https://lore.kernel.org/all/cover.1719771133.git.lukas@xxxxxxxxx/ Please review and test -- thank you! Lukas Wunner (5): ASN.1: Add missing include <linux/types.h> crypto: akcipher - Drop usage of sglists for verify op crypto: ecdsa - Avoid signed integer overflow on signature decoding crypto: ecdsa - Move X9.62 signature decoding into template crypto: ecdsa - Support P1363 signature decoding crypto/Makefile | 4 +- crypto/akcipher.c | 11 +- crypto/asymmetric_keys/public_key.c | 43 +- crypto/ecdsa-p1363.c | 155 +++++ crypto/ecdsa-x962.c | 211 +++++++ crypto/ecdsa.c | 122 ++-- crypto/ecrdsa.c | 28 +- crypto/rsa-pkcs1pad.c | 27 +- crypto/sig.c | 24 +- crypto/testmgr.c | 57 +- crypto/testmgr.h | 847 +++++++++++++++++++++++++++- include/crypto/akcipher.h | 53 +- include/crypto/internal/ecc.h | 2 + include/linux/asn1_decoder.h | 1 + 14 files changed, 1391 insertions(+), 194 deletions(-) create mode 100644 crypto/ecdsa-p1363.c create mode 100644 crypto/ecdsa-x962.c -- 2.43.0