Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp1373898pxu; Fri, 16 Oct 2020 10:18:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxiAwTA1m7Pu+IFR8UlSh/XLvrqbMsUm8uPNg7mBbyP9v/PebHSLl6w6/CPPaq4/mpEaGe5 X-Received: by 2002:aa7:cd09:: with SMTP id b9mr5049600edw.55.1602868737474; Fri, 16 Oct 2020 10:18:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1602868737; cv=none; d=google.com; s=arc-20160816; b=N4syxfFRipOdk5uAtwq4ZDkjBQDYEzTGgMwOSEK6GuTLuqJ4QVTK2ujdaIfPZ6gzOO GpaXjH9qwUPRQgj7Cp7fIvM7QqYE17jKxPMI8HrOzEDpxuDdTcTk3GuaTdT9wypmIwaO 9KBMbft5tHym0PTAPxtrIkPNPhwLDREYhr00Sv+x+2lpU8ph0OjMuXzzF7PtCf2ZMkuM 8faoadrffbS9pvFdKrRyIZsD88ahQtAC5aZRvjI4xqtAxX+6ao7xFdXG7AaReTjAMZZg sbP+iAoHTkI5dSdU+8sJhAaVrVTOz42lJvTLAccjyoclYeB96s4ZTt6RVxkRxGMiCXzE 37Bg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=H+J4aL8mj2hPmW8++OyQy3FS5qEVdRBJxmwJsZUtiuc=; b=MP19HytDc0NNHsLAQW0J1xT9+PPKuznhOyjP9yJqC1P2UcKbz9i8xoeGgoQq6D/2uA dq0zjUACxv787y6rJWGCuHUi1seUaIwhhwvWO0kttoSrx/nJBF+4OxwkO+VLOmnvHE3n 3tn/0/xYsOHu6ALn8VRanU719a61Pj9h2m9jn0tPfVnbg7N6WOwu2c3hTw2SbMHyQ7QF Dj9Oc82hyGuRkwwBHOuiDH8hsJLsKc1rRztXHrvrXywDefbhlb1wXiKeWxjD/lRe0rlE zg9jf7y6SHFIMBvqOWX5IpscV0/dJsbXlXCMK0ZVb9FnlDErOzSz6lzTjrOo7COcGbgT wJzw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f2si2673909edl.147.2020.10.16.10.18.35; Fri, 16 Oct 2020 10:18:57 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390385AbgJPRQX (ORCPT + 99 others); Fri, 16 Oct 2020 13:16:23 -0400 Received: from smtp11.smtpout.orange.fr ([80.12.242.133]:52629 "EHLO smtp.smtpout.orange.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390303AbgJPRQR (ORCPT ); Fri, 16 Oct 2020 13:16:17 -0400 Received: from tomoyo.flets-east.jp ([153.230.197.127]) by mwinf5d46 with ME id ghG42300F2lQRaH03hGCKe; Fri, 16 Oct 2020 19:16:16 +0200 X-ME-Helo: tomoyo.flets-east.jp X-ME-Auth: bWFpbGhvbC52aW5jZW50QHdhbmFkb28uZnI= X-ME-Date: Fri, 16 Oct 2020 19:16:16 +0200 X-ME-IP: 153.230.197.127 From: Vincent Mailhol To: linux-kernel@vger.kernel.org, netdev@vger.kernel.org, linux-can@vger.kernel.org, Marc Kleine-Budde , Wolfgang Grandegger , "David S. Miller" , Jakub Kicinski Cc: Arunachalam Santhanam , Vincent Mailhol , Masahiro Yamada Subject: [PATCH v4 1/4] can: dev: can_get_echo_skb(): prevent call to kfree_skb() in hard IRQ context Date: Sat, 17 Oct 2020 02:13:30 +0900 Message-Id: <20201016171402.229001-2-mailhol.vincent@wanadoo.fr> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20201016171402.229001-1-mailhol.vincent@wanadoo.fr> References: <20201016171402.229001-1-mailhol.vincent@wanadoo.fr> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If a driver calls can_get_echo_skb() during a hardware IRQ (which is often, but not always, the case), the 'WARN_ON(in_irq)' in net/core/skbuff.c#skb_release_head_state() might be triggered, under network congestion circumstances, together with the potential risk of a NULL pointer dereference. The root cause of this issue is the call to kfree_skb() instead of dev_kfree_skb_irq() in net/core/dev.c#enqueue_to_backlog(). This patch prevents the skb to be freed within the call to netif_rx() by incrementing its reference count with skb_get(). The skb is finally freed by one of the in-irq-context safe functions: dev_consume_skb_any() or dev_kfree_skb_any(). The "any" version is used because some drivers might call can_get_echo_skb() in a normal context. The reason for this issue to occur is that initially, in the core network stack, loopback skb were not supposed to be received in hardware IRQ context. The CAN stack is an exeption. This bug was previously reported back in 2017 in [1] but the proposed patch never got accepted. While [1] directly modifies net/core/dev.c, we try to propose here a smoother modification local to CAN network stack (the assumption behind is that only CAN devices are affected by this issue). [1] https://patchwork.ozlabs.org/patch/835236/ Signed-off-by: Vincent Mailhol --- Changes in v3 and v4: None Changes in v2: - Minor changes of link format in the changelog. --- drivers/net/can/dev.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/net/can/dev.c b/drivers/net/can/dev.c index b70ded3760f2..73cfcd7e9517 100644 --- a/drivers/net/can/dev.c +++ b/drivers/net/can/dev.c @@ -538,7 +538,11 @@ unsigned int can_get_echo_skb(struct net_device *dev, unsigned int idx) if (!skb) return 0; - netif_rx(skb); + skb_get(skb); + if (netif_rx(skb) == NET_RX_SUCCESS) + dev_consume_skb_any(skb); + else + dev_kfree_skb_any(skb); return len; } -- 2.26.2