diff options
author | Sven Schnelle <svens@stackframe.org> | 2011-12-07 14:30:58 -0800 |
---|---|---|
committer | Peter Stuge <peter@stuge.se> | 2011-12-14 09:41:46 +0100 |
commit | d5992b8dd1e4a7d73e0aaf042f0cb96a5c28533a (patch) | |
tree | f86cdb0fd3f5d47e8ecdcfb8db5e3373715885b8 | |
parent | 009ad83d5c1791816801216c496ba9b3fe352fb5 (diff) | |
download | coreboot-d5992b8dd1e4a7d73e0aaf042f0cb96a5c28533a.tar.xz |
Lenovo X60/T60: add first_battery setting
The EC allows to select the order in which batteries are (dis)charged.
Make this setting available to the user.
Change-Id: Id2a98192565419dbb53f3a7cf0b2c46b672a3ed8
Signed-off-by: Sven Schnelle <svens@stackframe.org>
Reviewed-on: http://review.coreboot.org/475
Tested-by: build bot (Jenkins)
Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
Reviewed-by: Peter Stuge <peter@stuge.se>
-rw-r--r-- | src/ec/lenovo/h8/h8.c | 9 | ||||
-rw-r--r-- | src/mainboard/lenovo/t60/cmos.layout | 4 | ||||
-rw-r--r-- | src/mainboard/lenovo/x60/cmos.layout | 3 |
3 files changed, 14 insertions, 2 deletions
diff --git a/src/ec/lenovo/h8/h8.c b/src/ec/lenovo/h8/h8.c index f81a39cb24..f20cd389dc 100644 --- a/src/ec/lenovo/h8/h8.c +++ b/src/ec/lenovo/h8/h8.c @@ -104,7 +104,7 @@ int h8_ultrabay_device_present(void) static void h8_enable(device_t dev) { struct ec_lenovo_h8_config *conf = dev->chip_info; - u8 val; + u8 val, tmp; h8_log_ec_version(); @@ -142,6 +142,13 @@ static void h8_enable(device_t dev) if (!get_option(&val, "volume")) ec_write(H8_VOLUME_CONTROL, val); + + if (!get_option(&val, "first_battery")) { + tmp = ec_read(H8_CONFIG3); + tmp &= ~(1 << 4); + tmp |= (val & 1)<< 4; + ec_write(H8_CONFIG3, tmp); + } h8_set_audio_mute(0); } diff --git a/src/mainboard/lenovo/t60/cmos.layout b/src/mainboard/lenovo/t60/cmos.layout index a946b4b120..8d9dce49bb 100644 --- a/src/mainboard/lenovo/t60/cmos.layout +++ b/src/mainboard/lenovo/t60/cmos.layout @@ -109,6 +109,7 @@ entries 1060 1 e 1 touchpad 1064 8 h 0 volume +1072 1 e 9 first_battery # ----------------------------------------------------------------- enumerations @@ -142,7 +143,8 @@ enumerations 7 2 Keep 8 0 No 8 1 Yes - +9 0 Secondary +9 1 Primary # ----------------------------------------------------------------- checksums diff --git a/src/mainboard/lenovo/x60/cmos.layout b/src/mainboard/lenovo/x60/cmos.layout index a1575137c7..cae70cb91e 100644 --- a/src/mainboard/lenovo/x60/cmos.layout +++ b/src/mainboard/lenovo/x60/cmos.layout @@ -109,6 +109,7 @@ entries 1064 8 h 0 volume 1072 8 h 0 tft_brightness +1080 1 e 9 first_battery # ----------------------------------------------------------------- enumerations @@ -142,6 +143,8 @@ enumerations 7 2 Keep 8 0 No 8 1 Yes +9 0 Secondary +9 1 Primary # ----------------------------------------------------------------- checksums |