Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2768609imj; Mon, 11 Feb 2019 08:11:13 -0800 (PST) X-Google-Smtp-Source: AHgI3IaE1IuZ26pxL2lATDxvdAJaE8oCpsYO8CNb+w4ZgpsLGKeYmecvXKjP5IdTyJ1sW3gsqazP X-Received: by 2002:a63:fd0a:: with SMTP id d10mr18289330pgh.164.1549901473752; Mon, 11 Feb 2019 08:11:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549901473; cv=none; d=google.com; s=arc-20160816; b=h2rBhfagirfSDr3EKgOeUdgh2lIpitsctF4LHwJDN3iIoPmEwc8kR2nallcXacHw+y j+eBOUGXrzT631xTV8G81/EvIGDmb1aJO43zU4BFBTG7pbe3Hbo5m5kiOsNz7XtnQDqK VQ+6FFBzJsAgvK5E6h+jCxfYWliX6EOdBpIpGHuWDl+quEblOZ0cCW2w/AKJ/e7TjE54 PVDnNLyRYT9vuSR8oUYZlbwogewo9KGj5sweQn63AJKArbQr+4kgZkagv+QzVqAb0mJR 2l8XHIz8uNToSj9WgugHduais6WKf3oeEraQSblbTTNJSatspEZMUEHVIGp9QmojjU7C VbmQ== 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=XBvsDxZeivkmLNvhIo93enXW31AXaYfpxbL/mDbEf7A=; b=V/cF/BCqQ2LSOxdvCTHhwXDPwHvCZKNBQnOe3ynS8U7/xkTFEj1XusY7O6+dS/3F84 QNHgWFHQdBf/p7uhQymdOXDWKy/pm74VLeJ7Ta+1NuZci6aU3pk0jdNo06iVm1pD0vzk pMbWoqQkHYGFcOcWezAmIB/cvXD10abbNwkRv2lf86eN8SYBlD8qVQ/Ltp2wJhaczfhp 4OAZBcD8IzQgiMjpK4YSocnGZOX+9+gnFvwC3SadwsrZudVZ6vjKoyQwefK40WinwIG1 8BBjnSL6KffQrv+Jz/rsO3RmbAodX/BsyWNAIp2J2lgpwLj9A+YQPkHEURovZTuVAZdv Y6/Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=uupCXIfd; 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 e63si9901251pgc.239.2019.02.11.08.10.56; Mon, 11 Feb 2019 08:11:13 -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=uupCXIfd; 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 S1729718AbfBKQJ5 (ORCPT + 99 others); Mon, 11 Feb 2019 11:09:57 -0500 Received: from mail.kernel.org ([198.145.29.99]:58386 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729315AbfBKOZD (ORCPT ); Mon, 11 Feb 2019 09:25: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 12C3D20838; Mon, 11 Feb 2019 14:25:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1549895102; bh=TzS6G3PGtL6GaTTvRvMoEij3PZEMMUEXz6L/5FGZFtQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=uupCXIfdXVEzH0JhHmmzG146I3g/4UfC6QJCHZAilF5rpjaNrOEp5Afbk72Jg172W HWZWx1WQzksrBJXhzS5rizLvORd1iXA6QyTDFwCqrAl/4Z4YyTX7JxjFT3V1blxvxm s0IfFUr0mFIw7gMrtkQhP1C5bgZDmPDVQIzCbSC8= 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.20 093/352] Thermal: do not clear passive state during system sleep Date: Mon, 11 Feb 2019 15:15:20 +0100 Message-Id: <20190211141851.804404363@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190211141846.543045703@linuxfoundation.org> References: <20190211141846.543045703@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.20-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 d6ebc1cf6aa9..3a014cd8daf0 100644 --- a/drivers/thermal/thermal_core.c +++ b/drivers/thermal/thermal_core.c @@ -453,16 +453,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) { @@ -1504,7 +1508,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