PIC 16F877A
S. PARTHIBAN, M. TECH.
11/1/2013
What is PIC?
The term PIC or Peripheral Interface Controller, has been coined by Microchip Technology Inc. Low-end range, mid-range and high end range of controllers.
S. PARTHIBAN, M. TECH.
11/1/2013
PIC Architecture: Background
Were used to the Von-Neuman Architecture
Used in: 80X86 (PCs), 8051, 68HC11, etc.) Only one bus between CPU and memory RAM and program memory share the same bus and the same memory, and so must have the same bit width Bottleneck: Getting instructions interferes with accessing RAM
Memory
CPU
8
(& Data)
S. PARTHIBAN, M. TECH.
11/1/2013
PIC Architecture: Background
PICs use the Harvard Architecture Used mostly in RISC CPUs (well get there) Separate program bus and data bus: can be different widths! For example, PICs use: Data memory (RAM): a small number of 8bit registers Program memory (ROM): 12bit, 14bit or 16bit wide (in EPROM, FLASH, or ROM)
Memory (Data)
Memory
CPU
8
12 14 16
(Program)
S. PARTHIBAN, M. TECH.
11/1/2013
CISC
Traditionally, CPUs are CISC Complex Instruction Set Computer (CISC) Used in: 80X86, 8051, 68HC11, etc. Many instructions (usually > 100) Many, many addressing modes Usually takes more than 1 internal clock cycle (T cycle) to execute Example:
MC68HC05: LDAA 0x55
1000 1100
2 bytes, 2 cycles
01010101 5 S. PARTHIBAN, M. TECH. 11/1/2013
RISC
PICs and most Harvard chips are RISC Reduced Instruction Set Computer (RISC) Used in: SPARC, ALPHA, Atmel AVR, etc. Few instructions (usually < 50) Only a few addressing modes Executes 1 instruction in 1 internal clock cycle (Tcyc) Example:
PIC16CXXX: MOVLW 0x55
1100XX 01010101
1 word, 1 cycle
6 S. PARTHIBAN, M. TECH. 11/1/2013
What is New in PIC?
High performance RISC CPU with 35 no. of instruction set only Harvard Architecture Pipelined Instructions And a large number of Peripherals In-built
S. PARTHIBAN, M. TECH.
11/1/2013
Pin Diagram
S. PARTHIBAN, M. TECH.
11/1/2013
Features
8kB of flash program memory 368bytes of Data memory 256-EEPROM data memory 15 Interrupts In-circuit programming 3 internal hardware timers
S. PARTHIBAN, M. TECH.
Capture/Compare/PW M modules Up to 8 channels of 10Bit A/D Built-in USART for serial communication 5 digital I/O ports (Up to 22 lines)
11/1/2013
I/O Ports
PIC 16F877A has FIVE I/O Ports A total of 33 pins are used for I/O operations.
PORT A
Port A is 6 bit wide and bi-directional. Its corresponding data direction register is TRISA. If TRISA port pin is set to 1,corresponding port A pin will act as an input pin and vice versa. Port A is used for analog inputs.
10
S. PARTHIBAN, M. TECH.
11/1/2013
Port B
Port B is 8 bit wide and bi-directional. Its corresponding data direction register is TRISB. If TRISB port pin is set to 1,corresponding port B pin will act as an input pin and vice versa. Port B is used for Data Transmission.
11
S. PARTHIBAN, M. TECH.
11/1/2013
Port C
Port C is 8 bit wide and bi-directional. Its corresponding data direction register is TRISC. If TRISC port pin is set to 1,corresponding port C pin will act as an input pin and vice versa. Port C is used for control registers(serial communication, I2C functions,serial data transfer).
12
S. PARTHIBAN, M. TECH.
11/1/2013
Port D
Port D is 8 bit wide and bi-directional. Its corresponding data direction register is TRISD. If TRISD port pin is set to 1,corresponding port D pin will act as an input pin and vice versa. Port D is used as Data port
13
S. PARTHIBAN, M. TECH.
11/1/2013
Port E
Port E is 3 bit wide . They are for read, write and chip select operation. Each pin is individually configurable as inputs and outputs. Port E is generally used for controlling purposes.
14
S. PARTHIBAN, M. TECH.
11/1/2013
Machine Cycle
4 cycles per4 cycles per instruction on the PIC16F87x micro controllers. instruction on the PIC16F87x micro controllers. T1 T2 T3 T4
Clock Read Instruction
Decode Instruction
Execute Instruction
Store Result
Oscillator circuits generate a clock signal.
15 S. PARTHIBAN, M. TECH. 11/1/2013
Calculations
A Machine cycle is the time taken for a data transfer from or to memory/ I/O Ports. Machine cycle is calculated using the formula: Clock Frequency=6.144MHz Machine cycle frequency= 6.144 MHz /4 Hence 1 Machine cycle(Time taken for a data transfer)= 1/T = 4/ 6.144 MHz = 0.651 s
16
S. PARTHIBAN, M. TECH.
11/1/2013
Instruction Cycle
An instruction cycle is the time taken to complete an instruction.
All instructions in 16F877A are single cycle instructions except for Branching instruction. They take two machine cycles to complete an instruction.
17
S. PARTHIBAN, M. TECH.
11/1/2013
PIC overview
Different PICs have different on-board peripherals some common peripherals are: 3 Timers (0 & 2- 8bits, 1-16 bits) 2 Compare/Capture/PWM Modules Analog to Digital Converters (ADC) (8, 10 and 12bit, 50ksps) 2 Serial communications: UART (RS-232C), SPI, I C, CAN Pulse Width Modulation (PWM) (10bit) Voltage Comparators Voltage Reference Modules MSSP Master Synchronous Serial Port I2C (Master and Slave) SPI (Master and Slave) Watchdog timers, Brown out detect, LCD drivers 11/1/2013 S. PARTHIBAN, M. TECH.
18
Overview
Instructions Memory Organisation
19
S. PARTHIBAN, M. TECH.
11/1/2013
20
S. PARTHIBAN, M. TECH.
11/1/2013
Data Memory Organisation
The data memory partitioned into General Purpose registers and Special Function Registers. Bits RP1 and RP0 are the bank select bits. RP1 RP0 Bank 0 0 0 0 1 1 1 0 2 1 1 3
21
S. PARTHIBAN, M. TECH.
11/1/2013
22
S. PARTHIBAN, M. TECH.
11/1/2013
Timers
PIC16F877A has 3 Timers
Timer 0 - 8 bit
can be used as a Timer/counter
Timer 1 16 bit can be used as a Timer/counter Timer 2 8 bit Timer can be used as the PWM time-base for the PWM mode of the CCP module.
23
S. PARTHIBAN, M. TECH.
11/1/2013
24
S. PARTHIBAN, M. TECH.
11/1/2013
Timer 1
The data registers of Timer 1 are TMR1H and TMR1L. The 16 bit value to be loaded in the timer is given to Data registers The Control register is T1CON. The timer ON and oscillator enable operations are controlled through the control register. To determine if the timer has completed its operation, the timer overflow bit TMR1IF of the PIR1 register is checked continuously.
25
S. PARTHIBAN, M. TECH.
11/1/2013
USART
Universal synchronous asynchronous receiver transmitter is also known as a serial communication interface. USART can be configured in the following modes: Asynchronous - FULL DUPLEX synchronous - HALF DUPLEX
26
S. PARTHIBAN, M. TECH.
11/1/2013
Serial Communication
For serial Communication, the SFR involved are TXSTA, TXREG, RCSTA,,RCREG and SPBRG. SPBRG is used to set the required baud rate. In TXSTA,TXEN is set high to enable transmission. The transmitted data is stored in a temporary buffer,TXREG. In RCSTA, SPEN and CREN are set high to enable reception. The received data is stored in a temporary buffer, RCREG.
S. PARTHIBAN, M. TECH. 11/1/2013
27
28
S. PARTHIBAN, M. TECH.
11/1/2013
29
S. PARTHIBAN, M. TECH.
11/1/2013
30
S. PARTHIBAN, M. TECH.
11/1/2013
FOR BAUD RATE: For asynchronous mode, Baud rate=Fosc / 64(x+1) For synchronous mode, Baud rate=Fosc / 4(x+1) FOR RECEPTION: Check RCIF flag till it is set. This indicates that the data is completely received in the RCREG. Move this value to working register for further manipulation. FOR TRANSMISSION: To transmit the calculated data, move the value to TXREG. Check the TXIF flag till it is set. This indicates that the data is completely transmitted out.
31 S. PARTHIBAN, M. TECH. 11/1/2013
32 S. PARTHIBAN, M. TECH.
11/1/2013
Interrupts
PIC16F877A has 15 sources of interrupts. Only one vector location is allocated for the interrupts. The Global interrupt enable bit is set, so that any interrupt can be acknowledged. Regardless of the Global enable bit, the user should ensure,the appropriate interrupt flag bits that needs to be executed, is also set.
33
S. PARTHIBAN, M. TECH.
11/1/2013
34
S. PARTHIBAN, M. TECH.
11/1/2013
Thank You
35
S. PARTHIBAN, M. TECH.
11/1/2013