* [PATCH] net/mlx5: Update mlx5_irq.mask when IRQ affinity changes
@ 2026-05-14 7:42 Yi Li
0 siblings, 0 replies; only message in thread
From: Yi Li @ 2026-05-14 7:42 UTC (permalink / raw)
To: Saeed Mahameed, Tariq Toukan, Leon Romanovsky, Mark Bloch
Cc: Andrew Lunn, David S . Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, netdev, linux-rdma, linux-kernel, Yi Li
mlx5_irq.mask is used for:
1) Setting IRQ affinity_hint in mlx5_irq_alloc()
2) Determining mlx5e_channel.cpu in mlx5e_open_channel(), which in turn
decides the NUMA node for queue allocations.
When a user modifies IRQ affinity, mlx5_irq.mask remains unchanged.
Consequently even if mlx5e_open_channel() is invoked again, queues are
still allocated on the original NUMA node instead of the newly
preferred one.
Fix this by registering an irq_set_affinity_notifier to update
mlx5_irq.mask when /proc/irq/N/smp_affinity is modified.
Therefore subsequent queue allocations reflect the updated affinity.
Signed-off-by: Yi Li <liyi@hygon.cn>
---
.../net/ethernet/mellanox/mlx5/core/pci_irq.c | 18 ++++++++++++++++++
1 file changed, 18 insertions(+)
diff --git a/drivers/net/ethernet/mellanox/mlx5/core/pci_irq.c b/drivers/net/ethernet/mellanox/mlx5/core/pci_irq.c
index e051b9a939ee..501496159aa2 100644
--- a/drivers/net/ethernet/mellanox/mlx5/core/pci_irq.c
+++ b/drivers/net/ethernet/mellanox/mlx5/core/pci_irq.c
@@ -35,6 +35,7 @@ struct mlx5_irq {
int refcount;
struct msi_map map;
u32 pool_index;
+ struct irq_affinity_notify af_notify;
};
struct mlx5_irq_table {
@@ -158,6 +159,9 @@ static void mlx5_system_free_irq(struct mlx5_irq *irq)
struct cpu_rmap *rmap;
#endif
+ if (irq->af_notify.notify)
+ irq_set_affinity_notifier(irq->map.virq, NULL);
+
/* free_irq requires that affinity_hint and rmap will be cleared before
* calling it. To satisfy this requirement, we call
* irq_cpu_rmap_remove() to remove the notifier
@@ -252,6 +256,16 @@ static void irq_set_name(struct mlx5_irq_pool *pool, char *name, int vecidx)
snprintf(name, MLX5_MAX_IRQ_NAME, "mlx5_comp%d", vecidx);
}
+static void mlx5_irq_affinity_changed(struct irq_affinity_notify *notify,
+ const cpumask_t *mask)
+{
+ struct mlx5_irq *irq = container_of(notify, struct mlx5_irq, af_notify);
+
+ cpumask_copy(irq->mask, mask);
+}
+
+static void mlx5_irq_affinity_notifier_release(struct kref *ref) {}
+
struct mlx5_irq *mlx5_irq_alloc(struct mlx5_irq_pool *pool, int i,
struct irq_affinity_desc *af_desc,
struct cpu_rmap **rmap)
@@ -307,6 +321,10 @@ struct mlx5_irq *mlx5_irq_alloc(struct mlx5_irq_pool *pool, int i,
if (af_desc) {
cpumask_copy(irq->mask, &af_desc->mask);
irq_set_affinity_and_hint(irq->map.virq, irq->mask);
+
+ irq->af_notify.notify = mlx5_irq_affinity_changed;
+ irq->af_notify.release = mlx5_irq_affinity_notifier_release;
+ irq_set_affinity_notifier(irq->map.virq, &irq->af_notify);
}
irq->pool = pool;
irq->refcount = 1;
--
2.53.0
^ permalink raw reply related [flat|nested] only message in thread
only message in thread, other threads:[~2026-05-14 7:43 UTC | newest]
Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-05-14 7:42 [PATCH] net/mlx5: Update mlx5_irq.mask when IRQ affinity changes Yi Li
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox