Message ID | 20240220111044.133776-2-herve.codina@bootlin.com |
---|---|
State | New |
Headers |
Return-Path: <linux-kernel+bounces-72880-ouuuleilei=gmail.com@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:a05:693c:2685:b0:108:e6aa:91d0 with SMTP id mn5csp325229dyc; Tue, 20 Feb 2024 03:12:16 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCU2p73gF2c6O6+0rqWJbHI/10NmUNMyaU2NjDYq0HKUowyENeeQE0g62gwsbyZPIKFbjodM033FcdZm5/RWosq3FCYwUg== X-Google-Smtp-Source: AGHT+IEy3k+3y6qWwexdxlbtXH55AM93LlkLC4x/SHzikKE+Wu/cl/1aWxCws69b+zVHYgGYyIFK X-Received: by 2002:a17:903:1205:b0:1db:68d5:6281 with SMTP id l5-20020a170903120500b001db68d56281mr18501380plh.35.1708427536040; Tue, 20 Feb 2024 03:12:16 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1708427536; cv=pass; d=google.com; s=arc-20160816; b=it/BKFtiJ/072uh5htVzndAKmfP4Q2HvLvq8CXSMgnP35Bo0lG/cS2rhhv8AFsdFaj AlmTtLVDMLcPOBeySC+yuOONaneEVkPfAFVZQkVxw+An8kLA4mewtwFIMEA56ci3iWOH 0QXi5Jx9TIIVEI7riS1jrbPCapU1AEYvnhA6S9Ie8CobgkUIqlWkvGOcbnd8HG5ubFLZ VA0dYGo3zr+oULXCOYsbCV8mGrRMtTlF/F6RFSRoPniYdClkYE4ZZEfPSUYBsU4ZvoAa j4uTTXNXsKg2aidggWHnGQtqCo1MFU1LhePf/H7sqC514DwbHrobV6QtDyFbs1KKKxj/ ITHw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=dIMzuvrtDamZE0HiEkiJxqOPfEthKIYmnyBT6Ohkkxg=; fh=njSy/rlbAoKk1TdE9G+RzNVawG67mOpp31Vpsfilr4g=; b=inekXfJ7Er5S00x70GlLzbnOItRyri8biRUKZ5c74LPAqLgcH0JgBCwL8DC48vVu72 VPt+7HcNBm2Pe4UhG1OxdYOP9HHzkK8h+TdxvtTxiO1oWbpTS34etbt5rxKwU4NUYmoG 3Tv2VXOz6Uj/t6otYYvG4HYteLhwgjFcT71vzmkcvAg5VAq49rshx9npoPqpUNKtq4hj VTU8HjLs7LZpngJ4Y08/EiVFNWaBmjGlyAJ5O2ZfaUO7MEEw1Uuwu3vmb1XWbdxgPeie P8cvR4WIkJ7WwbJ5j8DucckzI/+ID1YpfemlFixTPwnMMvGjznf7cx5l71ZyyYFk2ZVH XVOQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b=BSSqGygS; arc=pass (i=1 spf=pass spfdomain=bootlin.com dkim=pass dkdomain=bootlin.com dmarc=pass fromdomain=bootlin.com); spf=pass (google.com: domain of linux-kernel+bounces-72880-ouuuleilei=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-72880-ouuuleilei=gmail.com@vger.kernel.org"; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id e8-20020a170902784800b001d8ffa784cfsi5968099pln.130.2024.02.20.03.12.15 for <ouuuleilei@gmail.com> (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 20 Feb 2024 03:12:16 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-72880-ouuuleilei=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b=BSSqGygS; arc=pass (i=1 spf=pass spfdomain=bootlin.com dkim=pass dkdomain=bootlin.com dmarc=pass fromdomain=bootlin.com); spf=pass (google.com: domain of linux-kernel+bounces-72880-ouuuleilei=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-72880-ouuuleilei=gmail.com@vger.kernel.org"; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 18D16287454 for <ouuuleilei@gmail.com>; Tue, 20 Feb 2024 11:11:59 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id C3F04664DC; Tue, 20 Feb 2024 11:11:01 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=bootlin.com header.i=@bootlin.com header.b="BSSqGygS" Received: from relay8-d.mail.gandi.net (relay8-d.mail.gandi.net [217.70.183.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id B7826664CE; Tue, 20 Feb 2024 11:10:56 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=217.70.183.201 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708427459; cv=none; b=KTZyC14ktQClUCiXAIk0pki1PwXdJAihePlEPannGM0rJiMl9l+vQmjkQ28PwjEiZhMan2eHKHiPj3IcpSKMPfezMe/mMnItlxWsacByzzcFrKil6D6PYM9lCRZeo00tOOiquoY0L22D/qr7vUVbN+QOX1s1l9thJWQT1TgNnXA= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708427459; c=relaxed/simple; bh=eRdcavBrbS7Z1tgoLtld/S/+yifdcL68SWTMBVmtqiw=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=gdZrQjECEnIgtDZJfEQ4z19X/uhT0LuJp8n+D2dJAv38+KFSzJDvjqZ7hm8Dr7hCXRiFeHiChWP9boLUtdsoste7HM3xYdt+GyWNnUtQTEIUilJbL6He6CiO17pGst2hCMeMFmeqdrSwaqLBQeeZyAXzTHDR0qrSrjuxH9+7vo0= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=bootlin.com; spf=pass smtp.mailfrom=bootlin.com; dkim=pass (2048-bit key) header.d=bootlin.com header.i=@bootlin.com header.b=BSSqGygS; arc=none smtp.client-ip=217.70.183.201 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=bootlin.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=bootlin.com Received: by mail.gandi.net (Postfix) with ESMTPA id 8228F1BF211; Tue, 20 Feb 2024 11:10:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bootlin.com; s=gm1; t=1708427455; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=dIMzuvrtDamZE0HiEkiJxqOPfEthKIYmnyBT6Ohkkxg=; b=BSSqGygS1kfJ6h9uzsvevdfUzDbIxGanc5XtUCMUXQGcdCnf3cnhtH0K7dvIZnvx1o4gv9 pb8b/liLFtzXzfv9QHiHxYs6OKadiTWet707mwjuUUWn+48AZGNzUacFArNfD7qRADz366 CH7XVs+tmLzCYIaR1jRaQEG7WipxeK+paTL9zXrHvGFqFqITUr+onbxt1Z5ZZ6T7Tenksz zNJl2XJlmMUsG4+Ok1TjcDClxVbHO4MsSQ8f0AeKsDJjegLT/08RTNak4iyejl2G4ZRJj7 8CLqxjwkIZXE4ur2TBC4seu3WJnSSrkMS9zlPTkP3GyxV9kpZb9GR2Trg0DJVw== From: Herve Codina <herve.codina@bootlin.com> To: Greg Kroah-Hartman <gregkh@linuxfoundation.org>, "Rafael J. Wysocki" <rafael@kernel.org>, Rob Herring <robh+dt@kernel.org>, Frank Rowand <frowand.list@gmail.com>, Shawn Guo <shawnguo@kernel.org>, Saravana Kannan <saravanak@google.com>, Wolfram Sang <wsa@kernel.org>, Mark Brown <broonie@kernel.org> Cc: Geert Uytterhoeven <geert+renesas@glider.be>, Rob Herring <robh@kernel.org>, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, Luca Ceresoli <luca.ceresoli@bootlin.com>, Thomas Petazzoni <thomas.petazzoni@bootlin.com>, Herve Codina <herve.codina@bootlin.com>, stable@vger.kernel.org Subject: [PATCH 1/2] driver core: Clear FWNODE_FLAG_NOT_DEVICE when a device is added Date: Tue, 20 Feb 2024 12:10:36 +0100 Message-ID: <20240220111044.133776-2-herve.codina@bootlin.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240220111044.133776-1-herve.codina@bootlin.com> References: <20240220111044.133776-1-herve.codina@bootlin.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: <linux-kernel.vger.kernel.org> List-Subscribe: <mailto:linux-kernel+subscribe@vger.kernel.org> List-Unsubscribe: <mailto:linux-kernel+unsubscribe@vger.kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-GND-Sasl: herve.codina@bootlin.com X-getmail-retrieved-from-mailbox: INBOX X-GMAIL-THRID: 1791416112224292819 X-GMAIL-MSGID: 1791416112224292819 |
Series |
devlink: Take care of FWNODE_FLAG_NOT_DEVICE in case of DT overlays
|
|
Commit Message
Herve Codina
Feb. 20, 2024, 11:10 a.m. UTC
Since commit 1a50d9403fb9 ("treewide: Fix probing of devices in DT
overlays"), when using device-tree overlays, the FWNODE_FLAG_NOT_DEVICE
is set on each overlay nodes.
When an overlay contains a node related to a bus (i2c for instance)
and its children nodes representing i2c devices, the flag is cleared for
the bus node by the OF notifier but the "standard" probe sequence takes
place (the same one is performed without an overlay) for the bus and
children devices are created simply by walking the children DT nodes
without clearing the FWNODE_FLAG_NOT_DEVICE flag for these devices.
Clear the FWNODE_FLAG_NOT_DEVICE when the device is added, no matter if
an overlay is used or not.
Fixes: 1a50d9403fb9 ("treewide: Fix probing of devices in DT overlays")
Cc: <stable@vger.kernel.org>
Signed-off-by: Herve Codina <herve.codina@bootlin.com>
---
drivers/base/core.c | 1 +
1 file changed, 1 insertion(+)
Comments
On Tue, Feb 20, 2024 at 3:10 AM Herve Codina <herve.codina@bootlin.com> wrote: > > Since commit 1a50d9403fb9 ("treewide: Fix probing of devices in DT > overlays"), when using device-tree overlays, the FWNODE_FLAG_NOT_DEVICE > is set on each overlay nodes. > When an overlay contains a node related to a bus (i2c for instance) > and its children nodes representing i2c devices, the flag is cleared for > the bus node by the OF notifier but the "standard" probe sequence takes > place (the same one is performed without an overlay) for the bus and > children devices are created simply by walking the children DT nodes > without clearing the FWNODE_FLAG_NOT_DEVICE flag for these devices. > > Clear the FWNODE_FLAG_NOT_DEVICE when the device is added, no matter if > an overlay is used or not. > > Fixes: 1a50d9403fb9 ("treewide: Fix probing of devices in DT overlays") > Cc: <stable@vger.kernel.org> > Signed-off-by: Herve Codina <herve.codina@bootlin.com> > --- > drivers/base/core.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/drivers/base/core.c b/drivers/base/core.c > index 14d46af40f9a..61d09ac57bfb 100644 > --- a/drivers/base/core.c > +++ b/drivers/base/core.c > @@ -3619,6 +3619,7 @@ int device_add(struct device *dev) > */ > if (dev->fwnode && !dev->fwnode->dev) { > dev->fwnode->dev = dev; > + dev->fwnode->flags &= ~FWNODE_FLAG_NOT_DEVICE; > fw_devlink_link_device(dev); > } Temporary Nack on this. I think depending on how we address patch 2/2 this patch might not be necessary. Also, I'd ideally prefer this gets cleared before the device is added, but it's a position that I'd be willing to change. -Saravana
diff --git a/drivers/base/core.c b/drivers/base/core.c index 14d46af40f9a..61d09ac57bfb 100644 --- a/drivers/base/core.c +++ b/drivers/base/core.c @@ -3619,6 +3619,7 @@ int device_add(struct device *dev) */ if (dev->fwnode && !dev->fwnode->dev) { dev->fwnode->dev = dev; + dev->fwnode->flags &= ~FWNODE_FLAG_NOT_DEVICE; fw_devlink_link_device(dev); }