net: hns3: Check variable is valid before assigning it to another
authorYonglong Liu <liuyonglong@huawei.com>
Wed, 20 Feb 2019 02:32:41 +0000 (10:32 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 17 Dec 2019 19:35:34 +0000 (20:35 +0100)
[ Upstream commit 676131f7c53ecdd79e29fc8cfcdefe6f9f2485e8 ]

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>
drivers/net/ethernet/hisilicon/hns3/hnae3.c

index f98bff6..f9259e5 100644 (file)
@@ -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;
        }