]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
accel/habanalabs: set hard reset flag if graceful reset is skipped
authorTomer Tayar <ttayar@habana.ai>
Thu, 20 Jul 2023 13:50:39 +0000 (16:50 +0300)
committerOded Gabbay <ogabbay@kernel.org>
Tue, 19 Dec 2023 09:09:43 +0000 (11:09 +0200)
hl_device_cond_reset() might be called with the hard reset flag unset,
because a compute reset upon device release as part of a graceful reset
is valid.
If the conditions for graceful reset are not met, hl_device_reset() will
be called for an immediate reset. In this case a compute reset is not
valid, so it will be replaced with a hard reset together with a debug
message about it.
This message might be confusing, as it implies that a compute reset was
requested when it shouldn't. To prevent this confusion, set the hard
reset flag in hl_device_cond_reset() if going to an immediate reset.

Signed-off-by: Tomer Tayar <ttayar@habana.ai>
Reviewed-by: Oded Gabbay <ogabbay@kernel.org>
Signed-off-by: Oded Gabbay <ogabbay@kernel.org>
drivers/accel/habanalabs/common/device.c

index 6bf5f1d0d0057bc667b3ed2b04fa133bd63be330..a365791a9f5c6cb5e24c8552062982f405e949f2 100644 (file)
@@ -2040,7 +2040,7 @@ device_reset:
        if (ctx)
                hl_ctx_put(ctx);
 
-       return hl_device_reset(hdev, flags);
+       return hl_device_reset(hdev, flags | HL_DRV_RESET_HARD);
 }
 
 static void hl_notifier_event_send(struct hl_notifier_event *notifier_event, u64 event_mask)