int (*sw_init)(struct hl_device *hdev);
        int (*sw_fini)(struct hl_device *hdev);
        int (*hw_init)(struct hl_device *hdev);
-       void (*hw_fini)(struct hl_device *hdev, bool hard_reset, bool fw_reset);
+       int (*hw_fini)(struct hl_device *hdev, bool hard_reset, bool fw_reset);
        void (*halt_engines)(struct hl_device *hdev, bool hard_reset, bool fw_reset);
        int (*suspend)(struct hl_device *hdev);
        int (*resume)(struct hl_device *hdev);
 
        return rc;
 }
 
-static void gaudi_hw_fini(struct hl_device *hdev, bool hard_reset, bool fw_reset)
+static int gaudi_hw_fini(struct hl_device *hdev, bool hard_reset, bool fw_reset)
 {
        struct cpu_dyn_regs *dyn_regs =
                        &hdev->fw_loader.dynamic_loader.comm_desc.cpu_dyn_regs;
 
        if (!hard_reset) {
                dev_err(hdev->dev, "GAUDI doesn't support soft-reset\n");
-               return;
+               return 0;
        }
 
        if (hdev->pldm) {
 
                hdev->device_cpu_is_halted = false;
        }
+       return 0;
 }
 
 static int gaudi_suspend(struct hl_device *hdev)
 
                                reg_val);
 }
 
-static void gaudi2_hw_fini(struct hl_device *hdev, bool hard_reset, bool fw_reset)
+static int gaudi2_hw_fini(struct hl_device *hdev, bool hard_reset, bool fw_reset)
 {
        struct gaudi2_device *gaudi2 = hdev->asic_specific;
        u32 poll_timeout_us, reset_sleep_ms;
                gaudi2_get_soft_rst_done_indication(hdev, poll_timeout_us);
 
        if (!gaudi2)
-               return;
+               return 0;
 
        gaudi2->dec_hw_cap_initialized &= ~(HW_CAP_DEC_MASK);
        gaudi2->tpc_hw_cap_initialized &= ~(HW_CAP_TPC_MASK);
                        HW_CAP_PDMA_MASK | HW_CAP_EDMA_MASK | HW_CAP_MME_MASK |
                        HW_CAP_ROT_MASK);
        }
+       return 0;
 }
 
 static int gaudi2_suspend(struct hl_device *hdev)
 
        return rc;
 }
 
-static void goya_hw_fini(struct hl_device *hdev, bool hard_reset, bool fw_reset)
+static int goya_hw_fini(struct hl_device *hdev, bool hard_reset, bool fw_reset)
 {
        struct goya_device *goya = hdev->asic_specific;
        u32 reset_timeout_ms, cpu_timeout_ms, status;
                                                HW_CAP_GOLDEN | HW_CAP_TPC);
                WREG32(mmGIC_DISTRIBUTOR__5_GICD_SETSPI_NSR,
                                GOYA_ASYNC_EVENT_ID_SOFT_RESET);
-               return;
+               return 0;
        }
 
        /* Chicken bit to re-initiate boot sequencer flow */
 
                memset(goya->events_stat, 0, sizeof(goya->events_stat));
        }
+       return 0;
 }
 
 int goya_suspend(struct hl_device *hdev)