]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
nfp: Use IRQF_NO_AUTOEN flag in request_irq()
authorJinjie Ruan <ruanjinjie@huawei.com>
Wed, 11 Sep 2024 09:44:45 +0000 (17:44 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 17 Oct 2024 13:08:12 +0000 (15:08 +0200)
[ Upstream commit daaba19d357f0900b303a530ced96c78086267ea ]

disable_irq() after request_irq() still has a time gap in which
interrupts can come. request_irq() with IRQF_NO_AUTOEN flag will
disable IRQ auto-enable when request IRQ.

Reviewed-by: Louis Peens <louis.peens@corigine.com>
Signed-off-by: Jinjie Ruan <ruanjinjie@huawei.com>
Link: https://patch.msgid.link/20240911094445.1922476-4-ruanjinjie@huawei.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/ethernet/netronome/nfp/nfp_net_common.c

index 5ab230aab2cd88e16c16e03037a72ebff95ba0d3..4a4d171e4f5b1163f82710b5cb191f1066c17f76 100644 (file)
@@ -2631,8 +2631,8 @@ nfp_net_prepare_vector(struct nfp_net *nn, struct nfp_net_r_vector *r_vec,
 
        snprintf(r_vec->name, sizeof(r_vec->name),
                 "%s-rxtx-%d", nfp_net_name(nn), idx);
-       err = request_irq(r_vec->irq_vector, r_vec->handler, 0, r_vec->name,
-                         r_vec);
+       err = request_irq(r_vec->irq_vector, r_vec->handler, IRQF_NO_AUTOEN,
+                         r_vec->name, r_vec);
        if (err) {
                if (nn->dp.netdev)
                        netif_napi_del(&r_vec->napi);
@@ -2642,7 +2642,6 @@ nfp_net_prepare_vector(struct nfp_net *nn, struct nfp_net_r_vector *r_vec,
                nn_err(nn, "Error requesting IRQ %d\n", r_vec->irq_vector);
                return err;
        }
-       disable_irq(r_vec->irq_vector);
 
        irq_set_affinity_hint(r_vec->irq_vector, &r_vec->affinity_mask);