STM32 Timer : Base Timer, Input Capture, PWM, Output Compare
http://www.cs.indiana.edu/~geobrown/book.pdf
An example of a basic timer is illustrated in Figure 10.1.
This timer has four components – a controller, a prescaler (PSC), an “auto-reload” register (ARR) and a counter (CNT).
The function of the prescaler is to divide a reference clock to lower frequency.
The STM32 timers have 16-bit prescaler registers and can divide the reference clock by any value 1..65535.
For example, the 24Mhz system clock of the STM32 VL Discovery
could be used to generate a 1 Mhz count frequency with a prescaler of 23 (0..23 == 24 values). T
he counter register can be configured to count up, down, or up/down and to be reloaded from the auto reload register
whenever it wraps around (an “update event”) or to stop when it wraps around.
The basic timer generates an output event (TGRO) which can be configured
to occur on an update event or when the counter is enabled (for example on a GPIO input).
To understand the three counter modes consider Figure 10.2.
In these examples, we assume a prescaler of 1 (counter clock is half the internal clock), and a auto reload value of 3.
Notice that in “Up” mode, the counter increments from 0 to 3 (ARR) and then is reset to 0.
When the reset occurs, an “update event” is generated.
This update event may be tied to TRGO, or in more complex timers with capture/compare channels
it may have additional effects (described below).
Similarly, in “Down” mode, the counter decrements from 3 to 0 and then is reset to 3 (ARR).
In Down mode, an update “event” (UEV) is generated when the counter is reset to ARR.
Finally, in Up/Down mode, the counter increments to ARR, then decrements to 0, and repeats.
A UEV is generated before each reversal with the effect that the period in Up/Down mode
is one shorter than in either Up or Down mode.
Many timers extend this basic module with the addition of counter channels such as the one illustrated in Figure 10.3.
The “x” refers to the channel number – frequently, timers support multiple channels.
With this modest additional hardware, an output can be generated whenever the count register reaches a specific value
or the counter register can be captured when a specific input event occurs (possibly a prescaled input clock).
An important use of counter channels is the generation of precisely timed pulses.
There are two variations of this use – “one-pulse” pulses,
in which a single pulse is generated, and pulse width modulation, in which a series of pulses is generated with the counter UEV period.
The pulse width is controlled by the Capture/Compare Register (CCR).
For example, the channel output (OCxREF) may tied to whether the CNT register is greater (or less) than the Compare register.
In Figure 10.4 we illustrate the use of two channels for one-pulse and PWM outputs.
Here we assume that the ARR is 7 and the CCR is 3.
In PWM mode, ARR controls the period, and CCR controls the pulse width (and hence the duty cycle).
In one-pulse mode, the pulse begins CCR cycles after an initial trigger event, and has a width of ARR-CRR.
It is possible to use multiple channels to create a set of synchronized, pulses beginning at precise delays from each other.
A timer channel may also be used to measure pulse widths – in effect decoding pwm signals.
There are many other configuration options for the STM32 timers including mechanisms
to synchronize multiple timers both to each other and to external signals.
In the remainder of this chapter we consider two timer applications including PWM output (Section 10.1),
input pulse measurement (Section 10.2).
In Chapter 13 we show how to use a timer to control DMA transfers for an audio player and
in Chapter 14 we use a timer to sample and analog input at regular intervals.
STM32 Timer : Base Timer, Input Capture, PWM, Output Compare的更多相关文章
- PIC32MZ tutorial -- Output Compare
Output Compare is a powerful feature of embedded world. The PIC32 Output Compare module compares the ...
- STM32 System and Timer Clock Configurations
STM32 System and Timer Clock Configurations I've started writing some software to drive a series of ...
- TIMER门控模式控制PWM输出长度
TIMER门控模式控制PWM输出长度 参照一些网友代码做了些修改,由TIM4来控制TIM2的PWM输出长度, 采用主从的门控模式,即TIM4输出高时候TIM2使能输出 //TIM2 PWM输出,由TI ...
- PIC32MZ tutorial -- Input Capture
Today I accomplish a simple application for PIC32MZ EC Starter Kit. This application uses Input Capt ...
- An Isolated DAC Using PWM Output
An Isolated DAC Using PWM Output Arduino‘s (ATmega328P) PWM outputs via analogWrite can be convenien ...
- 深入比特币原理(三)——交易的输入(input)与输出(output)
本节内容非常重要,如果你不能很好的掌握本节内容,你无法真正理解比特币的运行原理,请务必要学习清楚. 比特币的交易模型为UTXO(unspend transaction output),即只记录未花费的 ...
- Linux部署Django:报错 nohup: ignoring input and appending output to ‘nohup.out’
一.部署 Django 到远程 Linux 服务器 利用 xshell 通过 ssh 连接到 Linux服务器,常规的启动命令是 python3 manage.py runserver 但是,关闭 x ...
- STM32: TIMER门控模式控制PWM输出长度
搞了两天单脉冲没搞定,无意中发现,这个利用主从模式的门控方式来控制一路PWM的输出长度很有效. //TIM2 PWM输出,由TIM4来控制其输出与停止 //frequency_tim2:TIM2 PW ...
- STM32 Seminar 2007 -- Timer
随机推荐
- python实现两个经纬度点之间的距离和方位角
from:http://blog.csdn.net/zhuqiuhui/article/details/53180395 1. 求两个经纬点的方位角,P0(latA, lonA), P1(latB, ...
- 【Python】exe2shellcode,shellcode2exe
用python写这类程序真简洁,要是用C++又不知道得多写多少行代码了. exe2shellcode #! /usr/bin/env python # -*- coding: utf-8 -*- im ...
- GET和POST两种基本请求方法的区别(转载)
get与post请求的区别: 通常回答: GET在浏览器回退时是无害的,而POST会再次提交请求. GET产生的URL地址可以被Bookmark,而POST不可以. GET请求会被浏览器主动cache ...
- Nginx安装及常用命令
一.选定源码目录 cd /usr/local/src 可以是任何目录,本文选定的是/usr/local/src 二.安装依赖库 yum install gcc yum install pcre-dev ...
- 一个浏览器Fuzzing框架的学习
一个浏览器Fuzzing框架的学习 关于框架 之前是LCatro师傅在小密圈分享的他写的这个Fuzzing框架(不过我以前翻github时好像就看到过),但是之前一直没啥时间搞这方面,这两天研究学习了 ...
- 1 、在Linux(centos6.8)系统下的JDK安装与配置
一.解压jdk安装包: 附上jdk1.8的下载地址: http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-21 ...
- .NetCore WebApi利用Swagger文档实现选择文件上传
介绍 实现这个功能主要还是依赖过滤器 在Swagger中利用 IOperationFilter 操作来实现文件上传 与之前处理结合Idr4授权一样的处理方式,不同的是授权处理的是Security,而文 ...
- day10--协成\异步IO\缓存
协成(Gevent) 协程,又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程.CPU只认识线程. 协程拥有自己的寄存器上下文和栈.协程调度切换时,将 ...
- shell学习(三)
libvirt用于管理KVM本身的工具 virt-install用于安装虚拟机需要的安装包,安装虚拟机 virt-mananger:管理创建删除虚拟机的工具 ---恢复内容开始--- 1 gre ...
- 【LOJ】#2493. 「BJOI2018」染色
题面 题解 推结论大题--然而我推不出什么结论 奇环显然是NO 如果一个联通块里有两个分离的环,也是NO 如果一个联通块里,点数为n,边数为m m <= n的时候,是YES m >= n ...