Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2666696imj; Mon, 11 Feb 2019 06:43:51 -0800 (PST) X-Google-Smtp-Source: AHgI3IahXRN1bHJ+nqKNzPgEN8yQkcUyf9HS6ODTgCEOFhTp/u8mdGcijQdeNyjusDet0b5PMEWp X-Received: by 2002:aa7:8802:: with SMTP id c2mr36860215pfo.20.1549896231168; Mon, 11 Feb 2019 06:43:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549896231; cv=none; d=google.com; s=arc-20160816; b=MRIEGhQQAnn1AIPuqEQYg9NTv3WbOWhhpl6jadILTtGTViL5LlqQ/qTFa1tsAv8AsB EekWtYUmhdAOaJWz8+q/0FDP9JwCekHn77bqMpcSRxxaEBP7voC/jsOSrBbW/hMS4Jca XuFANUSD1pb6GLjFBgq5RpBa9/k509BV79iIYZ2Uh9J6XK+DAj84mvhlT6qif1TGhsl3 EollOKynzybDs8WW/uy6b3LC358bgRWwCftK0QWCjp9QVXl7k8aJaiZYNEc4i8k+q72N h0DWWe92qCuPQqrn0+Zh5NBjewv+huYCIyS5mrjnIc1/TOClJwi9lWrpDi1vthWuvXLt fbpA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=bz7xgjCnPEjSub4MyVkDBzgJt9vD2AzLKEhIZp58mPg=; b=itf7SX4PmJRz0iH/GUd12IEU1TrAYoAqTOU7L2aOz7rVZ2Jv68kXtpmvDSbe57bENJ 0qpXyttuFnI3fnUhxJuzsQ/kC4FVluIe9GzYF7njkVUBl8284mi8lYreXWVlKe9d7xVZ u9Kv1sGn+0iBU3NywB2y3F7aPZ+dY2l2dkcZs2JZzmY11dSrGxxYh+cdczcI7Q2NXWM8 gigvP/PZuMjHKcWmmXbOSABjGrsms9LlnLB3zm7n53PdZX83qBZe7VHNnx9NEQS80ux8 hxDT8YMkvpkS7da29kF8BE5gUy9h0+rqCbIxD+AIu8jKazNH7qjAGPh8eFDfe7T8w1Su TZ3w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=leaPzGJV; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n80si186937pfj.177.2019.02.11.06.43.34; Mon, 11 Feb 2019 06:43:51 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=leaPzGJV; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732366AbfBKOmI (ORCPT + 99 others); Mon, 11 Feb 2019 09:42:08 -0500 Received: from mail.kernel.org ([198.145.29.99]:53740 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732345AbfBKOmD (ORCPT ); Mon, 11 Feb 2019 09:42:03 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D44E120838; Mon, 11 Feb 2019 14:42:02 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1549896123; bh=bv9bq6Ko5Xx7AmP6+DZhxMJAqyYXP0Xji1rnrf+M/z4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=leaPzGJViVpvQRSFf/kL2gmUbw4Yqvo7+VIvdBeXXes6EddRFNP7Oy8k4ayAJkOID 2ia5PD+DxSLppGbAQqwzvUa6yOstx+YbYu7+JyBSNVBId1Tycr0V9QfVJIhrDc8JuX 0WSnRpRtMHE9PqTOja27Vbsc/dDZmrpZpzhPHTIk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Kame Wang , Wei Wang , Zhang Rui , Sasha Levin Subject: [PATCH 4.19 080/313] Thermal: do not clear passive state during system sleep Date: Mon, 11 Feb 2019 15:16:00 +0100 Message-Id: <20190211141859.224202143@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190211141852.749630980@linuxfoundation.org> References: <20190211141852.749630980@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 964f4843a455d2ffb199512b08be8d5f077c4cac ] commit ff140fea847e ("Thermal: handle thermal zone device properly during system sleep") added PM hook to call thermal zone reset during sleep. However resetting thermal zone will also clear the passive state and thus cancel the polling queue which leads the passive cooling device state not being cleared properly after sleep. thermal_pm_notify => thermal_zone_device_reset set passive to 0 thermal_zone_trip_update will skip update passive as `old_target == instance->target'. monitor_thermal_zone => thermal_zone_device_set_polling will cancel tz->poll_queue, so the cooling device state will not be changed afterwards. Reported-by: Kame Wang Signed-off-by: Wei Wang Signed-off-by: Zhang Rui Signed-off-by: Sasha Levin --- drivers/thermal/thermal_core.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/drivers/thermal/thermal_core.c b/drivers/thermal/thermal_core.c index 441778100887..bf9721fc2824 100644 --- a/drivers/thermal/thermal_core.c +++ b/drivers/thermal/thermal_core.c @@ -451,16 +451,20 @@ static void update_temperature(struct thermal_zone_device *tz) tz->last_temperature, tz->temperature); } -static void thermal_zone_device_reset(struct thermal_zone_device *tz) +static void thermal_zone_device_init(struct thermal_zone_device *tz) { struct thermal_instance *pos; - tz->temperature = THERMAL_TEMP_INVALID; - tz->passive = 0; list_for_each_entry(pos, &tz->thermal_instances, tz_node) pos->initialized = false; } +static void thermal_zone_device_reset(struct thermal_zone_device *tz) +{ + tz->passive = 0; + thermal_zone_device_init(tz); +} + void thermal_zone_device_update(struct thermal_zone_device *tz, enum thermal_notify_event event) { @@ -1502,7 +1506,7 @@ static int thermal_pm_notify(struct notifier_block *nb, case PM_POST_SUSPEND: atomic_set(&in_suspend, 0); list_for_each_entry(tz, &thermal_tz_list, node) { - thermal_zone_device_reset(tz); + thermal_zone_device_init(tz); thermal_zone_device_update(tz, THERMAL_EVENT_UNSPECIFIED); } -- 2.19.1