122 lines
3.8 KiB
C
122 lines
3.8 KiB
C
/* 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
|