From: Alexey Starikovskiy <astarikovskiy@suse.de>
To: "Rafael J. Wysocki" <rjw@sisk.pl>
Cc: LenBrown <lenb@kernel.org>,
Linux-acpi@vger.kernel.org,
Henrique de Moraes Holschuh <hmh@hmh.eng.br>
Subject: Re: [RFC][PATCH] ACPI: battery: add power_{now, avg} properties to power_class
Date: Tue, 16 Dec 2008 18:28:36 +0300 [thread overview]
Message-ID: <4947C924.6090002@suse.de> (raw)
In-Reply-To: <200812161617.21420.rjw@sisk.pl>
Rafael J. Wysocki wrote:
> Hi,
>
> On Monday, 15 of December 2008, Alexey Starikovskiy wrote:
>> ACPI has smart batteries, which work in units of energy and measure
>> rate of (dis)charge as power, thus it is not appropriate to export it
>> as a current_now.
>>
>> Signed-off-by: Alexey Starikovskiy <astarikovskiy@suse.de>
>> ---
>>
>> drivers/acpi/battery.c | 3 ++-
>> drivers/acpi/sbs.c | 6 ++++--
>> drivers/power/power_supply_sysfs.c | 2 ++
>> include/linux/power_supply.h | 2 ++
>> 4 files changed, 10 insertions(+), 3 deletions(-)
>>
>>
>> diff --git a/drivers/acpi/battery.c b/drivers/acpi/battery.c
>> index 1423b0c..88f1fb5 100644
>> --- a/drivers/acpi/battery.c
>> +++ b/drivers/acpi/battery.c
>> @@ -173,6 +173,7 @@ static int acpi_battery_get_property(struct power_supply *psy,
>> val->intval = battery->voltage_now * 1000;
>> break;
>> case POWER_SUPPLY_PROP_CURRENT_NOW:
>> + case POWER_SUPPLY_PROP_POWER_NOW:
>> val->intval = battery->current_now * 1000;
>> break;
>> case POWER_SUPPLY_PROP_CHARGE_FULL_DESIGN:
>> @@ -223,7 +224,7 @@ static enum power_supply_property energy_battery_props[] = {
>> POWER_SUPPLY_PROP_TECHNOLOGY,
>> POWER_SUPPLY_PROP_VOLTAGE_MIN_DESIGN,
>> POWER_SUPPLY_PROP_VOLTAGE_NOW,
>> - POWER_SUPPLY_PROP_CURRENT_NOW,
>> + POWER_SUPPLY_PROP_POWER_NOW,
>> POWER_SUPPLY_PROP_ENERGY_FULL_DESIGN,
>> POWER_SUPPLY_PROP_ENERGY_FULL,
>> POWER_SUPPLY_PROP_ENERGY_NOW,
>> diff --git a/drivers/acpi/sbs.c b/drivers/acpi/sbs.c
>> index 6050ce4..994c04e 100644
>> --- a/drivers/acpi/sbs.c
>> +++ b/drivers/acpi/sbs.c
>> @@ -224,10 +224,12 @@ static int acpi_sbs_battery_get_property(struct power_supply *psy,
>> acpi_battery_vscale(battery) * 1000;
>> break;
>> case POWER_SUPPLY_PROP_CURRENT_NOW:
>> + case POWER_SUPPLY_PROP_POWER_NOW:
>> val->intval = abs(battery->current_now) *
>> acpi_battery_ipscale(battery) * 1000;
>
> Please introduce another field called 'battery->power_now' for this purpose.
> Otherwise, confusion is guaranteed to ensue.
How about 'battery->rate_now' for both cases? All other fields are re-used as well, and it did not cause any confusion.
Probably no-one ever looked at this code.
>
>> break;
>> case POWER_SUPPLY_PROP_CURRENT_AVG:
>> + case POWER_SUPPLY_PROP_POWER_AVG:
>> val->intval = abs(battery->current_avg) *
>> acpi_battery_ipscale(battery) * 1000;
>
> Same here.
>
> Also, as per our IRC conversation, I'd like 'current_now' to be reported even
> if energy units are used, at least for some time, to give a chance to the user
> land to switch to 'power_now' and 'power_avg' without pain.
To clarify, you suggest that "current_now" will report same value
as "power_now" in case of energy units?
>
> You can put information about that into
> Documentation/feature-removal-schedule.txt and say that after 2.6.29
> 'current_now' will no longer be reported when energy units are used.
Sounds good.
Thanks,
Alex.
>
> Thanks,
> Rafael
next prev parent reply other threads:[~2008-12-16 15:28 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-12-15 21:38 [RFC][PATCH] ACPI: battery: add power_{now, avg} properties to power_class Alexey Starikovskiy
2008-12-16 1:22 ` Henrique de Moraes Holschuh
2008-12-16 8:53 ` Alexey Starikovskiy
2008-12-16 14:18 ` Henrique de Moraes Holschuh
2008-12-16 15:19 ` Rafael J. Wysocki
2008-12-16 15:17 ` Rafael J. Wysocki
2008-12-16 15:28 ` Alexey Starikovskiy [this message]
2008-12-16 15:51 ` Rafael J. Wysocki
-- strict thread matches above, loose matches on Subject: below --
2008-12-16 16:27 Alexey Starikovskiy
2008-12-16 17:41 ` Len Brown
2008-12-16 20:49 ` Rafael J. Wysocki
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4947C924.6090002@suse.de \
--to=astarikovskiy@suse.de \
--cc=Linux-acpi@vger.kernel.org \
--cc=hmh@hmh.eng.br \
--cc=lenb@kernel.org \
--cc=rjw@sisk.pl \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.