Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp928236pxk; Fri, 25 Sep 2020 01:19:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJys/9X+o/3YBqT0Yd2GfpPf9UtW9kzDxJKmW6y6b+iZxa/yMYsRY+zNzX5P4UEVqFgo/Lvh X-Received: by 2002:a17:906:a1d8:: with SMTP id bx24mr1506166ejb.161.1601021974365; Fri, 25 Sep 2020 01:19:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601021974; cv=none; d=google.com; s=arc-20160816; b=I6ffjOLF2XJFgBWtqq0T1a3iQovfWwb5GqzOe8GNqJcLaW3P1w+aFCzSL8EbWipEnB U/h+bGZID2faQktnoof0VfYx3d+eRA1veUy0NNSeMLPUzAmco7YopJPY4CV4Qi7BYPmv BTXItFUI4lEhfsK9I50+yGJ15W1U2CtP5SNB5fCUXxjowqOJxKJcH1l3a78XMNUAfG/e Y2jH7pmh28zqFWAUXFH5O0FrVvW0TBXfda+OznLDNMxl9VT7wmJ0PG2nqKLjIQZJDEUF oL1sYXenp20++bTVjBDaFJY+ZwZ39uY/bJ5U7N/slS20maUSOiuMRN9A8z2M0scI4d3g sThw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=exROAdFF2rk214QUVv50LO/ayOcu1MphEWPuBB1RfGs=; b=QomnhJUHCuxTykQq5gRLcG8S/HBn1DQPaNFdxbxYo+nt3sLh5dwe5KATZrLldVt20U 9kRpLwhBLCO1ZRrLlhwTcUxNilxLT4kR1CMI+hI5AE9jmqXAcmF30HVmF+59Oe2ZYCZs Bp9ihEZhXQcE7XnhAVAVodHqraf5TTvMl0d9LmxpKh+HUuT8qOhPiDioeBj2GWm3Gese xZUi0NR1Ly8BlwAozdsc11JLfQ8d2Sox/Xu8ds/v4p6DatnPTywt+MAHa38OriSV2Az8 AbIQv30JyVBj/LajGKo7W39DVuJUIFDzExC0HSjXFejftHMabjOT6FrLS7KJbsOFF+t9 iPfA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y20si1391772edi.281.2020.09.25.01.19.05; Fri, 25 Sep 2020 01:19:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727420AbgIYISp (ORCPT + 99 others); Fri, 25 Sep 2020 04:18:45 -0400 Received: from helcar.hmeau.com ([216.24.177.18]:53466 "EHLO fornost.hmeau.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726990AbgIYISo (ORCPT ); Fri, 25 Sep 2020 04:18:44 -0400 Received: from gwarestrin.arnor.me.apana.org.au ([192.168.0.7]) by fornost.hmeau.com with smtp (Exim 4.92 #5 (Debian)) id 1kLivC-0007RD-Jf; Fri, 25 Sep 2020 18:17:39 +1000 Received: by gwarestrin.arnor.me.apana.org.au (sSMTP sendmail emulation); Fri, 25 Sep 2020 18:17:38 +1000 Date: Fri, 25 Sep 2020 18:17:38 +1000 From: Herbert Xu To: Tianjia Zhang Cc: "David S. Miller" , David Howells , Eric Biggers , Jarkko Sakkinen , Maxime Coquelin , Alexandre Torgue , James Morris , "Serge E. Hallyn" , Stephan Mueller , Marcelo Henrique Cerri , "Steven Rostedt (VMware)" , Masahiro Yamada , Brendan Higgins , Andrew Morton , Johannes Weiner , Waiman Long , Mimi Zohar , Lakshmi Ramasubramanian , Colin Ian King , Tushar Sugandhi , Vitaly Chikunov , Gilad Ben-Yossef , Pascal van Leeuwen , linux-crypto@vger.kernel.org, keyrings@vger.kernel.org, linux-integrity@vger.kernel.org, linux-security-module@vger.kernel.org, linux-stm32@st-md-mailman.stormreply.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Xufeng Zhang , Jia Zhang Subject: Re: [PATCH v7 00/10] crpyto: introduce OSCCA certificate and SM2 asymmetric algorithm Message-ID: <20200925081738.GU6381@gondor.apana.org.au> References: <20200920162103.83197-1-tianjia.zhang@linux.alibaba.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200920162103.83197-1-tianjia.zhang@linux.alibaba.com> User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org On Mon, Sep 21, 2020 at 12:20:53AM +0800, Tianjia Zhang wrote: > Hello all, > > This new module implement the OSCCA certificate and SM2 public key > algorithm. It was published by State Encryption Management Bureau, China. > List of specifications for OSCCA certificate and SM2 elliptic curve > public key cryptography: > > * GM/T 0003.1-2012 > * GM/T 0003.2-2012 > * GM/T 0003.3-2012 > * GM/T 0003.4-2012 > * GM/T 0003.5-2012 > * GM/T 0015-2012 > * GM/T 0009-2012 > > IETF: https://tools.ietf.org/html/draft-shen-sm2-ecdsa-02 > oscca: http://www.oscca.gov.cn/sca/xxgk/2010-12/17/content_1002386.shtml > scctc: http://www.gmbz.org.cn/main/bzlb.html > > These patchs add the OID object identifier defined by OSCCA. The > x509 certificate supports sm2-with-sm3 type certificate parsing > and verification. > > The sm2 algorithm is based on libgcrypt's mpi implementation, and has > made some additions to the kernel's original mpi library, and added the > implementation of ec to better support elliptic curve-like algorithms. > > sm2 has good support in both openssl and gnupg projects, and sm3 and sm4 > of the OSCCA algorithm family have also been implemented in the kernel. > > Among them, sm3 and sm4 have been well implemented in the kernel. > This group of patches has newly introduced sm2. In order to implement > sm2 more perfectly, I expanded the mpi library and introduced the > ec implementation of the mpi library as the basic algorithm. Compared > to the kernel's crypto/ecc.c, the implementation of mpi/ec.c is more > complete and elegant, sm2 is implemented based on these algorithms. > > --- > v7 changes: > 1. add sm2 test vectors to testmgr. > 2. fix potential memory leak in testmgr (PATCH 6/10). > 3. rebase on mainline. > > v6 changes: > 1. remove mpi_sub_ui function from mpi library. > 2. rebase on mainline. > > v5 changes: > 1. fix compilation failure when SM2 is configured as a module. > 2. simplify the mpi and ec code, remove unused functions reported by test robot. > > v4 changes: > 1. Pass data directly when calculating sm2 certificate digest. > 2. rebase on mainline. > > v3 changes: > 1. integrity asymmetric digsig support sm2-with-sm3 algorithm. > 2. remove unused sm2_set_priv_key(). > 3. rebase on mainline. > > v2 changes: > 1. simplify the sm2 algorithm and only retain the verify function. > 2. extract the sm2 certificate code into a separate file. > > > Tianjia Zhang (10): > crypto: sm3 - export crypto_sm3_final function > lib/mpi: Extend the MPI library > lib/mpi: Introduce ec implementation to MPI library > crypto: sm2 - introduce OSCCA SM2 asymmetric cipher algorithm > crypto: testmgr - support test with different ciphertext per > encryption > crypto: testmgr - Fix potential memory leak in test_akcipher_one() > crypto: sm2 - add SM2 test vectors to testmgr > X.509: support OSCCA certificate parse > X.509: support OSCCA SM2-with-SM3 certificate verification > integrity: Asymmetric digsig supports SM2-with-SM3 algorithm > > crypto/Kconfig | 17 + > crypto/Makefile | 8 + > crypto/asymmetric_keys/Makefile | 1 + > crypto/asymmetric_keys/public_key.c | 6 + > crypto/asymmetric_keys/public_key_sm2.c | 61 + > crypto/asymmetric_keys/x509_cert_parser.c | 27 +- > crypto/asymmetric_keys/x509_public_key.c | 3 + > crypto/sm2.c | 481 +++++++ > crypto/sm2signature.asn1 | 4 + > crypto/sm3_generic.c | 7 +- > crypto/testmgr.c | 24 +- > crypto/testmgr.h | 59 + > include/crypto/public_key.h | 15 + > include/crypto/sm2.h | 25 + > include/crypto/sm3.h | 2 + > include/linux/mpi.h | 192 +++ > include/linux/oid_registry.h | 6 + > lib/mpi/Makefile | 6 + > lib/mpi/ec.c | 1509 +++++++++++++++++++++ > lib/mpi/mpi-add.c | 155 +++ > lib/mpi/mpi-bit.c | 251 ++++ > lib/mpi/mpi-cmp.c | 46 +- > lib/mpi/mpi-div.c | 238 ++++ > lib/mpi/mpi-internal.h | 53 + > lib/mpi/mpi-inv.c | 143 ++ > lib/mpi/mpi-mod.c | 155 +++ > lib/mpi/mpi-mul.c | 94 ++ > lib/mpi/mpicoder.c | 336 +++++ > lib/mpi/mpih-div.c | 294 ++++ > lib/mpi/mpih-mul.c | 25 + > lib/mpi/mpiutil.c | 204 +++ > security/integrity/digsig_asymmetric.c | 14 +- > 32 files changed, 4435 insertions(+), 26 deletions(-) > create mode 100644 crypto/asymmetric_keys/public_key_sm2.c > create mode 100644 crypto/sm2.c > create mode 100644 crypto/sm2signature.asn1 > create mode 100644 include/crypto/sm2.h > create mode 100644 lib/mpi/ec.c > create mode 100644 lib/mpi/mpi-add.c > create mode 100644 lib/mpi/mpi-div.c > create mode 100644 lib/mpi/mpi-inv.c > create mode 100644 lib/mpi/mpi-mod.c > create mode 100644 lib/mpi/mpi-mul.c All applied. Thanks. -- Email: Herbert Xu Home Page: http://gondor.apana.org.au/~herbert/ PGP Key: http://gondor.apana.org.au/~herbert/pubkey.txt