]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
net: airoha: Fix schedule while atomic in airoha_ppe_deinit()
authorLorenzo Bianconi <lorenzo@kernel.org>
Mon, 5 Jan 2026 08:43:31 +0000 (09:43 +0100)
committerPaolo Abeni <pabeni@redhat.com>
Thu, 8 Jan 2026 10:23:20 +0000 (11:23 +0100)
airoha_ppe_deinit() runs airoha_npu_ppe_deinit() in atomic context.
airoha_npu_ppe_deinit routine allocates ppe_data buffer with GFP_KERNEL
flag. Rely on rcu_replace_pointer in airoha_ppe_deinit routine in order
to fix schedule while atomic issue in airoha_npu_ppe_deinit() since we
do not need atomic context there.

Fixes: 00a7678310fe3 ("net: airoha: Introduce flowtable offload support")
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Link: https://patch.msgid.link/20260105-airoha-fw-ethtool-v2-1-3b32b158cc31@kernel.org
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
drivers/net/ethernet/airoha/airoha_ppe.c

index 0caabb0c3aa06948e46ad087c50eba5babc81994..2221bafaf7c9fed73dcf8d30ff3b1c5eecc463d4 100644 (file)
@@ -1547,13 +1547,16 @@ void airoha_ppe_deinit(struct airoha_eth *eth)
 {
        struct airoha_npu *npu;
 
-       rcu_read_lock();
-       npu = rcu_dereference(eth->npu);
+       mutex_lock(&flow_offload_mutex);
+
+       npu = rcu_replace_pointer(eth->npu, NULL,
+                                 lockdep_is_held(&flow_offload_mutex));
        if (npu) {
                npu->ops.ppe_deinit(npu);
                airoha_npu_put(npu);
        }
-       rcu_read_unlock();
+
+       mutex_unlock(&flow_offload_mutex);
 
        rhashtable_destroy(&eth->ppe->l2_flows);
        rhashtable_destroy(&eth->flow_table);