aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>2014-11-13 10:01:11 -0500
committerEduardo Valentin <edubezval@gmail.com>2014-11-20 09:53:17 -0500
commit8328a4b1d67fa6a4e0c51c27ddb7cb61b562f33e (patch)
tree58b5f47a4bdbf9278872d0ee487b905a5040fdd3
parent1e04ee8053b5f0af6bfab52b86a57de1c13c57ef (diff)
thermal: exynos: add sanitize_temp_error() helper
Factor out code for initializing data->temp_error[1,2] values from exynos_tmu_initialize() into sanitize_temp_error(). This is a preparation for introducing per-SoC type tmu_initialize method. There should be no functional changes caused by this patch. Cc: Amit Daniel Kachhap <amit.daniel@samsung.com> Cc: Lukasz Majewski <l.majewski@samsung.com> Cc: Eduardo Valentin <edubezval@gmail.com> Cc: Zhang Rui <rui.zhang@intel.com> Signed-off-by: Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com> Acked-by: Kyungmin Park <kyungmin.park@samsung.com> Tested-by: Lukasz Majewski <l.majewski@samsung.com> Signed-off-by: Eduardo Valentin <edubezval@gmail.com>
-rw-r--r--drivers/thermal/samsung/exynos_tmu.c33
1 files changed, 20 insertions, 13 deletions
diff --git a/drivers/thermal/samsung/exynos_tmu.c b/drivers/thermal/samsung/exynos_tmu.c
index e4d75a1a17ae..b0c07151e2eb 100644
--- a/drivers/thermal/samsung/exynos_tmu.c
+++ b/drivers/thermal/samsung/exynos_tmu.c
@@ -139,6 +139,25 @@ static void exynos_tmu_clear_irqs(struct exynos_tmu_data *data)
139 writel(val_irq, data->base + reg->tmu_intclear); 139 writel(val_irq, data->base + reg->tmu_intclear);
140} 140}
141 141
142static void sanitize_temp_error(struct exynos_tmu_data *data, u32 trim_info)
143{
144 struct exynos_tmu_platform_data *pdata = data->pdata;
145
146 data->temp_error1 = trim_info & EXYNOS_TMU_TEMP_MASK;
147 data->temp_error2 = ((trim_info >> EXYNOS_TRIMINFO_85_SHIFT) &
148 EXYNOS_TMU_TEMP_MASK);
149
150 if (!data->temp_error1 ||
151 (pdata->min_efuse_value > data->temp_error1) ||
152 (data->temp_error1 > pdata->max_efuse_value))
153 data->temp_error1 = pdata->efuse_value & EXYNOS_TMU_TEMP_MASK;
154
155 if (!data->temp_error2)
156 data->temp_error2 =
157 (pdata->efuse_value >> EXYNOS_TRIMINFO_85_SHIFT) &
158 EXYNOS_TMU_TEMP_MASK;
159}
160
142static int exynos_tmu_initialize(struct platform_device *pdev) 161static int exynos_tmu_initialize(struct platform_device *pdev)
143{ 162{
144 struct exynos_tmu_data *data = platform_get_drvdata(pdev); 163 struct exynos_tmu_data *data = platform_get_drvdata(pdev);
@@ -200,19 +219,7 @@ static int exynos_tmu_initialize(struct platform_device *pdev)
200 else 219 else
201 trim_info = readl(data->base + EXYNOS_TMU_REG_TRIMINFO); 220 trim_info = readl(data->base + EXYNOS_TMU_REG_TRIMINFO);
202 } 221 }
203 data->temp_error1 = trim_info & EXYNOS_TMU_TEMP_MASK; 222 sanitize_temp_error(data, trim_info);
204 data->temp_error2 = ((trim_info >> EXYNOS_TRIMINFO_85_SHIFT) &
205 EXYNOS_TMU_TEMP_MASK);
206
207 if (!data->temp_error1 ||
208 (pdata->min_efuse_value > data->temp_error1) ||
209 (data->temp_error1 > pdata->max_efuse_value))
210 data->temp_error1 = pdata->efuse_value & EXYNOS_TMU_TEMP_MASK;
211
212 if (!data->temp_error2)
213 data->temp_error2 =
214 (pdata->efuse_value >> EXYNOS_TRIMINFO_85_SHIFT) &
215 EXYNOS_TMU_TEMP_MASK;
216 223
217 rising_threshold = readl(data->base + reg->threshold_th0); 224 rising_threshold = readl(data->base + reg->threshold_th0);
218 225