linux内核对S3C2410睡眠模式的支持

发布者:RainbowGarden最新更新时间:2013-03-18 来源: dzsc关键字:linux内核  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进入掉电模式前的准备工作

  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[page]

  七、实现方法

  具体的实现原理可以通过阅读上述相关文件获取。下面如何实现系统的睡眠及唤醒

  (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:[page]

  (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 ");

  exit(0);

  }

  printf (" /dev/apm_bios opened, fd=%d ",fd);

  ioctl (fd, APM_IOC_SUSPEND);

  close (fd);

  printf ("/dev/apm_bios closed :) ");

  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 :)

  #

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

关键字:linux内核  S3C2410  睡眠模式 引用地址:linux内核对S3C2410睡眠模式的支持

上一篇:NandFlash系列之二:S3C2410读写Nand Flash分析
下一篇:基于VxWorks的油井数据采集远程终端的设计

推荐阅读最新更新时间:2024-03-16 13:20

arm驱动linux内核时钟
《 linux内核时钟》涉及内核驱动函数四个,内核结构体一个,分析了内核驱动函数一个;可参考的相关应用程序模板或内核驱动模板一个,可参考的相关应用程序模板或内核驱动一个 一、内核定时器 意义:内核定时器是软件意义上的定时器,最终依赖定时器来实现。时钟中断处理程序会唤起Timer_softirq软中断,运行当前处理器上到期的所有定时器。 二、linux设备驱动编程 linux内核提供一组函数,时钟数据结构;这组函数和数据结构使驱动工程师不用关心具体的软件定时器究竟对应着怎样的内核和硬件行为。 三、数据结构和函数: 1)数据结构 结构体一)Linux在include/linux/timer.h头文件中定义了数据结构timer_list来
[单片机]
基于嵌入式Linux图像采集恢复和应用
1.引言       随着后PC时代的到来和嵌入式的蓬勃发展,运用嵌入式系统实现远程数据采集已成为社会需求的趋势。本文采用嵌入式系统采集图像数据实现加工零件的远程测量,代替传统的人工检测。其特点有:网络化,准确性高,节约人力和物力。   2.系统软硬件平 台       由于嵌入式设备资源有限,所以在开发嵌入式系统的软件部分需要在宿主机平台上实现,运用宿主机的资源编译目标机平台上可运行的软件。本文系统的宿主机平台:Redhat 9.0,交叉编译环境:ARM-Linux-Gcc;目标机平台:UBOOT 1.1,Linux 2.4.18 和YAFFS 根文件系统。       系统硬件平台的处理器采用 Samsung 公司的集成
[嵌入式]
lpc1114深度睡眠模式Deep-sleep
在深度睡眠模式,除了BOD模块和看门狗振荡器的时钟可以继续工作,其它所有的时钟都会停止工作。可以通过PDSLEEPCFG寄存器来配置在深度睡眠模式期间BOD模块和看门狗振荡器是否需要工作。 在深度睡眠模式,消除了flash、所有模拟外设、处理器自身、存储器、相关控制器和内部总线的功耗。处理器的状态和寄存器、外设的寄存器、内部SRAM的数据和单片机引脚的电平保持不变。 在深度睡眠模式,看门狗振荡器是唯一可以工作的时钟源。当需要定时器定时唤醒单片机的时候,可以开启看门狗时钟。其它的时钟,诸如系统振荡器、IRC和PLL都会掉电。如果需要看门狗振荡器工作,它的时钟必须设置到最小值,即把WDTOSCCTRL寄存器中的FREQSEL位设置为0
[单片机]
lpc1114深度<font color='red'>睡眠</font><font color='red'>模式</font>Deep-sleep
基于s3c2410软中断服务的uC/OS-II任务切换
1.关于软中断指令 软件中断指令(SWI)可以产生一个软件中断异常,这为应用程序调用系统例程提供了一种机制。 语法: SWI { cond } SWI_number SWI执行后的寄存器变化: lr_svc = SWI指令后面的指令地址 spsr_svc = cpsr pc = vectors + 0x08 cpsr模式 = SVC cpsr I = 1(屏蔽IRQ中断) 处理器执行SWI指令时,设置程序计数器pc为向量表的0x08偏移处,同事强制切换处理器模式到SVC模式,以便操作系统例程可以在特权模式下被调用。 每个SWI指令有一个关联的SWI号(number)
[单片机]
S3C2410 MMU(存储器管理单元)详述
  MMU,全称Memory Manage Unit, 中文名——存储器管理单元。   许多年以前,当人们还在使用DOS或是更古老的操作系统的时候,计算机的内存还非常小,一般都是以K为单位进行计算,相应的,当时的程序规模也不大,所以内存容量虽然小,但还是可以容纳当时的程序。但随着图形界面的兴起还用用户需求的不断增大,应用程序的规模也随之膨胀起来,终于一个难题出现在程序员的面前,那就是应用程序太大以至于内存容纳不下该程序,通常解决的办法是把程序分割成许多称为覆盖块(overlay)的片段。覆盖块0首先运行,结束时他将调用另一个覆盖块。虽然覆盖块的交换是由OS完成的,但是必须先由程序员把程序先进行分割,这是一个费时费力的工作,而且相
[单片机]
<font color='red'>S3C2410</font> MMU(存储器管理单元)详述
stm32f429的u-boot、uclinux内核烧写说明
最近比较忙,针对前面的留言说有怎么download u-boot、uclinux到stm32,我翻了翻以前记录下的笔记,特意贴上来,其实有些步骤我都已经忘记了。。。 一、搭建嵌入式linux开发环境 1. 准备一台Linux系统(Fedora,CentOS,Ubuntu等)的电脑,将BSP压缩包(linux-cortexm-2.0.0.tar.gz)拷贝到一个目录; 2. 解压BSP包: tar -xzvf linux-cortexm-2.0.0.tar.gz 3. 解压arm工具链: cd linux-cortexm-2.0.0/tools tar xvfj arm-2010q1-189-arm-uc
[单片机]
stm32f429的u-boot、uc<font color='red'>linux内核</font>烧写说明
WinCE-IIC调试助手(S3C2410)
这两天在调试一款新的硬件平台,它采用的MCU依然是S3C2410。该平台新增了一个RTC模块,采用的芯片是DS1337。这是一个IIC接口的时钟芯片。在开始调试时碰到了一些问题,MCU始终无法与DS1337通讯,走了些弯路,浪费了不少时间。后来发现是IIC的SDA和SCL接反了。为了以后能方便调试2410下的IIC设备,所以决定为2410的WinCE做一个IIC调试助手,以免下次再碰到类似的问题,而多花冤枉时间。 IIC调试助手的主要功能:检测S3C2410 IIC-Bus上的设备,并给出对应的Slave Address。这样,我们就可以快速判断硬件是否有问题。除了侦测设备,同时也要支持读和写的功能。通过选择,能方便控制IIC
[单片机]
WinCE-IIC调试助手(<font color='red'>S3C2410</font>)
linux内核S3C2410睡眠模式的支持
  一、S3C2410支持4种供电模式   (1)NORMAL MODE   耗电最大、可以通过关闭具体控制器的时钟来节电   (2)SLOW MODE   在此模式下可以没有内部PLL,耗电情况依赖于外部时钟的频率   (3)IDLE MODE   FCLK被关断,主要由于CPU core节电。可以任何通过外部中断唤醒   (4)Power_OFF MODE   除了处理器唤醒逻辑单元外,处理器不损耗任何电量。可以通过EINT 或 RTC alarm interrupt唤醒系统   二、S3C2410各种节电模式的进入   (1)慢速模式(SLOW)   CLKSLOW的SLOW_BI
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

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

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

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