qed: Move devlink registration to be last devlink command
authorLeon Romanovsky <leonro@nvidia.com>
Sat, 25 Sep 2021 11:22:55 +0000 (14:22 +0300)
committerDavid S. Miller <davem@davemloft.net>
Mon, 27 Sep 2021 15:31:59 +0000 (16:31 +0100)
This change prevents from users to access device before devlink is
fully configured.

Signed-off-by: Leon Romanovsky <leonro@nvidia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/qlogic/qed/qed_devlink.c

index c51f959..6bb4e16 100644 (file)
@@ -215,7 +215,6 @@ struct devlink *qed_devlink_register(struct qed_dev *cdev)
        qdevlink = devlink_priv(dl);
        qdevlink->cdev = cdev;
 
-       devlink_register(dl);
        rc = devlink_params_register(dl, qed_devlink_params,
                                     ARRAY_SIZE(qed_devlink_params));
        if (rc)
@@ -226,15 +225,13 @@ struct devlink *qed_devlink_register(struct qed_dev *cdev)
                                           QED_DEVLINK_PARAM_ID_IWARP_CMT,
                                           value);
 
-       devlink_params_publish(dl);
        cdev->iwarp_cmt = false;
 
        qed_fw_reporters_create(dl);
-
+       devlink_register(dl);
        return dl;
 
 err_unregister:
-       devlink_unregister(dl);
        devlink_free(dl);
 
        return ERR_PTR(rc);
@@ -245,11 +242,11 @@ void qed_devlink_unregister(struct devlink *devlink)
        if (!devlink)
                return;
 
+       devlink_unregister(devlink);
        qed_fw_reporters_destroy(devlink);
 
        devlink_params_unregister(devlink, qed_devlink_params,
                                  ARRAY_SIZE(qed_devlink_params));
 
-       devlink_unregister(devlink);
        devlink_free(devlink);
 }