提交 e04728ed 编写于 作者: W Weili Qian 提交者: Zheng Zengkai

crypto: hisilicon/qm - split 'hisi_qm_init' into smaller pieces

mainline inclusion
from mainline-v5.11-rc1
commit fefc046f
category: bugfix
bugzilla: 173981
CVE: NA

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=fefc046f2b0e0bdbd4d5944f6b489039678e001e

----------------------------------------------------------------------

'hisi_qm_init' initializes configuration of QM.
To improve code readability, split it into two pieces.
Signed-off-by: NWeili Qian <qianweili@huawei.com>
Reviewed-by: NZhou Wang <wangzhou1@hisilicon.com>
Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: NMingqiang Ling <lingmingqiang@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 dbc25c13
...@@ -2442,6 +2442,16 @@ static void hisi_qm_pre_init(struct hisi_qm *qm) ...@@ -2442,6 +2442,16 @@ static void hisi_qm_pre_init(struct hisi_qm *qm)
qm->is_frozen = false; qm->is_frozen = false;
} }
static void hisi_qm_pci_uninit(struct hisi_qm *qm)
{
struct pci_dev *pdev = qm->pdev;
pci_free_irq_vectors(pdev);
iounmap(qm->io_base);
pci_release_mem_regions(pdev);
pci_disable_device(pdev);
}
/** /**
* hisi_qm_uninit() - Uninitialize qm. * hisi_qm_uninit() - Uninitialize qm.
* @qm: The qm needed uninit. * @qm: The qm needed uninit.
...@@ -2460,9 +2470,6 @@ void hisi_qm_uninit(struct hisi_qm *qm) ...@@ -2460,9 +2470,6 @@ void hisi_qm_uninit(struct hisi_qm *qm)
return; return;
} }
uacce_remove(qm->uacce);
qm->uacce = NULL;
hisi_qp_memory_uninit(qm, qm->qp_num); hisi_qp_memory_uninit(qm, qm->qp_num);
idr_destroy(&qm->qp_idr); idr_destroy(&qm->qp_idr);
...@@ -2474,10 +2481,9 @@ void hisi_qm_uninit(struct hisi_qm *qm) ...@@ -2474,10 +2481,9 @@ void hisi_qm_uninit(struct hisi_qm *qm)
} }
qm_irq_unregister(qm); qm_irq_unregister(qm);
pci_free_irq_vectors(pdev); hisi_qm_pci_uninit(qm);
iounmap(qm->io_base); uacce_remove(qm->uacce);
pci_release_mem_regions(pdev); qm->uacce = NULL;
pci_disable_device(pdev);
up_write(&qm->qps_lock); up_write(&qm->qps_lock);
} }
...@@ -4038,34 +4044,22 @@ void hisi_qm_alg_unregister(struct hisi_qm *qm, struct hisi_qm_list *qm_list) ...@@ -4038,34 +4044,22 @@ void hisi_qm_alg_unregister(struct hisi_qm *qm, struct hisi_qm_list *qm_list)
} }
EXPORT_SYMBOL_GPL(hisi_qm_alg_unregister); EXPORT_SYMBOL_GPL(hisi_qm_alg_unregister);
/** static int hisi_qm_pci_init(struct hisi_qm *qm)
* hisi_qm_init() - Initialize configures about qm.
* @qm: The qm needing init.
*
* This function init qm, then we can call hisi_qm_start to put qm into work.
*/
int hisi_qm_init(struct hisi_qm *qm)
{ {
struct pci_dev *pdev = qm->pdev; struct pci_dev *pdev = qm->pdev;
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
unsigned int num_vec; unsigned int num_vec;
int ret; int ret;
hisi_qm_pre_init(qm);
ret = qm_alloc_uacce(qm);
if (ret < 0)
dev_warn(&pdev->dev, "fail to alloc uacce (%d)\n", ret);
ret = pci_enable_device_mem(pdev); ret = pci_enable_device_mem(pdev);
if (ret < 0) { if (ret < 0) {
dev_err(&pdev->dev, "Failed to enable device mem!\n"); dev_err(dev, "Failed to enable device mem!\n");
goto err_remove_uacce; return ret;
} }
ret = pci_request_mem_regions(pdev, qm->dev_name); ret = pci_request_mem_regions(pdev, qm->dev_name);
if (ret < 0) { if (ret < 0) {
dev_err(&pdev->dev, "Failed to request mem regions!\n"); dev_err(dev, "Failed to request mem regions!\n");
goto err_disable_pcidev; goto err_disable_pcidev;
} }
...@@ -4093,9 +4087,42 @@ int hisi_qm_init(struct hisi_qm *qm) ...@@ -4093,9 +4087,42 @@ int hisi_qm_init(struct hisi_qm *qm)
goto err_iounmap; goto err_iounmap;
} }
return 0;
err_iounmap:
iounmap(qm->io_base);
err_release_mem_regions:
pci_release_mem_regions(pdev);
err_disable_pcidev:
pci_disable_device(pdev);
return ret;
}
/**
* hisi_qm_init() - Initialize configures about qm.
* @qm: The qm needing init.
*
* This function init qm, then we can call hisi_qm_start to put qm into work.
*/
int hisi_qm_init(struct hisi_qm *qm)
{
struct pci_dev *pdev = qm->pdev;
struct device *dev = &pdev->dev;
int ret;
hisi_qm_pre_init(qm);
ret = qm_alloc_uacce(qm);
if (ret < 0)
dev_warn(dev, "fail to alloc uacce (%d)\n", ret);
ret = hisi_qm_pci_init(qm);
if (ret)
goto err_remove_uacce;
ret = qm_irq_register(qm); ret = qm_irq_register(qm);
if (ret) if (ret)
goto err_free_irq_vectors; goto err_pci_uninit;
if (qm->fun_type == QM_HW_VF && qm->ver != QM_HW_V1) { if (qm->fun_type == QM_HW_VF && qm->ver != QM_HW_V1) {
/* v2 starts to support get vft by mailbox */ /* v2 starts to support get vft by mailbox */
...@@ -4118,14 +4145,8 @@ int hisi_qm_init(struct hisi_qm *qm) ...@@ -4118,14 +4145,8 @@ int hisi_qm_init(struct hisi_qm *qm)
err_irq_unregister: err_irq_unregister:
qm_irq_unregister(qm); qm_irq_unregister(qm);
err_free_irq_vectors: err_pci_uninit:
pci_free_irq_vectors(pdev); hisi_qm_pci_uninit(qm);
err_iounmap:
iounmap(qm->io_base);
err_release_mem_regions:
pci_release_mem_regions(pdev);
err_disable_pcidev:
pci_disable_device(pdev);
err_remove_uacce: err_remove_uacce:
uacce_remove(qm->uacce); uacce_remove(qm->uacce);
qm->uacce = NULL; qm->uacce = NULL;
...@@ -4133,7 +4154,6 @@ int hisi_qm_init(struct hisi_qm *qm) ...@@ -4133,7 +4154,6 @@ int hisi_qm_init(struct hisi_qm *qm)
} }
EXPORT_SYMBOL_GPL(hisi_qm_init); EXPORT_SYMBOL_GPL(hisi_qm_init);
MODULE_LICENSE("GPL v2"); MODULE_LICENSE("GPL v2");
MODULE_AUTHOR("Zhou Wang <wangzhou1@hisilicon.com>"); MODULE_AUTHOR("Zhou Wang <wangzhou1@hisilicon.com>");
MODULE_DESCRIPTION("HiSilicon Accelerator queue manager driver"); MODULE_DESCRIPTION("HiSilicon Accelerator queue manager driver");
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册