Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751581Ab2JaFGb (ORCPT ); Wed, 31 Oct 2012 01:06:31 -0400 Received: from mailout4.samsung.com ([203.254.224.34]:42413 "EHLO mailout4.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750860Ab2JaFGa (ORCPT ); Wed, 31 Oct 2012 01:06:30 -0400 MIME-version: 1.0 Content-transfer-encoding: 8BIT Content-type: text/plain; charset=UTF-8 X-AuditID: cbfee61b-b7f616d00000319b-eb-5090b1cdc7ac Message-id: <5090B1C9.9050000@samsung.com> Date: Wed, 31 Oct 2012 14:06:17 +0900 From: jonghwa3.lee@samsung.com User-Agent: Mozilla/5.0 (X11; Linux i686; rv:10.0.2) Gecko/20120216 Thunderbird/10.0.2 To: Jonghwan Choi Cc: "'open list'" , "'Amit Daniel Kachhap'" , "'Zhang Rui'" , "'Sachin Kamat'" Subject: Re: [PATCH 2/2] therma: exynos: Supports thermal tripping References: <000101cdb660$05e7ded0$11b79c70$%choi@samsung.com> In-reply-to: <000101cdb660$05e7ded0$11b79c70$%choi@samsung.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFlrOLMWRmVeSWpSXmKPExsVy+t9jQd2zGycEGHRMVbW4vGsOmwOjx+dN cgGMUVw2Kak5mWWpRfp2CVwZEy/1shWslKvYdWgvcwNjm3gXIyeHhICJxJ3Hb9ggbDGJC/fW g9lCAtMZJbbO9wSxeQUEJX5MvsfSxcjBwSwgL3HkUjZImFlAXWLSvEXMXYxcQOVdTBJbzp5h h6jXkrj+YSUjiM0ioCrx/fY7FhCbTUBO4m3TN0aQOaICERK/+jlAwiIC2hJ9T2exgsxhFtjA KLHm3iewG4QFnCTOr5nODHGPncTXtbPA4pwC9hKXrv9imsAoMAvJebMQzpuF5LwFjMyrGEVT C5ILipPSc430ihNzi0vz0vWS83M3MYKD75n0DsZVDRaHGAU4GJV4eA3+9QcIsSaWFVfmHmKU 4GBWEuEtmTEhQIg3JbGyKrUoP76oNCe1+BCjNAeLkjhvs0dKgJBAemJJanZqakFqEUyWiYNT qoFR4cYmRvWCmieb+w6nPznFUnCf+8zaaBnJn5/dHWLuHV676PGj4D3HX/5Z7K3genGizc3L Ehtnu92/J+3Ostx75+Rvqf/W+Syau3TqlcWvXwtZCC247Td5k8XTPVb8SdFbKyY2yPckdpZe uGDwcXnrYYslZ8OqLjEuDqxMcGGSqGj6s9Jjq+xOISWW4oxEQy3mouJEAGUGsgo6AgAA Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4028 Lines: 103 On 2012년 10월 30일 14:32, Jonghwan Choi wrote: > TMU urgently sends active-high signal (thermal trip) to PMU, > and thermal tripping by hardware logic i.e PMU is performed. > Thermal tripping means that PMU cut off the whole power of SoC > by controlling external voltage regulator. > > Signed-off-by: Jonghwan Choi > --- > drivers/thermal/exynos_thermal.c | 7 ++++++- > include/linux/platform_data/exynos_thermal.h | 4 ++++ > 2 files changed, 10 insertions(+), 1 deletions(-) > > diff --git a/drivers/thermal/exynos_thermal.c > b/drivers/thermal/exynos_thermal.c > index 6ce6667..edac601 100644 > --- a/drivers/thermal/exynos_thermal.c > +++ b/drivers/thermal/exynos_thermal.c > @@ -53,6 +53,7 @@ > #define EXYNOS_TMU_TRIM_TEMP_MASK 0xff > #define EXYNOS_TMU_GAIN_SHIFT 8 > #define EXYNOS_TMU_REF_VOLTAGE_SHIFT 24 > +#define EXYNOS_TMU_TRIP_EN BIT(12) > #define EXYNOS_TMU_CORE_ON 1 > #define EXYNOS_TMU_CORE_OFF 0 > #define EXYNOS_TMU_DEF_CODE_TO_TEMP_OFFSET 50 > @@ -656,6 +657,8 @@ static void exynos_tmu_control(struct platform_device > *pdev, bool on) > if (data->soc == SOC_ARCH_EXYNOS) { > con |= pdata->noise_cancel_mode << > EXYNOS_TMU_TRIP_MODE_SHIFT; > con |= (EXYNOS_MUX_ADDR_VALUE << EXYNOS_MUX_ADDR_SHIFT); > + if (pdata->trip_en) > + con |= EXYNOS_THERMAL_TRIP_EN; > } > > if (on) { > @@ -762,10 +765,12 @@ static struct exynos_tmu_platform_data const > exynos_default_tmu_data = { > .trigger_levels[0] = 85, > .trigger_levels[1] = 103, > .trigger_levels[2] = 110, > + .trigger_levels[3] = 120, > .trigger_level0_en = 1, > .trigger_level1_en = 1, > .trigger_level2_en = 1, > - .trigger_level3_en = 0, > + .trigger_level3_en = 1, > + .trip_en = 1, > .gain = 8, > .reference_voltage = 16, > .noise_cancel_mode = 4, > diff --git a/include/linux/platform_data/exynos_thermal.h > b/include/linux/platform_data/exynos_thermal.h > index a7bdb2f..9e44aac 100644 > --- a/include/linux/platform_data/exynos_thermal.h > +++ b/include/linux/platform_data/exynos_thermal.h > @@ -79,6 +79,9 @@ struct freq_clip_table { > * @trigger_level3_en: > * 1 = enable trigger_level3 interrupt, > * 0 = disable trigger_level3 interrupt > + * @trip_en: > + * 1 = enable thermal tripping > + * 0 = disable thermal tripping > * @gain: gain of amplifier in the positive-TC generator block > * 0 <= gain <= 15 > * @reference_voltage: reference voltage of amplifier > @@ -102,6 +105,7 @@ struct exynos_tmu_platform_data { > bool trigger_level1_en; > bool trigger_level2_en; > bool trigger_level3_en; > + bool trip_en; I think this variable addition is not necessary. It's enough to use trigger_level3_en variable to determine hardware thermal tripping enable or not. Since exynos4210 has different register map from other exynos SOC's, trigger level 3 enable is existed different region. exynos4210 has it in interrupt enable register and others has it in TMU core control register (exynos4x12 and exynos5 doesn't have trigger_level3_en bit in interrupt enable register). Thus it's better to use trigger_level3_en variable to enable hardware thermal tripping support for compatibility. Thanks, Jonghwa Lee. > > u8 gain; > u8 reference_voltage; > -- > 1.7.4.1 > > -- > To unsubscribe from this list: send the line "unsubscribe linux-kernel" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html > Please read the FAQ at http://www.tux.org/lkml/ > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/