关于S3C2410的电源管理

发布者:SereneVoyage最新更新时间:2016-11-25 来源: eefocus关键字:S3C2410  电源管理 手机看文章 扫描二维码
随时随地手机看文章

一、S3C2410支持4种供电模式

(1)NORMAL MODE

耗电最大、可以通过关闭具体控制器的时钟来节电

(2)SLOW MODE

在此模式下可以没有内部PLL,耗电情况依赖于外部时钟的频率

(3)IDLE MODE

FCLK被关断,主要由于CPU core节电。可以任何通过外部中断唤醒

(4)Power_OFF MODE

除了处理器唤醒逻辑单元外,处理器不损耗任何电量。可以通过EINT[15:0] 或 RTC alarm interrupt唤醒系统

二、S3C2410各种节电模式的进入

(1)慢速模式(SLOW)

CLKSLOW的SLOW_BIT置1进入

(2)空闲模式(IDLE)

CLKCON[2]被置1则进入

(3)掉电模式(Power_OFF)

CLKCON[3]置1进入

关于S3C2410的电源管理 - 715433351 - 715433351的博客

三、S3C2410进入掉电模式前的准备工作

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电源管理

关于S3C2410的电源管理 - 715433351 - 715433351的博客

六、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)内核修改过程

根据硬件的实际情况,设置睡眠唤醒中断源。我的系统是让中断0-3作为唤醒源。所以让内核允许EINT0--3外部中断将其唤醒。内核版本是2.6.26.5。系统默认容许EINT0..EINT15和IRQ_RTC作为中断唤醒源。

s3c_irqwake_intmask和s3c_irqwake_eintmask是屏蔽码。为了让EINT0--3外部中断可以作为唤醒源,

需要修改:

arch/arm/plat-s3c24xx/irq.c中

unsigned long s3c_irqwake_intmask = 0xffffffffL;

为:

unsigned long s3c_irqwake_intmask = 0xfffffff0L;

(2)修改U-boot

系统睡眠在唤醒后会运行复位程序,当然就是U-boot了。为了让唤醒后的系统能够恢复正常工作状态,及进入到睡眠前运行的位置,需要修改U-boot

将下面的代码加入到uboot的cpu/arm920t/start.s中,注意:要放在sdram初始化后,参考本文的第四标题“S3C2410掉电模式唤醒过程”

/* Power Manage Check if this is a wake-up from sleep */
        ldr r1, =0x560000B4
        ldr r0, [r1]
        tst r0, #0x02
        beq notPowerOFF

/****led test****
        ldr r0, =0x56000050
        ldr r1,=0x55555555
        str r1,[r0]
        ldr r0, =0x56000054
        ldr r1,=0x0
        str r1,[r0]
        */

WakeupStart:
        //Clear sleep reset bit 
        ldr r0, =0x560000B4
        mov r1, #0x2 
        str r1, [r0]

ldr r0, =0x56000080 //Release the SDRAM signal protections 
        ldr r1, =0x00010330

str r1, [r0]

ldr r0, =0x48000024
        ldr r1, [r0]
        bic r1, r1, #0x400000
        str r1, [r0]

mov r1, #0x1000
1: subs r1, r1, #1 // wait until the SelfRefresh is released. 
        bne 1b

/*
        ldr r0, =0x56000050
        ldr r1,=0x55555555
        str r1,[r0]
        ldr r0, =0x56000054
        ldr r1,=0x5555
        str r1,[r0]
        */

        ldr r0, =0x560000B8 //read a return address go to s3c2410_cpu_resume
                ldr r1, [r0] 
                mov pc, r1 //go to resume 恢复到睡眠前的位置
                nop
                nop
1: b 1b 
        notPowerOFF:

(3)编写测试程序

#include
        #include 
        #include 
        #include 
        #include 
        #include 
        #define APM_IOC_STANDBY _IO('A', 1)
        #define APM_IOC_SUSPEND _IO('A', 2)
        int main (void) 
        {
                int fd;
                fd = open ("/dev/apm_bios",O_RDWR);
                if (fd < 0) {
                printf ("fd open failed\n");
                exit(0);
                }
                printf ("\n/dev/apm_bios opened, fd=%d\n",fd);
                ioctl (fd, APM_IOC_SUSPEND);
                close (fd);
                printf ("/dev/apm_bios closed :)\n");
                return 0;
        }

(4)测试效果

#./test
                .....
                sleep: irq wakeup masks: fffffff0,fffffff0
                GSTATUS3 0x30367140
                GSTATUS4 0x00000000

进入睡眠状态,此时按K10按键,即中断0,唤醒系统

        GPIO[0] CON 007fffff => 007fffff, DAT 00000000 => 00000000
                GPIO[1] CON 00044555 => 00044555, DAT 00000540 => 00000540
                GPIO[2] CON aaaaaaaa => aaaaaaaa, DAT 00000000 => 00000000
                GPIO[3] CON aaaaaaaa => aaaaaaaa, DAT 00000000 => 00000000
                GPIO[4] CON aaaaa6aa => aaaaa6aa, DAT 0000ffc5 => 0000ffc5
                GPIO[5] CON 000055aa => 000055aa, DAT 000000fe => 000000ff
                GPIO[6] CON ffa5ff30 => ffa5ffba, DAT 0000aced => 0000aced
                GPIO[7] CON 002afaaa => 002afaaa, DAT 000001ff => 000001fb
                post sleep: IRQs 0x02000001, 0x00000200
                IRQ 16 asserted at resume
                post sleep, preparing to return
                S3C2410 PM Resume (post-restore)
                s3c2410-sdi s3c2410-sdi: powered down.
                s3c24xx-pm: check if we have anything to wake-up with
                Disabling IRQ 52 (pin 192)
                Disabling IRQ 53 (pin 193)
                Disabling IRQ 55 (pin 195)
                dma3: restoring configuration
                timer tcon=00000000, tcnt a2c1, tcfg 00000200,00000000, usec 00001eb8
                s3c2410-wdt: watchdog disabled
                s3c2410-i2c s3c2410-i2c: slave address 0x10
                s3c2410-i2c s3c2410-i2c: bus frequency set to 390 KHz
                s3c2410-nand s3c2410-nand: Tacls=3, 30ns Twrph0=7 70ns, Twrph1=3 30ns
                s3c2410-sdi s3c2410-sdi: running at 0kHz (requested: 0kHz).
                s3c2410-sdi s3c2410-sdi: running at 98kHz (requested: 97kHz).
                s3c2410-sdi s3c2410-sdi: running at 98kHz (requested: 97kHz).
                s3c2410-sdi s3c2410-sdi: running at 98kHz (requested: 97kHz).
                s3c2410-sdi s3c2410-sdi: powered down.
                usb usb1: root hub lost power or was reset
                Restarting tasks ... done.
                /dev/apm_bios closed :)
                #

此时系统恢复了正常运行。


关键字:S3C2410  电源管理 引用地址:关于S3C2410的电源管理

上一篇:关于S3C2410的存储器
下一篇:S3C2410 TFT LCD显示原理分析

推荐阅读最新更新时间:2024-03-16 15:22

AVR单片机用于电源管理系统的研究
简介:本文设计了一套UAV 电源管理系统, 该系统具有自动控制充放电管理, 实时监测电池电压等功能。该系统已经经过调试和试验验证了其可行性, 但是为了保证飞机安全, 还要做更多的试验以保证无人机自主飞行的安全和稳定。除此之外, 高低频滤波, 电池电量预测等也是重要的方向, 需要深入的研究。 由于在民用及国防等诸多领域中的广泛应用, 空中机器人技术已经越来越被人们所重视, 并吸引了各国专家学者的注意。小型旋翼机器人是以模型直升机为载体, 装备上传感器单元, 控制单元和伺服机构等装置以实现自主飞行。而为了提高飞机的安全性, 需要设计一套设备监测系统, 实时的监测飞机的姿态信息, 机载设备的状况以及电源的情况等。 该平台所使用的
[单片机]
AVR单片机用于<font color='red'>电源管理</font>系统的研究
便携设备电源管理系统
  1 引言   早期嵌入式便携设备由于结构简单,往往只采用一两种电源管理器件即可满足供电需求。但是随着嵌入式处理器功能不断增强,便携设备的电源管理系统设计面对尺寸和成本的全新挑战。因此,采用传统的单一功能电源管理器件已无法满足需求,因此。采用专门集成电源管理单元(PMU)设计电源系统已是大势所趋。这里给出了一种基于LP3913的便携式设备电源管理系统设计方案。   2 LP3913简介   LP3913是美国国家半导体公司推出的一款功能强大的PMU,专门针对嵌入式便携设备应用,其主要特点为:2路线性电源(LDO)输出和3路DC—DC Buck变换器输出,每路输出电压可动态调节;开关机检测和控制功能;USB/AC外部电源输入管理,
[电源管理]
便携设备<font color='red'>电源管理</font>系统
电源管理芯片power1208介绍
作者Email: gavin@jenshin.com 摘要:介绍莱迪思(Lattice)半导体公司推出的业界第一个混合信号的可编程逻辑器件Power1208的特征、结构和原理。该器件的特点就是用一颗芯片就可完成对现代集成电路板上复杂电源的管理。 关键词:可编程逻辑器件 电源管理 Power1208 在对现代集成电路板的设计中,设计者们往往要使用一大堆的比较器、电阻器、电容器、定时器和逻辑器来实现对电路板电源的管理,而这样做的后果就是需要花费大量的时间和占用电路板的空间。而莱迪思半导体公司推出的ispPAC电源管理器Powr1208就用单颗芯片实现了对电路板电源定序和监控功能完全管理!而且要重新更改设计时,只要对器件的
[应用]
数码相机电池重组技巧分析
在最开始的半年里,随着照相机使用时间的延长,有一种不愉快的现象始终缠绕着我。这个现象就是照相机在使用的过程中会突然关机,我重新开机后又一切回复正常。刚开始,这个现象出现的概率并不大,后来随着时间的推移,这种故障越来越频繁。随着该故障出现的次数增多,我发现有这样的规律: * 在照相机浏览相片的时候,较少发生自动关机。 * 拍摄模式的时候,发生自动关机的概率大一些。 * 拍摄的时候,如果打开了闪光灯,或者打开了机器后背的外置取景器,则故障发生的概率更大。 依据以上现象,我有些怀疑照相机是否有故障了。但由于故障是随机出现的,无法100%确定故障就是照相机引起。再进一步的使用,还发现有这样的规律: * 如果电池刚充好,就
[电源管理]
QNX 发布智能家用能源管理系统的参考设计
2010 年 3 月 2 日讯——哈曼国际集团(NYSE:HAR)旗下的 QNX 软件系统公司今日发布了最新的智能能源参考,即一种便于设计、部署和扩展智能家用能源管理系统的预集成软件栈。 这种能源参考可立即支持 Zigbee 传感器、Insteon 家用局域网 (HAN)、流式 IP 视频摄像头(安全监控用)、用于计算能耗成本的应用程序,以及获取气象信息并执行远程控制和故障诊断的因特网连接。其他功能还包括区域温度控制、独立照明和区域照明控制以及家电监测和控制。 智能能源参考是基于 QNX® Aviage® 人机界面套件的系统,它提供的框架允许开发人员通过 Adobe Flash 创建引人入胜的家用能源系统触摸
[嵌入式]
Diodes 公司的超高功率密度充电器整体解决方案
Diodes 公司的超高功率密度充电器整体解决方案,具备更高效率、更省空间的产品优点 【2021 年11月04日美国德州普拉诺讯】Diodes 公司推出一款三芯片解决方案,可提升超高功率密度 USB Type-C® power delivery (PD) 系统的效能。方案产品可适用在智能型手机充电器及笔记本电脑变压器等多种消费性电子产品应用。 AP43771V USB Type-C PD 解码器兼容于PD3.0、PPS Rev 3.0、V1.2 (TID – 4305) 及Qualcomm® Quick Charge™ QC4/QC4+/QC5 (QC20201127203)等多项通讯协议。此产品支持 3.3V 至
[电源管理]
Diodes 公司的超高功率密度充电器整体解决方案
ADIADP5034微电源管理(PMU)解决方案
电源管理单元(PMU)评估板主要特性,电路图,材料清单和元器件布局图. The ADP5034 combines two high performance buck regulators and two low dropout (LDO) regulators in a small, 24-lead 4 mm × 4 mm LFCSP to meet demanding performance and board space requirements. The high switching frequency of the buck regulators enables tiny multilayer external compon
[电源管理]
ADIADP5034微<font color='red'>电源管理</font>(PMU)解决方案
PDP显示器电源管理架构分析
  电浆显示器在大尺寸的平面显示器中,尽管在良率、可视角度等方面具有优势,然其显示原理倚赖电弧放电,由于放电必须要有较高的电极电压,也因此电浆显示器比起其他显示器更为耗电。本文将介绍电浆显示器电源耗损之主因,并分两大层面介绍电浆显示器之电源管理方案。   PDP的显示原理、PDP为何较耗电?   在此以逐步的方式来说明PDP的显示原理,相信各位都看过打雷吧?雷电直接从云层落到地面,所经过的路径是空气,要让原本不适合导电的空气成为电流流经的导体路径,自然要有很高的电压作为引力,此即是所谓的电弧放电。   在日常生活中有许多应用即是电弧放电的应用,例如防身用的电击棒,以及照明用的日光灯管(也称萤光灯),灯管的左右端各是一个电极,
[电源管理]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved