Re: [PATCH 27/57] power: sysfs interface update

From: Mathieu Poirier
Date: Fri Sep 28 2012 - 14:26:44 EST


On 12-09-27 01:20 AM, Anton Vorontsov wrote:
> On Tue, Sep 25, 2012 at 10:12:24AM -0600, mathieu.poirier@xxxxxxxxxx wrote:
>> From: Michel JAOUEN <michel.jaouen@xxxxxxxxxxxxxx>
>>
>> Add new sysfs interface to get current charge status
>>
>> Signed-off-by: Michel JAOUEN <michel.jaouen@xxxxxxxxxxxxxx>
>> Signed-off-by: Loic Pallardy <loic.pallardy@xxxxxxxxxxxxxx>
>> Signed-off-by: Mathieu Poirier <mathieu.poirier@xxxxxxxxxx>
>> Reviewed-by: Marcus COOPER <marcus.xm.cooper@xxxxxxxxxxxxxx>
>> Reviewed-by: Olivier CLERGEAUD <olivier.clergeaud@xxxxxxxxxxxxxx>
>> Reviewed-by: Jonas ABERG <jonas.aberg@xxxxxxxxxxxxxx>
>> ---
>> drivers/power/ab8500_charger.c | 3 +++
>> drivers/power/abx500_chargalg.c | 24 +++++++++++++++++++++++-
>> 2 files changed, 26 insertions(+), 1 deletions(-)
>>
>> diff --git a/drivers/power/ab8500_charger.c b/drivers/power/ab8500_charger.c
>> index 4129599..0a781a0 100644
>> --- a/drivers/power/ab8500_charger.c
>> +++ b/drivers/power/ab8500_charger.c
>> @@ -2759,6 +2759,9 @@ static int ab8500_charger_usb_notifier_call(struct notifier_block *nb,
>> enum ab8500_usb_state bm_usb_state;
>> unsigned mA = *((unsigned *)power);
>>
>> + if (di == NULL)
>> + return NOTIFY_DONE;
>> +
>
> I'd write !di.

Not sure I agree with you here. If di is NULL there is nothing to work
with and as such, exit.

>
> [...]
>> +static ssize_t abx500_chargalg_sysfs_show(struct kobject *kobj,
>> + struct attribute *attr, char *buf)
>> +{
>> + struct abx500_chargalg *di = container_of(kobj,
>> + struct abx500_chargalg, chargalg_kobject);
>> +
>> + if ((di->susp_status.ac_suspended == true) &&
>> + (di->susp_status.usb_suspended == true))
>> + return sprintf(buf, "0\n");
>> + else
>> + return sprintf(buf, "1\n");
>
> just
>
> return sprintf(buf, "%d\n", di->susp_status.ac_suspended &&
> di->susp_status.usb_suspended);

Much cleaner yes.

>
>> +}
>> +
>> /* Exposure to the sysfs interface */
>>
>> /**
>> @@ -1749,7 +1770,7 @@ static ssize_t abx500_chargalg_sysfs_charger(struct kobject *kobj,
>> static struct attribute abx500_chargalg_en_charger = \
>> {
>> .name = "chargalg",
>> - .mode = S_IWUGO,
>> + .mode = S_IRUGO | S_IWUSR,
>> };
>>
>> static struct attribute *abx500_chargalg_chg[] = {
>> @@ -1758,6 +1779,7 @@ static struct attribute *abx500_chargalg_chg[] = {
>> };
>>
>> static const struct sysfs_ops abx500_chargalg_sysfs_ops = {
>> + .show = abx500_chargalg_sysfs_show,
>> .store = abx500_chargalg_sysfs_charger,
>> };
>>
>> --
>> 1.7.5.4

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/