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 5A231370D4D for ; Fri, 8 May 2026 18:05:21 +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=1778263523; cv=none; b=a4XdxR+NqrgJM2lsYJlUnrZOSmpg4DhlcVm6lFzS+Up8hwaHmGyE9DFOQqNEe0g6EGmWX7oMbOPi75+FkBfDzm6t5S16iv1nSSFMBxO+7bqvMyGeYTOt65eVOfODHMppblldNDZfHnZn/Tu/6Tk/zgv5Sf4uHX1QjwMZy/k3Bw0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778263523; c=relaxed/simple; bh=Llpuo7ptAkoG1U7XPGvqcjBxPcBuKxYKyRljn2+GScw=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=PsrO/OhQl6dm6CnrjyUnGj51kwIJ2takTQD0djOBIv1vY8QrE02Jftagdhm3uXdyNYgx7JcsQJrPQRo5jiZg8LlQxKhC6usqVAqpeSnAYJD6i5AU2Oaanj2mDJP6Lgrt4mYM+7nF2XImUIMigJPEvCWWOjICMwZWrYa0r88g3AU= 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=NW0DDFRN; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=iwBUmDVU; 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="NW0DDFRN"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="iwBUmDVU" 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 648HU5sW2515481 for ; Fri, 8 May 2026 18:05:20 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:date:from:in-reply-to:message-id :mime-version:references:subject:to; s=qcppdkim1; bh=bwHWFphaJiJ LzQOfhxubcUS0JiF4OejVKSh/+aqeLSo=; b=NW0DDFRN1gJ1PWlk3nP7HBsE6/q XPYTnKWjZrrPpCZ9ii6+uJS74SSFiJWR+IzjcaIi8j6wJqRdvPpwM+yA82TevPtx otCZehqoqiKjm8/Bw5QgNnRKAIUAwZuHpmndou8OqMtZtLgti+c/XLeH7BUoS1bl oZfOSye9pZYqC02vmxR2jvvNLmpFsRYKmXdwAOOHg/Qghl4OHT2CMpE0fTWl7Dtf qRdoEtkfhWFtNhv7BxXuDbeh0AGjWRUTS+UJy27JXC6DyJIYZZIDpdqaIqE9xDbs PoHYHoVd9mShFjmwcmgNZBe+pMrE078eIah/XmIDiRPY7zghjvtOJk6as8Q== Received: from mail-vs1-f72.google.com (mail-vs1-f72.google.com [209.85.217.72]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4e1m9nr4de-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Fri, 08 May 2026 18:05:20 +0000 (GMT) Received: by mail-vs1-f72.google.com with SMTP id ada2fe7eead31-62eae604ac8so1359894137.1 for ; Fri, 08 May 2026 11:05:20 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1778263520; x=1778868320; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=bwHWFphaJiJLzQOfhxubcUS0JiF4OejVKSh/+aqeLSo=; b=iwBUmDVU9z+8ZUwq15rSw7iEejG8A5+Mk1clsPMlxNPMus68u4gG3PByUSrgwAekvK E9/kn3lE9Y+N2TGAqO5+Z6KkgaUSINMW9d6CqgLCvHJvZwIlo5pKn5jUICEGT+szY0uP MLVP+mLe6EoDAfQFhADdiAo+vPu8eFz4aBIjCMgkjIaddNz3GZuy5fgOkNEN6DuQm0Oa rqM/JRphKOuM50kF55Z5aOx9Rz8GzkESLdmQfwps/+/TfBpVdSuV1r9/OkwV7fTpixtj SuSXykoT3mzKdSOGb8Qpcw21Bx3JDzTNkxm77GzMRYCn9kK/f1jBRN1/hqLOsBMoXZuj 12hw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1778263520; x=1778868320; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=bwHWFphaJiJLzQOfhxubcUS0JiF4OejVKSh/+aqeLSo=; b=RTCcSN47N++4qJ+iEZjSOz5J1XfFJWzvx1K9ZLIX9s8MFMi2RWQMvzMoXSHZ6zguBC J6VWvgLshG/lrDz5HBB/hgtjER0wfoxz7RqVo9DvZL1uXX5Hw4GZ5Z7jqhtDHmEwdPk3 qUJ6n1OILrXu37VHp2LF354zkOSKHwAnbY74hq3BZ5T2UGWNIdr+jkBgUGR4jEHjZrLU 9upFwF1o43Xl3DWrskPdYZAmLv/8sVMkSyTbAzBMHo147/npFQYbzN8Jw2Jy5L8gwR9q VCuMtL18PmMMaBqsN+6QyQaTQsPmfCcjaYndqOe3/nqMepcULQutNhEu0m9qUbSNK8G2 YxnA== X-Forwarded-Encrypted: i=1; AFNElJ/RlKXmeSvx9PZtsAfL9csCRus5L+ahwundtVbYBYJzbr/TASuUY/3HedNC6Jiw1/Vrb7+YgvqS4T7NtAo=@vger.kernel.org X-Gm-Message-State: AOJu0Yzk8eyyfJDmehUEQFI3ZedtCgZySQM3AdrZRd/V9eK9504wVfdC /9GFktoVlJuMZIKmaqFPRX5S7gEEMYCZmq8T3WLtrqgoPicaVijAsKuYwMSq06KFMNpa0O0u+aW Zpx45jkqw4gkkhKJKDa2PYOOvK6UjDK7x+CJESdRu+XnMcbzYcmNg3qmfG/NkXTSDDr4= X-Gm-Gg: Acq92OFHzv58rSr2BL50UpskpZpXKHkmTf0xgbbAdzzzpvwajsgQoh2QfgVMEBDaBfX NTWwx9Tw96/RzYLTOe8R/4Fp0kwCR2/3HOZqgyAkEMGpu1Sp+iD/vUAwC5CVs5GdBJcwnJf0jkd Hxlsqolho641NachRq/i35+74mFKjV19QriOh7VssraPRbJOJYIapDRqbcOYJTyt+lAIdSUKHpu 8VaKabiJ4WPMjwJp5BK+5PT9CoMMjR/wULUJMnjt9sv6l4zYUV42uRso2WUd3lcZsa/tUwsH7TT 7dLBVS+uea6MOIW8jROQFEtsOZeuO5LnstGFqt/cvv7HdRTGj1Y+HMMpmnxBxK34nHPi9C6peIO 9xWt5F3FJDL0uMygeSQSPugRAL2tweXXh5Z2Dhx6Bv2HgwzZRS8dqMYboeFjj X-Received: by 2002:a05:6102:dd0:b0:622:702c:fd3f with SMTP id ada2fe7eead31-6313eb02d16mr1824531137.21.1778263519749; Fri, 08 May 2026 11:05:19 -0700 (PDT) X-Received: by 2002:a05:6102:dd0:b0:622:702c:fd3f with SMTP id ada2fe7eead31-6313eb02d16mr1824481137.21.1778263519303; Fri, 08 May 2026 11:05:19 -0700 (PDT) Received: from mai.box.freepro.com ([2a05:6e02:1041:c10:cda6:5a1c:b564:d3ee]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-48e6dd32afasm11654825e9.5.2026.05.08.11.05.18 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 08 May 2026 11:05:18 -0700 (PDT) From: Daniel Lezcano To: daniel.lezcano@oss.qualcomm.com, lukasz.luba@arm.com, rafael@kernel.org Cc: rui.zhang@intel.com, linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 3/4] thermal/core: Allocate the thermal class dynamically Date: Fri, 8 May 2026 20:05:10 +0200 Message-ID: <20260508180511.1306659-4-daniel.lezcano@oss.qualcomm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260508180511.1306659-1-daniel.lezcano@oss.qualcomm.com> References: <20260508180511.1306659-1-daniel.lezcano@oss.qualcomm.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Authority-Analysis: v=2.4 cv=DaEnbPtW c=1 sm=1 tr=0 ts=69fe25e0 cx=c_pps a=DUEm7b3gzWu7BqY5nP7+9g==:117 a=xqWC_Br6kY4A:10 a=NGcC8JguVDcA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=Um2Pa8k9VHT-vaBCBUpS:22 a=EUspDBNiAAAA:8 a=_90HsjT7k80V3hT8LC8A:9 a=-aSRE8QhW-JAV6biHavz:22 X-Proofpoint-GUID: aN8j6F4AGDSAnpqtiZxfnHOTEDdH_8qa X-Proofpoint-ORIG-GUID: aN8j6F4AGDSAnpqtiZxfnHOTEDdH_8qa X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNTA4MDE4MCBTYWx0ZWRfX06KmLevD1jGi Cg2f2Q6wcPhBbt10ug2vOLv9Gg4myQAcmAdL90vb0X6He8utxnI/MevcHsz4CCZJK5TsAm+d5UR FpdKyRvnxjjiUFGqRGIMa94fwg3loTBO3U3QJOvsULN6KLGlxqSyKZIszryUjcmk5e0CELZ0T5i 3P1JWvZFzqnx4xlD4uUYupA1wROuZ3t3iwJjv1BPm298wtLHpGBkQLnlphX1+kHcWkAMXZnH+1O 6M6jcCl1nzFBRQTD5fJdnqVkN6Aol/nEaOEaEEMP1FOv42ruJvtn8USvQgBBHU9v3NyYySGihPe sZKrA1/+fhVgjDBDRV5ElLHQC89WdJkWi/WV8ZF0qTG6WmySW28SxImW13AQyniiVfvJ+VrxksA fnsxYtnVWJYJAxoXumLpl5g/old2SxXldK755XCf2VtvNrFXCqnxgL6TPiQtqBJpattvyKwsXdK NXaODophBqfgZdb4uwQ== X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1143,Hydra:6.1.51,FMLib:17.12.100.49 definitions=2026-05-07_02,2026-05-08_02,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 bulkscore=0 spamscore=0 priorityscore=1501 adultscore=0 malwarescore=0 suspectscore=0 impostorscore=0 clxscore=1015 lowpriorityscore=0 phishscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2604200000 definitions=main-2605080180 Use class_create() instead of a statically allocated struct class. This allows the thermal class to be managed through a dynamically allocated class object and avoids keeping a static class instance around. Signed-off-by: Daniel Lezcano --- drivers/thermal/thermal_core.c | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/drivers/thermal/thermal_core.c b/drivers/thermal/thermal_core.c index a79fc4cdb078..748ab76823a3 100644 --- a/drivers/thermal/thermal_core.c +++ b/drivers/thermal/thermal_core.c @@ -949,9 +949,7 @@ static void thermal_unbind_cdev_from_trip(struct thermal_zone_device *tz, kfree(pos); } -static const struct class thermal_class = { - .name = "thermal", -}; +static struct class *thermal_class; static bool thermal_class_unavailable __ro_after_init = true; static inline @@ -1078,7 +1076,7 @@ __thermal_cooling_device_register(struct device_node *np, cdev->np = np; cdev->ops = ops; cdev->updated = false; - cdev->device.class = &thermal_class; + cdev->device.class = thermal_class; cdev->device.release = thermal_cdev_release; cdev->devdata = devdata; @@ -1574,7 +1572,7 @@ thermal_zone_device_register_with_trips(const char *type, if (!tz->ops.critical) tz->ops.critical = thermal_zone_device_critical; - tz->device.class = &thermal_class; + tz->device.class = thermal_class; tz->device.release = thermal_zone_device_release; tz->devdata = devdata; tz->num_trips = num_trips; @@ -1898,15 +1896,18 @@ static int __init thermal_init(void) if (result) goto destroy_workqueue; - result = class_register(&thermal_class); - if (result) + thermal_class = class_create("thermal"); + if (IS_ERR(thermal_class)) { + result = PTR_ERR(thermal_class); goto unregister_governors; + } thermal_class_unavailable = false; return 0; unregister_governors: + thermal_class = NULL; thermal_unregister_governors(); destroy_workqueue: destroy_workqueue(thermal_wq); -- 2.43.0