Re: [PATCH v3 3/4] platform/x86/amd: pmc: Add helper function to check the cpu id

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Ilpo,

On 5/25/2023 3:29 PM, Ilpo Järvinen wrote:
> On Thu, 25 May 2023, Shyam Sundar S K wrote:
>> On 5/23/2023 1:56 PM, Ilpo Järvinen wrote:
>>> On Tue, 16 May 2023, Shyam Sundar S K wrote:
>>>
>>>> Add a helper routine to check the underlying cpu id, that can be used
>>>> across the PMC driver to remove the duplicate code.
>>>>
>>>> Co-developed-by: Sanket Goswami <Sanket.Goswami@xxxxxxx>
>>>> Signed-off-by: Sanket Goswami <Sanket.Goswami@xxxxxxx>
>>>> Signed-off-by: Shyam Sundar S K <Shyam-sundar.S-k@xxxxxxx>
>>>> ---
>>>>  drivers/platform/x86/amd/pmc.c | 17 ++++++++++++++---
>>>>  1 file changed, 14 insertions(+), 3 deletions(-)
>>>>
>>>> diff --git a/drivers/platform/x86/amd/pmc.c b/drivers/platform/x86/amd/pmc.c
>>>> index e2439fda5c02..7e5e6afb3410 100644
>>>> --- a/drivers/platform/x86/amd/pmc.c
>>>> +++ b/drivers/platform/x86/amd/pmc.c
>>>> @@ -564,6 +564,18 @@ static void amd_pmc_dbgfs_unregister(struct amd_pmc_dev *dev)
>>>>  	debugfs_remove_recursive(dev->dbgfs_dir);
>>>>  }
>>>>  
>>>> +static bool amd_pmc_check_sup_cpuid(struct amd_pmc_dev *dev)
>>>
>>> Does sup refer to "supported" or some other acronym? If the latter,
>>
>> Yes, please read that as "supported"
>>
>>> you should mention/open it in the changelog and/or in a comment. If the 
>>> former, the function naming seems too generic (an observation entirely 
>>> based on how/where the function is used, you're not exactly verbose on 
>>> what this actually checks for other than what looks like a set of CPU 
>>> IDs but clearly there's more behind it).
>>
>> OK. renaming the function as amd_pmc_is_cpu_supported() would be fine?
> 
> This makes things odder, it gets used in two places:
> 
> 	if (enable_stb) {
> 		if (amd_pmc_check_sup_cpuid(dev))
> 			debugfs_create_file(..., &amd_pmc_stb_debugfs_fops_v2);
> 		else
> 			debugfs_create_file(..., &amd_pmc_stb_debugfs_fops);
> 	}
> 
> What about that else branch (PMC is not supported so who does that make 
> sense when the file is called pmc.c)? And here:

I did not understand the actual concern. STB is an on-demand debug
feature and that can only be enabled when enable_stb module param is set.

The check for amd_pmc_check_sup_cpuid() is to see if the underlying CPU
(with the right PMFW support) supported is pre-Rembrandt, then Spill to
DRAM is not supported. So reading the STB buffer is a different
mechanism and that has been handled in the amd_pmc_stb_debugfs_fops().

But the platforms after Rmebrandt, supports spilling to DRAM, and that
has been handled in amd_pmc_stb_debugfs_fops_v2().

What am I missing in your comments?


> 
> static int amd_pmc_probe(...)
> {
> 	...
> 	if (enable_stb && amd_pmc_check_sup_cpuid(dev)) {
> 		err = amd_pmc_s2d_init(dev);
> 		if (err)
> 			...goto + returns error
> 	}
> 
> 
> If enable_stb is not set, pmc not being supported is not going to return 
> error?
> 
> 

here we return only whne there is failure in s2d_init() - right?

And yes, if enable_stb is not set, there is no need to init the s2d path.

Thanks,
Shyam



[Index of Archives]     [Linux Kernel Development]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux