久久ER99热精品一区二区-久久精品99国产精品日本-久久精品免费一区二区三区-久久综合九色综合欧美狠狠

新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > 深入理解ARM體系架構(S3C6410)---PWM實例

深入理解ARM體系架構(S3C6410)---PWM實例

作者: 時間:2016-11-09 來源:網絡 收藏
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.

本文引用地址:http://cqxgywz.com/article/201611/317827.htm

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. #definerTCFG0(*(volatileunsigned*)(0x7F006000))
  2. #definerTCFG1(*(volatileunsigned*)(0x7F006004))
  3. #definerTCON(*(volatileunsigned*)(0x7F006008))
  4. #definerTCNTB0(*(volatileunsigned*)(0x7F00600C))
  5. #definerTCMPB0(*(volatileunsigned*)(0x7F006010))
  6. #definerTCNTO0(*(volatileunsigned*)(0x7F006014))
  7. #definerTCNTB1(*(volatileunsigned*)(0x7F006018))
  8. #definerTCMPB1(*(volatileunsigned*)(0x7F00601c))
  9. #definerTCNTO1(*(volatileunsigned*)(0x7F006020))
  10. #definerTCNTB2(*(volatileunsigned*)(0x7F006024))
  11. #definerTCNTO2(*(volatileunsigned*)(0x7F00602c))
  12. #definerTCNTB3(*(volatileunsigned*)(0x7F006030))
  13. #definerTCNTO3(*(volatileunsigned*)(0x7F006038))
  14. #definerTCNTB4(*(volatileunsigned*)(0x7F00603c))
  15. #definerTCNTO4(*(volatileunsigned*)(0x7F006040))
  16. #definerTINT_CSTAT(*(volatileunsigned*)(0x7F006044))

編寫初始化函數:


  1. voidinit_pwm()
  2. {
  3. rGPFCON&=~(0x3U<<28);
  4. rGPFCON|=(0x2U<<28);
  5. rTCFG0&=~0xff;
  6. rTCFG0|=(50-1);
  7. rTCFG1=0x4;
  8. #definefreq800
  9. rTCNTB0=(133000000/50/16)/freq;
  10. rTCMPB0=rTCNTB0/2;
  11. rTCON&=~0x1f;
  12. rTCON|=0xb;//disabledeadzone,auto-reload,inv-off,updateTCNTB0&TCMPB0,starttimer0
  13. rTCON&=~2;//clearmanualupdatebit
  14. }

在main函數中:


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



評論


技術專區

關閉