[PATCH v3 09/20] soc: mediatek: mtk-svs: Move t-calibration-data retrieval to svs_probe()

Eugen Hristev eugen.hristev at collabora.com
Wed Nov 22 04:51:31 PST 2023


On 11/22/23 14:41, AngeloGioacchino Del Regno wrote:
> Il 22/11/23 12:23, Eugen Hristev ha scritto:
>> On 11/21/23 14:50, AngeloGioacchino Del Regno wrote:
>>> The t-calibration-data (SVS-Thermal calibration data) shall exist for
>>> all SoCs or SVS won't work anyway: move it to the common svs_probe()
>>> function and remove it from all of the per-SoC efuse_parsing() probe
>>> callbacks.
>>>
>>> Signed-off-by: AngeloGioacchino Del Regno 
>>> <angelogioacchino.delregno at collabora.com>
>>> ---
>>>   drivers/soc/mediatek/mtk-svs.c | 32 ++++++--------------------------
>>>   1 file changed, 6 insertions(+), 26 deletions(-)
>>>
>>> diff --git a/drivers/soc/mediatek/mtk-svs.c 
>>> b/drivers/soc/mediatek/mtk-svs.c
>>> index ab564d48092b..1042af2aee3f 100644
>>> --- a/drivers/soc/mediatek/mtk-svs.c
>>> +++ b/drivers/soc/mediatek/mtk-svs.c
>>> @@ -1884,11 +1884,6 @@ static bool svs_mt8195_efuse_parsing(struct 
>>> svs_platform *svsp)
>>>           svsb->vmax += svsb->dvt_fixed;
>>>       }
>>> -    ret = svs_get_efuse_data(svsp, "t-calibration-data",
>>> -                 &svsp->tefuse, &svsp->tefuse_max);
>>> -    if (ret)
>>> -        return false;
>>> -
>>
>> Hello Angelo,
>>
>> if you removed the code using `ret` in this patch, it makes sense to 
>> also remove the variable here instead of doing it in patch 18.
>> It will avoid unused variable warnings for this patch.
>>
>>
> 
> Yes, though the comment is not for this function, but rather for 8183. 
> Anyway, that
> makes sense, but if it's the only change of this v3, it's something that 
> I can fix
> while applying instead of sending another 20 patches round. Thanks.
> 
>>>       for (i = 0; i < svsp->tefuse_max; i++)
>>>           if (svsp->tefuse[i] != 0)
>>>               break;
>>> @@ -1949,11 +1944,6 @@ static bool svs_mt8192_efuse_parsing(struct 
>>> svs_platform *svsp)
>>>           svsb->vmax += svsb->dvt_fixed;
>>>       }
>>> -    ret = svs_get_efuse_data(svsp, "t-calibration-data",
>>> -                 &svsp->tefuse, &svsp->tefuse_max);
>>> -    if (ret)
>>> -        return false;
>>> -
>>>       for (i = 0; i < svsp->tefuse_max; i++)
>>>           if (svsp->tefuse[i] != 0)
>>>               break;
>>> @@ -2009,11 +1999,6 @@ static bool svs_mt8188_efuse_parsing(struct 
>>> svs_platform *svsp)
>>>           svsb->vmax += svsb->dvt_fixed;
>>>       }
>>> -    ret = svs_get_efuse_data(svsp, "t-calibration-data",
>>> -                 &svsp->tefuse, &svsp->tefuse_max);
>>> -    if (ret)
>>> -        return false;
>>> -
>>>       for (i = 0; i < svsp->tefuse_max; i++)
>>>           if (svsp->tefuse[i] != 0)
>>>               break;
>>> @@ -2097,11 +2082,6 @@ static bool svs_mt8186_efuse_parsing(struct 
>>> svs_platform *svsp)
>>>           svsb->vmax += svsb->dvt_fixed;
>>>       }
>>> -    ret = svs_get_efuse_data(svsp, "t-calibration-data",
>>> -                 &svsp->tefuse, &svsp->tefuse_max);
>>> -    if (ret)
>>> -        return false;
>>> -
>>>       golden_temp = (svsp->tefuse[0] >> 24) & GENMASK(7, 0);
>>>       if (!golden_temp)
>>>           golden_temp = 50;
>>> @@ -2198,11 +2178,6 @@ static bool svs_mt8183_efuse_parsing(struct 
>>> svs_platform *svsp)
>>>           }
>>>       }
>>> -    ret = svs_get_efuse_data(svsp, "t-calibration-data",
>>> -                 &svsp->tefuse, &svsp->tefuse_max);
>>> -    if (ret)
>>> -        return false;
>>> -
>>>       /* Thermal efuse parsing */
>>>       adc_ge_t = (svsp->tefuse[1] >> 22) & GENMASK(9, 0);
>>>       adc_oe_t = (svsp->tefuse[1] >> 12) & GENMASK(9, 0);
>>> @@ -3040,8 +3015,13 @@ static int svs_probe(struct platform_device 
>>> *pdev)
>>>       ret = svs_get_efuse_data(svsp, "svs-calibration-data",
>>>                    &svsp->efuse, &svsp->efuse_max);
>>> +    if (ret)
>>> +        return dev_err_probe(&pdev->dev, ret, "Cannot read SVS 
>>> calibration\n");
>>
>> With the previous code, if svs-calibration-data could not be read, the 
>> code would go to svs_probe_free_efuse. In your case, it returns directly.
>> I believe that svs_get_efuse_data using nvmem_cell_read does not 
>> allocate the buffer for the efuse , hence no more need to free it ? 
>> The exit code is checking if it's ERR or NULL, but still, if the 
>> buffer was not allocated, it doesn't make sense to jump there indeed.
>> In that case, you are also changing the behavior here , and your 
>> commit appears to do more than a simple move.
>>
> 
> I'm not changing the behavior: the previous behavior was to fail and 
> free the efuse
> variable if previously allocated, the current behavior is to fail and 
> free the
> efuse variable if previously allocated, and the tefuse variable if 
> previously
> allocated, which is a result of the actual move of the retrieval of the 
> thermal
> fuse calibration data.
> 
> I really don't see anything implicit here.
> 

Previous behavior was


ret = svs_get_efuse_data (efuse)

if (ret) goto svs_probe_free_efuse


Now, you have it as

ret = svs_get_efuse_data (efuse)

if (ret) return dev_err_probe...


>>> +
>>> +    ret = svs_get_efuse_data(svsp, "t-calibration-data",
>>> +                 &svsp->tefuse, &svsp->tefuse_max);
>>>       if (ret) {
>>> -        ret = -EPERM;
>>> +        dev_err_probe(&pdev->dev, ret, "Cannot read SVS-Thermal 
>>> calibration\n");
>>>           goto svs_probe_free_efuse;
>>
>> again in this case the tefuse has not been allocated I assume.
>>
>> So previous code was a bit excessive in trying to free the efuse/tefuse ?
> 
> The previous code was performing an useless error check on something 
> that was not
> supposed to be allocated *yet*. Yes, it was wrong before.
> 
> Cheers,
> Angelo
> _______________________________________________
> Kernel mailing list -- kernel at mailman.collabora.com
> To unsubscribe send an email to kernel-leave at mailman.collabora.com




More information about the Linux-mediatek mailing list