[PATCH net-next v6 3/9] net: dsa: microchip: Decorrelate msg_irq index from IRQ bit offset
From: Bastien Curutchet (Schneider Electric)
Date: Wed Mar 04 2026 - 05:21:16 EST
KSZ8463 has one register containing all the PTP-related interrupts from
all ports. So it will use one IRQ domain for all of them, leading to 4
interrupt bits to be dispatched in two ports. Current implementation
doesn't allow to do so because the IRQ bit offset is also used as index
to store the struct ptpmsg_irq in the table held by the port.
Add a new input to the setup() function to independently provide the
interrupt bit offset and the ptpmsg_irq index.
Signed-off-by: Bastien Curutchet (Schneider Electric) <bastien.curutchet@xxxxxxxxxxx>
---
drivers/net/dsa/microchip/ksz_ptp.c | 12 ++++++------
1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/drivers/net/dsa/microchip/ksz_ptp.c b/drivers/net/dsa/microchip/ksz_ptp.c
index 64afe92a3479ec87b5afc66e489b92787a0fc715..79f2210df8588e0a75b4f29dae2d7281ede12a3c 100644
--- a/drivers/net/dsa/microchip/ksz_ptp.c
+++ b/drivers/net/dsa/microchip/ksz_ptp.c
@@ -1100,7 +1100,7 @@ static void ksz_ptp_msg_irq_free(struct ksz_port *port, u8 n)
}
static int ksz_ptp_msg_irq_setup(struct irq_domain *domain,
- struct ksz_port *port, u8 n)
+ struct ksz_port *port, u8 index, int irq)
{
u16 ts_reg[] = {REG_PTP_PORT_PDRESP_TS, REG_PTP_PORT_XDELAY_TS,
REG_PTP_PORT_SYNC_TS};
@@ -1109,15 +1109,15 @@ static int ksz_ptp_msg_irq_setup(struct irq_domain *domain,
const struct ksz_dev_ops *ops = port->ksz_dev->dev_ops;
struct ksz_ptp_irq *ptpmsg_irq;
- ptpmsg_irq = &port->ptpmsg_irq[n];
- ptpmsg_irq->num = irq_create_mapping(domain, n);
+ ptpmsg_irq = &port->ptpmsg_irq[index];
+ ptpmsg_irq->num = irq_create_mapping(domain, irq);
if (!ptpmsg_irq->num)
return -EINVAL;
ptpmsg_irq->port = port;
- ptpmsg_irq->ts_reg = ops->get_port_addr(port->num, ts_reg[n]);
+ ptpmsg_irq->ts_reg = ops->get_port_addr(port->num, ts_reg[index]);
- strscpy(ptpmsg_irq->name, name[n]);
+ strscpy(ptpmsg_irq->name, name[index]);
return request_threaded_irq(ptpmsg_irq->num, NULL,
ksz_ptp_msg_thread_fn, IRQF_ONESHOT,
@@ -1162,7 +1162,7 @@ int ksz_ptp_irq_setup(struct dsa_switch *ds, u8 p)
goto out;
for (irq = 0; irq < ptpirq->nirqs; irq++) {
- ret = ksz_ptp_msg_irq_setup(ptpirq->domain, port, irq);
+ ret = ksz_ptp_msg_irq_setup(ptpirq->domain, port, irq, irq);
if (ret)
goto out_ptp_msg;
}
--
2.53.0