On 16/04/2018 12:11, Bartlomiej Zolnierkiewicz wrote: > From: Marek Szyprowski <m.szyprowski@xxxxxxxxxxx> > > tmu_read() in case of Exynos4210 might return error for out of bound > values. Current code ignores such value, what leads to reporting critical > temperature value. Add proper error code propagation to exynos_get_temp() > function. For me the comment in the function exynos4210_tmu_read /* "temp_code" should range between 75 and 175 */ ... is strange. I would double check this assertion before dealing with the error value. > Signed-off-by: Marek Szyprowski <m.szyprowski@xxxxxxxxxxx> > CC: stable@xxxxxxxxxxxxxxx # v4.6+ > Signed-off-by: Bartlomiej Zolnierkiewicz <b.zolnierkie@xxxxxxxxxxx> > --- > drivers/thermal/samsung/exynos_tmu.c | 9 +++++++-- > 1 file changed, 7 insertions(+), 2 deletions(-) > > diff --git a/drivers/thermal/samsung/exynos_tmu.c b/drivers/thermal/samsung/exynos_tmu.c > index 986cbd0..ac83f72 100644 > --- a/drivers/thermal/samsung/exynos_tmu.c > +++ b/drivers/thermal/samsung/exynos_tmu.c > @@ -892,6 +892,7 @@ static void exynos7_tmu_control(struct platform_device *pdev, bool on) > static int exynos_get_temp(void *p, int *temp) > { > struct exynos_tmu_data *data = p; > + int value, ret = 0; > > if (!data || !data->tmu_read || !data->enabled) > return -EINVAL; > @@ -899,12 +900,16 @@ static int exynos_get_temp(void *p, int *temp) > mutex_lock(&data->lock); > clk_enable(data->clk); > > - *temp = code_to_temp(data, data->tmu_read(data)) * MCELSIUS; > + value = data->tmu_read(data); > + if (value < 0) > + ret = value; > + else > + *temp = code_to_temp(data, value) * MCELSIUS; > > clk_disable(data->clk); > mutex_unlock(&data->lock); > > - return 0; > + return ret; > } > > #ifdef CONFIG_THERMAL_EMULATION > -- <http://www.linaro.org/> Linaro.org │ Open source software for ARM SoCs Follow Linaro: <http://www.facebook.com/pages/Linaro> Facebook | <http://twitter.com/#!/linaroorg> Twitter | <http://www.linaro.org/linaro-blog/> Blog -- To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html