Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp23243rwl; Wed, 4 Jan 2023 14:32:24 -0800 (PST) X-Google-Smtp-Source: AMrXdXvlVC7rdq0PPeg146a+ZxtrfTJuqLt3gpHKtvrtOabyEEV5bgm4hktGV6jzrsw6z23xwFJ7 X-Received: by 2002:a17:906:6d2:b0:7e7:4dd7:bb88 with SMTP id v18-20020a17090606d200b007e74dd7bb88mr39019505ejb.57.1672871543852; Wed, 04 Jan 2023 14:32:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1672871543; cv=none; d=google.com; s=arc-20160816; b=Njhug5dw3JVlQJBaxFkKT0VYVwd1spNJaiku8BwXWy3v+14lJs3vVY8EdNDrykkljc 3B1quR5zhuHJQZKyRpqNdT+ppEnjOCj4McFNOsJbokPZcP7YyvTcwa/Z+3OgPX4n6AMR b7Xdhj6zKwu2tq97aTYb4Ljk+nTs7uBm+gZSO5A8nSxNQGpbUrsSHSubK2+xqL7YKf8M 8Sk5wfDiAlMESw7019QJ7g3HaAbR1Nrjal+AKAqgSkJu8Ik7RsXfL90uM51Oxjwj5Xjv b38mepkBhq0JCZ9DT/oAihFScb+cZ28L4chcMtC1R4YeqIqbrlFRcuoKscOZxAIt/FvK fYzA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=WisTl2/jQnyj0HaOzjGAaCKi4fhfXEEwsPLq/X09SZo=; b=ookDwaL5OXRvQMhV8nZBRJMqZwD+OwUicvanEXrQ8i9U71jCI+e6YFAbiQTm4QxxVw +Q/DHtz3dNMZ3N03FFl37TS+u5O4CQc7vq1w8HhPWGSnu3J2RHW00fzx6gsipHAWNTw9 X/ynYOLPqjSwem8Q6vQIEtw0RW//FTF7J5rsEQuyZBVfPdXUxKwvU8xeJdKPGfdQIr/h wr2ygSaq8c3lp/GYZIY1H7G9+KtTD5WQhlWvrAgCmk3FbEuf7LKTXMyr1JVPBspJtVOf MQuPcgF/bz+UVQj/EDoOQbT+n2N35cH8TJ5BdN/JoH1jWTUMbOXkGEaiYHnl+XzKjLAc IsvQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=cD6944PC; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hv15-20020a17090760cf00b007ae1e635ea3si33261557ejc.754.2023.01.04.14.32.10; Wed, 04 Jan 2023 14:32:23 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=cD6944PC; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240572AbjADWVw (ORCPT + 56 others); Wed, 4 Jan 2023 17:21:52 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43458 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240558AbjADWVi (ORCPT ); Wed, 4 Jan 2023 17:21:38 -0500 Received: from mail-wm1-x332.google.com (mail-wm1-x332.google.com [IPv6:2a00:1450:4864:20::332]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 55E5BE35 for ; Wed, 4 Jan 2023 14:21:36 -0800 (PST) Received: by mail-wm1-x332.google.com with SMTP id ja17so26724770wmb.3 for ; Wed, 04 Jan 2023 14:21:36 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; 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=WisTl2/jQnyj0HaOzjGAaCKi4fhfXEEwsPLq/X09SZo=; b=cD6944PCnLq8drhYHKHUrq0ielkWQVciHL7pDRpNACUVoSKeM0StZq+ckd9jN91ltQ g5QU4dUa51ZYh7Ntg06S0zKAAFspwByXMEZUSExZIr9ryaWHxB2kjQiLC7RiB/rza0+C wAIlQLkRWlSV9ubmJbsK0bAIl09aVJaU3w9zYWFRSImRvdaPb+/CdHjDkgCxehuLI3Ir u8ImyOrVidXATce8i03ZYt3nJ4pk8WfzGVxMT3CRydbLvBjJgk6NqS8UXOQUkR37p5+E NF14uybfr8sGVoQ45dWMCF4MBeJ09NVR2k6tftAEXdOmWRzMLThvriOIjUFmVo9+noKR QMOw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=WisTl2/jQnyj0HaOzjGAaCKi4fhfXEEwsPLq/X09SZo=; b=u61beVJfG684cDLkDJ6uZm46Cr0isxugG/bt7ugksJZpQABPIGvhvk0DgM0v++bV9b gwByd5dhU4ZkKiWar6TEZJ7t2GajcnLOIoO/Jyg/BPS3D81PmHE3cUPrNv4PGtVT4jL/ n86KtHeOj8lGaeucKRUTaH2xafiHWywnQtV2dhlhrzJOqm+InOZBIRwxwbjcthP0Pzbu iOrAGEvEQNGAO5oDVr7t0GrARt4V59FJwVVpq8phJHZtOr0EpNiBYe9Cl2nY9lZCbgcO vAQ5cb58csqKGxihaOpfbdcAUQ/bXub0fAODoLuSWRFMsyuFgmALKppV0nDFA9F7e7GW 7PWw== X-Gm-Message-State: AFqh2kpXgXX0BUmrwJd60rpWGc96b41Bxkirl4giA9rDklyqcONdwDj9 z9k7IwywUGe+zAH5GNmYcrmJN0SPN2LfbpY6 X-Received: by 2002:a05:600c:5113:b0:3d3:5c21:dd99 with SMTP id o19-20020a05600c511300b003d35c21dd99mr34219998wms.18.1672870894769; Wed, 04 Jan 2023 14:21:34 -0800 (PST) Received: from mai.. (146725694.box.freepro.com. [130.180.211.218]) by smtp.gmail.com with ESMTPSA id l7-20020adfc787000000b002238ea5750csm42430278wrg.72.2023.01.04.14.21.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 04 Jan 2023 14:21:34 -0800 (PST) From: Daniel Lezcano X-Google-Original-From: Daniel Lezcano To: daniel.lezcano@linaro.org, rafael@kernel.org, srinivas.pandruvada@linux.intel.com Cc: linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org, rui.zhang@intel.com, christophe.jaillet@wanadoo.fr, Amit Kucheria , Len Brown , Randy Dunlap , Ricardo Neri Subject: [PATCH v3 2/3] thermal/drivers/intel: Use generic trip points for intel_pch Date: Wed, 4 Jan 2023 23:21:26 +0100 Message-Id: <20230104222127.2364396-3-daniel.lezcano@kernel.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230104222127.2364396-1-daniel.lezcano@kernel.org> References: <20230104222127.2364396-1-daniel.lezcano@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Daniel Lezcano The thermal framework gives the possibility to register the trip points with the thermal zone. When that is done, no get_trip_* ops are needed and they can be removed. Convert the ops content logic into generic trip points and register them with the thermal zone. In order to consolidate the code, use the ACPI thermal framework API to fill the generic trip point from the ACPI tables. It has been tested on a Intel i7-8650U - x280 with the INT3400, the PCH, ACPITZ, and x86_pkg_temp. No regression observed so far. Signed-off-by: Daniel Lezcano --- V3: - The driver Kconfig option selects CONFIG_THERMAL_ACPI --- drivers/thermal/intel/Kconfig | 1 + drivers/thermal/intel/intel_pch_thermal.c | 88 +++++------------------ 2 files changed, 20 insertions(+), 69 deletions(-) diff --git a/drivers/thermal/intel/Kconfig b/drivers/thermal/intel/Kconfig index f0c845679250..738b88b290f4 100644 --- a/drivers/thermal/intel/Kconfig +++ b/drivers/thermal/intel/Kconfig @@ -75,6 +75,7 @@ config INTEL_BXT_PMIC_THERMAL config INTEL_PCH_THERMAL tristate "Intel PCH Thermal Reporting Driver" depends on X86 && PCI + select THERMAL_ACPI help Enable this to support thermal reporting on certain intel PCHs. Thermal reporting device will provide temperature reading, diff --git a/drivers/thermal/intel/intel_pch_thermal.c b/drivers/thermal/intel/intel_pch_thermal.c index dabf11a687a1..530fe9b38381 100644 --- a/drivers/thermal/intel/intel_pch_thermal.c +++ b/drivers/thermal/intel/intel_pch_thermal.c @@ -65,6 +65,8 @@ #define WPT_TEMP_OFFSET (PCH_TEMP_OFFSET * MILLIDEGREE_PER_DEGREE) #define GET_PCH_TEMP(x) (((x) / 2) + PCH_TEMP_OFFSET) +#define PCH_MAX_TRIPS 3 /* critical, hot, passive */ + /* Amount of time for each cooling delay, 100ms by default for now */ static unsigned int delay_timeout = 100; module_param(delay_timeout, int, 0644); @@ -82,12 +84,7 @@ struct pch_thermal_device { const struct pch_dev_ops *ops; struct pci_dev *pdev; struct thermal_zone_device *tzd; - int crt_trip_id; - unsigned long crt_temp; - int hot_trip_id; - unsigned long hot_temp; - int psv_trip_id; - unsigned long psv_temp; + struct thermal_trip trips[PCH_MAX_TRIPS]; bool bios_enabled; }; @@ -102,33 +99,22 @@ static void pch_wpt_add_acpi_psv_trip(struct pch_thermal_device *ptd, int *nr_trips) { struct acpi_device *adev; - - ptd->psv_trip_id = -1; + int ret; adev = ACPI_COMPANION(&ptd->pdev->dev); - if (adev) { - unsigned long long r; - acpi_status status; - - status = acpi_evaluate_integer(adev->handle, "_PSV", NULL, - &r); - if (ACPI_SUCCESS(status)) { - unsigned long trip_temp; - - trip_temp = deci_kelvin_to_millicelsius(r); - if (trip_temp) { - ptd->psv_temp = trip_temp; - ptd->psv_trip_id = *nr_trips; - ++(*nr_trips); - } - } - } + if (!adev) + return; + + ret = thermal_acpi_trip_psv(adev, &ptd->trips[*nr_trips]); + if (ret) + return; + + ++(*nr_trips); } #else static void pch_wpt_add_acpi_psv_trip(struct pch_thermal_device *ptd, int *nr_trips) { - ptd->psv_trip_id = -1; } #endif @@ -163,21 +149,19 @@ static int pch_wpt_init(struct pch_thermal_device *ptd, int *nr_trips) } read_trips: - ptd->crt_trip_id = -1; trip_temp = readw(ptd->hw_base + WPT_CTT); trip_temp &= 0x1FF; if (trip_temp) { - ptd->crt_temp = GET_WPT_TEMP(trip_temp); - ptd->crt_trip_id = 0; + ptd->trips[*nr_trips].temperature = GET_WPT_TEMP(trip_temp); + ptd->trips[*nr_trips].type = THERMAL_TRIP_CRITICAL; ++(*nr_trips); } - ptd->hot_trip_id = -1; trip_temp = readw(ptd->hw_base + WPT_PHL); trip_temp &= 0x1FF; if (trip_temp) { - ptd->hot_temp = GET_WPT_TEMP(trip_temp); - ptd->hot_trip_id = *nr_trips; + ptd->trips[*nr_trips].temperature = GET_WPT_TEMP(trip_temp); + ptd->trips[*nr_trips].type = THERMAL_TRIP_HOT; ++(*nr_trips); } @@ -298,39 +282,6 @@ static int pch_thermal_get_temp(struct thermal_zone_device *tzd, int *temp) return ptd->ops->get_temp(ptd, temp); } -static int pch_get_trip_type(struct thermal_zone_device *tzd, int trip, - enum thermal_trip_type *type) -{ - struct pch_thermal_device *ptd = tzd->devdata; - - if (ptd->crt_trip_id == trip) - *type = THERMAL_TRIP_CRITICAL; - else if (ptd->hot_trip_id == trip) - *type = THERMAL_TRIP_HOT; - else if (ptd->psv_trip_id == trip) - *type = THERMAL_TRIP_PASSIVE; - else - return -EINVAL; - - return 0; -} - -static int pch_get_trip_temp(struct thermal_zone_device *tzd, int trip, int *temp) -{ - struct pch_thermal_device *ptd = tzd->devdata; - - if (ptd->crt_trip_id == trip) - *temp = ptd->crt_temp; - else if (ptd->hot_trip_id == trip) - *temp = ptd->hot_temp; - else if (ptd->psv_trip_id == trip) - *temp = ptd->psv_temp; - else - return -EINVAL; - - return 0; -} - static void pch_critical(struct thermal_zone_device *tzd) { dev_dbg(&tzd->device, "%s: critical temperature reached\n", tzd->type); @@ -338,8 +289,6 @@ static void pch_critical(struct thermal_zone_device *tzd) static struct thermal_zone_device_ops tzd_ops = { .get_temp = pch_thermal_get_temp, - .get_trip_type = pch_get_trip_type, - .get_trip_temp = pch_get_trip_temp, .critical = pch_critical, }; @@ -423,8 +372,9 @@ static int intel_pch_thermal_probe(struct pci_dev *pdev, if (err) goto error_cleanup; - ptd->tzd = thermal_zone_device_register(bi->name, nr_trips, 0, ptd, - &tzd_ops, NULL, 0, 0); + ptd->tzd = thermal_zone_device_register_with_trips(bi->name, ptd->trips, + nr_trips, 0, ptd, + &tzd_ops, NULL, 0, 0); if (IS_ERR(ptd->tzd)) { dev_err(&pdev->dev, "Failed to register thermal zone %s\n", bi->name); -- 2.34.1