鄒勁,林超,楊琦
(廣州中海達衛星導航技術股份有限公司,廣州 511400)
?
電源管理芯片AXP192在手持設備上的應用
鄒勁,林超,楊琦
(廣州中海達衛星導航技術股份有限公司,廣州 511400)
大多數移動或手持產品使用低功耗、高度集成的微處理器平臺,需要多路供電電壓和電池管理功能,電源管理芯片滿足這些需求并具備其他特性。本文介紹了一種國產電源管理芯片AXP192應用在以三星S5PV210移動處理器為核心的工業平板上的方案,給出了AXP192與S5PV210的電源分配設計、上電時序以及AXP192控制接口原理設計和基于Linux操作系統的驅動程序設計,實現了電源的智能管理,達到降低功耗、延長設備使用時間的目的。
電源管理;手持設備;PMIC;Linux;S5PV210;AXP192
AXP192 是KrossPower公司的一款高度集成的電源系統管理芯片(PMIC),具有可定制、初始化多路輸出電壓、可編程設置各路輸出電壓、體積小、加工方便和價格便宜等優點。配合S5PV210使用,可減少核心供電使用獨立電源數量,同時減小PCB使用面積,動態調節核心電壓,智能管理最小系統電源,最大程度降低設備使用功耗,從而達到延長設備使用壽命的目的。相比三星配套推薦的WM8310,在同樣滿足功能和性能穩定的基礎上,AXP192加工方便、價格便宜、供貨穩定和周期短是其最大的優勢。
1.1 S5PV210電源設計與上電時序
S5PV210工作模式有正常、待機、休眠3種。根據這3種工作模式,分析各路電源需要的電流大小、上電時間先后、使用電壓的大小等,將S5PV210的電源分成幾組,合并可以一起供電的電源,在滿足3種工作模式的前提條件下,盡可能優化電源的供給,減少獨立電源的使用。根據優化后的電源設計,S5PV210最小系統只需要3路DC-DC和7路LDO便可以正常工作,AXP192能提供7路電源,因此只需要額外增加3路獨立的LDO。本設計方法相比AXP192為Cortex-A8內核處理器推薦的設計減少了5路獨立電源,大大減少了獨立電源芯片的使用,這也是本設計的優勢所在。
AXP192具有3路DC-DC以及4路LDO,各路特性如表1所列。
7路電源輸出除了LDO1是固定電壓輸出外,其他6路電源均可通過I2C總線控制接口打開或者關閉其輸出,并可設置它們的電壓大小。
根據AXP192各路電源的驅動能力和S5PV210電源對電流大小的要求,將DC-DC1和DC-DC3分別接到S5PV210的內核電源VDD_INT_AP和VDD_ARM_AP,這兩個內核電壓隨著ARM內核、總線工作頻率做相應的調節,以實現正常工作情況下最優的功耗。DC-DC2給DDR2內存和S5PV210的內存總線接口電路供電,其他各路LDO給S5PV210的I/O電路供電。根據電源分配,額外增加的3路獨立LDO,其中LDO4供電VDD_ALIVE_AP,LDO5供電VDD_xPLL_AP,LDO6供電其他I/O電路。

表1 AXP192各路特性表
S5PV210有嚴格的上電時序要求,如圖1所示。為了保證每次上電都能正確運行,各路電源的上電時序必須要滿足其需求。AXP192除LDO1外的6路電源的上電時序均可配置,每步延時間隙分別有1 ms、4 ms和16 ms三種選擇,上電步驟選擇方式A則有7個上電順序配置。

圖1 S5PV210上電時序要求

圖2 AXP192與S5PV210通信接口設計
根據S5PV210上電時序要求設定3步上電順序,每步上電延時間隙均為4 ms。具體上電時序分配為:第1步上電DC-DC2,并用DC-DC2作為LDO4的輸入使其同時上電;第2步上電DC-DC1和DC-DC3,并用DC-DC1使能LDO5;第3步上電剩余的LDO。按此設計的供電方式簡單有效,S5PV210每次都能正常開機,并且運行穩定。
1.2 AXP192與S5PV210通信接口設計
AXP192通過I2C總線接口與S5PV210通信。工作時,I2C總線引腳上拉到系統I/O電源,S5PV210可以通過這個接口去打開或關閉某些電源輸出,設置它們的電壓,訪問內部寄存器和多種測量數據等。其他系統管理如復位信號、休眠信號、中斷信號等接口如圖2所示。
應用中采用Android2.3.7操作系統,其內核是Linux2.6.35。在Linux系統中,I2C總線驅動由3部分組成,即I2C總線核心、I2C總線驅動和I2C設備驅動,其中I2C核心、I2C總線驅動Linux內核已經完善,因此,驅動程序的開發主要集中在AXP192設備驅動這一層,用來實現對AXP192各種功能的操作控制,其中主要是對其寄存器的讀寫操作。驅動實現的功能有系統開關機、各路電壓的動態設置以及打開與關閉等。
Linux內核有兩種編寫I2C設備驅動方式:legacy方式和new style方式。應用中使用new style方式,其中重要的I2C_driver結構體為:
static struct i2c_driver axp192_pmic_driver = {
.probe = axp192_pmic_probe,
//當有i2c_client和i2c_driver匹配時調用
.remove = __devexit_p(axp192_pmic_remove),
//注銷時調用
.driver = {
.name = "axp192", //設備名稱
},
.id_table = axp192_ids,//匹配規則
};
下面介紹驅動中幾個函數的具體實現方法。
(1) AXP192設備初始化函數
static int __devinit axp192_pmic_probe(struct i2c_client *client,const struct i2c_device_id *i2c_id){
struct regulator_dev **rdev;
struct axp192_platform_data *pdata = client->dev.platform_data;
struct axp192_data *axp192;
int i = 0, id, ret;
if (!pdata)
return -EINVAL;
axp192 = kzalloc(sizeof(struct axp192_data), GFP_KERNEL); //分配內存空間
if (!axp192)
return -ENOMEM;
axp192->rdev = kzalloc(sizeof(struct regulator_dev *) * (pdata->num_regulators + 1), GFP_KERNEL);
if (!axp192->rdev) {
kfree(axp192);
return -ENOMEM;
}
if (!i2c_check_functionality(client->adapter, I2C_FUNC_I2C)) { //檢查I2C設備的功能
AXPDBG("i2c error");
return-ENODEV;
}
axp192->client = client; //將client賦值給全局變量
axp192->dev = &client->dev;
axp192->pdata = pdata;
i!2c_set_clientdata(client, axp192);
axp192_point = axp192;
mutex_init(&axp192->mutex); //互斥,防止線程卡死
return 0;
}
(2) I2C讀函數
static int axp192_i2c_read(struct i2c_client *client, u8 reg, u8 *dest){
struct i2c_msg msg[2];
uint8_t buf0[4];
uint8_t buf1[8];
int ret;
ret = i2c_smbus_read_byte_data(client, reg);
if (ret < 0){
printk(KERN_ERR "i2c_transfer failed:%d ",ret);
return -EIO;
}
*dest = ret & 0xff;
}
(3) I2C寫函數
static int axp192_i2c_write(struct i2c_client *client, u8 reg, u8 value){
return i2c_smbus_write_byte_data(client, reg, value);
}
(4) AXP192寄存器讀操作函數
static u8 axp192_read_reg(struct axp192_data *axp192, u8 reg){
u8 val = 0;
mutex_lock(&axp192->mutex);
axp192_i2c_read(axp192->client, reg, &val);
mutex_unlock(&axp192->mutex);
return val;
}
(5) AXP192寄存器寫操作函數
static int axp192_write_reg(struct axp192_data *axp192, u8 reg, u8 value){
mutex_lock(&axp192->mutex);
axp192_i2c_write(axp192->client, reg, value);
mutex_unlock(&axp192->mutex);
return 0;
}
具體的設備驅動完成后,將AXP192設備驅動的配置添加到相應的kconfig文件中,在配置內核選項時就可以把AXP192設備驅動添加到內核中,系統啟動時可自動加載AXP192設備驅動。驅動設計成功后,可以編寫相應的上層應用軟件對AXP192驅動進行管理應用,如控制某個設備電源的開關等。
AXP192完全可替代三星配套推薦的WM8310使S5PV210正常工作。相比WM8310,AXP192可輸出電源路數不多,需要額外增加3路LDO。但是,AXP192的QFN-48封裝比WM8310的0.4 mm間距焊球容易加工和維修,而且PCB設計走線要求比WM8310低。其他方面(如價格、供貨周期等)都有極大的優勢。

[1] 李俊. 嵌入式Linux 設備驅動程序[M].北京:人民郵電出版社, 2008:206-230.
[2] 程昌南.ARM Cortex-A8硬件設計DIY[M].北京:北京航空航天大學出版社, 2012(10): 9-160.
[3] 胡文,寧世勇,李明俊,等. Android嵌入式系統程序開發(基于Cortex-A8) [M].北京:機械工業出版社,2013(2):194-200.
[4] 朱南浩,李正祥.嵌入式Linux中I2C設備驅動程序的研究與實現[J].微計算機信息,2010,26(4): 67-69.
[5] Samsung Electronics. S5PV210_Hardware Design Guide_Rev1.0[EB/OL].(2010-02)[2014-05].http://www.samsung.com/global/business/semiconductor/.
[6] X-powers. AXP19x EVM Guide [EB/OL].[2014-05]. http://www.x-powers.com/.
[7] X-powers. AXP192 Datasheet v1.13 [EB/OL].[ 2014-05]. http://www.x-powers.com/.
鄒勁(學士),主要從事手持設備硬件開發。
Application of Power Management Chip AXP192 on Handheld Device
Zou Jin,Lin Chao,Yang Qi
(Product Research&Development Center,Hi-Target Survey Instruments Company Ltd.,Guangzhou 511400,Chian)
Because of making use of low-power and high-integrated microprocessor platform, most of mobile or handheld products require multiple supply voltages and battery management. Power management chip meets these needs and has other features.In this paper,domestic power management chip AXP192 is applied in the industrial tablet using Samsung S5PV210 mobile processor as the core.Through the designes of power distribution of AXP192 and S5PV210,power-on sequences,control interface of AXP192 and driver based on Linux, the intelligent management of power supply is realized so as to reduce power consumption and extend the use time of the equipments.
power management;handheld device;PMIC;Linux;S5PV210;AXP192
TP216
A
迪娜
2014-05-22)