Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp2234962ybb; Sun, 5 Apr 2020 02:19:09 -0700 (PDT) X-Google-Smtp-Source: APiQypIL6y6D4IZWHsJuBnitYsGRNYZpUN31WgUSFbyXWSPgjC0vQcIjacyo+Oo/mC/uOEnYpeyh X-Received: by 2002:a05:6808:43:: with SMTP id v3mr9279324oic.59.1586078349489; Sun, 05 Apr 2020 02:19:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586078349; cv=none; d=google.com; s=arc-20160816; b=h/srHheFuCkJjS58BgKih5GoWBv7/L95PbrsYgInnYc0PkiTGZZMfo1SkuZKXTKnJG P/gA59vBqU7pNJFY8xBFyKdmeNiRttUJg9dAJYR3ddlepOW7ice1BTo0h06B0MCmzXqV 9vfleLzwy45IA9VBKCGDP9IgVcaxli2YmYL17H9/D9LjqrFXG5VztbPwTm0Ukg5mRBnS Ibvo/ZlezA3g5T+1C1GsP5eQ21zyg32YUHVax9Qr+gAuNrmtSHOdithEekswWIdPfHp/ +H7gYvGm8UQUzSU0Ls/NRS4w+dlapBEv9lrcBgLqWGIpWCrs7PrOPV3wByoSmkVp+Fyl TQyg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=ezAeoP6FHV4AgjLzQuSOWjGz7T/3USe1LlIeyEWnVyY=; b=N+nu/gZYizuk7RDHSJ04iS1FTD7lYkYKAzKx5rCPY2jaegSWq+lH3nyn8LyBX/RwSu xulE8Qa+bf8ksX9v7qJ5gfvjiADdu8IqtFxR3dprsS/tZ40Z/NiMZDd1l1Cnhae2BoOc S+/CL+bAV+8X4Q0f6Fu76S7P6dpR4vCRwrUHNN8zeO87PQhv2O2369/obhkUKLoUYZtl OqJ0rp7wEw4jjGSMGlAKpGizGPngSyxDn9V11hRp3JX9ftLmTGm611T27bTh90BFomNX mN1azecsxYkqhwEgvqcuk3xxWmQweIiPzUKcP/XdDnEEez8xLXxj8v5MknYPnXd9kCd6 U7XA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=BJop5i+E; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c31si5962883otb.281.2020.04.05.02.18.56; Sun, 05 Apr 2020 02:19:09 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=BJop5i+E; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726549AbgDEJSF (ORCPT + 99 others); Sun, 5 Apr 2020 05:18:05 -0400 Received: from mail-lj1-f193.google.com ([209.85.208.193]:46213 "EHLO mail-lj1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726399AbgDEJSF (ORCPT ); Sun, 5 Apr 2020 05:18:05 -0400 Received: by mail-lj1-f193.google.com with SMTP id r7so11297189ljg.13; Sun, 05 Apr 2020 02:18:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=ezAeoP6FHV4AgjLzQuSOWjGz7T/3USe1LlIeyEWnVyY=; b=BJop5i+EaG3paQbNb4bN/ifD24C0PwLCf4+Fe1ldfM6T5WuJdO6h34bW8Mg3TT2j9a RTSZOePJPsJzM/ejFEoFXHzK4y7WW1IQjDrY5AeDsZtZcLuUJomZykzce7OY3U0FIeer sz3CwiDmFbmYJJ1dsHGqLtoN74nBjxpnCPLTXG7qE9tU/cKisiP5ovyQoFSlaTJtEWi1 vlNmEU3ozk0LKP4qYL07NHUaKzYmCY+ZH501//0zXFvEeNke0kp9MbSWbiuQ9j8ZIz2d xLXItZEC+zgMrjwETAydoLc8vEedkihxqKq3bl+ivRp46f9i55SX20cXTipr3iPqHerY U+Cw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=ezAeoP6FHV4AgjLzQuSOWjGz7T/3USe1LlIeyEWnVyY=; b=VNCT/uVTd0dm+uPy4zEluEArEWv925MnR842mjqTXnvBH4ByLF+QmZSbfPAj+hZSFk KfGSGYXRHwkn08hSL3hPc/AgU5uT9gg254pQwZ+dSZCijPUHvlZk5ky5G1hZp4/80VTb HmqS5z1dc/x8Zu0BGPaQOSpBkqB+l718UUh69zZ07Q2Rn6qMrJbaqD7Uu4IjVMPLNq1t 7IZejh6AF1piiniO0PyJRuTfakqDrJT8KfN3Jmo2milzx9KQTNZut7EZHJUq6ur0wbyI heO38wd4qjAczs92189pFAMXjzSATLIrY64+Velj6EDtpZmG8QIjCcZ/KX0gKgs/pc3S GCNw== X-Gm-Message-State: AGi0PubgPbSsdIUeC005+CGe/ijeEseDSQj8Ddxp0VcFGarhjUFrYBnl ty4BENfJChXkubU3qrVrYaLc9Bq99j63ZASZaKQIHn6d X-Received: by 2002:a2e:9252:: with SMTP id v18mr9228042ljg.114.1586078282352; Sun, 05 Apr 2020 02:18:02 -0700 (PDT) MIME-Version: 1.0 References: <20200404141909.26399-1-ap420073@gmail.com> <20200404155122.GD1476305@kroah.com> <20200405073212.GA1551960@kroah.com> In-Reply-To: <20200405073212.GA1551960@kroah.com> From: Taehee Yoo Date: Sun, 5 Apr 2020 18:17:50 +0900 Message-ID: Subject: Re: [PATCH net v2 2/3] net: core: add netdev_class_has_file_ns() helper function To: Greg KH Cc: David Miller , Jakub Kicinski , rafael@kernel.org, j.vosburgh@gmail.com, vfalico@gmail.com, Andy Gospodarek , Netdev , LKML , mitch.a.williams@intel.com Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, 5 Apr 2020 at 16:32, Greg KH wrote: > Hi Greg, Thank you for the review! > On Sun, Apr 05, 2020 at 02:18:22AM +0900, Taehee Yoo wrote: > > On Sun, 5 Apr 2020 at 00:51, Greg KH wrote: > > > > > > > Hi Greg, > > Thank you for your review! > > > > > On Sat, Apr 04, 2020 at 02:19:09PM +0000, Taehee Yoo wrote: > > > > This helper function is to check whether the class file "/sys/class/net/*" > > > > is existing or not. > > > > In the next patch, this helper function will be used. > > > > > > > > Reported-by: syzbot+830c6dbfc71edc4f0b8f@syzkaller.appspotmail.com > > > > Fixes: b76cdba9cdb2 ("[PATCH] bonding: add sysfs functionality to bonding (large)") > > > > Signed-off-by: Taehee Yoo > > > > --- > > > > > > > > v1 -> v2: > > > > - use class_has_file_ns(), which is introduced by the first patch. > > > > > > > > include/linux/netdevice.h | 2 +- > > > > net/core/net-sysfs.c | 6 ++++++ > > > > 2 files changed, 7 insertions(+), 1 deletion(-) > > > > > > > > diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h > > > > index 130a668049ab..a04c487c0975 100644 > > > > --- a/include/linux/netdevice.h > > > > +++ b/include/linux/netdevice.h > > > > @@ -4555,7 +4555,7 @@ int netdev_class_create_file_ns(const struct class_attribute *class_attr, > > > > const void *ns); > > > > void netdev_class_remove_file_ns(const struct class_attribute *class_attr, > > > > const void *ns); > > > > - > > > > +bool netdev_class_has_file_ns(const char *name, const void *ns); > > > > static inline int netdev_class_create_file(const struct class_attribute *class_attr) > > > > { > > > > return netdev_class_create_file_ns(class_attr, NULL); > > > > diff --git a/net/core/net-sysfs.c b/net/core/net-sysfs.c > > > > index cf0215734ceb..8a20d658eff0 100644 > > > > --- a/net/core/net-sysfs.c > > > > +++ b/net/core/net-sysfs.c > > > > @@ -1914,6 +1914,12 @@ void netdev_class_remove_file_ns(const struct class_attribute *class_attr, > > > > } > > > > EXPORT_SYMBOL(netdev_class_remove_file_ns); > > > > > > > > +bool netdev_class_has_file_ns(const char *name, const void *ns) > > > > +{ > > > > + return class_has_file_ns(&net_class, name, ns); > > > > +} > > > > +EXPORT_SYMBOL(netdev_class_has_file_ns); > > > > > > Again, this feels broken, it can not solve a race condition. > > > > > > > This function is considered to be used under rtnl mutex and > > I assume that no one could use "/sys/class/net/*" outside of rtnl mutex. > > So, I think it returns the correct information under rtnl mutex. > > But you are creating a globally exported function that can be called > from anywhere, and as such, is not useful because it has no locking or > hints of how to use it correctly at all. > Yes, I agree with that. > Again, don't push this "solution" down to sysfs to solve, you know if > you have a device that is not cleaned up yet, so don't try to > rename/create a device of the same name before that is finished. > Okay, Thank you for that. I will find another way to fix it. Thanks a lot! Taehee Yoo