<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > linux內(nèi)核對S3C2410睡眠模式的支持

          linux內(nèi)核對S3C2410睡眠模式的支持

          作者: 時間:2013-03-18 來源:網(wǎng)絡(luò) 收藏

            一、支持4種供電模式

           ?。?)NORMAL MODE

            耗電最大、可以通過關(guān)閉具體控制器的時鐘來節(jié)電

           ?。?)SLOW MODE

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

            (3)IDLE MODE

            FCLK被關(guān)斷,主要由于CPU core節(jié)電??梢匀魏瓮ㄟ^外部中斷喚醒

            (4)Power_OFF MODE

            除了處理器喚醒邏輯單元外,處理器不損耗任何電量??梢酝ㄟ^EINT[15:0] 或 RTC alarm interrupt喚醒系統(tǒng)

            二、各種節(jié)電模式的進入

            (1)慢速模式(SLOW)

            CLKSLOW的SLOW_BIT置1進入

           ?。?)空閑模式(IDLE)

            CLKCON[2]被置1則進入

           ?。?)掉電模式(Power_OFF)

            CLKCON[3]置1進入


            三、進入掉電模式前的準(zhǔn)備工作

            1、為掉電模式設(shè)置合理的GPIO

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

            3、合理配置包括實時時鐘在內(nèi)的喚醒源

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

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

            6、配置MISCCR[1:0]讓數(shù)據(jù)總線上拉

            7、關(guān)閉LCD

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

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

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

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

            10、等待sdram自刷新有效

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

            12、設(shè)置CLKCON進入Power_OFF模式

            四、S3C2410掉電模式喚醒過程

            1、通過喚醒源喚醒系統(tǒng),產(chǎn)生內(nèi)部復(fù)位信號

            2、系統(tǒng)復(fù)位后,測試GSTATUS2[2] 確實系統(tǒng)是否是從Power_OFF模式喚醒的

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

            4、配置SDRAM控制器

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

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

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

            五、配置2.6.26.5內(nèi)核支持S3C2410電源管理


            六、Linux系統(tǒng)對S3C2410 掉電模式的支持

            (1)內(nèi)核接口驅(qū)動文件

            Linux-2.6.26.5內(nèi)核的/drivers/char/apm-emulation.c提供了系統(tǒng)進入睡眠的入口函數(shù)。早期的版本的接口文件為:arch/arm/kernel/apm.c

           ?。?)與進入sleep前的準(zhǔn)備相關(guān)的內(nèi)核文件

            kernel/power/console.c

            該文件提供了使所有系統(tǒng)進程休眠或關(guān)閉的函數(shù)

            drivers/base/power/suspend.c

            該文件使所有設(shè)備驅(qū)動suspend的函數(shù)

           ?。?)進入sleep前的設(shè)置相關(guān)的文件

            arch/arm/mach-s3c2410/pm.c

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

            arch/arm/mach-s3c2410/sleep.s

           ?。?)睡眠喚醒部分在Uboot中

            cpu/arm920t/start.s

           ?。?)內(nèi)核中喚醒階段相關(guān)的匯編段程序文件

            arch/arm/mach-s3c2410/sleep.s


          上一頁 1 2 3 下一頁

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();