[PATCH v8 5/9] mfd: bcm590xx: Add PMU ID/revision parsing function

Artur Weber aweber.kernel at gmail.com
Tue May 6 12:03:15 PDT 2025


On 5/6/25 18:11, Stanislav Jakubek wrote:
> Hi Artur,
> one note below.
> 
> On Wed, Apr 30, 2025 at 09:07:09AM +0200, Artur Weber wrote:
>> The BCM590xx PMUs have two I2C registers for reading the PMU ID
>> and revision. The revision is useful for subdevice drivers, since
>> different revisions may have slight differences in behavior (for
>> example - BCM59054 has different regulator configurations for
>> revision A0 and A1).
>>
>> Check the PMU ID register and make sure it matches the DT compatible.
>> Fetch the digital and analog revision from the PMUREV register
>> so that it can be used in subdevice drivers.
>>
>> Also add some known revision values to bcm590xx.h, for convenience
>> when writing subdevice drivers.
>>
>> Signed-off-by: Artur Weber <aweber.kernel at gmail.com>
>> ---
> 
> [snip]
> 
>> diff --git a/include/linux/mfd/bcm590xx.h b/include/linux/mfd/bcm590xx.h
>> index 8d146e3b102a7dbce6f4dbab9f8ae5a9c4e68c0e..fbc458e94bef923ca1b69afe2cac944adf6fedf8 100644
>> --- a/include/linux/mfd/bcm590xx.h
>> +++ b/include/linux/mfd/bcm590xx.h
>> @@ -17,6 +17,16 @@
>>   #define BCM590XX_PMUID_BCM59054		0x54
>>   #define BCM590XX_PMUID_BCM59056		0x56
>>   
>> +/* Known chip revision IDs */
>> +#define BCM59054_REV_DIGITAL_A1		1
> 
> 1 seems to be the digital revision ID for A0 (couldn't find the analog
> revision ID), see [1].
> 
> Other values seems to match downstream (as far as I can tell anyway).
> 
> [1] https://github.com/Samsung-KYLEPROXX/android_kernel_samsung_kyleproxx/blob/cm-13.0/include/linux/mfd/bcmpmu59xxx.h#L82
 From my testing on a device with the BCM59054A1 (BCM23550-based Samsung 
Galaxy Grand Neo), the digital value is also 1 on this model:

   bcm590xx 0-0008: PMU ID 0x54 (BCM59054), revision: dig 1 ana 2

(This constant is not actually used anywhere in code yet - I just
included it for the sake of completeness, since the BCM59056 headers
in downstream listed both values...)

Best regards
Artur



More information about the linux-arm-kernel mailing list