| From: Leon Romanovsky <leonro@nvidia.com> |
| Date: Sat, 25 Sep 2021 14:22:55 +0300 |
| Subject: qed: Move devlink registration to be last devlink command |
| Patch-mainline: v5.16-rc1 |
| Git-commit: 1b8e0bdbea654bd11d285e4e01e68b3bdab196b4 |
| References: jsc#SLE-19001 |
| |
| 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> |
| Acked-by: Thomas Bogendoerfer <tbogendoerfer@suse.de> |
| |
| drivers/net/ethernet/qlogic/qed/qed_devlink.c | 7 ++----- |
| 1 file changed, 2 insertions(+), 5 deletions(-) |
| |
| |
| |
| @@ -215,7 +215,6 @@ struct devlink *qed_devlink_register(str |
| 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(str |
| 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 devli |
| 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); |
| } |