新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > linux內核對S3C2410睡眠模式的支持

        linux內核對S3C2410睡眠模式的支持

        作者: 時間:2013-03-18 來源:網絡 收藏

          一、支持4種供電模式

          (1)NORMAL MODE

          耗電最大、可以通過關閉具體控制器的時鐘來節電

          (2)SLOW MODE

          在此模式下可以沒有內部PLL,耗電情況依賴于外部時鐘的頻率

          (3)IDLE MODE

          FCLK被關斷,主要由于CPU core節電。可以任何通過外部中斷喚醒

          (4)Power_OFF MODE

          除了處理器喚醒邏輯單元外,處理器不損耗任何電量。可以通過EINT[15:0] 或 RTC alarm interrupt喚醒系統

          二、各種節電模式的進入

          (1)慢速模式(SLOW)

          CLKSLOW的SLOW_BIT置1進入

          (2)空閑模式(IDLE)

          CLKCON[2]被置1則進入

          (3)掉電模式(Power_OFF)

          CLKCON[3]置1進入


          三、進入掉電模式前的準備工作

          1、為掉電模式設置合理的GPIO

          2、在中斷屏蔽寄存器中屏蔽所有中斷

          3、合理配置包括實時時鐘在內的喚醒源

          4、掛起USB。MISCCR[13:12]=11b

          5、將睡眠返回地址或一些不希望在掉電模式下丟失的數據存放在GSTATUS3,4 中

          6、配置MISCCR[1:0]讓數據總線上拉

          7、關閉LCD

          8、為了填充TLB讀取REFRESH、 CLKCON 和MISCCR寄存器.

          第8點理解起來可能稍微困難一點,需要說明一下:

          因為在進入掉電模式前還需要讓SDRAM掛起,在SDRAM掛起后還需要操作REFRESH、CLKCON、MISCCR特殊功能寄存器,而這些寄存器的地址可能是虛擬地址,這就要求TLB中要有相應的入口。如果沒有的話就要到sdram中取相應的頁表,而此時sdram已經掛起了,所以為了防止這種情況的產生,可以在掛起sdram前讀取要訪問的地址,這樣TLB中就會保留有相應的頁表項,訪問REFRESH、CLKCON、MISCCR時就不會需要sdram的支持了。

          9、設置REFRESH[22]=1b讓sdram進入自刷新模式

          10、等待sdram自刷新有效

          11、設置 MISCCR[19:17]=111b 使 SDRAM 的信號 (SCLK0,SCLK1 and SCKE) 在 Power_OF 模式下被保護

          12、設置CLKCON進入Power_OFF模式

          四、S3C2410掉電模式喚醒過程

          1、通過喚醒源喚醒系統,產生內部復位信號

          2、系統復位后,測試GSTATUS2[2] 確實系統是否是從Power_OFF模式喚醒的

          3、設置MISCCR[19:17]=000b釋放SDRAM信號保護

          4、配置SDRAM控制器

          5、等待直到SDRAM自刷新釋放

          6、讀取GSTATUS3、4的值,可以利用它們回復到睡眠前的程序位置

          注意:利用外部中斷EINT[15:0]喚醒系統,需要保持nBATT_FLT為高電平

          五、配置2.6.26.5內核支持S3C2410電源管理


          六、Linux系統對S3C2410 掉電模式的支持

          (1)內核接口驅動文件

          Linux-2.6.26.5內核的/drivers/char/apm-emulation.c提供了系統進入睡眠的入口函數。早期的版本的接口文件為:arch/arm/kernel/apm.c

          (2)與進入sleep前的準備相關的內核文件

          kernel/power/console.c

          該文件提供了使所有系統進程休眠或關閉的函數

          drivers/base/power/suspend.c

          該文件使所有設備驅動suspend的函數

          (3)進入sleep前的設置相關的文件

          arch/arm/mach-s3c2410/pm.c

          (4)進休眠前的匯編段程序文件

          arch/arm/mach-s3c2410/sleep.s

          (5)睡眠喚醒部分在Uboot中

          cpu/arm920t/start.s

          (6)內核中喚醒階段相關的匯編段程序文件

          arch/arm/mach-s3c2410/sleep.s


        上一頁 1 2 3 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 兴城市| 峨边| 鲁甸县| 封丘县| 文登市| 襄汾县| 江门市| 甘德县| 晋州市| 嘉荫县| 娄底市| 叙永县| 荥经县| 峨眉山市| 罗定市| 河池市| 牟定县| 开平市| 德清县| 耿马| 云安县| 西林县| 衢州市| 浪卡子县| 顺义区| 大新县| 齐齐哈尔市| 光泽县| 麻栗坡县| 诸暨市| 浦县| 台北县| 缙云县| 仁寿县| 洛隆县| 平凉市| 巍山| 吉林省| 辽阳市| 阿鲁科尔沁旗| 通江县|