summarylogtreecommitdiffstats
path: root/0044-drm-amdkfd-Handle-restart-of-kfd_ioctl_wait_events.patch
diff options
context:
space:
mode:
Diffstat (limited to '0044-drm-amdkfd-Handle-restart-of-kfd_ioctl_wait_events.patch')
-rw-r--r--0044-drm-amdkfd-Handle-restart-of-kfd_ioctl_wait_events.patch125
1 files changed, 0 insertions, 125 deletions
diff --git a/0044-drm-amdkfd-Handle-restart-of-kfd_ioctl_wait_events.patch b/0044-drm-amdkfd-Handle-restart-of-kfd_ioctl_wait_events.patch
deleted file mode 100644
index 98c1497dea94..000000000000
--- a/0044-drm-amdkfd-Handle-restart-of-kfd_ioctl_wait_events.patch
+++ /dev/null
@@ -1,125 +0,0 @@
-From 21e3891abc83f2d5482c67cca2fb7f228635daaf Mon Sep 17 00:00:00 2001
-From: Felix Kuehling <Felix.Kuehling@amd.com>
-Date: Thu, 4 Aug 2022 18:19:38 -0400
-Subject: [PATCH 44/73] drm/amdkfd: Handle restart of kfd_ioctl_wait_events
-
-[ Upstream commit bea9a56afbc4b5a41ea579b8b0dc5e189b439504 ]
-
-When kfd_ioctl_wait_events needs to restart due to a signal, we need to
-update the timeout to account for the time already elapsed. We also need
-to undo auto_reset of events that have signaled already, so that the
-restarted ioctl will be able to count those signals again.
-
-This fixes infinite hangs when kfd_ioctl_wait_events is interrupted by a
-signal.
-
-Signed-off-by: Felix Kuehling <Felix.Kuehling@amd.com>
-Reviewed-and-tested-by: Xiaogang Chen <Xiaogang.Chen@amd.com>
-Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
-Signed-off-by: Sasha Levin <sashal@kernel.org>
----
- drivers/gpu/drm/amd/amdkfd/kfd_chardev.c | 2 +-
- drivers/gpu/drm/amd/amdkfd/kfd_events.c | 24 ++++++++++++------------
- drivers/gpu/drm/amd/amdkfd/kfd_priv.h | 2 +-
- 3 files changed, 14 insertions(+), 14 deletions(-)
-
-diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_chardev.c b/drivers/gpu/drm/amd/amdkfd/kfd_chardev.c
-index 1c7016958d6d..bfca17ca399c 100644
---- a/drivers/gpu/drm/amd/amdkfd/kfd_chardev.c
-+++ b/drivers/gpu/drm/amd/amdkfd/kfd_chardev.c
-@@ -814,7 +814,7 @@ static int kfd_ioctl_wait_events(struct file *filp, struct kfd_process *p,
- err = kfd_wait_on_events(p, args->num_events,
- (void __user *)args->events_ptr,
- (args->wait_for_all != 0),
-- args->timeout, &args->wait_result);
-+ &args->timeout, &args->wait_result);
-
- return err;
- }
-diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_events.c b/drivers/gpu/drm/amd/amdkfd/kfd_events.c
-index 4df9c36146ba..cbc20d779e5a 100644
---- a/drivers/gpu/drm/amd/amdkfd/kfd_events.c
-+++ b/drivers/gpu/drm/amd/amdkfd/kfd_events.c
-@@ -895,7 +895,8 @@ static long user_timeout_to_jiffies(uint32_t user_timeout_ms)
- return msecs_to_jiffies(user_timeout_ms) + 1;
- }
-
--static void free_waiters(uint32_t num_events, struct kfd_event_waiter *waiters)
-+static void free_waiters(uint32_t num_events, struct kfd_event_waiter *waiters,
-+ bool undo_auto_reset)
- {
- uint32_t i;
-
-@@ -904,6 +905,9 @@ static void free_waiters(uint32_t num_events, struct kfd_event_waiter *waiters)
- spin_lock(&waiters[i].event->lock);
- remove_wait_queue(&waiters[i].event->wq,
- &waiters[i].wait);
-+ if (undo_auto_reset && waiters[i].activated &&
-+ waiters[i].event && waiters[i].event->auto_reset)
-+ set_event(waiters[i].event);
- spin_unlock(&waiters[i].event->lock);
- }
-
-@@ -912,7 +916,7 @@ static void free_waiters(uint32_t num_events, struct kfd_event_waiter *waiters)
-
- int kfd_wait_on_events(struct kfd_process *p,
- uint32_t num_events, void __user *data,
-- bool all, uint32_t user_timeout_ms,
-+ bool all, uint32_t *user_timeout_ms,
- uint32_t *wait_result)
- {
- struct kfd_event_data __user *events =
-@@ -921,7 +925,7 @@ int kfd_wait_on_events(struct kfd_process *p,
- int ret = 0;
-
- struct kfd_event_waiter *event_waiters = NULL;
-- long timeout = user_timeout_to_jiffies(user_timeout_ms);
-+ long timeout = user_timeout_to_jiffies(*user_timeout_ms);
-
- event_waiters = alloc_event_waiters(num_events);
- if (!event_waiters) {
-@@ -971,15 +975,11 @@ int kfd_wait_on_events(struct kfd_process *p,
- }
-
- if (signal_pending(current)) {
-- /*
-- * This is wrong when a nonzero, non-infinite timeout
-- * is specified. We need to use
-- * ERESTARTSYS_RESTARTBLOCK, but struct restart_block
-- * contains a union with data for each user and it's
-- * in generic kernel code that I don't want to
-- * touch yet.
-- */
- ret = -ERESTARTSYS;
-+ if (*user_timeout_ms != KFD_EVENT_TIMEOUT_IMMEDIATE &&
-+ *user_timeout_ms != KFD_EVENT_TIMEOUT_INFINITE)
-+ *user_timeout_ms = jiffies_to_msecs(
-+ max(0l, timeout-1));
- break;
- }
-
-@@ -1020,7 +1020,7 @@ int kfd_wait_on_events(struct kfd_process *p,
- event_waiters, events);
-
- out_unlock:
-- free_waiters(num_events, event_waiters);
-+ free_waiters(num_events, event_waiters, ret == -ERESTARTSYS);
- mutex_unlock(&p->event_mutex);
- out:
- if (ret)
-diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_priv.h b/drivers/gpu/drm/amd/amdkfd/kfd_priv.h
-index 2585d6e61d42..c6eec54b8102 100644
---- a/drivers/gpu/drm/amd/amdkfd/kfd_priv.h
-+++ b/drivers/gpu/drm/amd/amdkfd/kfd_priv.h
-@@ -1314,7 +1314,7 @@ void kfd_event_free_process(struct kfd_process *p);
- int kfd_event_mmap(struct kfd_process *process, struct vm_area_struct *vma);
- int kfd_wait_on_events(struct kfd_process *p,
- uint32_t num_events, void __user *data,
-- bool all, uint32_t user_timeout_ms,
-+ bool all, uint32_t *user_timeout_ms,
- uint32_t *wait_result);
- void kfd_signal_event_interrupt(u32 pasid, uint32_t partial_id,
- uint32_t valid_id_bits);
---
-2.37.3
-