Received: by 2002:a05:6358:111d:b0:dc:6189:e246 with SMTP id f29csp1103718rwi; Thu, 3 Nov 2022 00:41:36 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5I99krK99HYpntz1Oqj4zFMIxD0bjhbN92eMklR+WUGI0JPmto5vcgkNzDGLRxUIp2g1OY X-Received: by 2002:a65:5644:0:b0:46f:e930:1968 with SMTP id m4-20020a655644000000b0046fe9301968mr11771105pgs.458.1667461295825; Thu, 03 Nov 2022 00:41:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1667461295; cv=none; d=google.com; s=arc-20160816; b=clnOvRQzkpZuHuY2k2DwU2kRUEf3fjohvm5f8Tp3XzQQ+BZv9xog//pbUpKTN1Ohq9 6Na61F6dE/0UrVsnJG5omsUF9DTpvruh1ypvBVTA5x8pd2rbPKWk5xBUvpWAdFZYq2zb E3S+jICjMR4DPh7iyParcdMRBUnRClASq73xAmgmrew8BWS02AnMvWfsIF6s2enrZ6g1 LvQsZlx5DhKqf4tj/egZ9qRVv2oVHsUku2BEM/Q9vlpJ4LUGCu3lg65rJEaVznBvkbUu vgWvNgMrTSSidP5w4zAqUSjF6Ow9TSuF42+e4g4Z0h+Vx2NnA9a278hBchi97dZfqqGA LTgQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from; bh=H+KUEei3Deq+QWgtNoY/MwiPQG8GQXr0SQIdmD3auLg=; b=g5PWZNTNlGaDfoTj9WBN6Dz0Ftw1Ncb33bqdhPGJ8E9AKc3qyN0frZSTFm/MaE0Qqv cL5YDUV0gmWxlNhyBrW1JoLg4Rr/RRNuWSnANL1a2Wx7ejIXbzl7dEGaYxkmm7ux/ieC S1OWekGEEAx4GtvAPYsyc+rD4myliBNxJPDMKowonE1qv56EAXWxo/0zV6YQJmFKIIWP GUxyGKEsFZUs17Xp9JlAk3rtHboOSYwmY/4QSkersKt6WZd6d97iuEMEBoLeAAiwhhb5 xJrFsLH7xSwb0Qh5L4Qbe/md48j9y8ALzwJRVvyfbW7DWIBI1UP3a6N85vaHbRHxh3rn CMDQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id mw11-20020a17090b4d0b00b0020a5121be54si5801790pjb.23.2022.11.03.00.41.14; Thu, 03 Nov 2022 00:41:35 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230320AbiKCHku (ORCPT + 99 others); Thu, 3 Nov 2022 03:40:50 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37922 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230013AbiKCHkt (ORCPT ); Thu, 3 Nov 2022 03:40:49 -0400 Received: from out30-131.freemail.mail.aliyun.com (out30-131.freemail.mail.aliyun.com [115.124.30.131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AEF5D10A2; Thu, 3 Nov 2022 00:40:47 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R161e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046059;MF=guanjun@linux.alibaba.com;NM=1;PH=DS;RN=8;SR=0;TI=SMTPD_---0VTrcGFd_1667461243; Received: from localhost(mailfrom:guanjun@linux.alibaba.com fp:SMTPD_---0VTrcGFd_1667461243) by smtp.aliyun-inc.com; Thu, 03 Nov 2022 15:40:45 +0800 From: 'Guanjun' To: herbert@gondor.apana.org.au, elliott@hpe.com Cc: zelin.deng@linux.alibaba.com, artie.ding@linux.alibaba.com, guanjun@linux.alibaba.com, linux-crypto@vger.kernel.org, linux-kernel@vger.kernel.org, xuchun.shang@linux.alibaba.com Subject: [PATCH v3 RESEND 0/9] Drivers for Alibaba YCC (Yitian Cryptography Complex) cryptographic accelerator Date: Thu, 3 Nov 2022 15:40:34 +0800 Message-Id: <1667461243-48652-1-git-send-email-guanjun@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 X-Spam-Status: No, score=-9.9 required=5.0 tests=BAYES_00, ENV_AND_HDR_SPF_MATCH,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, UNPARSEABLE_RELAY,USER_IN_DEF_SPF_WL autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org From: Guanjun Hi, This patch series aims to add drivers for Alibaba YCC (Yitian Cryptography Complex) cryptographic accelerator. Enables the on-chip cryptographic accelerator of Alibaba Yitian SoCs which is based on ARMv9 architecture. It includes PCIe enabling, skcipher, aead, rsa, sm2 support. Please help to review. Thanks, Guanjun. Change log: v3 -> v3 RESEND: - [*/09] Fix compile warnings when sparse turned on v2 -> v3: - [01/09] Fix the lost "$" in Makefile - [08/09] Fix compile warnings when both CONFIG_CRYPTO_SM2 and CONFIG_CRYPTO_DEV_YCC are enabled v1 RESEND -> v2: - [01/09] Remove char device that is not used now. v1 -> v1 RESEND: - [01/09] Adjust the Kconfig entry in alphabetical order - [05/09][07/09][08/09] Adjust the format of algorithm names v2: https://lore.kernel.org/all/1664350687-47330-1-git-send-email-guanjun@linux.alibaba.com/ v1: https://lore.kernel.org/all/1661334621-44413-1-git-send-email-guanjun@linux.alibaba.com/ v1 RESEND: https://lore.kernel.org/all/1662435353-114812-1-git-send-email-guanjun@linux.alibaba.com/ Guanjun (3): crypto/ycc: Add skcipher algorithm support crypto/ycc: Add aead algorithm support crypto/ycc: Add rsa algorithm support Xuchun Shang (1): crypto/ycc: Add sm2 algorithm support Zelin Deng (5): crypto/ycc: Add YCC (Yitian Cryptography Complex) accelerator driver crypto/ycc: Add ycc ring configuration crypto/ycc: Add irq support for ycc kernel rings crypto/ycc: Add device error handling support for ycc hw errors MAINTAINERS: Add Yitian Cryptography Complex (YCC) driver maintainer entry MAINTAINERS | 8 + drivers/crypto/Kconfig | 2 + drivers/crypto/Makefile | 1 + drivers/crypto/ycc/Kconfig | 18 + drivers/crypto/ycc/Makefile | 7 + drivers/crypto/ycc/sm2signature_asn1.c | 38 ++ drivers/crypto/ycc/sm2signature_asn1.h | 13 + drivers/crypto/ycc/ycc_aead.c | 646 ++++++++++++++++++++++ drivers/crypto/ycc/ycc_algs.h | 176 ++++++ drivers/crypto/ycc/ycc_dev.h | 157 ++++++ drivers/crypto/ycc/ycc_drv.c | 567 ++++++++++++++++++++ drivers/crypto/ycc/ycc_isr.c | 276 ++++++++++ drivers/crypto/ycc/ycc_isr.h | 13 + drivers/crypto/ycc/ycc_pke.c | 946 +++++++++++++++++++++++++++++++++ drivers/crypto/ycc/ycc_ring.c | 649 ++++++++++++++++++++++ drivers/crypto/ycc/ycc_ring.h | 170 ++++++ drivers/crypto/ycc/ycc_ske.c | 925 ++++++++++++++++++++++++++++++++ 17 files changed, 4612 insertions(+) create mode 100644 drivers/crypto/ycc/Kconfig create mode 100644 drivers/crypto/ycc/Makefile create mode 100644 drivers/crypto/ycc/sm2signature_asn1.c create mode 100644 drivers/crypto/ycc/sm2signature_asn1.h create mode 100644 drivers/crypto/ycc/ycc_aead.c create mode 100644 drivers/crypto/ycc/ycc_algs.h create mode 100644 drivers/crypto/ycc/ycc_dev.h create mode 100644 drivers/crypto/ycc/ycc_drv.c create mode 100644 drivers/crypto/ycc/ycc_isr.c create mode 100644 drivers/crypto/ycc/ycc_isr.h create mode 100644 drivers/crypto/ycc/ycc_pke.c create mode 100644 drivers/crypto/ycc/ycc_ring.c create mode 100644 drivers/crypto/ycc/ycc_ring.h create mode 100644 drivers/crypto/ycc/ycc_ske.c -- 1.8.3.1