ARM Ltd.
ARM
ARM_Example
ARMCM3
1.2
ARM 32-bit Cortex-M3 Microcontroller based device, CPU clock up to 80MHz, etc.
ARM Limited (ARM) is supplying this software for use with Cortex-M\n
processor based microcontroller, but can be equally used for other\n
suitable processor architectures. This file can be freely distributed.\n
Modifications to this file shall be clearly marked.\n
\n
THIS SOFTWARE IS PROVIDED "AS IS". NO WARRANTIES, WHETHER EXPRESS, IMPLIED\n
OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF\n
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.\n
ARM SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR\n
CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
CM3
r1p0
little
true
false
3
false
8
32
32
read-write
0x00000000
0xFFFFFFFF
TIMER0
1.0
32 Timer / Counter, counting up or down from different sources
TIMER
0x40010000
32
read-write
0
0x100
registers
TIMER0
Timer 0 interrupt
0
CR
Control Register
0x00
32
read-write
0x00000000
0x1337F7F
EN
Enable
[0:0]
read-write
Disable
Timer is disabled and does not operate
0
Enable
Timer is enabled and can operate
1
RST
Reset Timer
[1:1]
write-only
No_Action
Write as ZERO if necessary
0
Reset_Timer
Reset the Timer
1
CNT
Counting direction
[3:2]
read-write
Count_UP
Timer Counts UO and wraps, if no STOP condition is set
0
Count_DOWN
Timer Counts DOWN and wraps, if no STOP condition is set
1
Toggle
Timer Counts up to MAX, then DOWN to ZERO, if no STOP condition is set
2
MODE
Operation Mode
[6:4]
read-write
Continous
Timer runs continously
0
Single_ZERO_MAX
Timer counts to 0x00 or 0xFFFFFFFF (depending on CNT) and stops
1
Single_MATCH
Timer counts to the Value of MATCH Register and stops
2
Reload_ZERO_MAX
Timer counts to 0x00 or 0xFFFFFFFF (depending on CNT), loads the RELOAD Value and continues
3
Reload_MATCH
Timer counts to the Value of MATCH Register, loads the RELOAD Value and continues
4
PSC
Use Prescaler
[7:7]
read-write
Disabled
Prescaler is not used
0
Enabled
Prescaler is used as divider
1
CNTSRC
Timer / Counter Source Divider
[11:8]
read-write
CAP_SRC
Capture Source is used directly
0
CAP_SRC_div2
Capture Source is divided by 2
1
CAP_SRC_div4
Capture Source is divided by 4
2
CAP_SRC_div8
Capture Source is divided by 8
3
CAP_SRC_div16
Capture Source is divided by 16
4
CAP_SRC_div32
Capture Source is divided by 32
5
CAP_SRC_div64
Capture Source is divided by 64
6
CAP_SRC_div128
Capture Source is divided by 128
7
CAP_SRC_div256
Capture Source is divided by 256
8
CAPSRC
Timer / Counter Capture Source
[15:12]
read-write
CClk
Core Clock
0
GPIOA_0
GPIO A, PIN 0
1
GPIOA_1
GPIO A, PIN 1
2
GPIOA_2
GPIO A, PIN 2
3
GPIOA_3
GPIO A, PIN 3
4
GPIOA_4
GPIO A, PIN 4
5
GPIOA_5
GPIO A, PIN 5
6
GPIOA_6
GPIO A, PIN 6
7
GPIOA_7
GPIO A, PIN 7
8
GPIOB_0
GPIO B, PIN 0
9
GPIOB_1
GPIO B, PIN 1
10
GPIOB_2
GPIO B, PIN 2
11
GPIOB_3
GPIO B, PIN 3
12
GPIOC_0
GPIO C, PIN 0
13
GPIOC_5
GPIO C, PIN 1
14
GPIOC_6
GPIO C, PIN 2
15
CAPEDGE
Capture Edge, select which Edge should result in a counter increment or decrement
[17:16]
read-write
RISING
Only rising edges result in a counter increment or decrement
0
FALLING
Only falling edges result in a counter increment or decrement
1
BOTH
Rising and falling edges result in a counter increment or decrement
2
TRGEXT
Triggers an other Peripheral
[21:20]
read-write
NONE
No Trigger is emitted
0
DMA1
DMA Controller 1 is triggered, dependant on MODE
1
DMA2
DMA Controller 2 is triggered, dependant on MODE
2
UART
UART is triggered, dependant on MODE
3
RELOAD
Select RELOAD Register n to reload Timer on condition
[25:24]
read-write
RELOAD0
Selects Reload Register number 0
0
RELOAD1
Selects Reload Register number 1
1
RELOAD2
Selects Reload Register number 2
2
RELOAD3
Selects Reload Register number 3
3
IDR
Selects, if Reload Register number is incremented, decremented or not modified
[27:26]
read-write
KEEP
Reload Register number does not change automatically
0
INCREMENT
Reload Register number is incremented on each match
1
DECREMENT
Reload Register number is decremented on each match
2
S
Starts and Stops the Timer / Counter
[31:31]
read-write
STOP
Timer / Counter is stopped
0
START
Timer / Counter is started
1
SR
Status Register
0x04
16
read-write
0x00000000
0xD701
RUN
Shows if Timer is running or not
[0:0]
read-only
Stopped
Timer is not running
0
Running
Timer is running
1
MATCH
Shows if the MATCH was hit
[8:8]
read-write
No_Match
The MATCH condition was not hit
0
Match_Hit
The MATCH condition was hit
1
UN
Shows if an underflow occured. This flag is sticky
[9:9]
read-write
No_Underflow
No underflow occured since last clear
0
Underflow
A minimum of one underflow occured since last clear
1
OV
Shows if an overflow occured. This flag is sticky
[10:10]
read-write
No_Overflow
No overflow occured since last clear
0
Overflow_occured
A minimum of one overflow occured since last clear
1
RST
Shows if Timer is in RESET state
[12:12]
read-only
Ready
Timer is not in RESET state and can operate
0
In_Reset
Timer is in RESET state and can not operate
1
RELOAD
Shows the currently active RELOAD Register
[15:14]
read-only
RELOAD0
Reload Register number 0 is active
0
RELOAD1
Reload Register number 1 is active
1
RELOAD2
Reload Register number 2 is active
2
RELOAD3
Reload Register number 3 is active
3
INT
Interrupt Register
0x10
16
read-write
0x00000000
0x0771
EN
Interrupt Enable
[0:0]
read-write
Disabled
Timer does not generate Interrupts
0
Enable
Timer triggers the TIMERn Interrupt
1
MODE
Interrupt Mode, selects on which condition the Timer should generate an Interrupt
[6:4]
read-write
Match
Timer generates an Interrupt when the MATCH condition is hit
0
Underflow
Timer generates an Interrupt when it underflows
1
Overflow
Timer generates an Interrupt when it overflows
2
COUNT
The Counter Register reflects the actual Value of the Timer/Counter
0x20
32
read-write
0x00000000
0xFFFFFFFF
MATCH
The Match Register stores the compare Value for the MATCH condition
0x24
32
read-write
0x00000000
0xFFFFFFFF
PRESCALE_RD
The Prescale Register stores the Value for the prescaler. The cont event gets divided by this value
0x28
32
read-only
0x00000000
0xFFFFFFFF
PRESCALE_WR
The Prescale Register stores the Value for the prescaler. The cont event gets divided by this value
0x28
32
write-only
0x00000000
0xFFFFFFFF
4
4
RELOAD[%s]
The Reload Register stores the Value the COUNT Register gets reloaded on a when a condition was met.
0x50
32
read-write
0x00000000
0xFFFFFFFF
TIMER1
0x40010100
TIMER1
Timer 1 interrupt
4
TIMER2
0x40010200
TIMER2
Timer 2 interrupt
6