From nobody Tue Feb 10 06:26:33 2026 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 AB7B430CD8F for ; Mon, 19 Jan 2026 10:40:38 +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=1768819241; cv=none; b=c6CJhP4+Zs8HOn/C3OfaPuWr9cljOche75Tb+hYuJMUde5g/Q5efICYkOyfS/ZbpQLjOp81iEVZNOmdI9sLfvPMUU/f6cuub69Vi2YQ+VWVoasOYDACoS5VG1E/7XN0t5FtKA6juXDPSC8b1e3DGXIwxrQsHZrW9tKPwKoUVNYM= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1768819241; c=relaxed/simple; bh=/FOsnl+0vWD/ZzcTEo1dF12opBcr7kB+UcsUPg1w+Ds=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=HJ8iFS8EKsQFbvftgEj7ZbIBszzkei2LpyAnwOoMHZvbdU/hy1LEiMoT22mSNdevbZsuBRrCXQT5A0i8SWwqtgyd3Ve5yzswOpbdHIkzzl8jQ36OwEoD2ZW7VfOwqWTcA3pIaw3z72aeIgWi/pqeY7L5aGRKR6vHw/Zxjav/9WI= 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=WtUGhrbO; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=WOxTtoIK; 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="WtUGhrbO"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="WOxTtoIK" Received: from pps.filterd (m0279866.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 60J9kPi1774200 for ; Mon, 19 Jan 2026 10:40:38 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= igmXtZijQdt1UfbUzxesg6BqpEFZh/onZIxk1K1+ZUE=; b=WtUGhrbOL3zGykR7 r4/OlW1KGfz7xdKxgvWS0dDCsADMy3NZ4qVmPEK203fYSKO2zNCRKw8EPzt7nYeS dJ9LiPOykZNzsHxDxTQvjOID6ItOjmYDzUmOsFXCTr0Wizd5cUF053qxsDzgOOhy v9ARBQIMTjYM3nCBcpMLOBRuea8/XIv8QBNl8MQE3IRfuNIfdAXq9+BhKhSuj4eW G8n1YO6C4fzqUxXVqE3iz3mXV7IyMoRa0IE4y7vh06iQi1k/y/jY3d4oNxzavNAS ZoY83WfgRrLyaveYxpbT5cWLW3WpiBLh2QW6GUTURjN1cfkRhVz/mL1OaVgXYRwG SbB0PA== Received: from mail-qk1-f199.google.com (mail-qk1-f199.google.com [209.85.222.199]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4bsj9a85w1-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Mon, 19 Jan 2026 10:40:37 +0000 (GMT) Received: by mail-qk1-f199.google.com with SMTP id af79cd13be357-8c6a0ec2496so819061085a.1 for ; Mon, 19 Jan 2026 02:40:37 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1768819237; x=1769424037; 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=igmXtZijQdt1UfbUzxesg6BqpEFZh/onZIxk1K1+ZUE=; b=WOxTtoIKNjkwHauNvCIS9QhPgB1MJLJGqtnPfuDt4uVrHzcc4JLvBJbzBvCMfQb1k+ ra7Z+OF3L11WLEX7MDFGYD7kApegINcVgAHqZuOlsJuFcOUjl3ZbLFO3UnekPl3O3Ngz fcngCVu/JR1oST4Zae/JLCpfv7u4uFgS56j4yN20Zn9VUPo5Ka0dlOWk2nwE4balck1l 6u4IswpRTJ1T8lhDEa+7KKzOd+/7DmZ3gv07mOfLiOW53bUQvkkNb+827MC/cmB50QlH csYRsxF9qO6bybVbrwko5awf+zL623pDwPW3GVGJhVLhsR1zbGhUAeYTp3ShFe97XLBB G5qQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1768819237; x=1769424037; 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=igmXtZijQdt1UfbUzxesg6BqpEFZh/onZIxk1K1+ZUE=; b=mge1f56TetOVghmwsZacTJOd+oPPxI9gkCAi6mMTCuF1HrgdomVIj0eUKTds0wBuK2 X2jk8BimWoGYeTvlQQGwYKrNnA0iN7JSuXcXOioyHW4jARw1UiRLFZoJt/rEcJYjheFc hSb2sYpyHtyCIGZsoaAKjwTEiKmTjvKYjuF60juNFOFENbteLLyw2qyeYQUDMGm4BpeT 6uRisHs2RKqR1s0V+pT5kMymX61dyIPP7+jTTGpuO5jsesubnkIs2uK7Sg7sZ+QXPNsI ttyWkSnHIyXRhxTppD+BUIaWfk0NbCtQp1pbDqn7C3QVOud8RYBQJayEJPw9Gi2Ze9uT fv6Q== X-Forwarded-Encrypted: i=1; AJvYcCXZmWHMrGyP+doWObwH0sGXvmQx220ef75iwbdjIgcNo3pdYPT4sAIu191Y02kQiSP3IdCCyaBQmv88IUY=@vger.kernel.org X-Gm-Message-State: AOJu0YxbYP5CMGDqOueOWl0Mog2DQi4xhD/RgCvZB26R2e0tpxIEFlzE pLcKBPZMpxlmaFwjrXdayK3cqx2dBIp4pTmBWO8Vuuqb2Dwz/nVJ/IWrEShyTu2J3bBehi4Bl0e VR2q5DLyGKFxBwm9xWm/Gb796OjDJeXQ97Y+3fjDKGRFWqb1UL/F4BQF/Lw5Dx+u0Dlw= X-Gm-Gg: AY/fxX5pvwEMykb5jJqzxY7e+RIPS/IUQZzmE4oOtLM/jK23xDaJo1LrFJeBWoYtkI3 dXno2KtP98OclCSsS2joRQtFcIh9eCtoWO8oGDIgIlqqYC77Um9aaJppRAZALT+cd4iVkoZIabX jQIw/C/1sz1oaass8xnFWqtyzluUVBuBh1miMPs+5JtRE1qfUu8v0GjSBP/zOLwV8XuuXYjbc9w JXSPHeTIEuEKWM17NG58dFspiH2MhaYB0TssGCFPtC9iUljr+AyQI2mRqNuF7HZEffr8y9kFpxy bfokWhsU8o4a+57Je6aYFO4qq6yOPt5jdIkwY8UAm2oKLvHfEYsJ0SjS1YGFSo7RFMowLjQ4B5W wsoOp4P/gLPHDZXN8kNfcQsaN7ekwCG8dggZDVq6F X-Received: by 2002:a05:620a:4801:b0:89e:67a9:fced with SMTP id af79cd13be357-8c6a6789e6bmr1409465585a.66.1768819236982; Mon, 19 Jan 2026 02:40:36 -0800 (PST) X-Received: by 2002:a05:620a:4801:b0:89e:67a9:fced with SMTP id af79cd13be357-8c6a6789e6bmr1409460985a.66.1768819236489; Mon, 19 Jan 2026 02:40:36 -0800 (PST) Received: from brgl-qcom.local ([2a01:cb1d:dc:7e00:4f55:d102:7129:1a8f]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-4801e8c9cbcsm185185245e9.12.2026.01.19.02.40.35 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 19 Jan 2026 02:40:36 -0800 (PST) From: Bartosz Golaszewski Date: Mon, 19 Jan 2026 11:40:14 +0100 Subject: [PATCH 3/8] base: soc: export soc_device_get_machine() Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260119-soc-of-root-v1-3-32a0fa9a78b4@oss.qualcomm.com> References: <20260119-soc-of-root-v1-0-32a0fa9a78b4@oss.qualcomm.com> In-Reply-To: <20260119-soc-of-root-v1-0-32a0fa9a78b4@oss.qualcomm.com> To: Rob Herring , Saravana Kannan , Greg Kroah-Hartman , "Rafael J. Wysocki" , Danilo Krummrich , "Christophe Leroy (CS GROUP)" , Shawn Guo , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , Geert Uytterhoeven , Magnus Damm , Chen-Yu Tsai , Jernej Skrabec , Samuel Holland Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org, imx@lists.linux.dev, linux-renesas-soc@vger.kernel.org, linux-sunxi@lists.linux.dev, Bartosz Golaszewski X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=openpgp-sha256; l=2587; i=bartosz.golaszewski@oss.qualcomm.com; h=from:subject:message-id; bh=/FOsnl+0vWD/ZzcTEo1dF12opBcr7kB+UcsUPg1w+Ds=; b=owEBbQKS/ZANAwAKAQWdLsv/NoTDAcsmYgBpbgoX3WZw5M4WHNvKkR821Z3quwcNTpVLMjbj6 AN1sWnvF1mJAjMEAAEKAB0WIQSR5RMt5bVGHXuiZfwFnS7L/zaEwwUCaW4KFwAKCRAFnS7L/zaE w0OsEAC7wjDs/oNX7OLNZrfQxWpth2eroBxR5f5YvRbchfyUdsKPsp/pGUq1bCzrx+aFpHxx5e+ YGBS1c3ttUgKMaQd5jrKLaE3yeb32HPfOWs3abNpDkknl5BpNJGa5KmxarRXVPTwRznB/rW1WrQ ylY1lIYr2FWxe42W2R+vB612/3VwwbZ+mcYQDInqP60F34urScgzOClDXHdJuzfgW81Jo1l06Vo 1JKeggoB1rOCAGSFsN8atiRIjo5Qqf3eX2CX0LMfn1esbyQEN35bfgJ8Pw0p0Aj3cNOE7RNxcFz nAKxdjSj5/8La7xLviBdOlLcE1F9hYO4UWEnlZEx8rhro+XbipEp4CixHHhjqjFb4LrwAto580s 08lMsBqp/Djpu8FJlgvEJMsp4nf+D0Y+hKVJX12HiNC1J2+M2g/iOkl1Vrh9jRRMRPjIT+uPkE3 jc8G2pdztcvlBzcvL2bLF6K5MpyT2ZJ5bSC/X8rJbiF2mpIU/ZV5KR9+wbgvvm2VfaE7t6CpoIr 7qCTPf/VgJu/wCb8zjVU0J3rzNTH/JQjQI6eFfRc787kBMnyualHqCR8x7X9CTphC11xWFYCiJr 3VrW6gEQx8bJYO8wLIvZrxKukEuCrle8mFyVNMRTGOzCRvHbKqQvajpz45u+G9rkctUxcAg72NC wK187rGA7W2Ay7w== X-Developer-Key: i=bartosz.golaszewski@oss.qualcomm.com; a=openpgp; fpr=169DEB6C0BC3C46013D2C79F11A72EA01471D772 X-Proofpoint-ORIG-GUID: Zq4MpUoDtLSGEJhw3lirjKbQNBNGVsA0 X-Authority-Analysis: v=2.4 cv=N40k1m9B c=1 sm=1 tr=0 ts=696e0a25 cx=c_pps a=HLyN3IcIa5EE8TELMZ618Q==:117 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10 a=vUbySO9Y5rIA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=EUspDBNiAAAA:8 a=KKAkSRfTAAAA:8 a=VU1FamAdWuTKyoDMntYA:9 a=QEXdDO2ut3YA:10 a=bTQJ7kPSJx9SKPbeHEYW:22 a=cvBusfyB2V15izCimMoJ:22 X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwMTE5MDA4OCBTYWx0ZWRfXz+b47AvJ0Bfg VMUn+Sj9xtZGA+gJHuEodoDDm8xVdxXqAfFyDSJWhLSlng2YkyXnova12KChPDbyLVotQ9Hay/Z NmKI7T2NP9q673uYXzvSG1LOLqutYQhhPxxMnal2v/HXgbv1L+tylr8w5QPm2PgEA4EBgrT6R0F 2gjtEltMukDXNN7QojxoC2gwpwuH0Y/uauvU/XaVz/WrL84WIT1XRDchp5oGPDULId4q22fYk8N w//u+EV/7Yq9EKNOJDrshD4u8UavmhrWsOGFPF0DjFTk00QVyI6Rr15b6nHU+3IG5en4nkqtyZ4 eZXsYLii7hme/UKdVt5DWz05u5xfukIhMJvij5/ME4EJqvMrc2SNMPkUhQhuLXTw2RXikBkz8L7 1sLYnI398In5cC0Z0v7OENNeDMQBOzr+khi5aVqvn6pSu0il25iRju7Zl6W0Ili/GiIoRCobwgl ZLgqsZiErR6Bp39HlNw== X-Proofpoint-GUID: Zq4MpUoDtLSGEJhw3lirjKbQNBNGVsA0 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1121,Hydra:6.1.9,FMLib:17.12.100.49 definitions=2026-01-19_02,2026-01-19_02,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 clxscore=1015 priorityscore=1501 impostorscore=0 malwarescore=0 adultscore=0 spamscore=0 suspectscore=0 lowpriorityscore=0 bulkscore=0 phishscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2601150000 definitions=main-2601190088 Some SoC drivers reimplement the functionality of soc_device_get_machine(). Make this function accessible through the sys_soc.h header. Rework it slightly to return a negative error number on failure to read the machine string (SoC core can keep on ignoring it). While at it: make it use the __free() helper from cleanup.h. Signed-off-by: Bartosz Golaszewski Reviewed-by: Christophe Leroy (CS GROUP) --- drivers/base/soc.c | 16 +++++++++------- include/linux/sys_soc.h | 10 ++++++++++ 2 files changed, 19 insertions(+), 7 deletions(-) diff --git a/drivers/base/soc.c b/drivers/base/soc.c index 6f42632d2b0fcc8a729484e6ad270f9bcabe4a0b..bec8771d40f0590d4d7c3985c08= fedfd4043a394 100644 --- a/drivers/base/soc.c +++ b/drivers/base/soc.c @@ -5,6 +5,7 @@ * Author: Lee Jones for ST-Ericsson. */ =20 +#include #include #include #include @@ -111,17 +112,18 @@ static void soc_release(struct device *dev) kfree(soc_dev); } =20 -static void soc_device_get_machine(struct soc_device_attribute *soc_dev_at= tr) +int soc_device_get_machine(struct soc_device_attribute *soc_dev_attr) { - struct device_node *np; - if (soc_dev_attr->machine) - return; + return -EBUSY; + + struct device_node *np __free(device_node) =3D of_find_node_by_path("/"); + if (!np) + return -ENOENT; =20 - np =3D of_find_node_by_path("/"); - of_property_read_string(np, "model", &soc_dev_attr->machine); - of_node_put(np); + return of_property_read_string(np, "model", &soc_dev_attr->machine); } +EXPORT_SYMBOL_GPL(soc_device_get_machine); =20 static struct soc_device_attribute *early_soc_dev_attr; =20 diff --git a/include/linux/sys_soc.h b/include/linux/sys_soc.h index d9b3cf0f410c8cfb509a4c1a4d6c83fde6fe33c6..2d2dbc18462a39ddee95e38826a= 769fab089026f 100644 --- a/include/linux/sys_soc.h +++ b/include/linux/sys_soc.h @@ -37,6 +37,16 @@ void soc_device_unregister(struct soc_device *soc_dev); */ struct device *soc_device_to_device(struct soc_device *soc); =20 +/** + * soc_device_get_machine - retrieve the machine model and store it in + * the soc_device_attribute structure + * @soc_dev_attr: SoC attribute structure to store the model in + * + * Returns: + * 0 on success, negative error number on failure. + */ +int soc_device_get_machine(struct soc_device_attribute *soc_dev_attr); + #ifdef CONFIG_SOC_BUS const struct soc_device_attribute *soc_device_match( const struct soc_device_attribute *matches); --=20 2.47.3