| /* Header file for Quanta I2C Battery Driver |
| * |
| * Copyright (C) 2009 Quanta Computer Inc. |
| * |
| * This software is licensed under the terms of the GNU General Public |
| * License version 2, as published by the Free Software Foundation, and |
| * may be copied, distributed, and modified under those terms. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| */ |
| |
| /* |
| * |
| * The Driver with I/O communications via the I2C Interface for ON2 of AP BU. |
| * And it is only working on the nuvoTon WPCE775x Embedded Controller. |
| * |
| */ |
| |
| #ifndef __QCI_BATTERY_H__ |
| #define __QCI_BATTERY_H__ |
| |
| #define BAT_I2C_ADDRESS 0x1A |
| #define BATTERY_ID_NAME "qci-i2cbat" |
| #define EC_FLAG_ADAPTER_IN 0x01 |
| #define EC_FLAG_POWER_ON 0x02 |
| #define EC_FLAG_ENTER_S3 0x04 |
| #define EC_FLAG_ENTER_S4 0x08 |
| #define EC_FLAG_IN_STANDBY 0x10 |
| #define EC_FLAG_SYSTEM_ON 0x20 |
| #define EC_FLAG_WAIT_HWPG 0x40 |
| #define EC_FLAG_S5_POWER_ON 0x80 |
| |
| #define MAIN_BATTERY_STATUS_BAT_DISCHRG 0x01 |
| #define MAIN_BATTERY_STATUS_BAT_CHARGING 0x02 |
| #define MAIN_BATTERY_STATUS_BAT_ABNORMAL 0x04 |
| #define MAIN_BATTERY_STATUS_BAT_IN 0x08 |
| #define MAIN_BATTERY_STATUS_BAT_FULL 0x10 |
| #define MAIN_BATTERY_STATUS_BAT_LOW 0x20 |
| #define MAIN_BATTERY_STATUS_BAT_SMB_VALID 0x80 |
| |
| #define CHG_STATUS_BAT_CHARGE 0x01 |
| #define CHG_STATUS_BAT_PRECHG 0x02 |
| #define CHG_STATUS_BAT_OVERTEMP 0x04 |
| #define CHG_STATUS_BAT_TYPE 0x08 |
| #define CHG_STATUS_BAT_GWROK 0x10 |
| #define CHG_STATUS_BAT_INCHARGE 0x20 |
| #define CHG_STATUS_BAT_WAKECHRG 0x40 |
| #define CHG_STATUS_BAT_CHGTIMEOUT 0x80 |
| |
| #define EC_ADAPTER_PRESENT 0x1 |
| #define EC_BAT_PRESENT 0x1 |
| #define EC_ADAPTER_NOT_PRESENT 0x0 |
| #define EC_BAT_NOT_PRESENT 0x0 |
| |
| #define ECRAM_POWER_SOURCE 0x40 |
| #define ECRAM_CHARGER_ALARM 0x42 |
| #define ECRAM_BATTERY_STATUS 0x82 |
| #define ECRAM_BATTERY_CURRENT_LSB 0x83 |
| #define ECRAM_BATTERY_CURRENT_MSB 0x84 |
| #define ECRAM_BATTERY_VOLTAGE_LSB 0x87 |
| #define ECRAM_BATTERY_VOLTAGE_MSB 0x88 |
| #define ECRAM_BATTERY_CAPACITY 0x89 |
| #define ECRAM_BATTERY_TEMP_LSB 0x8C |
| #define ECRAM_BATTERY_TEMP_MSB 0x8D |
| #define ECRAM_BATTERY_EVENTS 0x99 |
| |
| #define EC_EVENT_BATTERY 0x01 |
| #define EC_EVENT_CHARGER 0x02 |
| #define EC_EVENT_AC 0x10 |
| #define EC_EVENT_TIMER 0x40 |
| |
| /* smbus access */ |
| #define SMBUS_READ_BYTE_PRTCL 0x07 |
| #define SMBUS_READ_WORD_PRTCL 0x09 |
| #define SMBUS_READ_BLOCK_PRTCL 0x0B |
| |
| /* smbus status code */ |
| #define SMBUS_OK 0x00 |
| #define SMBUS_DONE 0x80 |
| #define SMBUS_ALARM 0x40 |
| #define SMBUS_UNKNOW_FAILURE 0x07 |
| #define SMBUS_DEVICE_NOACK 0x10 |
| #define SMBUS_DEVICE_ERROR 0x11 |
| #define SMBUS_UNKNOW_ERROR 0x13 |
| #define SMBUS_TIME_OUT 0x18 |
| #define SMBUS_BUSY 0x1A |
| |
| /* ec ram mapping */ |
| #define ECRAM_SMB_PRTCL 0 |
| #define ECRAM_SMB_STS 1 |
| #define ECRAM_SMB_ADDR 2 |
| #define ECRAM_SMB_CMD 3 |
| #define ECRAM_SMB_DATA_START 4 |
| #define ECRAM_SMB_DATA0 4 |
| #define ECRAM_SMB_DATA1 5 |
| #define ECRAM_SMB_BCNT 36 |
| #define ECRAM_SMB_ALARM_ADDR 37 |
| #define ECRAM_SMB_ALARM_DATA0 38 |
| #define ECRAM_SMB_ALARM_DATA1 39 |
| |
| /* smart battery commands */ |
| #define BATTERY_SLAVE_ADDRESS 0x16 |
| #define BATTERY_FULL_CAPACITY 0x10 |
| #define BATTERY_AVERAGE_TIME_TO_EMPTY 0x12 |
| #define BATTERY_AVERAGE_TIME_TO_FULL 0x13 |
| #define BATTERY_CYCLE_COUNT 0x17 |
| #define BATTERY_DESIGN_CAPACITY 0x18 |
| #define BATTERY_DESIGN_VOLTAGE 0x19 |
| #define BATTERY_SERIAL_NUMBER 0x1C |
| #define BATTERY_MANUFACTURE_NAME 0x20 |
| #define BATTERY_DEVICE_NAME 0x21 |
| |
| /* alarm bit */ |
| #define ALARM_REMAIN_CAPACITY 0x02 |
| #define ALARM_OVER_TEMP 0x10 |
| #define ALARM_OVER_CHARGE 0x80 |
| #endif |