Received: by 2002:a25:23cc:0:0:0:0:0 with SMTP id j195csp1399743ybj; Thu, 7 May 2020 23:59:53 -0700 (PDT) X-Google-Smtp-Source: APiQypLukwssZP+Wr3lVPNSDFDfMYRXH8Zb5CCe4EaEdfGEQklRa1wbwuJ4vYW+W7koaBeQO/7cf X-Received: by 2002:a17:906:748c:: with SMTP id e12mr623062ejl.375.1588921193732; Thu, 07 May 2020 23:59:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588921193; cv=none; d=google.com; s=arc-20160816; b=cSGs8/0PZrEBTRLOkJGr7NKuchPiq7zf619BDgHY7Jq1yXpmXl+6w9AILgH9lFwEPi xtsEmMo0euYD6YWiI0OwSPd1xyw+Gcf0hwmN6LhROQ0CmWvejYuSmzo/jdXoqvuqTqGS V3a97dNwquJitboAwVxSGN780Gvwq3H/GeQAre8t5Bgnp/lLGYEI3QZq6Bgo2fSUr1kw zrohU7OPOlx7/Kd/+VWmZfg4VJnYl+tgGpyMrs/jphqhahq6wh5MjiD5jHNRNZlcq1Fb EAkHjSDgRRGinm5rHUZxiONTuRqgqD7yB/umXwfnKtK8z5BivnNMJrWTrTZGLogbg/Bs D/Ng== 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=V+eVA4dx7cGQQa0mFNQJADI2TIXRzml91KOU1iIuYdQ=; b=QPIEJOBn7HxIvBLQJnfOi5m3NAwpGGN3HGfJows3FcYKbdCtnz5XHNBdeqMiWyfMsV pJNymWRttayCVs3MoPFEy0o6nB6aXbEl6mcNmAVxXKqVop1b8p0yfoqkcHTMYwsp28N6 KQXBeL9CGku3BrnAEHTUMSFOAWAGd3JV/NeAJbishxHrhHJTuAr0t8eHykIRiO0UmNkg EMhqEHFNC0n2vQ3kzBt0WzPOOPaH528DW4n3ZEJdyi1T2VvnzmwIJBvJnfYZJ4t2IKYb /he42oVWVLuaGi6HvbDrTV0nnGj4I0cHmsVqGjAT9pOGI0maEHP3Mtv6kmdilsqYAKTf 28zA== 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 bd6si481068edb.277.2020.05.07.23.59.30; Thu, 07 May 2020 23:59:53 -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 S1726770AbgEHG7E (ORCPT + 99 others); Fri, 8 May 2020 02:59:04 -0400 Received: from szxga06-in.huawei.com ([45.249.212.32]:42608 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726767AbgEHG7D (ORCPT ); Fri, 8 May 2020 02:59:03 -0400 Received: from DGGEMS411-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id EE0E64678534578F6ED2; Fri, 8 May 2020 14:58:59 +0800 (CST) Received: from localhost.localdomain (10.69.192.56) by DGGEMS411-HUB.china.huawei.com (10.3.19.211) with Microsoft SMTP Server id 14.3.487.0; Fri, 8 May 2020 14:58:52 +0800 From: Shukun Tan To: , CC: , , Subject: [PATCH 02/13] crypto: hisilicon/hpre - modify the HPRE probe process Date: Fri, 8 May 2020 14:57:37 +0800 Message-ID: <1588921068-20739-3-git-send-email-tanshukun1@huawei.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1588921068-20739-1-git-send-email-tanshukun1@huawei.com> References: <1588921068-20739-1-git-send-email-tanshukun1@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 From: Longfang Liu Misc fixes on coding style: 1.Merge pre-initialization and initialization of QM 2.Package the initialization of QM's PF and VF into a function Signed-off-by: Longfang Liu Signed-off-by: Zaibo Xu Signed-off-by: Shukun Tan --- drivers/crypto/hisilicon/hpre/hpre_main.c | 42 ++++++++++++++++++------------- 1 file changed, 25 insertions(+), 17 deletions(-) diff --git a/drivers/crypto/hisilicon/hpre/hpre_main.c b/drivers/crypto/hisilicon/hpre/hpre_main.c index 0d63666..f3859de 100644 --- a/drivers/crypto/hisilicon/hpre/hpre_main.c +++ b/drivers/crypto/hisilicon/hpre/hpre_main.c @@ -666,7 +666,7 @@ static void hpre_debugfs_exit(struct hpre *hpre) debugfs_remove_recursive(qm->debug.debug_root); } -static int hpre_qm_pre_init(struct hisi_qm *qm, struct pci_dev *pdev) +static int hpre_qm_init(struct hisi_qm *qm, struct pci_dev *pdev) { enum qm_hw_ver rev_id; @@ -685,13 +685,14 @@ static int hpre_qm_pre_init(struct hisi_qm *qm, struct pci_dev *pdev) qm->dev_name = hpre_name; qm->fun_type = (pdev->device == HPRE_PCI_DEVICE_ID) ? QM_HW_PF : QM_HW_VF; + if (pdev->is_physfn) { qm->qp_base = HPRE_PF_DEF_Q_BASE; qm->qp_num = hpre_pf_q_num; } qm->use_dma_api = true; - return 0; + return hisi_qm_init(qm); } static void hpre_log_hw_error(struct hisi_qm *qm, u32 err_sts) @@ -766,6 +767,20 @@ static int hpre_pf_probe_init(struct hpre *hpre) return 0; } +static int hpre_probe_init(struct hpre *hpre) +{ + struct hisi_qm *qm = &hpre->qm; + int ret = -ENODEV; + + if (qm->fun_type == QM_HW_PF) + ret = hpre_pf_probe_init(hpre); + else if (qm->fun_type == QM_HW_VF && qm->ver == QM_HW_V2) + /* v2 starts to support get vft by mailbox */ + ret = hisi_qm_get_vft(qm, &qm->qp_base, &qm->qp_num); + + return ret; +} + static int hpre_probe(struct pci_dev *pdev, const struct pci_device_id *id) { struct hisi_qm *qm; @@ -779,23 +794,16 @@ static int hpre_probe(struct pci_dev *pdev, const struct pci_device_id *id) pci_set_drvdata(pdev, hpre); qm = &hpre->qm; - ret = hpre_qm_pre_init(qm, pdev); - if (ret) - return ret; - - ret = hisi_qm_init(qm); - if (ret) + ret = hpre_qm_init(qm, pdev); + if (ret) { + pci_err(pdev, "Failed to init HPRE QM (%d)!\n", ret); return ret; + } - if (pdev->is_physfn) { - ret = hpre_pf_probe_init(hpre); - if (ret) - goto err_with_qm_init; - } else if (qm->fun_type == QM_HW_VF && qm->ver == QM_HW_V2) { - /* v2 starts to support get vft by mailbox */ - ret = hisi_qm_get_vft(qm, &qm->qp_base, &qm->qp_num); - if (ret) - goto err_with_qm_init; + ret = hpre_probe_init(hpre); + if (ret) { + pci_err(pdev, "Failed to probe (%d)!\n", ret); + goto err_with_qm_init; } ret = hisi_qm_start(qm); -- 2.7.4