Commit 45cc55f9 authored by Lan Tianyu's avatar Lan Tianyu Committed by Ben Hutchings

ACPI / battery: Fix parsing _BIX return value

commit 016d5baa upstream.

The _BIX method returns extended battery info as a package.
According the ACPI spec (ACPI 5, Section 10.2.2.2), the first member
of that package should be "Revision".  However, the current ACPI
battery driver treats the first member as "Power Unit" which should
be the second member.  This causes the result of _BIX return data
parsing to be incorrect.

Fix this by adding a new member called 'revision' to struct
acpi_battery and adding the offsetof() information on it to
extended_info_offsets[] as the first row.

[rjw: Changelog]
Reported-and-tested-by: default avatarJan Hoffmann <jan.christian.hoffmann@gmail.com>
References: http://bugzilla.kernel.org/show_bug.cgi?id=60519Signed-off-by: default avatarLan Tianyu <tianyu.lan@intel.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent 8e4f35b0
...@@ -117,6 +117,7 @@ struct acpi_battery { ...@@ -117,6 +117,7 @@ struct acpi_battery {
struct acpi_device *device; struct acpi_device *device;
struct notifier_block pm_nb; struct notifier_block pm_nb;
unsigned long update_time; unsigned long update_time;
int revision;
int rate_now; int rate_now;
int capacity_now; int capacity_now;
int voltage_now; int voltage_now;
...@@ -350,6 +351,7 @@ static struct acpi_offsets info_offsets[] = { ...@@ -350,6 +351,7 @@ static struct acpi_offsets info_offsets[] = {
}; };
static struct acpi_offsets extended_info_offsets[] = { static struct acpi_offsets extended_info_offsets[] = {
{offsetof(struct acpi_battery, revision), 0},
{offsetof(struct acpi_battery, power_unit), 0}, {offsetof(struct acpi_battery, power_unit), 0},
{offsetof(struct acpi_battery, design_capacity), 0}, {offsetof(struct acpi_battery, design_capacity), 0},
{offsetof(struct acpi_battery, full_charge_capacity), 0}, {offsetof(struct acpi_battery, full_charge_capacity), 0},
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment