Patch "can: kvaser_pciefd: Use a single write when releasing RX buffers" has been added to the 6.6-stable tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This is a note to let you know that I've just added the patch titled

    can: kvaser_pciefd: Use a single write when releasing RX buffers

to the 6.6-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     can-kvaser_pciefd-use-a-single-write-when-releasing-.patch
and it can be found in the queue-6.6 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit 4dc4d8001fac8d9798013765bdcad8b9f73d7a3e
Author: Martin Jocic <martin.jocic@xxxxxxxxxx>
Date:   Fri Aug 30 17:31:13 2024 +0200

    can: kvaser_pciefd: Use a single write when releasing RX buffers
    
    [ Upstream commit dd885d90c047dbdd2773c1d33954cbd8747d81e2 ]
    
    Kvaser's PCIe cards uses the KCAN FPGA IP block which has dual 4K
    buffers for incoming messages shared by all (currently up to eight)
    channels. While the driver processes messages in one buffer, new
    incoming messages are stored in the other and so on.
    
    The design of KCAN is such that a buffer must be fully read and then
    released. Releasing a buffer will make the FPGA switch buffers. If the
    other buffer contains at least one incoming message the FPGA will also
    instantly issue a new interrupt, if not the interrupt will be issued
    after receiving the first new message.
    
    With IRQx interrupts, it takes a little time for the interrupt to
    happen, enough for any previous ISR call to do it's business and
    return, but MSI interrupts are way faster so this time is reduced to
    almost nothing.
    
    So with MSI, releasing the buffer HAS to be the very last action of
    the ISR before returning, otherwise the new interrupt might be
    "masked" by the kernel because the previous ISR call hasn't returned.
    And the interrupts are edge-triggered so we cannot loose one, or the
    ping-pong reading process will stop.
    
    This is why this patch modifies the driver to use a single write to
    the SRB_CMD register before returning.
    
    Signed-off-by: Martin Jocic <martin.jocic@xxxxxxxxxx>
    Reviewed-by: Vincent Mailhol <mailhol.vincent@xxxxxxxxxx>
    Link: https://patch.msgid.link/20240830153113.2081440-1-martin.jocic@xxxxxxxxxx
    Fixes: 26ad340e582d ("can: kvaser_pciefd: Add driver for Kvaser PCIEcan devices")
    Signed-off-by: Marc Kleine-Budde <mkl@xxxxxxxxxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/drivers/net/can/kvaser_pciefd.c b/drivers/net/can/kvaser_pciefd.c
index 96b6e3d13e67..c490b4ba065b 100644
--- a/drivers/net/can/kvaser_pciefd.c
+++ b/drivers/net/can/kvaser_pciefd.c
@@ -1626,6 +1626,7 @@ static irqreturn_t kvaser_pciefd_irq_handler(int irq, void *dev)
 	const struct kvaser_pciefd_irq_mask *irq_mask = pcie->driver_data->irq_mask;
 	u32 pci_irq = ioread32(KVASER_PCIEFD_PCI_IRQ_ADDR(pcie));
 	u32 srb_irq = 0;
+	u32 srb_release = 0;
 	int i;
 
 	if (!(pci_irq & irq_mask->all))
@@ -1639,17 +1640,14 @@ static irqreturn_t kvaser_pciefd_irq_handler(int irq, void *dev)
 			kvaser_pciefd_transmit_irq(pcie->can[i]);
 	}
 
-	if (srb_irq & KVASER_PCIEFD_SRB_IRQ_DPD0) {
-		/* Reset DMA buffer 0, may trigger new interrupt */
-		iowrite32(KVASER_PCIEFD_SRB_CMD_RDB0,
-			  KVASER_PCIEFD_SRB_ADDR(pcie) + KVASER_PCIEFD_SRB_CMD_REG);
-	}
+	if (srb_irq & KVASER_PCIEFD_SRB_IRQ_DPD0)
+		srb_release |= KVASER_PCIEFD_SRB_CMD_RDB0;
 
-	if (srb_irq & KVASER_PCIEFD_SRB_IRQ_DPD1) {
-		/* Reset DMA buffer 1, may trigger new interrupt */
-		iowrite32(KVASER_PCIEFD_SRB_CMD_RDB1,
-			  KVASER_PCIEFD_SRB_ADDR(pcie) + KVASER_PCIEFD_SRB_CMD_REG);
-	}
+	if (srb_irq & KVASER_PCIEFD_SRB_IRQ_DPD1)
+		srb_release |= KVASER_PCIEFD_SRB_CMD_RDB1;
+
+	if (srb_release)
+		iowrite32(srb_release, KVASER_PCIEFD_SRB_ADDR(pcie) + KVASER_PCIEFD_SRB_CMD_REG);
 
 	return IRQ_HANDLED;
 }




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux