From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) (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 B57FF3F9F25 for ; Mon, 29 Jun 2026 09:13:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1782724395; cv=none; b=B9eFbW4K2zXCt2gjnuRRLUdxm1frVHatId5ufg7veKqfZxw1mHc7Lix2JK70IiPODdKTJpbmDOWkUH+XoCXaQ2tAd1aikkPkP6MVgUdwZpYTaN+f8bVLv6K+/o7kBx+lS1A0a/R8zEJAJgHrMdwB4+/RkwJObtP9sSyq45OtNVM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1782724395; c=relaxed/simple; bh=4Xem2fZJuhLkEpQ8AuCHhmO9dgYwD7FFiD2wwhhVUBk=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=X0520EBePpyMoEW/xQ0Gp2qJS9auoz7y/Y9P3FM3QRpcWC/Og6i528HPV5udE70AaA7y2cTy1hgqVCXpHifasrOySmNhc7NcrUIvkDswcnhblGBw2cOO1mvAynk1t7rOSsUwYhQAABaP9D/awDAN6iF++iqtIG2d0pttM6Jf3uk= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com; spf=pass smtp.mailfrom=oss.qualcomm.com; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b=lka551JY; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=H3YdDiIS; arc=none smtp.client-ip=205.220.168.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b="lka551JY"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="H3YdDiIS" Received: from pps.filterd (m0279865.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 65T7DxuA2188882 for ; Mon, 29 Jun 2026 09:13:13 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to; s=qcppdkim1; bh= BmmK6vf3xg5kSs+g+NySw3CxCiN6R9NnyD/njOvPVjA=; b=lka551JY52AAQD0N E1nsTsclnKJB9amehHdeu7bzmvQhFFyH9jnIDHlkrxX+7hSdRvhB8oznWibv1n47 TQJ93IOSM+SS3HBW6OhkTYu/8uBEGRh96wB+2s3baNMiaHwcod7+emf0GARrG4dG ujmpsZ/GRFx64Ut0bLqS/upYq5ytq9s48TVwl7RViMDdtwEFBTi3PdvLviVP2MFm YTUb+PFU9akJEbNi8hyUgnaCeAdALfzfFj3s7iFe38BNuMC+pavQ9JJtRHyTehT1 FLI6q2M9RNjFVtvofU3cjlu0pDwZzcqZgMmAje0zblGjFrXVez6nANvsIq9pnj3H KnpFzw== Received: from mail-qk1-f198.google.com (mail-qk1-f198.google.com [209.85.222.198]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4f3m4trg1y-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Mon, 29 Jun 2026 09:13:13 +0000 (GMT) Received: by mail-qk1-f198.google.com with SMTP id af79cd13be357-92b2ccd7971so561722685a.0 for ; Mon, 29 Jun 2026 02:13:12 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1782724392; x=1783329192; darn=vger.kernel.org; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:from:to:cc:subject:date:message-id :reply-to; bh=BmmK6vf3xg5kSs+g+NySw3CxCiN6R9NnyD/njOvPVjA=; b=H3YdDiISSSgcXUUw86ZYqtpTt/KlUCGE80b5Cvx2FStjoTWThmO8W2B4ErB0HO5Xud fkbbVyLQFxmxd/eM550ODcdCfOC89nvM2mvelOQdsS3mBeBXhwbmL0tyNxpIfovB9ViK 9P5+hO8Xo9+hc3/OtadaS6bhCPdXg1ygNFwjezqOJb5P86Sa2c5Ess0mTymjSBdiXo3M ppektWiKVGg/nir3eb9XeYQ8va6+pq9sYvkfwL3vngPnfVZY5swMeTjCCSa0l6RdJbiQ cRF+/04MVm9c2J3b+koLyX4YlhRnoMQr92iHI44+SCUg/yRftLLVt80/SDkzQgZkTn2p pkmQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1782724392; x=1783329192; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:x-gm-gg:x-gm-message-state:from:to :cc:subject:date:message-id:reply-to; bh=BmmK6vf3xg5kSs+g+NySw3CxCiN6R9NnyD/njOvPVjA=; b=NhTGSWMCACECRssav4ANbfkSyxBb8MQpTGQwf1NuuxEVXS5qWuFdQRcYuiN8XldWCQ PaH2rjsKgDRBfT2q9cXY77hsnqZnyXmuy+QbsQGLJkZWc4H5luzOFGKT8fJG+F7CcKUy cADazORxnU9KB0+GdiGHrWLmKeFTtQV6rOTNHUhiFXNdkGX9r84R6M57l14ij3IqLNvD sBLpy2T/UOgScQULn/f+gAPBRK905OiiAunJplRFwGmfJix/sXimdwdor6BKLnNql261 11I1/VkOoyKIenaKfvGdMKwhrIB+Kslteof6+3Oce+Cx+m5+XX4oNJd0e9u3kQDHO6s9 x4nQ== X-Forwarded-Encrypted: i=1; AFNElJ/rln5FamdpzvLofjLtP2ygE25R6F+WU2pQk0jhSA5xblRsYuwz3YYqkKXMUuSoAjOQSzFmKzMH9w==@vger.kernel.org X-Gm-Message-State: AOJu0Yy3rBrWV+r8Q1fSKg21XfP7HJuLRsZPgFz5N2X49psa4l+B1Eu3 8Q3+pAFNeRuvEZuzyxcMf9WyLpyglrO6E/MirbIzcp6iCWlYRse/sWsO2s7Jyxa2qgw2KF6epQ2 M7ATgoA6fkgXoZEmohhRMZEv7kPqOlIQ5DbrK+m9qE/SQufNQfU9PZ7TI2AO6Wg== X-Gm-Gg: AfdE7clMl1gJ1wUuZ9WvmnPQA69eeN1QjxqAEfmuNoPWuVciNWy30s62lhdko678XK/ zjQbySqNdz5j/2n2maxv4+3MD1M70en/rprhmI+jljhnvmpTW48fizG/2PvtULtZlUNuAPaFtp/ wvh5jJBMlmNqe5a3QKFPT/M3qtm03b8lbn0LdnLBaK1rOyTDFLc3K8GmrCAkVfZIN2zmTqE9Dqe 7Ujw9alzxnYncz76ow7L+Hxnk/TFlduMK7uFhHW8fPVzPllIFawN5bg/OjNMX/Ckk45lFNKHkud Vmf2qmadHGtd/T5dljtlEBr3hX0ELEtJJxGjlmBn2eEgDyLW+Ub1D01KTVQdk9F8MYA2LX3Gf3Y BXA9OlvZkADJFvvVez3zDos/hh19FkbuQE7svLw2d X-Received: by 2002:a05:620a:a195:20b0:92b:4ce5:6390 with SMTP id af79cd13be357-92b4ce57573mr1026450385a.25.1782724391976; Mon, 29 Jun 2026 02:13:11 -0700 (PDT) X-Received: by 2002:a05:620a:a195:20b0:92b:4ce5:6390 with SMTP id af79cd13be357-92b4ce57573mr1026435185a.25.1782724390191; Mon, 29 Jun 2026 02:13:10 -0700 (PDT) Received: from brgl-qcom.local ([2a01:cb1d:dc:7e00:4640:d76a:6126:9b65]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-470f55acda0sm20109240f8f.23.2026.06.29.02.13.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 29 Jun 2026 02:13:08 -0700 (PDT) From: Bartosz Golaszewski Date: Mon, 29 Jun 2026 11:12:27 +0200 Subject: [PATCH v2 04/19] driver core: platform: provide platform_device_set_of_node_from_dev() Precedence: bulk X-Mailing-List: linux-pm@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Message-Id: <20260629-pdev-fwnode-ref-v2-4-8abe2513f96e@oss.qualcomm.com> References: <20260629-pdev-fwnode-ref-v2-0-8abe2513f96e@oss.qualcomm.com> In-Reply-To: <20260629-pdev-fwnode-ref-v2-0-8abe2513f96e@oss.qualcomm.com> To: Lee Jones , Mark Brown , Thierry Reding , Sebastian Hesselbarth , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Srinivas Kandagatla , Greg Kroah-Hartman , Vinod Koul , "Rafael J. Wysocki" , Danilo Krummrich , Rob Herring , Saravana Kannan , Madhavan Srinivasan , Michael Ellerman , Nicholas Piggin , "Christophe Leroy (CS GROUP)" , Andi Shyti , Andy Shevchenko , Joerg Roedel , Will Deacon , Robin Murphy , Doug Berger , Florian Fainelli , Broadcom internal kernel review list , Ulf Hansson , Frank Li , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , Matthew Brost , =?utf-8?q?Thomas_Hellstr=C3=B6m?= , Rodrigo Vivi , David Airlie , Simona Vetter , Peter Chen , Paul Cercueil , Bin Liu , Philipp Zabel , Maximilian Luz , Hans de Goede , =?utf-8?q?Ilpo_J=C3=A4rvinen?= , Krzysztof Kozlowski , Benjamin Herrenschmidt Cc: brgl@kernel.org, linux-kernel@vger.kernel.org, netdev@vger.kernel.org, linux-arm-msm@vger.kernel.org, linux-sound@vger.kernel.org, driver-core@lists.linux.dev, devicetree@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-i2c@vger.kernel.org, iommu@lists.linux.dev, linux-pm@vger.kernel.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, intel-xe@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-usb@vger.kernel.org, linux-mips@vger.kernel.org, platform-driver-x86@vger.kernel.org, Bartosz Golaszewski X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=openpgp-sha256; l=2284; i=bartosz.golaszewski@oss.qualcomm.com; h=from:subject:message-id; bh=4Xem2fZJuhLkEpQ8AuCHhmO9dgYwD7FFiD2wwhhVUBk=; b=owEBbQKS/ZANAwAKAQWdLsv/NoTDAcsmYgBqQjcKKhTwBlGLPKN++MiZnFDb7ToqrUhpCsLFF bslLR74S6qJAjMEAAEKAB0WIQSR5RMt5bVGHXuiZfwFnS7L/zaEwwUCakI3CgAKCRAFnS7L/zaE w/b0D/9hlzF+MuyoI63nIic0Ze6VbI7qxNCbhn6uZeyniPLgZtbwhc69m2JUdgrAsHuQj0IpgJ5 RCEa24lCvBE2SclclefxC17v1wor7uj4mUrvqJAsmjgFueZdPPr1N600723ruBzPxuJumeQzssh jlRIYTX7/407wi5FmqwD448VpGUlB7Pa8NNjN4IxiVGs5XNbGOoj/im/ZWZEqGnDlSu01mcNJ6H iCfItNYSQATbNs8tXytgXjr2lFulGi9myKKDBQTaxbB5YtuL+8nWjUC+8o8kzBnw0EB5rK2I3RZ xOnAwjeUNAsnoHP1h5Zu3bola+8Dt77547fO6ziravWksfKzGMhGBTDYqtHYdVBNiSbOu01mOhj wW2esT/uXcCEuSBCz5c6WMXwwp5oY07WTlwLR5FKetn3Nr8g0u7Jct0e9Ae0Mt7+sOKVLeVMy6H VRRwZ02oyzNv6rvb2wurGxqaqfrcXzQuJCOYNJ3jXfPXjuhBl0/jsf/Mh+jygRzqUCoxEpt2gB4 VgJ1DsNmgpFosrKXs4a3l3flS+45sPbHJm3BdJMiIo/xXOgRhIEL8CNJjywDB0OugyemEEIs2ih rS4p2TSq2yTzG7YADPWUwWt9NpbmH36Qfqd4amAhIgP0uFrRnLP+2T42NgZ8X9f7xOLG6mDeruO VLhlU915iOWWEBQ== X-Developer-Key: i=bartosz.golaszewski@oss.qualcomm.com; a=openpgp; fpr=169DEB6C0BC3C46013D2C79F11A72EA01471D772 X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNjI5MDA3NCBTYWx0ZWRfX45BYXlZ6HD8/ jMapwRyylBdDnWnblqBB1aRCsTtmxPOPw3aynsNywIpimDTm1LySY8xF5S4E7Y9VqO8WdcUNP5j PAq9kbB6gb4wnNCsETcbahzTCyKrTMzujbXysBoRu6cyWFYSj6YOfH7HLpZnnoWihpHZjqTcRJi iFhR/sAHFXTv7XtkQ2CY+CZBDbIa+7Q2tXntkFSE9XqEqIjvDwk64VvzyAqObORZx7V+nfRCxNE TFQgVS9yjaTYec6d9Dk8BUHnXlqqLvdIYUWut9J/s4TbpUldUpLoB4mJY8PuYBXZoYPnLJ9gWp/ 3wpVXx5ZdxjTipUdZpizaMGyz8nVpbUf3nPN/met8YfNxOOqxbWzwjltMkdrzA9bNpJWNfiVkm4 EkwYSKYnVLD1YtiC+KZrc/Jng0/7JXb8ayIYs1FLcKKeAGvmxhA0yUdRSgqB6s2vUGco8EZgEtF g/Z8qgUkpnSTctyKrEw== X-Authority-Analysis: v=2.4 cv=R58z39RX c=1 sm=1 tr=0 ts=6a423729 cx=c_pps a=qKBjSQ1v91RyAK45QCPf5w==:117 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10 a=FelO9ux0wxsA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=Um2Pa8k9VHT-vaBCBUpS:22 a=EUspDBNiAAAA:8 a=hkCPowqfBUTF6yk2FrcA:9 a=QEXdDO2ut3YA:10 a=NFOGd7dJGGMPyQGDc5-O:22 X-Proofpoint-Spam-Info: AW1haW4tMjYwNjI5MDA3NCBTYWx0ZWRfX+5UvBtd2RSQe RLLd9ehLzzjtgbMZzDBgL944Qw/8VVYwbJNZimhmsCBFpz9+BbpH4WuEOBahnpEC4sJRlIs4p6t 95R1lKI2doJBcpvd0/g7MWnHOySLuCo= X-Proofpoint-ORIG-GUID: qYj6r0XFFukvJcXC4AnBHMcyYSW20d99 X-Proofpoint-GUID: qYj6r0XFFukvJcXC4AnBHMcyYSW20d99 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1143,Hydra:6.1.125,FMLib:17.12.100.49 definitions=2026-06-29_02,2026-06-26_01,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 impostorscore=0 spamscore=0 suspectscore=0 phishscore=0 clxscore=1015 adultscore=0 malwarescore=0 priorityscore=1501 bulkscore=0 lowpriorityscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2606150000 definitions=main-2606290074 Provide a platform-specific variant of device_set_of_node_from_dev(). In addition to bumping the reference count of the OF node being assigned, it also assigns the fwnode of the platform device. Signed-off-by: Bartosz Golaszewski --- drivers/base/platform.c | 16 ++++++++++++++++ include/linux/platform_device.h | 2 ++ 2 files changed, 18 insertions(+) diff --git a/drivers/base/platform.c b/drivers/base/platform.c index 6520b70cf3052d683a2ecb1a0dd7227575546ba0..f24a5f406746b53ca9eaab9472f6dd1345e04ad6 100644 --- a/drivers/base/platform.c +++ b/drivers/base/platform.c @@ -730,6 +730,22 @@ void platform_device_set_fwnode(struct platform_device *pdev, } EXPORT_SYMBOL_GPL(platform_device_set_fwnode); +/** + * platform_device_set_of_node_from_dev - reuse OF node of another device + * @pdev: platform device to set the node for + * @dev2: device whose OF node to reuse + * + * Reuses the OF node of another device in this platform device while + * internally keeping track of reference counting. + */ +void platform_device_set_of_node_from_dev(struct platform_device *pdev, + const struct device *dev2) +{ + device_set_of_node_from_dev(&pdev->dev, dev2); + pdev->dev.fwnode = of_fwnode_handle(pdev->dev.of_node); +} +EXPORT_SYMBOL_GPL(platform_device_set_of_node_from_dev); + /** * platform_device_add - add a platform device to device hierarchy * @pdev: platform device we're adding diff --git a/include/linux/platform_device.h b/include/linux/platform_device.h index c463d46b7b9ab6b891df1ca9f0c98608d2bb140f..94b8d2b46e913ebcdbdaa3710f008f478b59d7b4 100644 --- a/include/linux/platform_device.h +++ b/include/linux/platform_device.h @@ -268,6 +268,8 @@ void platform_device_set_of_node(struct platform_device *pdev, struct device_node *np); void platform_device_set_fwnode(struct platform_device *pdev, struct fwnode_handle *fwnode); +void platform_device_set_of_node_from_dev(struct platform_device *pdev, + const struct device *dev2); extern int platform_device_add(struct platform_device *pdev); extern void platform_device_del(struct platform_device *pdev); extern void platform_device_put(struct platform_device *pdev); -- 2.47.3