Download presentation
Presentation is loading. Please wait.
1
5-1 Timer/Counters In many microprocessor systems we need to: count logic pulses measure the frequency of signals measure the period of pulses generate pulses of specific periods time events generate delays accurately We can use Timer/Counters for all the above
2
5-2 Binary Counters n-bit Counter Overflow bit Clock signal Counter increments by one for every clock pulse Counter can be pre-loaded with a starting value This bit is set to one when the binary counter rolls over from all 1's back to 0's (Can be reset to zero by software)
3
5-3 Timer/Counters The clock source can be a fixed known frequency usually the cpu clock or some fraction of it An external signal – connected to an external pin. This allows the counting of pulses Some systems connect the overflow bit via a flip-flop to an output pin which is toggled every time an overflow occurs. Used for waveform generation (PWM). The overflow flag can be polled or used to generate an interrupt to the CPU.
4
5-4 PIC 18F452 Timer0 – 8 bit mode
5
5-5 PIC 18F452 Timer0 – 16 bit mode Note: Upon RESET, Timer0 is enabled in 8-bit mode with clock input from T0CKI max. prescale.
6
5-6 T0CON – Timer 0 Control register
7
5-7 To generate a fixed delay Configure T0CON timer mode 8 or 16 bit prescaler Load TMR0 with vale to give correct time delay NOTE: - High byte first then low byte Clear TMR0IF to zero (Bit 2 of INTCON register) Start timer by setting TMR0ON (bit 7 of T0CON) Poll TMR0IF – wait until bit is set. Alternatively use interrupts (a future lecture topic).
8
5-8 To measure a time period Configure T0CON timer mode 8 or 16 bit prescaler Clear TMR0 - High byte first then low byte Clear TMR0IF to zero (may not be required) When the event starts Start timer by setting TMR0ON (bit 7 of T0CON) When the event is over Stop the timer by clearing TMR0ON Read the value from TMR0 (Read low byte first!)
9
5-9 A 100ms delay CPU Clock frequency f osc = 4MHz, Timer input clock frequency = 4MHz /4 = 1MHz so period = 1us Max count for 16-bit TMR0 = 2^16 = 65536 counts So max timer period = 65536 x 1us =65.536ms Need to use prescaler Prescaler Resolution Max period 22us65536x2us = 131.072ms 44us262.144ms etc. 256256uS16.777216 seconds
10
5-10 Cont. So need prescaler set to 2. Timer input period = 2x1us = 2us Number of counts = time period/timer input period = 100ms/2us = 100000/2 = 50000 Value to load into timer = 65536 – 50000 = 15536 movlwhigh(15536) movwfTMR0H movwflow(15536) movwfTMR0L bcfINTCON,TMR0IF
11
5-11 Measure a time period ;Initialise timer 0 movlw 0x03 ;Prescaler = 16, so increment timer every 16us movwf T0CON ; with 4MHz Osc ;reset timer registers to zero clrf TMR0H ;notice order:high then low byte clrf TMR0L ; The event start is detected so start timer bsf T0CON,TMR0ON ; Wait for the event to end ; The event is over so stop timer bcf T0CON,TMR0ON ;Calc time taken movff TMR0L,TIML ;Note order of reading - Low then high byte movff TMR0H,TIMH
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.