staging: qlge: deal with the case that devlink_health_reporter_create fails
authorCoiby Xu <coiby.xu@gmail.com>
Wed, 24 Mar 2021 01:00:01 +0000 (09:00 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 26 Mar 2021 13:58:13 +0000 (14:58 +0100)
devlink_health_reporter_create may fail. In that case, do the cleanup
work.

Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Coiby Xu <coxu@redhat.com>
Link: https://lore.kernel.org/r/20210324010002.109846-1-coxu@redhat.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/qlge/qlge_devlink.c
drivers/staging/qlge/qlge_devlink.h
drivers/staging/qlge/qlge_main.c

index 86834d96cebf39610b28bd442788badaf04db7ce..0ab02d6d3817b77c71e2e7444bbf06a630ae4515 100644 (file)
@@ -148,16 +148,20 @@ static const struct devlink_health_reporter_ops qlge_reporter_ops = {
        .dump = qlge_reporter_coredump,
 };
 
-void qlge_health_create_reporters(struct qlge_adapter *priv)
+long qlge_health_create_reporters(struct qlge_adapter *priv)
 {
        struct devlink *devlink;
+       long err = 0;
 
        devlink = priv_to_devlink(priv);
        priv->reporter =
                devlink_health_reporter_create(devlink, &qlge_reporter_ops,
                                               0, priv);
-       if (IS_ERR(priv->reporter))
+       if (IS_ERR(priv->reporter)) {
+               err = PTR_ERR(priv->reporter);
                netdev_warn(priv->ndev,
                            "Failed to create reporter, err = %ld\n",
-                           PTR_ERR(priv->reporter));
+                           err);
+       }
+       return err;
 }
index 19078e1ac6944f569c2a15e7443041d32290c37d..94538e923f2fb0fb006da04b5f35c145f88c91e9 100644 (file)
@@ -4,6 +4,6 @@
 
 #include <net/devlink.h>
 
-void qlge_health_create_reporters(struct qlge_adapter *priv);
+long qlge_health_create_reporters(struct qlge_adapter *priv);
 
 #endif /* QLGE_DEVLINK_H */
index e11470910ef35f975cb82c300c1db859101878fd..c9dc6a852af4aac0ba42b1987c62d1c3025a829b 100644 (file)
@@ -4621,7 +4621,11 @@ static int qlge_probe(struct pci_dev *pdev,
        if (err)
                goto netdev_free;
 
-       qlge_health_create_reporters(qdev);
+       err = qlge_health_create_reporters(qdev);
+
+       if (err)
+               goto devlink_unregister;
+
        /* Start up the timer to trigger EEH if
         * the bus goes dead
         */
@@ -4633,6 +4637,8 @@ static int qlge_probe(struct pci_dev *pdev,
        cards_found++;
        return 0;
 
+devlink_unregister:
+       devlink_unregister(devlink);
 netdev_free:
        free_netdev(ndev);
 devlink_free: