diff options
author | Daniel Drake <dsd@laptop.org> | 2010-12-29 14:12:01 -0500 |
---|---|---|
committer | Anton Vorontsov <cbouatmailru@gmail.com> | 2011-01-12 12:28:24 -0500 |
commit | c566d299f91bdb622046126dbcb040f9e52572ba (patch) | |
tree | adeecaada08dec5c2dc643575dd360924ce88d91 | |
parent | f3dcab70e192b0489ac05cc554e0b1cedae46d1a (diff) |
olpc_battery: Ambient temperature is not available on XO-1.5
The XO-1.5 does not support the ambient temperature property.
Create a separate list of properties for that configuration where
ambient temperature is not included, and apply the correct property
list at runtime.
Signed-off-by: Daniel Drake <dsd@laptop.org>
Signed-off-by: Anton Vorontsov <cbouatmailru@gmail.com>
-rw-r--r-- | drivers/power/olpc_battery.c | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/drivers/power/olpc_battery.c b/drivers/power/olpc_battery.c index 5bc1dcf7785e..0cd4f15e3013 100644 --- a/drivers/power/olpc_battery.c +++ b/drivers/power/olpc_battery.c | |||
@@ -331,7 +331,7 @@ static int olpc_bat_get_property(struct power_supply *psy, | |||
331 | return ret; | 331 | return ret; |
332 | } | 332 | } |
333 | 333 | ||
334 | static enum power_supply_property olpc_bat_props[] = { | 334 | static enum power_supply_property olpc_xo1_bat_props[] = { |
335 | POWER_SUPPLY_PROP_STATUS, | 335 | POWER_SUPPLY_PROP_STATUS, |
336 | POWER_SUPPLY_PROP_CHARGE_TYPE, | 336 | POWER_SUPPLY_PROP_CHARGE_TYPE, |
337 | POWER_SUPPLY_PROP_PRESENT, | 337 | POWER_SUPPLY_PROP_PRESENT, |
@@ -348,6 +348,23 @@ static enum power_supply_property olpc_bat_props[] = { | |||
348 | POWER_SUPPLY_PROP_CHARGE_COUNTER, | 348 | POWER_SUPPLY_PROP_CHARGE_COUNTER, |
349 | }; | 349 | }; |
350 | 350 | ||
351 | /* XO-1.5 does not have ambient temperature property */ | ||
352 | static enum power_supply_property olpc_xo15_bat_props[] = { | ||
353 | POWER_SUPPLY_PROP_STATUS, | ||
354 | POWER_SUPPLY_PROP_CHARGE_TYPE, | ||
355 | POWER_SUPPLY_PROP_PRESENT, | ||
356 | POWER_SUPPLY_PROP_HEALTH, | ||
357 | POWER_SUPPLY_PROP_TECHNOLOGY, | ||
358 | POWER_SUPPLY_PROP_VOLTAGE_AVG, | ||
359 | POWER_SUPPLY_PROP_CURRENT_AVG, | ||
360 | POWER_SUPPLY_PROP_CAPACITY, | ||
361 | POWER_SUPPLY_PROP_CAPACITY_LEVEL, | ||
362 | POWER_SUPPLY_PROP_TEMP, | ||
363 | POWER_SUPPLY_PROP_MANUFACTURER, | ||
364 | POWER_SUPPLY_PROP_SERIAL_NUMBER, | ||
365 | POWER_SUPPLY_PROP_CHARGE_COUNTER, | ||
366 | }; | ||
367 | |||
351 | /* EEPROM reading goes completely around the power_supply API, sadly */ | 368 | /* EEPROM reading goes completely around the power_supply API, sadly */ |
352 | 369 | ||
353 | #define EEPROM_START 0x20 | 370 | #define EEPROM_START 0x20 |
@@ -419,8 +436,6 @@ static struct device_attribute olpc_bat_error = { | |||
419 | static struct platform_device *bat_pdev; | 436 | static struct platform_device *bat_pdev; |
420 | 437 | ||
421 | static struct power_supply olpc_bat = { | 438 | static struct power_supply olpc_bat = { |
422 | .properties = olpc_bat_props, | ||
423 | .num_properties = ARRAY_SIZE(olpc_bat_props), | ||
424 | .get_property = olpc_bat_get_property, | 439 | .get_property = olpc_bat_get_property, |
425 | .use_for_apm = 1, | 440 | .use_for_apm = 1, |
426 | }; | 441 | }; |
@@ -466,6 +481,13 @@ static int __init olpc_bat_init(void) | |||
466 | goto ac_failed; | 481 | goto ac_failed; |
467 | 482 | ||
468 | olpc_bat.name = bat_pdev->name; | 483 | olpc_bat.name = bat_pdev->name; |
484 | if (olpc_board_at_least(olpc_board_pre(0xd0))) { /* XO-1.5 */ | ||
485 | olpc_bat.properties = olpc_xo15_bat_props; | ||
486 | olpc_bat.num_properties = ARRAY_SIZE(olpc_xo15_bat_props); | ||
487 | } else { /* XO-1 */ | ||
488 | olpc_bat.properties = olpc_xo1_bat_props; | ||
489 | olpc_bat.num_properties = ARRAY_SIZE(olpc_xo1_bat_props); | ||
490 | } | ||
469 | 491 | ||
470 | ret = power_supply_register(&bat_pdev->dev, &olpc_bat); | 492 | ret = power_supply_register(&bat_pdev->dev, &olpc_bat); |
471 | if (ret) | 493 | if (ret) |