Received: by 2002:ac0:8c8e:0:0:0:0:0 with SMTP id r14csp118155ima; Wed, 6 Feb 2019 18:28:11 -0800 (PST) X-Google-Smtp-Source: AHgI3IZtLx4Ho/xxg29E6n+SoCiQJJIqXwQtRhQDsIWx9m1nxvJgrA1nci2jiJQBWDo773QahjWK X-Received: by 2002:a17:902:ba8e:: with SMTP id k14mr13909065pls.219.1549506491648; Wed, 06 Feb 2019 18:28:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549506491; cv=none; d=google.com; s=arc-20160816; b=Jib+tz1DMZeA5p35TLXInh+ozSxAlCrgavP9T3EpnVtGkA32NLc6DlWSctljzuPATG Sh3W6AXwYrejvBM0xpcX2sjMx+LCLVuqvoW0ElEUIPc4MwVv2sfN+OG5vvm+lo2j6GA7 bL7XRgzJfgyOqhC2z+94m7BnieBElUxDYtsbSPHo2zmxaXzyoe3slUezDLqb4MqiS4zs wojS5d2IxTzehWG+X/mkZisVlmk8LX36+My+EfYImDkEiEQ5gwnf7JtKpxmRcTkHfeYo 0WGx83ESRisBSHVVhsnrL4FRY99icC63hdPIgu4L3rRJEpRrNdeR0MCyWT66Z/4R1JGA 3tIQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=GDHURo37I4b5m1A7IYTUMb7FLYGy+RlyZhWOl/qQpQY=; b=wdR3QIfjsCPrfXoSDdWVf8ZFc9rc5Dfd0/oSJsvOK7oGHZdIDGIgHXvXBP6O0XGuT7 EhCJ5VMwAON3uDqsUDBFO3tiFac6ePDVNHg9NUuidwmyYqOzxiYZjYkFIsQ0EYdSi2tg oSeGHd17xh/1JsVjUfNIg46JkZ2q0l3kjXhsrZV99JGCfRjFXdBL+6eeaW5CZS4tgAVP ajqqwMbP34Bul76l+4wbkmXEr7MIBC42zpikl1+Aid+2LBrIYndByLtSr555vVUZAeEb oCLUam20ViHXmUkft4nfXJMif/S+JIHLGMvIBR6PNT7R/z6mGgZKQ6zAUYl5/YCCo+Y+ RRjw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=bW4Nj4KI; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d2si8033202pla.81.2019.02.06.18.27.56; Wed, 06 Feb 2019 18:28:11 -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=@chromium.org header.s=google header.b=bW4Nj4KI; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726796AbfBGB5c (ORCPT + 99 others); Wed, 6 Feb 2019 20:57:32 -0500 Received: from mail-pf1-f193.google.com ([209.85.210.193]:45656 "EHLO mail-pf1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726764AbfBGB5b (ORCPT ); Wed, 6 Feb 2019 20:57:31 -0500 Received: by mail-pf1-f193.google.com with SMTP id j3so1896062pfi.12 for ; Wed, 06 Feb 2019 17:57:30 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to :user-agent; bh=GDHURo37I4b5m1A7IYTUMb7FLYGy+RlyZhWOl/qQpQY=; b=bW4Nj4KIJ5lRWUhM8zP5aQwIwsfxhBOHCAzCL56es10m/IvbZa2jh4Nhrn3iIPVYPD nOtKp/N0XC0z7wOSlqUg9HfKi7dKdoQ0SVq/Qwzxi7XchTuQt0AcRFrJOw7Q7gCDXt72 Zwaq1wvfpbheXb6bp6NXN+3+ZStRI8IzbTBmc= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to:user-agent; bh=GDHURo37I4b5m1A7IYTUMb7FLYGy+RlyZhWOl/qQpQY=; b=YWprS9jM57U1gox5CXFy+ijT+ee3YKwD2R1ao3IeDrd2g8cIh7Kduj7k+lVF5R+Czs vRSQm3woV+MT+HUDZ1E7RyV0HH+Yths6iUICs86eUUuCdkx5JmJJnfeKCOX4B8zbg7FH vy23+PiHU6aYSMV4ULLgwu/Exxf8s2UCr0/Fxk7k3gxVnki/cgGjvKqDvb5KicQhYRN/ qLXM3qZcOP2eUfNGTAv77U4cd9mZHPSI7zQTTviscDS/RCo6ALHPaZhnHWd7fRMV7HrT 3Di42mFtzxf74qPrrXWKNQyAFyM5gq/fz5MI9DHdrwIpB1AePfa+JVnW6sWm0sw+6OpB 9QQw== X-Gm-Message-State: AHQUAuaQS8CAWW7k0f2HRVsLVXLw9cuLZ9WziMCNQgvDJ3uEg4CJiFjq fMrydYwtKqySebsy2SzGkINEpQ== X-Received: by 2002:a62:a510:: with SMTP id v16mr13676678pfm.18.1549504650312; Wed, 06 Feb 2019 17:57:30 -0800 (PST) Received: from localhost ([2620:15c:202:1:75a:3f6e:21d:9374]) by smtp.gmail.com with ESMTPSA id o16sm3937350pgv.41.2019.02.06.17.57.28 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Wed, 06 Feb 2019 17:57:29 -0800 (PST) Date: Wed, 6 Feb 2019 17:57:27 -0800 From: Matthias Kaehlcke To: Amit Kucheria Cc: Linux Kernel Mailing List , linux-arm-msm , Bjorn Andersson , Eduardo Valentin , Andy Gross , Taniya Das , Stephen Boyd , Doug Anderson , David Brown , Rob Herring , Mark Rutland , DTML Subject: Re: [PATCH v3 1/1] arm64: dts: sdm845: wireup the thermal trip points to cpufreq Message-ID: <20190207015727.GK117604@google.com> References: <6a21a9ee7663e1b32d8ea81ac5e51d187aed25fb.1548093127.git.amit.kucheria@linaro.org> <20190123021251.GJ261387@google.com> <20190124233528.GA81583@google.com> <20190125222051.GF81583@google.com> <20190206193441.GJ117604@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20190206193441.GJ117604@google.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 06, 2019 at 11:34:41AM -0800, Matthias Kaehlcke wrote: > On Wed, Feb 06, 2019 at 04:05:41PM +0530, Amit Kucheria wrote: > > On Sat, Jan 26, 2019 at 3:50 AM Matthias Kaehlcke wrote: > > > > > > trips { > > > > > > - cpu_alert0: trip0 { > > > > > > + cpu0_alert1: trip-point@0 { > > > > > > temperature = <75000>; > > > > > > > > > > In my observations a 'switch on/threshold' temperature of 75 degrees > > > > > leads to aggressive throttling with IPA when the temperature is above > > > > > this threshold: > > > > > > > > > > [ 716.760804] cpu_cooling_ratelimit: 31 callbacks suppressed > > > > > [ 716.760836] cpu cpu4: Cooling state set to 10. New max freq = 1920000 > > > > > [ 716.773390] power_allocator_ratelimit: 15 callbacks suppressed > > > > > [ 716.773405] thermal thermal_zone5: Controlling power: control_temp=95000 last_temp=73500, curr_temp=75200 total_requested_power=39025 total_granted_power=18654 > > > > > [ 749.609336] cpu_cooling_ratelimit: 45 callbacks suppressed > > > > > [ 749.609371] cpu cpu4: Cooling state set to 11. New max freq = 1843200 > > > > > [ 749.624300] power_allocator_ratelimit: 24 callbacks suppressed > > > > > [ 749.624323] thermal thermal_zone5: Controlling power: control_temp=95000 last_temp=70800, curr_temp=77200 total_requested_power=40136 total_granted_power=17402 > > > > > [ 780.152633] cpu_cooling_ratelimit: 41 callbacks suppressed > > > > > [ 780.152666] cpu cpu4: Cooling state set to 11. New max freq = 1843200 > > > > > [ 780.165247] power_allocator_ratelimit: 21 callbacks suppressed > > > > > [ 780.165261] thermal thermal_zone5: Controlling power: control_temp=95000 last_temp=64800, curr_temp=76900 total_requested_power=39719 total_granted_power=1759 > > > > > > > > > > (the logs come from a local patch in our tree: > > > > > https://chromium.googlesource.com/chromiumos/third_party/kernel/+/ec1c501a8093fed44a6697a5913ef2765f518e1f) > > > > > > > > > > At this point I don't have a clear idea what would be a reasonable > > > > > value for the 'switch on/threshold' temperature, but probably it > > > > > should to be higher than 75 degrees, at least with IPA. If there is > > > > > no reasonable common configuration for different thermal governors I > > > > > guess we'll have to target a commonly used governor and systems > > > > > using other 'incompatible' governors need to override the config in > > > > > their .dtsi. > > > > > > > > Thanks for the elaborate testing and for sharing the numbers. This is > > very useful information. > > > > > > On my system I don't see a significant delta in core temperatures for > > > > 'threshold' temperatures of 80, 85 or 90°C. However Dhrystone > > > > performance goes up by ~8% when changing the trip point from 80 to > > > > 85°C. For a switch from 85 to 90°C I see a ~2% performance delta. For > > > > all trip points the average core temperatures are ~80°C (silver) and > > > > ~85°C (gold). Interestingly I observed the highest average > > > > temperatures with the trip point at 80°C (repeated measurements were > > > > taken for different temperatures). > > > > > > > > Supposedly LMH throttling is disabled in the firmware I used for > > > > these tests, however data suggests that it is still active > > > > (temperature doesn't rise beyond 95°C, even without throttling in > > > > Linux; Dhrystone performance drops when raising the temperature beyond > > > > 95°C with a heat gun. I will do some more testing when I get my hands > > > > on a FW that effectively disables LMH (or raises the threshold to > > > > something like 105°C). > > > > > > > > From the data collected so far I'd suggest a 'threshold' temperature > > > > of 90°C or if that seems to high 85°C. Behavior might be different > > > > with other thermal governors or without LMH throttling.. > > > > > > Some more data from measurements with different trips points, for the > > > IPA and the Fair Share governors, LMH throttling was enabled: > > > > > > IPA > > > Dhrystone Temp Silver Temp Gold > > > 75 6M 78.4 84.9 > > > 80 6.21M 81.4 89.8 > > > 85 6.74M 81.7 88.2 > > > 90 6.88M 79.4 84.6 > > > > > > Fair Share > > > Dhrystone Temp Silver Temp Gold > > > 75 6.63M 80.1 88.5 > > > 80 6.71M 80.1 88.5 > > > 85 6.77M 81.1 87.8 > > > 90 7.12M 81.2 87.8 > > > > Interesting that you get more MIPs out of fair share governor when > > compared to IPA across the board. What devices were providing energy > > cost information (dynamic-power-coefficient) to the IPA engine? Just > > CPU and GPU? Can you point me to those patches in gerrit? > > Only the CPUs provide energy cost information, the GPU isn't fully > hooked up in our tree yet. The cause of the delta could be that for > temperatures < 'target' Fair Share only uses the performance states > specified in 'threshold' for throttling (currently only the boost > frequency), while IPA may use the full range of states of the > 'target' trip point. I saw that in v4 you allow all performance state to be used for throttling at the 'threshold' temperature. With this configuration I get: Dhrystone Temp Silver Temp Gold Fair Share 7.29M 81.4 87.7 IPA 7.14M 81.7 88.3 I have no good sense why we are seeing more MIPs for IPA than with the previous configuration. As for earlier tests the values are the average from 4 runs. In any case it seems like a reasonable default configuration with the data we have at this point. > You can find the patches/configuration here: > > https://chromium.googlesource.com/chromiumos/third_party/kernel/+log/refs/sandbox/dianders/190130-wip-tree > > arch/arm64/boot/dts/qcom/sdm845.dtsi > arch/arm64/boot/dts/qcom/sdm845-cheza.dtsi > > > > Within this range the 'threshold' temperature doesn't seem to have a > > > large impact on the average CPU temperature. There is a bit of > > > fluctuation between individual measurements, I wouldn't be surprised > > > if the outliers of Temp Gold for 75 and 90°C converged more with the > > > other values with some more measurements. > > > > > > I learned how to effectively disable LMH throttling, however with that > > > it was fairly easy to have the CPUs overheat, even with throttling in > > > Linux. If it is feasible at all to run with LMH disabled some more > > > actions will be needed (e.g. attaching a heatsink or interrupt support > > > for thermal sensors instead of polling, ...). > > > > Given that LMH kicks in at 95 and IPA manages to maintain temperatures > > in the ballpark of 80-90 regardless of the trip point value, I agree > > that we should move the 1st trip point to 90. This will give maximum > > performance. So in "threshold" and "target" terms 90 becomes the > > threshold. And since LMH kicks in at 95, I've left it as the target > > trip. > > > > These should be sane defaults for upstream and any device can override > > those numbers in their board file. > > Sounds good, thanks! > > FYI, since I mentioned this earlier: a small heatsink on the SoC > makes a huge difference, with that I didn't encounter thermal > shutdowns during my (limited) tests with LMH disabled. Temperatures > were only slightly higher than with LMH throttling, so it might be > feasible to raise the LMH threshold and only use it as last resort. > > Cheers > > Matthias