Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2976841ybt; Mon, 29 Jun 2020 11:57:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwD97xLzA0qanc8BcKum83UstUK7T/hggeBoKIYWTe1i9STHREX7y24Sq3wGQs5p7xzh7hc X-Received: by 2002:a05:6402:22f0:: with SMTP id dn16mr19344584edb.83.1593457058977; Mon, 29 Jun 2020 11:57:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593457058; cv=none; d=google.com; s=arc-20160816; b=ZioESgnH21qFyEvr5rS9+EhT+mLMSduzSTJ4F60kxIzGvG/PmkaqHZox4J///eq5F1 Pve3tFxYKZZFC3L9gfSOwXFYL1JdtjQf4+GLzQe6emeojEohuibelhVHJwr8ussg0mZx 01a16nA7b6Fm+ZXJVgMcY2Y0p21OzKtmE3yP3kxOJ2VYc6o4KWwFvhihJkw0YUcBd0qt Y10ZGQqa+R/5r5D9AqIFQhfooWukknOvhbQHzRgR3WS+aYOrq9Bp5jCeIDLWW3PqzlAM IeIulwXFox6phnvz3uUmrUcZ84sKx15hTpIflT5kSci48PeGBUVdDcgDRCUdcV53oERj 937A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from; bh=BjuyXBEc8XNgBKDehQHdSYhMj7fvacXdhYg5v79xKqc=; b=XfRp9DyW+LWO76q4KylaC3zp8As0cUh29LyiTYy7tLv86itwiRtKukabw6vrYcG2ju r35yyCncjqZRA7ylQ4vPRpd+wyWSmvqsl+Fhmyr2PdzCnJTpKatEOpVf6WnJHlr3rJDA BtjnyPChkIludImKmMLZt3EwE0durJGYCoH+T8rsLDU0MDotW6+Fb/6yBYWiRuQT21ac /3Y7ob0GpLpYH764eV7LQ3DhQJdv798bvwaiticgjOY9hQHC9+RG17+0mg6dTJWdB+TC 9MZ0SZIEkyovHutiwyoxlOShDJSFXQCtAJpa0xn0WNR8NLy6nrmyr28X8/p88FE+v6SY 4DQA== 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 lj13si271956ejb.357.2020.06.29.11.57.15; Mon, 29 Jun 2020 11:57:38 -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 S1726920AbgF2S5J (ORCPT + 99 others); Mon, 29 Jun 2020 14:57:09 -0400 Received: from szxga06-in.huawei.com ([45.249.212.32]:59620 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1729600AbgF2S5H (ORCPT ); Mon, 29 Jun 2020 14:57:07 -0400 Received: from DGGEMS405-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 4B647F433ACF9740B672; Mon, 29 Jun 2020 19:10:58 +0800 (CST) Received: from localhost.localdomain (10.69.192.56) by DGGEMS405-HUB.china.huawei.com (10.3.19.205) with Microsoft SMTP Server id 14.3.487.0; Mon, 29 Jun 2020 19:10:47 +0800 From: Yang Shen To: , CC: , , Subject: [PATCH 9/9] crypto: hisilicon/qm - register callback function to 'pci_driver.shutdown' Date: Mon, 29 Jun 2020 19:09:08 +0800 Message-ID: <1593428948-64634-10-git-send-email-shenyang39@huawei.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1593428948-64634-1-git-send-email-shenyang39@huawei.com> References: <1593428948-64634-1-git-send-email-shenyang39@huawei.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.69.192.56] X-CFilter-Loop: Reflected Sender: linux-crypto-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org Since the drivers such as HPRE/SEC/ZIP do not implement 'pci_driver.shutdow', a RAS will be triggered at OS rebooting or shutting down as the hardware device is processing request. The log looks like this: NOTICE: [NimbusSecNodeType1]:[2372L]This is sec, Base = 0x141800000 NOTICE: [NimbusSecHandle]:[2319L] SecIntSt = 0x3 NOTICE: [NimbusSecHandle]:[2320L] SecQmIntStatus = 0x2 NOTICE: [PrintSecurityType]:[344L] SecurityType is RECOVERABLE! This patch offers a new API in qm to shutdown devices, and add shutdown callbacks in ACC driver based on this new API. So the running devices will be stopped when the OS reboot or shutdown. Signed-off-by: Yang Shen --- drivers/crypto/hisilicon/hpre/hpre_main.c | 1 + drivers/crypto/hisilicon/qm.c | 17 +++++++++++++++++ drivers/crypto/hisilicon/qm.h | 1 + drivers/crypto/hisilicon/sec2/sec_main.c | 1 + drivers/crypto/hisilicon/zip/zip_main.c | 1 + 5 files changed, 21 insertions(+) diff --git a/drivers/crypto/hisilicon/hpre/hpre_main.c b/drivers/crypto/hisilicon/hpre/hpre_main.c index 360bdb0..52d605b 100644 --- a/drivers/crypto/hisilicon/hpre/hpre_main.c +++ b/drivers/crypto/hisilicon/hpre/hpre_main.c @@ -928,6 +928,7 @@ static struct pci_driver hpre_pci_driver = { .remove = hpre_remove, .sriov_configure = hisi_qm_sriov_configure, .err_handler = &hpre_err_handler, + .shutdown = hisi_qm_dev_shutdown, }; static void hpre_register_debugfs(void) diff --git a/drivers/crypto/hisilicon/qm.c b/drivers/crypto/hisilicon/qm.c index 8327365..0920d77 100644 --- a/drivers/crypto/hisilicon/qm.c +++ b/drivers/crypto/hisilicon/qm.c @@ -3853,6 +3853,23 @@ static int qm_irq_register(struct hisi_qm *qm) return ret; } +/** + * hisi_qm_dev_shutdown() - Shutdown device. + * @pdev: The device will be shutdown. + * + * This function will stop qm when OS shutdown or rebooting. + */ +void hisi_qm_dev_shutdown(struct pci_dev *pdev) +{ + struct hisi_qm *qm = pci_get_drvdata(pdev); + int ret; + + ret = hisi_qm_stop(qm, QM_NORMAL); + if (ret) + dev_err(&pdev->dev, "Fail to stop qm in shutdown!\n"); +} +EXPORT_SYMBOL_GPL(hisi_qm_dev_shutdown); + static void hisi_qm_controller_reset(struct work_struct *rst_work) { struct hisi_qm *qm = container_of(rst_work, struct hisi_qm, rst_work); diff --git a/drivers/crypto/hisilicon/qm.h b/drivers/crypto/hisilicon/qm.h index bd00897..233ed09e 100644 --- a/drivers/crypto/hisilicon/qm.h +++ b/drivers/crypto/hisilicon/qm.h @@ -378,4 +378,5 @@ int hisi_qm_alloc_qps_node(struct hisi_qm_list *qm_list, int qp_num, void hisi_qm_free_qps(struct hisi_qp **qps, int qp_num); int hisi_qm_alg_register(struct hisi_qm *qm, struct hisi_qm_list *qm_list); void hisi_qm_alg_unregister(struct hisi_qm *qm, struct hisi_qm_list *qm_list); +void hisi_qm_dev_shutdown(struct pci_dev *pdev); #endif diff --git a/drivers/crypto/hisilicon/sec2/sec_main.c b/drivers/crypto/hisilicon/sec2/sec_main.c index d9c162d2..a146095 100644 --- a/drivers/crypto/hisilicon/sec2/sec_main.c +++ b/drivers/crypto/hisilicon/sec2/sec_main.c @@ -949,6 +949,7 @@ static struct pci_driver sec_pci_driver = { .remove = sec_remove, .err_handler = &sec_err_handler, .sriov_configure = hisi_qm_sriov_configure, + .shutdown = hisi_qm_dev_shutdown, }; static void sec_register_debugfs(void) diff --git a/drivers/crypto/hisilicon/zip/zip_main.c b/drivers/crypto/hisilicon/zip/zip_main.c index 72e2cc0..beeb20e 100644 --- a/drivers/crypto/hisilicon/zip/zip_main.c +++ b/drivers/crypto/hisilicon/zip/zip_main.c @@ -879,6 +879,7 @@ static struct pci_driver hisi_zip_pci_driver = { .sriov_configure = IS_ENABLED(CONFIG_PCI_IOV) ? hisi_qm_sriov_configure : NULL, .err_handler = &hisi_zip_err_handler, + .shutdown = hisi_qm_dev_shutdown, }; static void hisi_zip_register_debugfs(void) -- 2.7.4