深入理解ARM体系架构(S3C6410)---PWM实例

转载 2012年03月31日 08:33:08
 

深入理解ARM体系架构(S3C6410)---PWM实例

分类: 嵌入式arm篇 2088人阅读 评论(3) 收藏 举报

本系列文章由muge0913编写,转载请注明出处:http://blog.csdn.net/muge0913/article/details/7389801

作者:张同浩,邮箱:muge0913@sina.com



S3C6410X中有5个定时器,这些定时器产生内部中断。其中,Timer0和Timer1具有PWM功能,而Timer2,3,4没有此功能。

The S3C6410X RISC microprocessorcomprises of five 32-bit timers. These timers are used to generate internal interruptsto the ARM subsystem. In addition, Timers 0 and 1 include a PWM function (PulseWidth Modulation),which can drive an external I/O signal. The PWM for timer 0and 1 have an optional dead-zone generator capability, which can be utilized tosupport a large current device. Timer 2, 3 and 4 are internal timers with no outputpins.

PWM具有两种操作模式:自动装载模式,一次触发模式。为实现PWM功能,芯片提供了16个功能寄存器。这些功能寄存器都连接APB总线。


总体架构图如下:


S3C6410X中有5个定时器,这些定时器产生内部中断。其中,Timer0和Timer1具有PWM功能,而Timer2,3,4没有此功能。定时器具有双缓冲特性,这样就能在不停止当前定时器操作的情况下,为下次定时器运行装入新的数值。尽管为定时器设置了新数值,但当前的定时操作能够成功完成。定时器从TCNTBn读取的值是为下次延时定时用的,并不影响当前定时器的运行。当TCNTn减小到0的时候,TCNTBn的值会自动复制到TCNTn中,这就是说的自动装载操作。定时器的当前技术数值可以从定时计数观察寄存器中TCNTOn读取。如果TCNTn为0且从装载也为0的话则TCNTn不在进行下次操作。


寄存器介绍:

1、总寄存器映射图

2、TCFG0寄存器:

3、TCFG1寄存器:

4、TCON控制寄存器:




mini6410蜂鸣器原理图:




定义寄存器:

  1. /* PWM Timer */  
  2. #define rTCFG0       (*(volatile unsigned *)(0x7F006000))  
  3. #define rTCFG1       (*(volatile unsigned *)(0x7F006004))  
  4. #define rTCON        (*(volatile unsigned *)(0x7F006008))  
  5. #define rTCNTB0      (*(volatile unsigned *)(0x7F00600C))  
  6. #define rTCMPB0      (*(volatile unsigned *)(0x7F006010))  
  7. #define rTCNTO0      (*(volatile unsigned *)(0x7F006014))  
  8. #define rTCNTB1      (*(volatile unsigned *)(0x7F006018))  
  9. #define rTCMPB1      (*(volatile unsigned *)(0x7F00601c))  
  10. #define rTCNTO1      (*(volatile unsigned *)(0x7F006020))  
  11. #define rTCNTB2      (*(volatile unsigned *)(0x7F006024))  
  12. #define rTCNTO2      (*(volatile unsigned *)(0x7F00602c))  
  13. #define rTCNTB3      (*(volatile unsigned *)(0x7F006030))  
  14. #define rTCNTO3      (*(volatile unsigned *)(0x7F006038))  
  15. #define rTCNTB4      (*(volatile unsigned *)(0x7F00603c))   
  16. #define rTCNTO4      (*(volatile unsigned *)(0x7F006040))   
  17. #define rTINT_CSTAT  (*(volatile unsigned *)(0x7F006044))  


编写初始化函数:

  1. void init_pwm()  
  2. {  
  3.    
  4.     rGPFCON &= ~(0x3U << 28);  
  5.     rGPFCON |=  (0x2U << 28);  
  6.       
  7.     rTCFG0 &= ~0xff;  
  8.     rTCFG0 |= (50 - 1);  
  9.    
  10.     rTCFG1 = 0x4;  
  11.     #define freq 800  
  12.     rTCNTB0 = (133000000/50/16)/freq;  
  13.     rTCMPB0 = rTCNTB0/2;  
  14.   
  15.   
  16.     rTCON &= ~0x1f;  
  17.     rTCON |= 0xb;       //disable deadzone, auto-reload, inv-off, update TCNTB0&TCMPB0, start timer 0  
  18.   
  19.   
  20.     rTCON &= ~2;            //clear manual update bit  
  21.       
  22. }  

在main函数中:

  1. init_pwm();  
  2. while(1);  



程序下载地址:http://download.csdn.net/detail/muge0913/4170428


相关文章推荐

深入理解ARM体系架构(S3C6410)---rtc实例

本系列文章由张同浩编写转载请注明出处:http://blog.csdn.net/muge0913/article/details/7460440 邮箱:muge0913@sina.com ...

嵌入式arm学习总结(六)--S3C2440体系架构学习总结

平台介绍:mini2440开发板,S3c2440主芯片 硬件信息 1.130个IO口,289个引脚17*17,BGA封装 2.电源 内核:1.25v 内存电源:1.8V GPIO:3.3v 3.芯片内...

S3C2440体系架构

本文是对ARM处理器架构的学习,针对S3C2440型号。参考了Samsung官方的技术文档S3C2440.pdf中的PROGRAMMER’S MODEL一节的内容。ARM和THUMB指令模式S3C24...

S3C6410的PWM驱动实例

我们使用PWM来控制蜂鸣器,主要是两种功能,一是使能蜂鸣器,并设置其频率;二是禁止蜂鸣器。这些操作均可通过ioctl来完成。所以在pwm的设备驱动中,主要也就是ioctl这个函数。    首先,我们...

S3C6410的PWM驱动实例

我们使用PWM来控制蜂鸣器,主要是两种功能,一是使能蜂鸣器,并设置其频率;二是禁止蜂鸣器。这些操作均可通过ioctl来完成。所以在pwm的设备驱动中,主要也就是ioctl这个函数。    首先,我们...

S3c6410 linux内核移植(8)---添加pwm驱动,控制lcd背光亮度

一般LCD的背光LED是通过PWM控制,调节PWM的占空比即可调整背光亮度。比如S3C6410的GPF15,即PWM1,可连接LCD的背光控制接口,进行背光控制。内核中pmw配置函数位于”arch/a...

S3C6410 PWM驱动(三) --- 源代码

/***********wzk_pwm.c**********/ #include "wzk_pwm.h" //init dev void init_pwm(void) { unsig...

S3C6410 PWM驱动(二) --- 原理分析

1.相关寄存器 (1)TCFG0:时钟预定标器和死区结构。 (2)TCFG1:时钟多路复用器和 DMA 模式的选择。 (3)TCON:定时器控制寄存器。 (4)TCNTB0:定时器 0 计数缓...

S3C6410 LCD 背光PWM控制研究

一般LCD的背光LED是通过PWM控制,调节PWM的占空比即可调整背光亮度。 比如S3C6410的GPF15,即PWM1,可连接LCD的背光控制接口,进行背光控制。 其工作流程如下: 1)在li...

S3C6410之PWM介绍

在分析PWM驱动的实现之前,我们需要看看6410的芯片手册中有关PWM章节,知道PWM的产生方式和控制方法,知道相关的一些寄存器才能知道设置那些寄存器,都应该赋什么值,下面就是其中的一部分,主要是芯片...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)