}
 }
 
-static void mlx5_sync_reset_reload_work(struct work_struct *work)
-{
-       struct mlx5_fw_reset *fw_reset = container_of(work, struct mlx5_fw_reset,
-                                                     reset_reload_work);
-       struct mlx5_core_dev *dev = fw_reset->dev;
-       int err;
-
-       mlx5_enter_error_state(dev, true);
-       mlx5_unload_one(dev);
-       err = mlx5_health_wait_pci_up(dev);
-       if (err)
-               mlx5_core_err(dev, "reset reload flow aborted, PCI reads still not working\n");
-       fw_reset->ret = err;
-       mlx5_fw_reset_complete_reload(dev);
-}
-
 static void mlx5_stop_sync_reset_poll(struct mlx5_core_dev *dev)
 {
        struct mlx5_fw_reset *fw_reset = dev->priv.fw_reset;
                mlx5_start_health_poll(dev);
 }
 
+static void mlx5_sync_reset_reload_work(struct work_struct *work)
+{
+       struct mlx5_fw_reset *fw_reset = container_of(work, struct mlx5_fw_reset,
+                                                     reset_reload_work);
+       struct mlx5_core_dev *dev = fw_reset->dev;
+       int err;
+
+       mlx5_sync_reset_clear_reset_requested(dev, false);
+       mlx5_enter_error_state(dev, true);
+       mlx5_unload_one(dev);
+       err = mlx5_health_wait_pci_up(dev);
+       if (err)
+               mlx5_core_err(dev, "reset reload flow aborted, PCI reads still not working\n");
+       fw_reset->ret = err;
+       mlx5_fw_reset_complete_reload(dev);
+}
+
 #define MLX5_RESET_POLL_INTERVAL       (HZ / 10)
 static void poll_sync_reset(struct timer_list *t)
 {
 
        if (fatal_error) {
                mlx5_core_warn(dev, "Got Device Reset\n");
-               mlx5_sync_reset_clear_reset_requested(dev, false);
                queue_work(fw_reset->wq, &fw_reset->reset_reload_work);
                return;
        }