drm/amdkfd: add event_age tracking when receiving interrupt
authorJames Zhu <James.Zhu@amd.com>
Wed, 17 May 2023 20:22:47 +0000 (16:22 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 15 Jun 2023 15:37:55 +0000 (11:37 -0400)
Add event_age tracking when receiving interrupt.

Signed-off-by: James Zhu <James.Zhu@amd.com>
Reviewed-by: Felix Kuehling <Felix.Kuehling@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdkfd/kfd_events.c
drivers/gpu/drm/amd/amdkfd/kfd_events.h

index ddca23e..d71ea06 100644 (file)
@@ -431,6 +431,7 @@ int kfd_event_create(struct file *devkfd, struct kfd_process *p,
        if (!ret) {
                *event_id = ev->event_id;
                *event_trigger_data = ev->event_id;
+               ev->event_age = 1;
        } else {
                kfree(ev);
        }
@@ -629,6 +630,11 @@ static void set_event(struct kfd_event *ev)
         * updating the wait queues in kfd_wait_on_events.
         */
        ev->signaled = !ev->auto_reset || !waitqueue_active(&ev->wq);
+       if (!(++ev->event_age)) {
+               /* Never wrap back to reserved/default event age 0/1 */
+               ev->event_age = 2;
+               WARN_ONCE(1, "event_age wrap back!");
+       }
 
        list_for_each_entry(waiter, &ev->wq.head, wait.entry)
                WRITE_ONCE(waiter->activated, true);
index 1c62c8d..52ccfd3 100644 (file)
@@ -53,6 +53,7 @@ struct signal_page;
 
 struct kfd_event {
        u32 event_id;
+       u64 event_age;
 
        bool signaled;
        bool auto_reset;