You are on page 1of 206

Unit 4

Interrupts and Timer

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 1


r
Unit 4-Interrupts and Timer
• Programming in timer and counter
• Basics of serial communication
• Serial port programming
• Interrupts
– Timer interrupts
– External hardware interrupts
– Serial communication interrupts
• ADC characteristics
ADC programming
• Compare and capture Mode
• PWM Programming
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 2
r
Programming in timer and counter
• EVERY time needs a clock pulse to tick.
• The clock source can be internal or external.
Timer
If use the internal clock source then 1/4th of the frequency
of the crystal oscillator on the OSC pins (Fosc/4) is fed into
the timer. Therefore it is used for time delay generation
and for reason is called timer.
Counter
By choosing the external clock option, we feed pluses
through one of the PIC pins then it is called counter.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 3


r
Basic registers of the timer
• Many of the pic timer are 16bit wide
• Pic 18 consist of four timer
– Timer 0-16bit/8bit
– Timer 1- only 16bit
– Timer2- 8bit
– Timer3 -16bit

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 4


r
Basic registers of the timer
• Pic18 has an 8bit architecture

• Each 16-bit timer is accessed as two separate


register of low bytes TMRXL and high bytes
TMRxH.

• Each timer also has the TCON (timer control)


register for setting modes of operation.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 5


r
Timer0 Register programming
• Timer0 can be used as an 8bit or 16 bit timer.
• The 16 bit register of timer0 is accessed a low
byte and high byte as shown.
• Refer as TMR0H and TMR0L (Special Function
Register )

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 6


r
T0CON (Timer0 control) register
• Each timer has a control register called TCON
• To set the various timer operation modes.
• T0CON is an 8bit register used for control of
timer0.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 7


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 8
r
Example:1
• Find the value for T0CON if we want to program
Timer0 in 16 bit mode, no prescaler.
Use pic18 fosc/4 crystal oscillator for the clock
source, increment on positive – edge.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 9


r
Example: 2
• Find the timer’s clock frequency and its period
for various pic18-based system, with the
following crystal frequency.
• A)10MHZ b) 16MHZ C) 4MHZ

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 10


r
TMR0IF Flag bit
• TMR0IF bit (timer0 interrupt flag) is part of
the INTCON register.
• When timer reaches its maximum value
FFFFH, it rolls over to 0000, and TMR0IF is set
to 1.
INTCON register.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 11


r
Timer0 Overflow Flag

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 12


r
16 bit programming
• The following are the characteristics of 16 bit
mode.
• It is a 16 bit timer: therefore it allows value of
0000 to FFFFH.
• After TMR0H and TMR0L are loaded with a 16bit
internal value, the timer must be started.
• After timer is started, it starts to count up.
• It count up until it reaches its limits of FFFFH.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 13


r
16 bit programming
• When its rolls over from FFFFH to 0000, it sets HIGH a flag bit
called TMR0IF(timer interrupt flag, which is the part of
INTCON register).

• Timer flag can monitored. When this flag is raised, one


option would be to stop the timer.

• After the timer reaches its limits and rolls over, in order to
repeat the process, the registers TMR0H and TMR0L must be
reloaded with the original value.

• And the TMR0IF flag must be reset to 0 for next round.


11/16/2023 19EECN2601-Microprocesor and Microcontrolle 14
r
Step to program TIMER0 in 16 bit mode
To generate a time delay using the timer0 mode 16, the following steps are
taken.

1. load the value into the T0CON register

2. load register TMR0H followed by register TMR0L with initial count values.

3. keep monitoring the timer flag to see if it raised. Get out of the loop when
TMR0IF become high.

4.Clear the TMR0IF flag for next round.

5. Go back to step 2 to load TMR0H and TMR0L again.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 15


r
Timer0 16 bit block diagram

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 16


r
Formula for delay calculation using 16bit
mode with 10Mhz

• Convert hex values of the TMR0H,TMR0L


register to decimal to get NNNNN decimal
number , then
Decimal
• Time delay = (65536-NNNNN)X0.4us
HEX
• TIME DELAY = (FFFF-NNNN+1)X0.4us

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 17


r
Prescaler and generating a large time
delay
• Size of the time delay depends on two factors,
a) Crystal frequency
b) Timer’s register
• Both factors are beyond the control of the
PIC18 programmer.
• Largest time delay is achieved by making both
TMR0H = 0
TMR0L =0

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 18


r
Prescaler and generating a large time
delay
• if that is not enough
• Use prescaler option in the T0CON register to
increase the delay by reducing the period.
• Prescaler option of T0CON allows us to divide
the instruction clock by a factor of 2 to 250.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 19


r
Example:3
• Find the value for T0CON if we want to program
Timer0 in 16bit mode with prescaler of 64 and
use internal clock (Fosc/4) for clock sourse,
postive edge.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 20


r
Example:4
• Find the timer’s clock frequency and its periods
for various PIC18 based system, with the
following crystal frequencies. Assume that
prescaler of 1:64 is used.
• A) 10MHz
• B) 16MHz

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 21


r
8-bit mode programming of Timer0
• Timer 0 can also used in 8 bit mode.
• The 8bit mode allows only values of 00 to FFH to
be loaded into the timer’ register TMRL0.
• After the timer is started, it starts to count up by
incrementing the TMR0l register.
• It counts up until it reaches its limit of FFH
• When it rolls over from FFH to 00, it set high the
TMR0IF.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 22


r
Timer0 8bit block diagram

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 23


r
Timer1 Programming

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 24


r
Timer 1 programming
• Timer1 is the 16 – bit timer
• 16bit register is split into two register
• Referred to as TMR1L and TMR1H
• It does not support 8bit mode.
• It also has timer control register T1CON
• The TMR1IF flag bits goes high when
TMR1L :TMR1H over flows from FFFF to 0000.
• Timer 1 also has prescaler option , but supports
factor of 1:1,1:2,1:4,1:8
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 25
r
Timer1 High and Low Register

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 26


r
Timer1 Block Diagram

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 27


r
T1CON REGISTER

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 28


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 29
r
PIR1 (interrupt control register1)

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 30


r
Counter Programming
• Pic18 to generate time delays
• Timers can also be used as counters to count
events happening outside the pic18
• In couter mode register such as T0CON and
TMR0H and TMR0L are same as the timer.
• T0CS bit in T0CON
• T0CS=1 – counter – pin RA4 provides the clock
pulse
• T0CS=0 – Timer – crystal osillator.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 31
r
Using external crystal for timer 1 clock

• Timer1 has two options when it comes to using the


external clock source.
• 32khz crystal connected to T10SC1 and T1OSC2 pins
in addition to main crystal
• During sleep mode main crystal shut down to save
power.
• The alternate 32khz crystal connected to pins T1OS0
AND T1OS1 provide clock during sleep mode.
• This allows timer to implement an on – chip
RTC(real time clock)
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 32
r
PROGAMMING TIMERS 2
• TIMER2 is an 8bit timer.
• 8 bit timer of timer2 is called TMR2.
• Timer2 also has 8bit register called Period
register.
• We can set the PR2 register to a fixed value and
timer2 register (TMR2) will increment from 00
until it matches the value in PR2.
• At that point, equal signal will raised the
TMR2IF flag and reset TMR2 to 00.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 33
r
PROGAMMING TIMERS 2
• The clock source for timer2 is Fosc/4
• With option prescaler and postscaler
• It cannot be used as counter.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 34


r
Block diagram

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 35


r
PIR1

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 36


r
T2CON REGISTER

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 37


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 38
r
TIMER 3
• TIMER 3 is 16 bit timer/ counter
• It not support 8 bit mode.
• It support CCP MODE Compare capture pulse
width modulation
• Timer3 TMR3IF flag bit goes HIGH when
TMR3H:TMR3L overflows from FFFF to 0000
• The TMR3IF is part of the PIR2 register

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 39


r
T3CON REGISTER

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 40


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 41
r
PIR2

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 42


r
Block diagram

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 43


r
PROGRAMS

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 44


r
• T0CONbits.TMR0ON=1;
OR
• TMR0ON=1;

• INTCONbits.TMR0IF=0;
OR
• TMR0IF=0;

• Similarly for timer 1,2,3


11/16/2023 19EECN2601-Microprocesor and Microcontrolle 45
r
TIMER 0:

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 46


r
Example 5
• Write a c18 program to toggle all the bits of
PORTB continuously with some delay. Use
TIMER0, 16bit mode, and no prescaler options
to generate.
T0CON=0X08
TMR0H=0X00;
TMR0L=0X00;
TMR0ON=1;

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 47


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 48
r
Finding values to be loaded into timer

• Divide the desired time delay by 0.4us


• Perform 65,536-n , where n is the decimal value
we got in step 1
• Convert the result of step2 to hex, where yyxx is
the initial hex value to be loaded into the timer
registers.
• Set TMR0L=xx and TMR0H=yy

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 49


r
Example:6
• Write a c18 program to toggle only the PORTB.4
bit continuously every 50ms. Use timer0, 16- bit
mode, the 1:4 prescaler to create the delay.
Assume XTAL=10MHz.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 50


r
Example:6
• Clk= 10mhz
• 10mhz/4=2.5mhz
• Prescaler = 4
• F= 2.5mhz/4 = 625000hz
• T=1/625000 = 1.6us
Given time delay =50ms
50ms/1.6us = 31250
Therefore TMR1H:TMR1L
Þ65536-31250= 34286= 85EEH (refer slide no 49)
ÞTMR1H=85 and TMR1L=EE
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 51
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 52
r
Example:7
• Write a c18 program to generate a frequency of
250 hz on all bits of PORTC. Use timer0, 16bit
mode and no prescaler to create the frequency.
Assume XTAL =10mhz

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 53


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 54
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 55
r
Example:8
• A switch is connected to pin PORTB.7. write a c18
program to monitor SW and create the following
frequencies on pin PORTB.0.
• SW=0 500HZ
• SW=1 750HZ
• Use timer0 with prescaler for both of them

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 56


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 57
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 58
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 59
r
Example:9
• Write a c18 program to create a frequency of
2500Hz on pin PORTB.1. use timer1 to create
the delay.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 60


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 61
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 62
r
PROGRAMMING OF TIMERS 0 AND
1 AS COUNTERS

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 63


r
Example 10
• Assume that a 1-HZ external clock is being fed
into pin T0CK1(RA4). Write a C18 program for
counter0 in 8bit mode to count up and display
the state of the TMR0L count on PORTB. Start
the count at 00h

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 64


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 65
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 66
r
Example 11
• Write embedded C program for counter0 in 8-bit
mode to display the seconds and minutes on
PORTB and PORTD respectively. Assume the
60mhz external clock is being fed into pinT0CK1
(RA4).

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 67


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 68
r
TIMER 2 PROGRAM

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 69


r
Example:12
• Assuming that XTAL=10MHz, write a C18
program to turn on pin PORTB4 when TMR2
reaches value 100.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 70


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 71
r
Example:13
• Using the prescaler and postscaler, find the
longest time delay that we can create using
timer2

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 72


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 73
r
Example:14
• Assuming that XTAL =10MHz, write a C18
program to turn on pin PORTB4 when TMR2
reaches value 100.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 74


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 75
r
TIMER3 PROGRAM

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 76


r
Example:15
• Write a c18 program to create a frequency of
2500 Hz on pin PORTB1 use timer3 to create the
delay

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 77


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 78
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 79
r
Example:16
• Assume that a 1 HZ external clock is being fed
into pin T3 (RC0). Write a c18 program for
timer3 to be used as counter. It should count the
pluses and display the TMR3H and TMR3L
registers on PORTD and PORTB respectively.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 80


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 81
r
PIC18 SERIAL PORT
PROGRAMMING

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 82


r
Basic of serial communication

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 83


r
Basic of serial communication
• Serial data communication to work, the byte of
data must be converted to serial bits using a
parallel – in serial out shift register, then it can
be transmitted over a single line

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 84


r
Simplex, Half, and Full- Duplex Transfer

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 85


r
Asynchronous serial communication

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 86


r
Data transfer rate
• The rate of data transfer in serial data
communication is stated in bps(bits per second).
Another widely used terminology for bps is baud
rate.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 87


r
RS232 Standards

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 88


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 89
r
9 pin connector

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 90


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 91
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 92
r
PIC 18 Connection to RS232
• RX- RC6
• TX-RC7
– These pins are TTL compatible therefore its required
a line driver to make them RS232 compatible.
– one such line driver is MAX232 chip.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 93


r
Max 232

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 94


r
PIC18- serial port programming
• Pic18 – program to transfer and receive data
using asynchronous mode.
• USART in the PIC18 has both the synchronous and
asynchronous feature.
• Synchronous mode can be used to transfer data
between the PIC and external peripherals such as
ADC and EEPROMs
• Asynchronous mode is used to connect the PIC18
to PC serial port for purpose of full duplex serial
data transfer.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 95
r
UART Register
1. SPBGR- Serial port baud rate generator.
2. TXREG- Transfer register
3. RCREG-Receive register
4. TXSTA-Transmit status and control register
5. RCSTA – Receive status and control register
6. PIR1- Peripheral interrupt request register1

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 96


r
SPBRG register and baud rate
• Computers are so widely used to communicate
with PIC18 system, with serial communication
of Pic18 and COM port of the PC.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 97


r
Baud rates supported by PC
• Some of the baud rates supported by PC
HyperTerminal are

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 98


r
SPBRG register and baud rate

• The baud rates of PIC18 are programmable.


• This done with the help of the 8 bit register called
SPBRG
• For the given crystal frequency, the value loaded
into SPBRG decides the baud rate.
• The relation between the value loaded into
SPBRG and Fosc is given by
• Desired baud rate = Fosc/(64X + 64)
= Fosc/64(X+1)
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 99
r
SPBRG register and baud rate
• Where X is the value we load into the SPBGR
register. Assume that, Fosc=10mhz
• Desired baud rate= Fosc/(4x16)(X+1)
= 10Mhz/64(X+1)
=156250/(X+1)
X= (156250/desired baud rate)-1

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 100


r
SPBRG register and baud rate
• Crystal frequency 10mhz/4= 2.5mhz
= 2.5/16 = 156,250Hz
This number use in SPBRG.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 101


r
Example:17
• With Fosc = 10mhz , find the SPBRG value
needed to have the following baud rate;
• 9600, 4800, 2400,1200

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 102


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 103
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 104
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 105
r
TXREG Register
• TXREG is another 8-bit register used for serial
communication
• For byte of data to be transferred via the Tx pin
• It must be placed in the TXREG register.
• TXREG is a special function register SFR.
• The moment a byte is written into TXREG it is
fetched into a register called TSR (Transmit
shift register).

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 106


r
TXREG Register
• TSR frames the 8bit data with start and stop bits
and 10bit data is transferred serially via
• Tx pin.
• TXREG – Programmable
• TSR- Not Accessible

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 107


r
RCREG register
• Bits are received serially via RX pin the PIC18
deframes them by eliminating start and stop
bits making a byte out of data received and
placed it in the RCREG

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 108


r
TXSTA- Transmit status and control
register
• The TXSTA register is an 8-bit register the
synchronous/ asynchronous modes and data
framing size.
• BRGH bit is used to select a higher speed for
transmission.
• The default is lower baud rate transmission.
• D6- register determines the framing of data by
specifying the number bits per second.
• We use an 8-bit data size.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 109
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 110
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 111
r
RCSTA
• The RCSTA register is an 8bit register used to
enable the send port to receive data among
other things.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 112


r
RCSTA-receive status and control register

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 113


r
PIR1
• Two of the PIR register bits are used by UART
• They are TXIF AND RCIF
• TXIF flag bit to make sure that all the bits of the
last byte are transmitted before we write
another byte into the TXREG.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 114


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 115
r
Programming the PIC18 to transfer data
serially
1. The TXSTA register is loaded with the value
20H, indicating asynchronous mode with 8bit
data frame , low baud rate and transmit enable

CSRC=0 BRGH=0
TX9=0
TXSTA=20H
TXEN=1
TRMT=0
TV9D=0
SYNC=0

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 116


r
Programming the PIC18 to transfer data
serially
2. Make TX pin of PORTC (RC6) an output for data
to come out from the PIC.
3. The SPBRG is loaded with value to set the baud
rate for serial data transfer.
– If baud rate 9600 and crystal = 10MHz
– 10Mhz/2=2.5mhz
– 2.5mhz/16 = 156250 hz (low baud rate)
– X= (156250/baud rate)-1
– (156250/9600)-1=15.27=15=F
– SPBRG=0X0F;
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 117
r
Programming the PIC18 to transfer data
serially

4. SPEN bit in RCSTA register is set HIGH to enable the


serial port of the PIC18.
RCSTA

SPEN=1
5. The character byte to be transmitted serially is
written into the TXREG register.
6. Monitor the TXIF bit of the PIR1 register to make
sure UART is ready for next byte
7. To transfer the next character, go to step 5.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 118
r
Importance of the TXIF flag
1. The byte character to be transmitted is written into the
TXREG register

2. The TXIF flag is set to 1 internally to indicate that TXREG


has a byte and will not accept another data byte until this
one is transmitted

3. The TSR reads the byte from TXREG and begins to transfer
the byte starting with the start bit.

4. The TXIF is cleared to indicate that the last byte is being


transmitted and TXREG is ready to accepts another byte
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 119
r
Importance of the TXIF flag
5. The 8-bit Character is transferred one bit at a
time

6. By monitoring the TXIF , we make sure that not


overloading the TXREG register. If we write
another byte into the TXREG register before
the TSR has fetched the last one, old byte could
be lost before transmitted.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 120


r
Transmitted block

Data bus Tx pin /RC6


8

Pin Buffer
TXREG(8-BIT) and
TSR
control

Interrupt
Baud rate clock
SPEN
TXIF SPBRG

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 121


r
1. The byte character to be transmitted is
written into the TXREG register

Tx pin
TXREG(8-BIT) TSR
Data

TXIF

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 122


r
2. The TXIF flag is set to 1 internally to indicate
that TXREG has a byte

Tx pin
TXREG(8-BIT) TSR
Data (Start bit -8bit data-stop bit)

TXIF =1

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 123


r
3. The TSR reads the byte from TXREG and
begins to transfer the byte starting with the
start bit.

Tx pin
TXREG(8-BIT) TSR
data (Start bit -8bit data-stop bit)

TXIF =1

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 124


r
4. The TXIF is cleared to indicate that the last byte is
being transmitted and TXREG is ready to accepts
another byte

Tx pin
TXREG(8-BIT) TSR
Data empty (Start bit -8bit data-stop bit)

TXIF =0

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 125


r
Programming the PIC18 to receive
data serially
1. The RCSTA register is loaded with the value 90h, to enable the continuous receive in
addition to the 8-bit data size option.

•SPEN=1
•RX9=0
•SREN=0
•CREN=1
•ADDE=0
•FERR=0
•OERR=0
•TXD9=0
RCSTA=90h

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 126


r
Programming the PIC18 to receive data
serially
2. The TXSTA register is loaded with the value 00H
to choose the low baud rate option.

CSRC=0 BRGH=0
TX9=0 TRMT=0
TXEN=0 TV9D=0
SYNC=0
• TXSTA=0;

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 127


r
Programming the PIC18 to receive data
serially
3. SPBRG is loaded with the values to set the
baud rate
– If baud rate 9600 and crystal = 10MHz
– 10Mhz/2=2.5mhz
– 2.5mhz/16 = 156250 hz (low baud rate)
– X= (156250/baud rate)-1
– (156250/9600)-1=15.27=15=F
– SPBRG=0X0F;

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 128


r
Programming the PIC18 to receive data
serially
4. Make the RX pin of PORTC (RC7) an input for
data to come into the PIC18.
5. The RCIF flag bit of the PIR1 register is
monitored for HIGH to see if an entire
character has been received yet.
6. When RCIF is raised the RCREG register has the
byte. Its contents are moved into a safe place
7. To receive the next character, go to step5

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 129


r
Importance of the RCIF flag bit
1. It receives the start bit indicating that the next
bit is the first bit of the character byte
2. The 8-bit character is receive one bit at a time
when the last bit received, a byte is formed and
placed in RCREG.
3. The stop bit is received. It is during receiving the
stop bit that the pic18 makes RCIF=1, indicating
that an entire character byte has been received
and must be picked up before it gets overwritten
by another incoming character
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 130
r
Importance of the RCIF flag bit
4. By checking the RCIF flag bit when it is raised,
we know that character has been received and is
sitting in the RCREG register.
5. Copy the RCREG contents to safe place in some
register or memory before it is lost.
6. After the RCREG contents read into a safe place,
RCIF flag bit forced to 0 by UART itself.
7. This allows the next received character byte to
be placed in RCREG and also prevents the same
byte from being picked up multiples time
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 131
r
PIC18 SERIAL PORT
PROGRAMMING IN C

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 132


r
Example 1
• Write a C program for the PIC18 to transfer the
letter “G” serially at 9600 baud, continuously.
use 8 bit data and stop bit. Assume XTAL
10MHz.
Find the values:
– TXSTA
– SPBRG
– Enable the transmitter - TXEN=1
– Enable Serial port enable bit - SPEN=1

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 133


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 134
r
Example 2
• Write a PIC18 program to transfer the message
“YES” serially at 9600 baud, 8-bit data and 1
stop bit. Do this continuously.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 135


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 136
r
Example 3
• Program the PIC18 in C to receive bytes of data
serially and put them on PORTB. Set the baud
rate at 9600, 8bit data, and 1 stop bit.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 137


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 138
r
Example 4
• Write an c18 program to send two different
strings to the serial port. Assuming that SW is
connected to pin PORTB.5 monitor its status and
make a decision as follows:
• SW=0: send your first name
• SW=1: send your last name
Assume XTAL =10Mhz, baud rate of 9600 and 8bit
data.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 139


r
#include <pic.h>
#define mysw RB0
Void main()
{
Unsigned char z;
Unsigned char fname[]=“MCET”;
Unsigned char lname[]=“POLLACHI”;
TRISB5=1;

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 140


r
TXSTA=0X20H
SPBREG=15;
TXEN=1;
SPEN=1;
if(mysw=1)
{
for(i=0;i<4;i++)
{
TXREG=fname[i];
While(TXIF==0);
}
}
11/16/2023 19EECN2601-Microprocesor and Microcontrolle
r
141
else
{
for(y=0;y<6;y++)
{
TXREG= lname[y];
While(TXIF==0);
}
}

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 142


r
Example 5
• Write a PIC18 C program to send the two
message “Normal speed” and “High speed” to
the serial port. Assuming that SW is connected to
pin PORTB0, monitor its status and set the baud
rate as follows
• SW =0 - 9600 baud rate
• SW=1 - 38400 baud rate
• Assume that XTAL = 10mhz for both cases

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 143


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 144
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 145
r
Low and high speed baud rate -BRGH

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 146


r
INTERRUPT PROGRAMMING IN C

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 147


r
Interrupt
– Timer interrupts
– External hardware interrupts
– Serial communication interrupts

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 148


r
Pic18 interrupts
• A single microcontroller can service several
devices
• There are two methods by devices receive
service from microcontroller
– Interrupt
– Polling

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 149


r
INTERRUPT VS POLLING
• Interrupt
• Whenever any device needs the microcontrollers service the device
notifies it by sending an interrupt signal
• Upon receiving an interrupt signal the microcontroller stops whatever it
is doing and service the device.
• The program associated with the interrupt is called interrupt service
routine (ISR)
• POLLING
• The microcontroller continuously monitors the status of the given
devices: when status condition met performs the service.
• After that it moves on to monitor the next devices until each one
serviced

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 150


r
Interrupt service routine
• Generally in most microcontroller runs the
interrupt service routine.
• For ever interrupt there is a fixed location in
memory that holds the address of its ISR.
• The group of memory locations set aside to hold
the addresses of ISR is called the interrupt vector
table.
• In the case of pic18 there are only two locations
for the interrupt vector table-location 0008 and
0018
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 151
r
Interrupt vector table
• Power on reset : 0000
• High priority interrupt: 0008
• Low priority interrupt : 0018

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 152


r
ADC characteristics
 Analog to digital converter are among the
most widely used device for data acquisition.
 Digital computers use binary values, but in the
physical world everything is analog.
 Temperature, pressure etc of physical
quantities is converted to electrical signals
using a device called a transducer.
 Transducers are also referred as sensors.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 153


r
ADC characteristics

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 154


r
ADC characteristics

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 155


r
ADC characteristics:
Major ADC characteristics:
• Resolution
• Vref.
• Conversion time
• Digital data output
• Start of conversion and end of conversion

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 156


r
Resolution
• ADC has n-bit resolution, where n can be 8,
10,12,16, or even 24 bits.
• The higher-resolution ADC provides a smaller
step size, where step size is the smallest change
that can be discerned by an ADC.
• Although the resolution of an ADC chip is decided
at the time of its design and cannot be changed,
we can control the step size with the help Vref.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 157


r
Conversion Time
• In addition to resolution, conversion time is
another major factor in judging an ADC.

• Conversion time is defined as the time it takes


the ADC to convert the analog input to a digital
(binary) number.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 158


r
Vref
• Vref is an input voltage used for the reference voltage.

• The voltage connected to this pin, along with the


resolution of the ADC chip, dictate the step size.

• For an 8-bit ADC, the step size is Vref/256 because it


is an 8-bit ADC, and 2^8 = 256 steps.

• For example, if the analog input range needs to be 0


to 4 volts, Vref is connected to 4 volts.
• That gives 4 v/256 = 5.62mV for the step size of an 8-bitADC.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 159
r
Step sizes for 8bit ADC

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 160


r
Vref

• For the 10-bit ADC, if the Vref = 5V then the


step size is 4.88 mV.
• In some applications, we need the differential
reference voltage where Vref ->Vref (+) AND
Vref (-).
• Often the Vref (-) pin is connected to ground
and the Vref (+) pin is used as the vref.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 161


r
Step sizes for 10bit ADC

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 162


r
Digital data output
• In an 8-bit ADC have an 8-bit digital data output
of D0-D7 while in the 10-bit ADC the data output
is D0-D9.
• To calculate the output voltage, we use the
following formula:
DOUT = Vin/ Step Size.
• Dout - digital data output (in decimal),
• Vin - analog input voltage,
• Step size (resolution) is the smallest change, which is Vref/ 256 for an 8-bit
ADC.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 163


r
Analog input channels
• Many data acquisition applications need more than one
ADC.
• For this reason, ADC chips with 2,4,8, or even 16
channels on a single chip.
• Multiplexing of analog inputs is widely used as shown in
the ADC848 and MAX1112.
• In these chips, we have 8 channels of analog inputs,
allowing us to monitor multiple quantities such as
temperature, pressure, heat, and so on.
• PIC18 microcontroller chips come with 5 to 15 ADC
channels, depending on the family member.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 164
r
Start of conversion and end-of-
conversion signals
• The fact that have multiple analog input channels and a
single digital output register makes it necessary for
start conversion (SC) and end-of conversion (EOC)
signals.
• When SC is activated, the ADC starts converting the
analog input value of Vin to an n-bit digital number.
• The amount of time it takes to convert varies
depending on the conversion method.
• When the data conversion is complete, the end-of-
conversion signal notifies the CPU that the converted
data is ready to be picked up.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 165
r
Following steps must be followed
for data conversion by an ADC chip

1. Select a channel.
2. Activate the start conversion (SC) signal to start
the conversion of analog input.
3. Keep monitoring the end-of-conversion (EOC)
signal.
4. After the EOC has been activated, Read data out
of the ADC chip.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 166


r
ADC PROGRAMMING in PlC18
• Because the ADC is widely used in data acquisition, in
recent years an increasing number of microcontrollers
have an on-chip ADC peripheral, just like timers and
USART.

• An on-chip ADC eliminates the need for an external


ADC connection, which leaves more pins for other I/O
activities.

• The vast majority of the PIC18 chips come with 8


channels of ADC, and some PIC18s have as many as 16
channels of ADCs.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 167
r
PIC18F452/458
ADC FEATURES PROGRAMMING

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 168


r
Characteristics of PIC18-ADC Peripheral

• It is a 10-bit ADC.

• It can have 5 to 15 channels of analog input channels,


depending on the family member.

• In PIC18452/458, pins RA0-RA7 of PORTA are used for the


8 analog channels.

• The converted output binary data is held by two special


function registers called ADRESL (A/D Result Low) and
ADRESH (A/D Result High).
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 169
r
Characteristics of PIC18-ADC Peripheral

• Because the ADRESH:ADRESL registers give us 16 bits


and the ADC data out is only 10 bits wide, 6 bits of
the 16 are unused.
• We have the option of making either the upper 6 bits
or the lower 6 bits unused
• We have the option of using Vdd (Vcc), the voltage
source of the PIC 18 chip itself, as the Vref or
connecting it to an external voltage source for the
Vref.
• The conversion time is dictated by the Fosc of crystal
frequency connected to the OSCs pins.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 170
r
Characteristics of PIC18-ADC Peripheral

• While the Fosc for PIC18 can be as high as 40 MHz,


the conversion time can not be shorter than 1.6 ms.

• It allows the implementation of the differential Vref


voltage using the Vref+; and Vref(-) pins.

• Many of the above features can be programmed by


way of
– ADCON0 (A/D control register 0)
– ADCON1(A/D control register 1)

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 171


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 172
r
ADCON0 Register
• The ADCON0 register is used to set the conversion time
and select the analog input channel among other things.
• IN order to reduce the power consumption of the PICI8,
the ADC feature is turned off when the microcontroller is
powered up.
– We turn on the ADC with the ADON bit of the ADCONO
register.
• The other important bit is the GO/DONE bit. We use this
bit to start conversion and monitor it to see if conversion
has ended.
• The conversion time is set with the ADCS bits.
– While ADCS1 and ADCS0 are held by the ADCON0 register.
– ADCS2 is part of the ADCON1 register.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 173
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 174
r
ADCON1
• The ADCON1 register is used to select the Vref voltage
among other things.
• After the A/D conversion is complete, the result sits
in registers
– ADRESL (A/D Result Low Byte)
– ADRESH (A/D Result High Byte)
• The ADFM bit of the ADCON1 is used for making it
right justified or left-justified because we need only
10 bits of the 16.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 175


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 176
r
ADRESH:ADRESL

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 177


r
ADC – pins
• The port configuration for A/D channels is handled by the PCFG
(A/D port configuration) bits.

• PIC18452/458, have up to 8 channels of analog input, not all


applications need that many ADC inputs.

• The PORTA pins of RA0-RA3 and RA5 and RE0-RE2 of PORTE are
used for the analog input channels.

• With PCFG:0110, we can use all the pins of the PORTA as the digital
I/O.

• The default is PCFG : 0000, which allows us to use all 8 pins for
analog inputs.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 178
r
ADC-pins
• In that case Vref : Vdd, the same voltage source used by the
PIC18 chip itself.

• In many applications we need Vref other than Vdd.

• The AN3 pin can be used as an external source of voltage for


Vref.

• For example, option PCFG : 0101 allows us to use two channels


for analog inputs, AN3 : Vref, and the other 5 pins for the digital
I/O. In this case the Vss (Gnd) pin of the PICI8 is used for the
Vref (-).

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 179


r
Calculating A/D Conversion Time
• By using the ADCS (A/D clock source) bits of both the
ADCON0 and ADCON1 registers we can set the A/D
conversion time.
• The conversion time is defined in terms of Tad,
– where Tad is the conversion time per bit.
• To calculate the Tad, we can select a conversion clock
source of Fosc/2,Fosc/4, Fosc/8, Fosc/16, Foso/32, or
Fosc/64,
– where Fosc is the speed of the crystal frequency connected to
the PICI8 chip.
• For the PIC18, the conversion time is 12 times the Tad.
Notice that the Tad cannot be faster than 1.6ms.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 180
r
Calculating A/D Conversion Time
• We can also use the internal RC oscillator for the
conversion clock source, instead of the Fosc of
the external crystal oscillator.

• In that case the Tad is typically 4-6us and


conversion time is 12 x 6us :72us.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 181


r
Steps in programming the A/D converter

1. Turn on the ADC module of the PIC18 because it is disabled upon power-on
reset to save power.
2. Make the pin for the selected ADC channel an input pin.
3. Select voltage reference and NC input channels using ADCON0
and ADCON1.
4. Select the conversion speed using ADCON0 and ADCON1.
(Fosc/64, channel0,ADC ON
right justified)
5. Wait for the required acquisition time.
6. Activate the start conversion bit of GO/DONE.
7. Wait for the conversion to be completed by polling the end-of-conversion
(GO/DONE) bit.
8. After the GO/DONE bit has gone LOW read the ADRESL and ADRESH registers to
get the digital data output.
9. Go back to step 5.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 182
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 183
r
CCP MODULE

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 184


r
CCP MODULE
• Depending on the family member, the PIC 18 has
anywhere between 0 and 5 CCP modules inside
it.
• The multiple CCP modules are designated as
CCP1, CCP2, CCP3, and so on (CCPx).
• In recent years, the PWM feature of the CCP has
been enhanced greatly for better DC motor
control.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 185


r
PIC18 usage of Timers
• To program these CCP modules, we must
understand PIC18 timers.
• Depending on the CCP feature used, the timer
usage is different.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 186


r
The CCP registers
1. CCPxCON is an 8-bit control register.
– select one of the compare, capture, and PWM modes
using this register.
2. CCPRXL - the low byte
3. CCPRxH - the high byte of the 16-bit register.
This 16-bit register can be used either as a 16-bit
compare register, or 16-bit capture register, or
an 8-bit duty cycle register by the pwm,

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 187


r
CCP1CON

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 188


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 189
r
Compare mode
• The Compare mode of the CCP module is selected using the select bits in the
CCPxCON register. The Compare mode can cause an event outside the
microcontroller.
• This event can be simply turning on a device connected to the CCP pin, or the start
of an ADC conversion.
• This event is caused when the content of the Timer1 (or Timer3) register is equal to
the 16-bit CCPRIH:CCPRIL register.
• To use the compare mode of the CCP, we must load both the 16-bit (CCPIH:CCPIL)
and the Timer1 (or Timer3) register with some initial values.
• As Timer1 (orTimer3) counts up, its value is constantly compared with the
CCPR1H:CCPRIL register and when a match occurs, the CCP 1 pin can perform one
of the following actions:
• (a) Drive high the CCP1 pin
• (b) Drive low the CCP1 pin
• (c) Toggle the CCP1 pin
• (d) Remain unaffected
• (e) Trigger a special event with a hardware interrupt and clear the timer
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 190
r
Capture mode
• We select Capture mode with the bit selection in the CCPICON register.
• In Capture mode, an event at the CCP pin will cause the contents of the
Timer1 (or Timer3) register to be loaded into the 16-bit CCPRIH:CCPRIL
register.
• That means, for the Capture mode to work, the CCP pin must be configured
as an input pin.
• The event that causes the contents of Timer1 (or Timer 3) to be captured
into the CCPRIH:CCPRIL register can be a High-to-Low (falling-edge) pulse or
Low to High (rising-edge) pulse. As far as the edge-triggering pulse is
concerned, we have the following four options to choose from:
(a) every falling-edge pulse
(b) every rising-edge pulse
(c) every fourth rising-edge pulse
(d) every l6th rising-edge pulse

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 191


r
PWM PROGRAMMING
• Another feature of CCP is pulse width modulation
(PWM).
• The PWM feature allows us to create pulses with
variable widths.
• PWM is widely used in industrial controls such as DC
motor controls.
• Indeed the PWM is so widely used that Microchip
has enhanced the PWM capabilities of the newer
generation of the PIC 18 family members and has
designated them as ECCP (enhanced CCP).
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 192
r
• In creating pulses with variable widths for the
• PWM, two factors are important:
– The period of the pulse
– its duty cycle.
• The duty cycle (DC) is the portion of the pulse that
stays HIGH relative to the entire period.
• Very often the DC is stated in the form of
percentages.
• For example, a pulse with a 4 ms period that stays
HIGH for 1ms has DC of 25% (1ms / 4 ms – 25%),
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 193
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 194
r
The period of PWM
• The CCP module uses Timer2 and its associated register, PR2,
for the PWM time-base, which means that the frequency of
the PWM is a fraction of the Fosc, the crystal frequency. It
uses the PR2 register to set the PWM period as follows:
– Tpwm : [(PR2) + 1 ] 4 x N x Tosc
• where Tosc is the inverse of 1/Fosc, the crystal frequency
• Tpwm is the desired PWM period
• N is the prescaler of 1 ,4, or 16 set by the Timer2 control register (T2CON).
• Therefore, we can get the value for the PR2 register as
follows:
– PR2 =[Fosc / (Fpwm x 4 x N)] - 1

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 195


r
The duty cycle of PWM
• As stated earlier, the duty cycle of PWM is the portion
of the pulse that stays HIGH relative to the entire
period.
• To set the duty cycle, the CCP module uses the 10-bit
register of DC1B9:DC1B0. The 10-bit register of
DC1B9:DC1B0 is formed from 8 bits of CCPRIL and 2
bits from the CCPICON register, where CCPRIL is the
upper 8 bits and DCIB2:DClBl of the CCPICON are the
lower 2 bits of the 10-bit register.
• In reality, CCPRL1 is the main register for the duty cycle
and the lower 2 bits of DC1B2:DC1B1
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 196
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 197
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 198
r
Steps in programming PWM
The following steps are taken to program the PWM feature of
the CCP module:
1. Set the PWM period by writing to the PR2 register.
2. Set the PWM duty cycle by writing to CCPRIL for the higher
8 bits.
3. Set the CCP pin as an output
4. Using theT2CON register, set the prescale value.
5. Clear the TMR2 register.
6. Configure the CCPICON register for PWM and set
DCIB2:DC1B1 bits for the decimal portion of the duty cycle.
7. Start Timer2.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 199
r
• The role of CCPRIH in the process of creating the duty cycle must be noted.
• A copy of the duty cycle value in register CCPRIL is given to CCPRIH as soon
as we start Timer2.
• Timer2 goes through the following stages in creating the PWM:
(a) The CCPRIL is loaded into CCPRIH and the CCP1 pin goes HIGH to start the
beginning of the period.
(b) As TMR2 counts up, the TMR2 value is compared with both the CCPRIH and
PR2 registers.
(c) When the TMR2 and CCPR1H (which is the same as CCPR1L) values are
equal, the CCP pin is forced low. That ends the duty cycle portion of the
period.
(d) The TMR2 keeps counting up until its value mqtches the PR2. At that point,
the CCP pin goes high, indicating the end of one period and the beginning

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 200


r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 201
r
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 202
r
PWM PERIOD
The PWM output pulse period (T) depends on
the value stored in the PR2 register of the
Timer2. It is calculated by means of the following
equation,
PWM Period = (PR2 +1) * 4Tosc * TMR2 Prescale Value
If the PWM period (T) is known, it is easy to
calculate signal frequency (F) because these two
values are related by equation F=1/T.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 203


r
PWM PULSE WIDTH:
The PWM pulse width is determined by means of 10 bits in
total: all bits (eight in total) of the CCPR1L register as MSBs
and two bits of the CCP1CON register as LSBs (DC1B1 and
DC1B0) The result is a 10-bit number contained in the
formula,
Pulse Width = (CCPR1L, DC1B1, DC1B0) * Tosc * TMR2 Prescale Value

The output pin will be constantly set if the pulse width is by


negligence set to be larger than PWM period. In this case, the
Timer2 postscaler cannot be used for generating long PWM
periods.

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 204


r
PWM SIGNAL RESOLUTION:
• A PWM signal is nothing more than a pulse sequence
with a varying duty cycle. For one specific frequency
(number of pulses per second), there is a limited number of
duty cycle combinations.
• Resolution is a maximum number of duty cycle
combinations measured in bits. For example, a 10-bit
resolution will result in 1024 discrete duty cycles, whereas
an 8-bit resolution will result in 256 discrete duty cycles
etc.
• As for this microcontroller, the resolution depends on
the contents of the PR2 register. The maximum resolution is
obtained by writing number FFh to this register.
11/16/2023 19EECN2601-Microprocesor and Microcontrolle 205
r
#include<pic.h>
void InitPWM();
void SetPWMDutyCycle(unsigned int DutyCycle);
void main()
{
InitPWM();
SetPWMDutyCycle(513); //50% duty cycle
}

void InitPWM()
{
TRISC2 = 0; // Make CCP1 pin as output
CCP1CON = 0x0C; // Configure CCP1 module in PWM mode

PR2 = 0xFF; // Configure the Timer2 period


T2CON = 0x01; // Set Prescaler to be 4, hence PWM frequency is set to 2.44KHz.

SetPWMDutyCycle(0); // Intialize the PWM to 0 duty cycle

T2CON |= 0x04; // Enable the Timer2, hence enable the PWM.


}

void SetPWMDutyCycle(unsigned int DutyCycle) // Give a value in between 0 and 1024 for DutyCycle
{
CCPR1L = DutyCycle>>2; // Put MSB 8 bits in CCPR1L
CCP1CON &= 0xCF; // Make bit4 and 5 zero
CCP1CON |= (0x30&(DutyCycle<<4)); // Assign Last 2 LSBs to CCP1CON
}

11/16/2023 19EECN2601-Microprocesor and Microcontrolle 206


r

You might also like