Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp1792920pxb; Wed, 2 Feb 2022 12:37:37 -0800 (PST) X-Google-Smtp-Source: ABdhPJzBfUGL6fCaqzgH2Ag0gSM6tXSCl7N/0/8TJYBkQwdrT3jeh/qFa5fV5Acwl4IFs/v82X9X X-Received: by 2002:a17:906:4c47:: with SMTP id d7mr19573662ejw.192.1643834256799; Wed, 02 Feb 2022 12:37:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643834256; cv=none; d=google.com; s=arc-20160816; b=v5vpGwEx+YHf5ABASTKXGtltsMiAtn6RERgX5kFvsYY2Ahl/GN320azGKH2OnN0ii2 ZTjQxkTNa2hX0UR3Z0huXU8whemPIYXSvNk4kWTJkIcHjLEW2I4L0g994r2DLT6nWLD2 wJ2KHva9zthxqLSxcnzZ5Zd9YAGRGXsbJ0QaSxhMaKkdYPRHPx1HZ/0v0wIfTWWcvJ1E L7rseVHKOXP9+ENCBWS+hwoL/NzpG0XUSuHzSPYtA+o6QQQyozFFRQUQMzNRRiHkXF1d OgWwdIaXATEJpaze9adGbOpscMb6DWVmGnv8/2zgfDsFrmIpiLAWiqhHGrbiVSM/Ivoi sYXQ== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=qSqeMrh/0yEYbg2VUhnAr+jTR26Lgz2OCGfvtcWYZMc=; b=wzgv1HfSzevHp4YFWolmg7lKvUv2G9pckacB3TZ5n6gTxUaJ5Xoi/+Dnzzk3j9be4C q+TLTJTyHaay0ERqRkJzWcpdT9Yf8pnjrXG4NNa0VXahMseF7zDsTYTGMfXLiK91st8t C7I18ux5cTIZaR3TI4G6CAmXcYyDoDzNwbVX2j0o8kbfYMuqRccby2PwkrUW/Jdc4L1c fD2EaB+zI2o8Xk+aMKEOIJwQRTVSvjYZ3P8VAbWvDHB6/8q2OQanP88nmKtoj8MfhWMJ Y7UmFH53U6B5BX2jbCvDyqUmLQs3DmNMo0USC8e9sPWTsN3Kshge5BvNddweSJqp/m33 nRjA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=sd7SNj1w; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id eb13si13199627edb.576.2022.02.02.12.37.10; Wed, 02 Feb 2022 12:37:36 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=sd7SNj1w; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229456AbiBASRv (ORCPT + 99 others); Tue, 1 Feb 2022 13:17:51 -0500 Received: from dfw.source.kernel.org ([139.178.84.217]:56668 "EHLO dfw.source.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233343AbiBASRX (ORCPT ); Tue, 1 Feb 2022 13:17:23 -0500 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 21C6B614A6; Tue, 1 Feb 2022 18:17:23 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 00D59C36AE2; Tue, 1 Feb 2022 18:17:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643739442; bh=axx0hirfpuLP7ciyUX3JOUDGdTEjVsMD+NDMyWTIHy0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=sd7SNj1wlfZcQKzmupw4pIKMKwHkA/1ogc4BxgtHXBKIZc2h9pypFcKm55/8DW009 JNp0K7ikiz3kSPVxKopiwz8SlLkTp2yq62NTJydxrMrwEObL8LyGWM8WvHS4vnQ0J9 IVEZYlYnFBKgSPwzSSVUcoovdz+NTIUgDP/k64Yk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jianguo Wu , "David S. Miller" Subject: [PATCH 4.4 17/25] net-procfs: show net devices bound packet types Date: Tue, 1 Feb 2022 19:16:41 +0100 Message-Id: <20220201180822.707270379@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220201180822.148370751@linuxfoundation.org> References: <20220201180822.148370751@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jianguo Wu commit 1d10f8a1f40b965d449e8f2d5ed7b96a7c138b77 upstream. After commit:7866a621043f ("dev: add per net_device packet type chains"), we can not get packet types that are bound to a specified net device by /proc/net/ptype, this patch fix the regression. Run "tcpdump -i ens192 udp -nns0" Before and after apply this patch: Before: [root@localhost ~]# cat /proc/net/ptype Type Device Function 0800 ip_rcv 0806 arp_rcv 86dd ipv6_rcv After: [root@localhost ~]# cat /proc/net/ptype Type Device Function ALL ens192 tpacket_rcv 0800 ip_rcv 0806 arp_rcv 86dd ipv6_rcv v1 -> v2: - fix the regression rather than adding new /proc API as suggested by Stephen Hemminger. Fixes: 7866a621043f ("dev: add per net_device packet type chains") Signed-off-by: Jianguo Wu Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- net/core/net-procfs.c | 35 ++++++++++++++++++++++++++++++++--- 1 file changed, 32 insertions(+), 3 deletions(-) --- a/net/core/net-procfs.c +++ b/net/core/net-procfs.c @@ -207,12 +207,23 @@ static const struct file_operations soft .release = seq_release, }; -static void *ptype_get_idx(loff_t pos) +static void *ptype_get_idx(struct seq_file *seq, loff_t pos) { + struct list_head *ptype_list = NULL; struct packet_type *pt = NULL; + struct net_device *dev; loff_t i = 0; int t; + for_each_netdev_rcu(seq_file_net(seq), dev) { + ptype_list = &dev->ptype_all; + list_for_each_entry_rcu(pt, ptype_list, list) { + if (i == pos) + return pt; + ++i; + } + } + list_for_each_entry_rcu(pt, &ptype_all, list) { if (i == pos) return pt; @@ -233,22 +244,40 @@ static void *ptype_seq_start(struct seq_ __acquires(RCU) { rcu_read_lock(); - return *pos ? ptype_get_idx(*pos - 1) : SEQ_START_TOKEN; + return *pos ? ptype_get_idx(seq, *pos - 1) : SEQ_START_TOKEN; } static void *ptype_seq_next(struct seq_file *seq, void *v, loff_t *pos) { + struct net_device *dev; struct packet_type *pt; struct list_head *nxt; int hash; ++*pos; if (v == SEQ_START_TOKEN) - return ptype_get_idx(0); + return ptype_get_idx(seq, 0); pt = v; nxt = pt->list.next; + if (pt->dev) { + if (nxt != &pt->dev->ptype_all) + goto found; + + dev = pt->dev; + for_each_netdev_continue_rcu(seq_file_net(seq), dev) { + if (!list_empty(&dev->ptype_all)) { + nxt = dev->ptype_all.next; + goto found; + } + } + + nxt = ptype_all.next; + goto ptype_all; + } + if (pt->type == htons(ETH_P_ALL)) { +ptype_all: if (nxt != &ptype_all) goto found; hash = 0;