mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-07 19:30:30 +09:00
net: hns3: Check variable is valid before assigning it to another
[ Upstream commit 676131f7c5 ]
In hnae3_register_ae_dev(), ae_algo->ops is assigned to ae_dev->ops
before check that ae_algo->ops is valid.
And in hnae3_register_ae_algo(), missing check for ae_algo->ops.
This patch fixes them.
Signed-off-by: Yonglong Liu <liuyonglong@huawei.com>
Signed-off-by: Peng Li <lipeng321@huawei.com>
Signed-off-by: Huazhong Tan <tanhuazhong@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
1f10b277ff
commit
84d3454ee8
@@ -173,8 +173,12 @@ void hnae3_register_ae_algo(struct hnae3_ae_algo *ae_algo)
|
||||
if (!id)
|
||||
continue;
|
||||
|
||||
/* ae_dev init should set flag */
|
||||
if (!ae_algo->ops) {
|
||||
dev_err(&ae_dev->pdev->dev, "ae_algo ops are null\n");
|
||||
continue;
|
||||
}
|
||||
ae_dev->ops = ae_algo->ops;
|
||||
|
||||
ret = ae_algo->ops->init_ae_dev(ae_dev);
|
||||
if (ret) {
|
||||
dev_err(&ae_dev->pdev->dev,
|
||||
@@ -182,6 +186,7 @@ void hnae3_register_ae_algo(struct hnae3_ae_algo *ae_algo)
|
||||
continue;
|
||||
}
|
||||
|
||||
/* ae_dev init should set flag */
|
||||
hnae3_set_bit(ae_dev->flag, HNAE3_DEV_INITED_B, 1);
|
||||
|
||||
/* check the client list for the match with this ae_dev type and
|
||||
@@ -256,15 +261,13 @@ int hnae3_register_ae_dev(struct hnae3_ae_dev *ae_dev)
|
||||
if (!id)
|
||||
continue;
|
||||
|
||||
ae_dev->ops = ae_algo->ops;
|
||||
|
||||
if (!ae_dev->ops) {
|
||||
dev_err(&ae_dev->pdev->dev, "ae_dev ops are null\n");
|
||||
if (!ae_algo->ops) {
|
||||
dev_err(&ae_dev->pdev->dev, "ae_algo ops are null\n");
|
||||
ret = -EOPNOTSUPP;
|
||||
goto out_err;
|
||||
}
|
||||
ae_dev->ops = ae_algo->ops;
|
||||
|
||||
/* ae_dev init should set flag */
|
||||
ret = ae_dev->ops->init_ae_dev(ae_dev);
|
||||
if (ret) {
|
||||
dev_err(&ae_dev->pdev->dev,
|
||||
@@ -272,6 +275,7 @@ int hnae3_register_ae_dev(struct hnae3_ae_dev *ae_dev)
|
||||
goto out_err;
|
||||
}
|
||||
|
||||
/* ae_dev init should set flag */
|
||||
hnae3_set_bit(ae_dev->flag, HNAE3_DEV_INITED_B, 1);
|
||||
break;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user