Commit 086ab54a authored by Tomer Tayar's avatar Tomer Tayar Committed by Oded Gabbay

habanalabs: skip device idle check in hpriv_release if in reset

When user context is released and hpriv_release() is called, there is a
device idle status check, to understand if user has left the device not
idle and then a reset is required.

However, if the user process is killed because of device hard reset,
the device at this point would always be not idle, because the device
engines were already forcefully halted.

Modify hpriv_release() to skip the idle check if reset is in progress.
Signed-off-by: default avatarTomer Tayar <ttayar@habana.ai>
Reviewed-by: default avatarOded Gabbay <ogabbay@kernel.org>
Signed-off-by: default avatarOded Gabbay <ogabbay@kernel.org>
parent 853413b2
...@@ -428,8 +428,10 @@ static void hpriv_release(struct kref *ref) ...@@ -428,8 +428,10 @@ static void hpriv_release(struct kref *ref)
*/ */
reset_device = hdev->reset_upon_device_release || hdev->reset_info.watchdog_active; reset_device = hdev->reset_upon_device_release || hdev->reset_info.watchdog_active;
/* Unless device is reset in any case, check idle status and reset if device is not idle */ /* Check the device idle status and reset if not idle.
if (!reset_device && hdev->pdev && !hdev->pldm) * Skip it if already in reset, or if device is going to be reset in any case.
*/
if (!hdev->reset_info.in_reset && !reset_device && hdev->pdev && !hdev->pldm)
device_is_idle = hdev->asic_funcs->is_device_idle(hdev, idle_mask, device_is_idle = hdev->asic_funcs->is_device_idle(hdev, idle_mask,
HL_BUSY_ENGINES_MASK_EXT_SIZE, NULL); HL_BUSY_ENGINES_MASK_EXT_SIZE, NULL);
if (!device_is_idle) { if (!device_is_idle) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment