UPC EETAC Bachelor's Degree in Telecommunications Systems and in Network Engineering EEL

L12.1

Lecture 2

L12.2: Timer/counter embedded peripherals. TMR0/TMR2

[P12] Peripherals: TMR0/TMR2 as a time-base for timing applications.

L12.3

[17/12]

3.8. Peripherals: TMR0 timer/counter and TMR2 timer

3.8.1. TMR0 hardware circuit and configuration registers

Peripheral hardware and configuration bits and registers: CLK edge, CLK source, prescaler selection, TMR0 in 8-bit or 16 bit mode, hardware interrupt flag TMR0IF and software variable var_TMR0_flag at the ISR().

Design equation for timing periods TP using TMR0.

Using the TMR0 as a counter of external pulses

 

3.8.2. TMR2 hardware circuit and configuration registers

Design equation for timing periods TP using TMR2.

Explain why there is TP inaccuracy when using TMR0. How to solve it? What is the main advantage of replacing TMR0 by TMR2?

 

3.8.3. Examples

3.8.3.1. Serial transmitter with TMR0 (P12) {s_trans_LCD_TMR0} (design phase#3)

Timer using an internal peripheral TMR0 to generate the time-base var_CLK_flag. Let us discuss how the functionality assigned to the counter and the time base circuits in the datapath can be covered by the peripheral TMR0 embedded in the μC. TMR0 replaces the previous time-base (external CLK interrupt INT0).

Study the hardware-software diagram of the timer: Prescaler (N1), counter (N2), (software) postscaler (N3)

How to increase counting capacity? Software variables like var_Postscaler (N3).

 

3.8.3.2. Serial transmitter with TMR2 {s_trans_LCD_TMR2} (design phase#4)

 

3.8.3.3.Timer_LCD_TMR0 (design phase#3). Circuit developed and tested in Lab11.

Discusion on limitations of TMR0. References. More topics related to hardware timers: timer overhead, run-time overhead.

 

3.8.3.2.Timer_LCD_TMR2 (design phase#4)

 


Exercise: Use the TMR1 for counting external events (for example falling edges from a given sensor).