久久ER99热精品一区二区-久久精品99国产精品日本-久久精品免费一区二区三区-久久综合九色综合欧美狠狠

新聞中心

EEPW首頁 > 電源與新能源 > 設計應用 > 一種基于SEP0611的電源管理驅動設計方案實現

一種基于SEP0611的電源管理驅動設計方案實現

作者: 時間:2014-02-09 來源:網絡 收藏
nd-color: rgb(255, 255, 255); ">volatile unsigned long *p_regs = i2s_info.base;

本文引用地址:http://www.cqxgywz.com/article/226567.htm

i2s_regs = kmalloc((I2S_PM_REGS_NUM 《 2),

GFP_KERNEL);

if(i2s_regs == NULL)

return -ENOMEM;

for(i=0; i《I2S_PM_REGS_NUM; i++)

i2s_regs[i] = *p_regs++;

clk_disable(i2s_info.clk);

return 0;

這段代碼主要實現:保存音頻設備硬件寄存器;禁止音頻設備時鐘。 2、休眠進入和休眠退出

完成了進入休眠的準備工作,接下來就是進入休眠。

suspend_enter是休眠進入函數,該函數將調用suspend_ops-》enter(state),調用該函數即是調用驅動接口函數sep_pm_enter;該接口函數在sep_pm.c中實現。該文件將保存在CPU寄存器,將休眠代碼搬運到sram中,然后系統在 sram中執行休眠代碼,先讓DDR進入自刷新狀態,而后處理器進入sleep模式。當系統處于休眠模式時,一旦接收到喚醒事件的中斷,如內部的RTC ALARM中斷或者外部的Wakeup按鍵信號才能夠讓系統退出休眠,即喚醒系統。綜上,進入/退出休眠的代碼流程圖如圖2所示。

一種基于SEP0611的電源管理驅動設計方案實現

圖2 進入/退出sleep模式的代碼流圖

在圖2中的休眠進入部分,保存CPU各模式狀態之后,跳轉到sram執行DDR2的自刷新和休眠的進入,而這段代碼(DDR2的自刷新和休眠的進入)此前已由copy_func_to_sram函數搬運至sram中;而跳轉通過將sram的物理地址靜態映射到linux內核(在對應架構的mm.c 中)實現。

此后,系統處于休眠(sleep)模式,直至喚醒信號的到來。

中可用的喚醒信號有:電源鍵、RTC的ALARM中斷、外部GPIO(AO)口。一旦喚醒信號到來,即是該執行休眠退出部分了。PMU 硬件部分將讓系統重新上電,而軟件則回到bootloader部分執行,在bootloader中有一段分支代碼,該部分代碼判斷是一次正常啟動還是一次從休眠的喚醒,若是后者,則恢復CPU各模式狀態,此后回到linux操作系統。需要說明的是,在進入休眠部分的保存CPU各模式狀態之前,PC值(用于返回的地址,實際保存的是PC值加上0x10(合4條指令))已經被保存到一個硬件寄存器中;因此,在退出休眠部分的恢復CPU各模式狀態之后,將PC值從硬件寄存器取出,通過其使程序回到linux操作系統執行。

3、完成喚醒

上面講到了程序回到linux系統執行后,休眠內核層將通過suspend_devices_and_enter函數中位于調用suspend_enter之后的部分和suspend_finish函數完成與休眠準備相逆的操作。

首先在suspend_devices_and_enter函數中執行以下完成喚醒的工作:

(1) 調用dpm_suspend_end函數,該函數分為兩步。

首先調用設備喚醒函數device_resume,該函數會遍歷dpm_off 鏈表隊列,依次調用該隊列上設備驅動的resume函數,讓驅動恢復正常工作模式,并將其從dpm_off 隊列恢復至dpm_active 隊列。然后調用device_complete函數,該函數通常無操作。下面仍以音頻驅動為例展示設備驅動resume函數的填寫(函數頭略):

int i;

volatile unsigned long *p_regs = i2s_info.base;

clk_enable(i2s_info.clk);

init_i2s_gpio();

for(i=0;i《I2S_PM_REGS_NUM; i++)

*p_regs++ = i2s_regs[i];

kfree(i2s_regs);



關鍵詞: SEP0611 電源管理

評論


相關推薦

技術專區

關閉