drm/amd/display: add an ASSERT() to irq service functions
authorHamza Mahfooz <hamza.mahfooz@amd.com>
Fri, 14 Oct 2022 14:29:46 +0000 (10:29 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 17 Oct 2022 21:41:21 +0000 (17:41 -0400)
Currently, if we encounter unimplemented functions, it is difficult to
tell what caused them just by looking at dmesg and that is compounded by
the fact that it is often hard to reproduce said issues, for instance we
have had reports of this condition being triggered when removing a
secondary display that is setup in mirror mode and is connected using
usb-c. So, to have access to more detailed debugging information, add an
ASSERT() to dal_irq_service_ack() and dal_irq_service_set() that only
triggers when we encounter an unimplemented function.

Reviewed-by: Harry Wentland <harry.wentland@amd.com>
Signed-off-by: Hamza Mahfooz <hamza.mahfooz@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/irq/irq_service.c

index 7bad39b..d100eda 100644 (file)
@@ -112,8 +112,15 @@ bool dal_irq_service_set(
 
        dal_irq_service_ack(irq_service, source);
 
-       if (info->funcs && info->funcs->set)
+       if (info->funcs && info->funcs->set) {
+               if (info->funcs->set == dal_irq_service_dummy_set) {
+                       DC_LOG_WARNING("%s: src: %d, st: %d\n", __func__,
+                                      source, enable);
+                       ASSERT(0);
+               }
+
                return info->funcs->set(irq_service, info, enable);
+       }
 
        dal_irq_service_set_generic(irq_service, info, enable);
 
@@ -146,8 +153,14 @@ bool dal_irq_service_ack(
                return false;
        }
 
-       if (info->funcs && info->funcs->ack)
+       if (info->funcs && info->funcs->ack) {
+               if (info->funcs->ack == dal_irq_service_dummy_ack) {
+                       DC_LOG_WARNING("%s: src: %d\n", __func__, source);
+                       ASSERT(0);
+               }
+
                return info->funcs->ack(irq_service, info);
+       }
 
        dal_irq_service_ack_generic(irq_service, info);