]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
firewire: ohci: move self_id_complete tracepoint after validating register
authorTakashi Sakamoto <o-takashi@sakamocchi.jp>
Sat, 23 Aug 2025 03:09:52 +0000 (12:09 +0900)
committerTakashi Sakamoto <o-takashi@sakamocchi.jp>
Sat, 23 Aug 2025 09:06:17 +0000 (18:06 +0900)
The value of OHCI1394_SelfIDCount register includes an error-indicating
bit. It is safer to place the tracepoint probe after validating the
register value.

Link: https://lore.kernel.org/r/20250823030954.268412-2-o-takashi@sakamocchi.jp
Signed-off-by: Takashi Sakamoto <o-takashi@sakamocchi.jp>
drivers/firewire/ohci.c

index c8c5d598e3c8f40e00f495a6d02a704023ca7422..b3a187e4cba7a41e91468ce6f404ef13abcd74e9 100644 (file)
@@ -1863,6 +1863,9 @@ static void bus_reset_work(struct work_struct *work)
                ohci_notice(ohci, "self ID receive error\n");
                return;
        }
+
+       trace_self_id_complete(ohci->card.index, reg, ohci->self_id, has_be_header_quirk(ohci));
+
        /*
         * The count in the SelfIDCount register is the number of
         * bytes in the self ID receive buffer.  Since we also receive
@@ -2024,15 +2027,8 @@ static irqreturn_t irq_handler(int irq, void *data)
        if (event & OHCI1394_busReset)
                reg_write(ohci, OHCI1394_IntMaskClear, OHCI1394_busReset);
 
-       if (event & OHCI1394_selfIDComplete) {
-               if (trace_self_id_complete_enabled()) {
-                       u32 reg = reg_read(ohci, OHCI1394_SelfIDCount);
-
-                       trace_self_id_complete(ohci->card.index, reg, ohci->self_id,
-                                              has_be_header_quirk(ohci));
-               }
+       if (event & OHCI1394_selfIDComplete)
                queue_work(selfid_workqueue, &ohci->bus_reset_work);
-       }
 
        if (event & OHCI1394_RQPkt)
                queue_work(ohci->card.async_wq, &ohci->ar_request_ctx.work);