

# The PIC Family: Speed

- Can use crystals, clock oscillators, or even an RC circuit.
- Some PICs have a built in 4MHz RC clock, Not very accurate, but requires no external components!
- **Instruction speed = 1/4 clock speed (Tcyc = 4 \* Tclk)**
- All PICs can be run from DC to their maximum specified speed:

|                 |       |
|-----------------|-------|
| 12C50x          | 4MHz  |
| 12C67x          | 10MHz |
| 16Cxxx          | 20MHz |
| 17C4x / 17C7xxx | 33MHz |
| 18Cxxx          | 40MHz |

# PIC 16F877 Pin IN/Out

- The chip can be obtained in different packages, such as conventional 40-pin DIP (Dual In-Line Package), square surface mount or socket format.
- Most of the pins are for input and output, and arranged as 5 ports: port A (5 pins), port B(8), C(8), D(8) and E(3), giving a total of 32 I/O pins.
  - These can all operate as simple digital I/O pins, but most have more than one function.
  - The mode of operation of each is selected by initializing various control registers within the chip.
  - Note, in particular, that Ports A and E become ANALOGUE INPUTS by default (on power up or reset), so they have to set up for digital I/O if required.

## PIC 16F877 Pin IN/Out – cont.

- Port B is used for downloading the program to the chip flash ROM (RB6 and RB7), and RB0 and RB4–RB7 can generate an interrupt.
- Port C gives access to timers and serial ports.
- Port D can be used as a slave port, with Port E providing the control pins for this function.

- There are 512 RAM File Register addresses (0–1FFh), which are organized in 4 banks (0–3), each bank containing 128 addresses.
- The default (selected on power up) is Bank 0 which is numbered from 0 to 7Fh, Bank 1 from 80h to FFh and so on.
- These contain both Special Function Registers (SFRs), which have a dedicated purpose, and the General Purpose Registers (GPRs).

| File Address                      | File Address                      | File Address                      | File Address                      |
|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|
| Indirect addr.(*) 00h             | Indirect addr.(*) 80h             | Indirect addr.(*) 100h            | Indirect addr.(*) 180h            |
| TMRO                              | OPTION_REG                        | TMRO                              | OPTION_REG                        |
| PCL                               | PCL                               | PCL                               | PCL                               |
| STATUS                            | STATUS                            | STATUS                            | STATUS                            |
| FSR                               | FSR                               | FSR                               | FSR                               |
| PORTA                             | TRISA                             | PORTB                             | TRISB                             |
| PORTB                             | TRISB                             | PORTB                             | TRISB                             |
| PORTC                             | TRISC                             | PORTB                             | TRISB                             |
| PORTD <sup>(1)</sup>              | TRISD <sup>(1)</sup>              | PORTB                             | TRISB                             |
| PORTE <sup>(1)</sup>              | TRISE <sup>(1)</sup>              | PORTB                             | TRISB                             |
| PCLATH                            | PCLATH                            | PCLATH                            | PCLATH                            |
| INTCON                            | INTCON                            | INTCON                            | INTCON                            |
| PIR1                              | PIE1                              | EEDATA                            | EECON1                            |
| PIR2                              | PIE2                              | EEADR                             | EECON2                            |
| TMR1L                             | PCON                              | EEDATH                            | Reserved <sup>(2)</sup>           |
| TMR1H                             | PCON                              | EEADRH                            | Reserved <sup>(2)</sup>           |
| T1CON                             |                                   |                                   |                                   |
| TMR2                              | SSPCON2                           | General Purpose Register 16 Bytes | General Purpose Register 16 Bytes |
| T2CON                             | PR2                               | 110h                              | 190h                              |
| SSPBUF                            | SSPADD                            | 111h                              | 191h                              |
| SSPCON                            | SSPSTAT                           | 112h                              | 192h                              |
| CCPR1L                            |                                   | 113h                              | 193h                              |
| CCPR1H                            |                                   | 114h                              | 194h                              |
| CCP1CON                           |                                   | 115h                              | 195h                              |
| RCSTA                             | TXSTA                             | 116h                              | 196h                              |
| TXREG                             | SPBRG                             | 117h                              | 197h                              |
| RCREG                             |                                   | 118h                              | 198h                              |
| CCPR2L                            |                                   | 119h                              | 199h                              |
| CCPR2H                            |                                   | 11Ah                              | 19Ah                              |
| CCP2CON                           |                                   | 11Bh                              | 19Bh                              |
| ADRESH                            | ADRESL                            | 11Ch                              | 19Ch                              |
| ADCNO0                            | ADCON1                            | 11Dh                              | 19Dh                              |
|                                   |                                   | 11Eh                              | 19Eh                              |
|                                   |                                   | 11Fh                              | 19Fh                              |
|                                   |                                   | 120h                              | 1A0h                              |
| General Purpose Register 96 Bytes | General Purpose Register 80 Bytes | General Purpose Register 80 Bytes | General Purpose Register 80 Bytes |
| 9Fh                               | EFh                               | 16Fh                              | 1EEh                              |
|                                   | F0h                               | 170h                              | 1F0h                              |
|                                   | FFh                               | 17Fh                              | 1FFh                              |
| Bank 0                            | 7Fh                               | Bank 1                            |                                   |
|                                   |                                   |                                   |                                   |
|                                   | accesses 70h-7Fh                  | accesses 70h-7Fh                  | accesses 70h - 7Fh                |
|                                   |                                   |                                   |                                   |

Unimplemented data memory locations, read as '0'.  
\* Not a physical register.  
**Note 1:** These registers are not implemented on the PIC16F876.  
**Note 2:** These registers are reserved, maintain these registers clear.

## Indirect Addressing:

- Full 8 bit register address is written the special function register FSR
- INDF is used to get the content of the address pointed by FSR
- Exp : A sample program to clear RAM locations H'20' – H'2F:

```
MOVLW 0x20 ;initialize pointer  
MOVWF FSR ;to RAM  
NEXT CLRF INDF ;clear INDF register  
INCF FSR,F ;inc pointer  
BTFS FSR,4 ;all done?  
GOTO NEXT ;no clear next  
CONTINUE  
;;
```

b:  
t  
L  
+  
0010 0000 -> 0011 0000

# PIC Family Control Registers

- Uses a series of “Special Function Registers” for controlling peripherals and PIC behaviors.

□ **STATUS** → Bank select bits, ALU bits (zero, borrow, carry)

□ **INTCON** → Interrupt control: interrupt enables, flags, etc.

□ **OPTION\_REG** → contains various control bits to  
configure the TMR0 prescaler/WDT postscaler ,the  
External INT Interrupt, TMR0 and the weak pull-  
ups on PORTB

# Special Function Register

## “STATUS Register”

|       | R/W-0 | R/W-0 | R/W-0 | R-1 | R-1 | R/W-x | R/W-x | R/W-x |
|-------|-------|-------|-------|-----|-----|-------|-------|-------|
|       | IRP   | RP1   | RP0   | TO  | PD  | z     | DC    | C     |
| bit 7 |       |       |       |     |     |       |       | bit 0 |

bit 7      IRP: Register Bank Select bit (used for indirect addressing)  
 1 = Bank 2, 3 (100h - 1FFh)  
 0 = Bank 0, 1 (00h - FFh)

bit 6-5      RP1:RP0: Register Bank Select bits (used for direct addressing)  
 11 = Bank 3 (180h - 1FFh)  
 10 = Bank 2 (100h - 17Fh)  
 01 = Bank 1 (80h - FFh)  
 00 = Bank 0 (00h - 7Fh)  
 Each bank is 128 bytes

bit 4      TO: Time-out bit  
 1 = After power-up, CLRWDT instruction, or SLEEP instruction  
 0 = A WDT time-out occurred

bit 3      PD: Power-down bit  
 1 = After power-up or by the CLRWDT instruction  
 0 = By execution of the SLEEP instruction

bit 2      Z: Zero bit  
 1 = The result of an arithmetic or logic operation is zero  
 0 = The result of an arithmetic or logic operation is not zero

bit 1      DC: Digit carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)  
 (for borrow, the polarity is reversed)  
 1 = A carry-out from the 4th low order bit of the result occurred  
 0 = No carry-out from the 4th low order bit of the result

bit 0      C: Carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)  
 1 = A carry-out from the Most Significant bit of the result occurred  
 0 = No carry-out from the Most Significant bit of the result occurred

**Note:** For borrow, the polarity is reversed. A subtraction is executed by adding the two's complement of the second operand. For rotate (RRF, RLF) instructions, this bit is loaded with either the high, or low order bit of the source register.

|                    |                  |                                    |                    |
|--------------------|------------------|------------------------------------|--------------------|
| Legend:            |                  |                                    |                    |
| R = Readable bit   | W = Writable bit | U = Unimplemented bit, read as '0' |                    |
| - n = Value at POR | '1' = Bit is set | '0' = Bit is cleared               | x = Bit is unknown |

# Special Function Register

## “INTCON Register”

|       | R/W-0 | R/W-0 | R/W-0  | R/W-0 | R/W-0 | R/W-0  | R/W-0 | R/W-X |
|-------|-------|-------|--------|-------|-------|--------|-------|-------|
|       | GIE   | PEIE  | TMROIE | INTE  | RBIE  | TMROIF | INTF  | RBIF  |
| bit 7 |       |       |        |       |       |        |       |       |
| bit 6 |       |       |        |       |       |        |       |       |
| bit 5 |       |       |        |       |       |        |       |       |
| bit 4 |       |       |        |       |       |        |       |       |
| bit 3 |       |       |        |       |       |        |       |       |
| bit 2 |       |       |        |       |       |        |       |       |
| bit 1 |       |       |        |       |       |        |       |       |
| bit 0 |       |       |        |       |       |        |       |       |

bit 7      **GIE: Global Interrupt Enable bit**  
           1 = Enables all unmasked interrupts  
           0 = Disables all interrupts

bit 6      **PEIE: Peripheral Interrupt Enable bit**  
           1 = Enables all unmasked peripheral interrupts  
           0 = Disables all peripheral interrupts

bit 5      **TMROIE: TMRO Overflow Interrupt Enable bit**  
           1 = Enables the TMRO interrupt  
           0 = Disables the TMRO interrupt

bit 4      **INTE: RB0/INT External Interrupt Enable bit**  
           1 = Enables the RB0/INT external interrupt  
           0 = Disables the RB0/INT external interrupt

bit 3      **RBIE: RB Port Change Interrupt Enable bit**  
           1 = Enables the RB port change interrupt  
           0 = Disables the RB port change interrupt

bit 2      **TMROIF: TMRO Overflow Interrupt Flag bit**  
           1 = TMRO register has overflowed (must be cleared in software)  
           0 = TMRO register did not overflow

bit 1      **INTF: RB0/INT External Interrupt Flag bit**  
           1 = The RB0/INT external interrupt occurred (must be cleared in software)  
           0 = The RB0/INT external interrupt did not occur

bit 0      **RBIF: RB Port Change Interrupt Flag bit**  
           1 = At least one of the RB7:RB4 pins changed state; a mismatch condition will continue to set the bit. Reading PORTB will end the mismatch condition and allow the bit to be cleared (must be cleared in software).  
           0 = None of the RB7:RB4 pins have changed state

We should write this      MOVF PORTB, F

Legend:  
   R = Readable bit      W = Writable bit      U = Unimplemented bit, read as '0'  
   - n = Value at POR      '1' = Bit is set      '0' = Bit is cleared      x = Bit is unknown

| Mnemonic,<br>Operands                  | Description | Cycles                       | 14-Bit Opcode |    |      |      | Status<br>Affected | Notes  |
|----------------------------------------|-------------|------------------------------|---------------|----|------|------|--------------------|--------|
|                                        |             |                              | MSb           |    |      | LSb  |                    |        |
| BYTE-ORIENTED FILE REGISTER OPERATIONS |             |                              |               |    |      |      |                    |        |
| ADDWF                                  | f, d        | Add W and f                  | 1             | 00 | 0111 | dfff | ffff               | C,DC,Z |
| ANDWF                                  | f, d        | AND W with f                 | 1             | 00 | 0101 | dfff | ffff               | Z      |
| CLRF                                   | f           | Clear f                      | 1             | 00 | 0001 | 1fff | ffff               | Z      |
| CLRW                                   | -           | Clear W                      | 1             | 00 | 0001 | 0xxx | xxxx               | 2      |
| COMF                                   | f, d        | Complement f                 | 1             | 00 | 1001 | dfff | ffff               | Z      |
| DECDF                                  | f, d        | Decrement f                  | 1             | 00 | 0011 | dfff | ffff               | Z      |
| DECFSZ                                 | f, d        | Decrement f, Skip if 0       | 1(2)          | 00 | 1011 | dfff | ffff               | 1,2,3  |
| INCF                                   | f, d        | Increment f                  | 1             | 00 | 1010 | dfff | ffff               | Z      |
| INCFSZ                                 | f, d        | Increment f, Skip if 0       | 1(2)          | 00 | 1111 | dfff | ffff               | 1,2,3  |
| IORWF                                  | f, d        | Inclusive OR W with f        | 1             | 00 | 0100 | dfff | ffff               | Z      |
| MOVF                                   | f, d        | Move f                       | 1             | 00 | 1000 | dfff | ffff               | Z      |
| MOVWF                                  | f           | Move W to f                  | 1             | 00 | 0000 | dfff | ffff               | Z      |
| NOP                                    | -           | No Operation                 | 1             | 00 | 0000 | 0xx0 | 0000               |        |
| RLF                                    | f, d        | Rotate Left f through Carry  | 1             | 00 | 1101 | dfff | ffff               | C      |
| RRF                                    | f, d        | Rotate Right f through Carry | 1             | 00 | 1100 | dfff | ffff               | C      |
| SUBWF                                  | f, d        | Subtract W from f            | 1             | 00 | 0010 | dfff | ffff               | C,DC,Z |
| SWAPF                                  | f, d        | Swap nibbles in f            | 1             | 00 | 1110 | dfff | ffff               | Z      |
| XORWF                                  | f, d        | Exclusive OR W with f        | 1             | 00 | 0110 | dfff | ffff               | Z      |
| BIT-ORIENTED FILE REGISTER OPERATIONS  |             |                              |               |    |      |      |                    |        |
| BCF                                    | f, b        | Bit Clear f                  | 1             | 01 | 00bb | bfff | ffff               | Z      |
| BSF                                    | f, b        | Bit Set f                    | 1             | 01 | 01bb | bfff | ffff               | Z      |
| BTFSC                                  | f, b        | Bit Test f, Skip if Clear    | 1(2)          | 01 | 10bb | bfff | ffff               | 3      |
| BTFSS                                  | f, b        | Bit Test f, Skip if Set      | 1(2)          | 01 | 11bb | bfff | ffff               | 3      |
| LITERAL AND CONTROL OPERATIONS         |             |                              |               |    |      |      |                    |        |
| ADDLW                                  | k           | Add literal and W            | 1             | 11 | 111x | kkkk | kkkk               | C,DC,Z |
| ANDLW                                  | k           | AND literal with W           | 1             | 11 | 1001 | kkkk | kkkk               | Z      |
| CALL                                   | k           | Call subroutine              | 2             | 10 | 0kkk | kkkk | kkkk               |        |
| CLRWDAT                                | -           | Clear Watchdog Timer         | 1             | 00 | 0000 | 0110 | 0100               | TO,PD  |
| GOTO                                   | k           | Go to address                | 2             | 10 | 1kkk | kkkk | kkkk               |        |
| IORLW                                  | k           | Inclusive OR literal with W  | 1             | 11 | 1000 | kkkk | kkkk               | Z      |
| MOVLW                                  | k           | Move literal to W            | 1             | 11 | 0xxx | kkkk | kkkk               |        |
| RETFIE                                 | -           | Return from interrupt        | 2             | 00 | 0000 | 0000 | 1001               |        |
| RETLW                                  | k           | Return with literal in W     | 2             | 11 | 01xx | kkkk | kkkk               |        |
| RETURN                                 | -           | Return from Subroutine       | 2             | 00 | 0000 | 0000 | 1000               | TO,PD  |
| SLEEP                                  | -           | Go into standby mode         | 1             | 00 | 0000 | 0110 | 0011               | C,DC,Z |
| SUBLW                                  | k           | Subtract W from literal      | 1             | 11 | 110x | kkkk | kkkk               | Z      |
| XORLW                                  | k           | Exclusive OR literal with W  | 1             | 11 | 1010 | kkkk | kkkk               |        |

Note 1: When an I/O register is modified as a function of itself (e.g., MOVF PORTB, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.  
 Note 2: If this instruction is executed on the TMR0 register (and, where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 module.  
 Note 3: If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is

- BTFSC (Bit Test and Skip if Clear) and BTFSS (Bit Test and Skip if Set) are used to test the bit and skip the next instruction, or not, according to the state of the bit tested.
- DECFSZ and INCFSZ embody a commonly used test – decrement or increment a register and jump depending on the effect of the result on the zero flag (Z is set if result 0).
- NOP simply does nothing for one instruction cycle (four clock cycles).
  - very useful for putting short delays in the program
- SLEEP stops the program, such that it can be restarted with an external interrupt.

# OPTIONAL INSTRUCTIONS

- TRIS was an instruction originally provided to make port initialization simpler.
  - It selects register bank 1 so that the TRIS data direction registers (TRISA, TRISB, etc.) can be loaded with a data direction code (e.g. 0 → output).
- The manufacturer no longer recommends use of this instruction, although it is still supported
- The assembler directive BANKSEL can be used
  - It gives more flexible access to the registers in banks 1, 2, 3.
- The other option is to change the bank select bits in the STATUS register directly, using BSF and BCF.
- OPTION, providing special access to the OPTION register, is the other instruction, which is no longer recommended.
  - It can be replaced by BANKSEL to select bank 1 which contains the OPTION register, which can then be accessed directly.

-CONFIG

## Chip Configuration Word

| Bit | Label | Function                           | Default | Enabled | Typical |
|-----|-------|------------------------------------|---------|---------|---------|
| 15  | -     | None                               | 0       | x       | 0       |
| 14  | -     | None                               | 0       | x       | 0       |
| 13  | CP1   | Code protection                    | 1       | 0       | 1       |
| 12  | CP0   | (4 levels)                         | 1       | 0       | 1       |
| 11  | DEBUG | In-circuit debugging (ICD)         | 1       | 0       | 0       |
| 10  | -     | None                               | 1       | x       | 1       |
| 9   | WRT   | Program memory write enable        | 1       | 1       | 1       |
| 8   | CPD   | EEPROM data memory write protect   | 1       | 0       | 1       |
| 7   | LVP   | Low-voltage programming enable     | 1       | 1       | 0       |
| 6   | BODEN | Brown-out reset (BoR) enable       | 1       | 1       | 0       |
| 5   | CP1   | Code protection (CP)               | 1       | 0       | 1       |
| 4   | CP0   | (repeats)                          | 1       | 0       | 1       |
| 3   | PWRTE | Power-up timer (PuT) enable        | 1       | 0       | 0       |
| 2   | WDTE  | Watchdog timer (WdT) enable        | 1       | 1       | 0       |
| 1   | FOSC1 | Oscillator type select             | 1       | x       | 0       |
| 0   | FOSC0 | RC = 11, HS = 10, XT = 01, LP = 00 | 1       | x       | 1       |

Default = 3FFF (RC clock, PuT disabled, WdT enabled).

Typical RC clock = 3FF3 (RC clock, ICD disabled, PuT enabled, WdT disabled).

Typical XT clock = 3731 (XT clock, ICD enabled, PuT enabled, WdT disabled).

# CRYSTAL (XTAL) OSCILLATOR

- Used for greater precision
  - uses the hardware timers to make accurate measurements
  - generate precise output signals
- Normally, it is connected across the clock pins with a pair of small capacitors (15 pF) to stabilize the frequency.
- The crystal acts as a self-contained resonant circuit, where the quartz or ceramic crystal vibrates at a precise frequency when subject to electrical stimulation.
- A convenient value (used in our examples later) is 4 MHz; this gives an instruction cycle time of 1  $\mu$ s
  - This is the maximum frequency allowed for the XT configuration setting.
- Operating at higher frequency requires the selection of the HS configuration option.
- Each instruction takes four clock cycles



$$4 \times \frac{1}{4M} = 1 \mu s$$

## Input/output ports

- There are five parallel ports in the PIC 16F877, labelled A-E.
- All pins can be used as bit- or byte-oriented digital input or output with
  - Some having alternate functions depending on the initialization of the relevant control registers.
- The TRIS (data direction) register bits in bank 1, default to 1, setting the ports B, C and D as inputs.
- Ports A and E are set to ANALOGUE INPUT by default, because the analogue control register ADCON1 in bank 1 defaults to 0 --- 0000.
- To set up these ports for digital I/O, this register must be loaded with the code x --- 011x (x don't care), e.g. 06h.
- ADCON1 can be initialized with bit codes that give a mixture of analogue and digital I/O on Ports A and E.
- ADCON1 is in bank 1 so BANKSEL is needed to access it.

if we put value in portA register 8-bit more than 5bit it will remove the upper bits values and just save the lower 5 bits

ADC  
0-4: A  
5-7: E

As you are only using the port in digital IO mode, set ADCON1 to a value of either 0x06 or 0x07 which makes all the pins digital. The LSB is ignored when 0x06 or 0x07 are used so both values do exactly the same thing.

## Port functions

|        | <b>Bits</b> | <b>Pins</b> | <b>Alternate function/s</b>                                                                                                       | <b>Bit</b>                 | <b>Default</b> |
|--------|-------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------|
| Port A | 6           | RA0–RA5     | Analogue inputs<br>Timer0 clock input<br>Serial port slave select input                                                           | 0,1,2,3,5<br>4<br>5        | Analogue Input |
| Port B | 8           | RB0–RB7     | External interrupt<br>Low-voltage programming input<br>Serial programming<br>In-circuit debugging                                 | 0<br>3<br>6,7<br>6,7       | Digital I/O    |
| Port C | 8           | RC0–RC7     | Timer1 clock input/output<br>Capture/Compare/PWM<br>SPI, I <sup>2</sup> C synchronous clock/data<br>USART asynchronous clock/data | 0,1<br>1,2<br>3,4,5<br>6,7 | Digital I/O    |
| Port D | 8           | RD0–RD7     | Parallel slave port data I/O                                                                                                      | 0–7                        | Digital I/O    |
| Port E | 3           | RE0–RE2     | Analogue inputs<br>Parallel slave port control bits                                                                               | 0,1,2<br>0,1,2             | Analogue Input |

## Interrupt Control Registers

- The registers involved in interrupt handling are INTCON, PIR1, PIR2, PIE1, PIE2 and PCON.
- Interrupts are external hardware signals which force the MCU to suspend its current process, and carry out an Interrupt Service Routine (ISR).
- In PIC when an interrupt occurs the program execution jumps to address 004.
- By default, interrupts are disabled.
- If interrupts are to be used
  - the main program start address needs to be 0005, or higher, and a 'GOTO start' (or similar label) placed at address 0000.
  - A 'GOTO ISR' instruction can then be placed at 004, using the ORG directive, which sets the address at which the instruction will be placed by the assembler.
- The Global Interrupt Enable bit (INTCON, GIE) must be set to enable the interrupt system.
  - The individual interrupt source is then enabled.
  - For example, the bit INTCON, TOIE is set to enable the Timer0 overflow to trigger the interrupt sequence.
  - When the timer overflows, INTCON, TOIF (Timer0 Interrupt Flag) is set to indicate the interrupt source, and the ISR called.
- The flags can be checked by the ISR to establish the source of the interrupt, if more than one is enabled.

# Interrupt sources and control bits

| Source      | Enable Bit Set | Flag Bit Set    | Interrupt Trigger Event                                 |
|-------------|----------------|-----------------|---------------------------------------------------------|
| TMR0        | INTCON.5       | INTCON.2        | Timer0 count overflowed                                 |
| RB0         | INTCON.4       | INTCON.1        | RB0 input changed (also uses INTEDG)                    |
| RB4-7       | INTCON.3       | INTCON.0        | Port B high nibble input changed                        |
| Peripherals | INTCON.6       |                 |                                                         |
| TMR1        | PIE1.0         | PIR1.0          | Timer1 count overflowed                                 |
| TMR2        | PIE1.1         | PIR1.1          | Timer2 count matched period register PR2                |
| CCP1        | PIE1.2         | PIR1.2          | Timer1 count captured in or matched CCPR1               |
| SSP         | PIE1.3         | PIR1.3          | Data transmitted or received in Synchronous Serial Port |
| TX          | PIE1.4         | PIR1.4          | Transmit buffer empty in Asynchronous Serial Port       |
| RC          | PIE1.5         | PIR1.5          | Receive buffer full in Asynchronous Serial Port         |
| AD          | PIE1.6         | PIR1.6          | Analogue to Digital Conversion completed                |
| PSP         | PIE1.7         | PIR1.7          | A read or write has occurred in the Parallel Slave Port |
| CCP2        | PIE2.0         | PIR2.0<br>CCPR2 | Timer2 count captured in or matched                     |
| BCL         | PIE2.3         | PIR2.3          | Bus collision detected in SSP (I <sup>2</sup> C mode)   |
| EE          | PIE2.4         | PIR2.4          | Write to EEPROM memory completed                        |

## Macros, Special Instructions, Assembler Directives Another structured

- Supplementary instructions

| S. Instruction | Meaning                                                                        | Assembler Code                |
|----------------|--------------------------------------------------------------------------------|-------------------------------|
| BZ addlab      | Branch to destination (address label) if result of previous operation zero     | BTFSC STATUS,Z<br>GOTO addlab |
| BNZ addlab     | Branch to destination (address label) if result of previous operation not zero | BTFSS STATUS,Z<br>GOTO addlab |
| BC addlab      | Branch to destination (address label)<br>if carry set                          | BTFSC STATUS,C<br>GOTO addlab |
| BNC addlab     | Branch to destination (address label)<br>if carry not set                      | BTFSS STATUS,C<br>GOTO addlab |
| NEG num1       | Negate (2s complement) a file register (labelled num1)                         | COMF num1<br>INCF num1        |
| TSTF num1      | Test a file register (labelled num1)<br>to modify status bits                  | MOVF num1                     |

العنكبوت  
العنكبوت

- Timer0 uses an 8-bit register
  - TMR0, file register address 01.
  - The register counts from 0 to 255, and then rolls over to 00 again.
  - When the register goes from FF to 00, an overflow flag, TOIF, bit 2 in the Interrupt Control Register INTCON, address 0B, is set.

## Timers – cont.

- A timer can work as a counter.
  - Counts external pulses
  - timers can also be used as counters.
- Timer0, can be controlled by a pre-scaler, see next slide.
- The pre-scaler is a divide by N register, where N = 2, 4, 8, 16, 32, 64, 128 or 256, meaning that the output count rate is reduced by this factor.
- This extends the count period or total count by the same ratio, giving a greater range to the measurement.
- The watchdog timer interval can also be extended, if this is selected as the clock source.
- The pre-scale select bits, and other control bits for Timer0 are found in OPTION\_REG.

N=2 -> MAX\_TIME =  
MAX\_TIME \* 2

4MHz -> 1 MHz clk inst.  
1u time  
N = 2  
Then 1u -> 2u

## OPTION\_REG REGISTER

| R/W-1 | R/W-1         | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
|-------|---------------|-------|-------|-------|-------|-------|-------|
| RBPU  | INTEDG        | T0CS  | T0SE  | PSA   | PS2   | PS1   | PS0   |
| bit 7 | <b>RBPU</b>   |       |       |       |       |       | bit 0 |
| bit 6 | <b>INTEDG</b> |       |       |       |       |       |       |

|         |                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                 |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 7   | <b>RBPU</b>                                                                                                                                               | Each of the PORTB pins has a weak internal pull-up. A single control bit can turn on all the pull-ups. This is performed by clearing bit <b>RBPU</b> (OPTION_REG<7>). The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on a Power-on Reset. |
| bit 6   | <b>INTEDG</b>                                                                                                                                             |                                                                                                                                                                                                                                                                                                                 |
| bit 5   | <b>T0CS</b> : TMR0 Clock Source Select bit<br>1 = Transition on T0CKI pin<br>0 = Internal instruction cycle clock (CLKOUT)                                |                                                                                                                                                                                                                                                                                                                 |
| bit 4   | <b>T0SE</b> : TMR0 Source Edge Select bit<br>1 = Increment on high-to-low transition on T0CKI pin<br>0 = Increment on low-to-high transition on T0CKI pin |                                                                                                                                                                                                                                                                                                                 |
| bit 3   | <b>PSA</b> : Prescaler Assignment bit<br>1 = Prescaler is assigned to the WDT<br>0 = Prescaler is assigned to the Timer0 module                           |                                                                                                                                                                                                                                                                                                                 |
| bit 2-0 | <b>PS2:PS0</b> : Prescaler Rate Select bits                                                                                                               | RBO/INT is an external interrupt input pin and is configured using the <b>INTEDG</b> bit (OPTION_REG<6>).                                                                                                                                                                                                       |
|         | Bit Value    TMR0 Rate    WDT Rate                                                                                                                        |                                                                                                                                                                                                                                                                                                                 |
|         | 000            1 : 2            1 : 1                                                                                                                     |                                                                                                                                                                                                                                                                                                                 |
|         | 001            1 : 4            1 : 2                                                                                                                     |                                                                                                                                                                                                                                                                                                                 |
|         | 010            1 : 8            1 : 4                                                                                                                     |                                                                                                                                                                                                                                                                                                                 |
|         | 011            1 : 16          1 : 8                                                                                                                      |                                                                                                                                                                                                                                                                                                                 |
|         | 100            1 : 32          1 : 16                                                                                                                     |                                                                                                                                                                                                                                                                                                                 |
|         | 101            1 : 64          1 : 32                                                                                                                     |                                                                                                                                                                                                                                                                                                                 |
|         | 110            1 : 128        1 : 64                                                                                                                      |                                                                                                                                                                                                                                                                                                                 |
|         | 111            1 : 256        1 : 128                                                                                                                     |                                                                                                                                                                                                                                                                                                                 |

Legend:

R = Readable bit

W = Writable bit

U = Unimplemented bit, read as '0'

- n = Value at POR

'1' = Bit is set

'0' = Bit is cleared

x = Bit is unknown

Assuming a clock frequency of 4 MHz and a prescaler value of 256, which is a common configuration for Timer0 in the PIC16F877A, each Timer0 count would take approximately 64 microseconds to complete. This can be calculated as follows:

The clock period at 4 MHz is 0.25 microseconds ( $1/4$  MHz).

The prescaler value of 256 divides the clock frequency by 256, resulting in a Timer0 clock frequency of 15.625 kHz ( $4 \text{ MHz} / 256$ ). Each Timer0 count therefore takes  $1 / 15.625 \text{ kHz}$ , or approximately 64 microseconds ( $1/15625 \text{ seconds}$ ).

To count from 0 to 255, Timer0 would need to complete 256 counts, so the total time it would take for Timer0 to count from 0 to 255 would be  $256 \times 64 \text{ microseconds}$ , or approximately 16.384 milliseconds.

## Timers – cont.

high  
low

- Timer1 is a 16-bit counter, consisting of TMR1H and TMR1L (addresses OE AND OF).
  - When the low byte rolls over from FF to 00, the high byte is incremented.
  - The maximum count is therefore 65535, which allows a higher count without sacrificing accuracy.
- Timer2 is an 8-bit counter (TMR2) with a 4-bit pre-scaler, 4-bit post-scaler and a comparator.
  - It can be used to generate Pulse Width Modulated (PWM) output which is useful for driving DC motors and servos, among other things.
- These timers can also be used in capture and compare modes, which allow external signals to be more easily measured.

### T1CON: TIMER1 CONTROL REGISTER (ADDRESS 10h)

|  | U-0 | U-0 | R/W-0   | R/W-0   | R/W-0   | R/W-0         | R/W-0  | R/W-0  |
|--|-----|-----|---------|---------|---------|---------------|--------|--------|
|  | —   | —   | T1CKPS1 | T1CKPS0 | T1OSCEN | <u>T1SYNC</u> | TMR1CS | TMR1ON |

bit 7

bit 0

- bit 7-6      **Unimplemented:** Read as '0'
- bit 5-4      **T1CKPS1:T1CKPS0:** Timer1 Input Clock Prescale Select bits  
 11 = 1:8 prescale value  
 10 = 1:4 prescale value  
 01 = 1:2 prescale value  
 00 = 1:1 prescale value
- bit 3      **T1OSCEN:** Timer1 Oscillator Enable Control bit  
 1 = Oscillator is enabled  
 0 = Oscillator is shut-off (the oscillator inverter is turned off to eliminate power drain)
- bit 2      **T1SYNC:** Timer1 External Clock Input Synchronization Control bit  
When TMR1CS = 1:  
 1 = Do not synchronize external clock input  
 0 = Synchronize external clock input  
When TMR1CS = 0:  
 This bit is ignored. Timer1 uses the internal clock when TMR1CS = 0.
- bit 1      **TMR1CS:** Timer1 Clock Source Select bit  
 1 = External clock from pin RC0/T1OSO/T1CKI (on the rising edge)  
 0 = Internal clock (Fosc/4)
- bit 0      **TMR1ON:** Timer1 On bit  
 1 = Enables Timer1  
 0 = Stops Timer1

# ADC

- Registers used
  - ADCON0
  - ADCON1
  - The output from the converter is stored in **ADRESH** (analogue to digital conversion result, high byte) and **ADRESL** (low byte).

## 8-bit Conversion

- The 16F877 MCU has eight analogue inputs available, at RA0, RA1, RA2, RA3, RA5, RE0, RE1 and RE2.
  - RA2 and RA3 may be used as reference voltage inputs, setting the minimum and maximum values for the measured voltage range.
  - These inputs default to analogue operation, so the register ADCON1 has to be initialized explicitly to use these pins for digital input or output.
  - The ADC converts an analogue input voltage (e.g. 0 – 2.56V) to 10-bit binary, but only the upper 8 bits of the result are used, giving a resolution of 10 mV per bit ((1/256) X 2.56 V).

| ADCON0 REGISTER (ADDRESS 1Fh)                                                                                                                                                             |                                                                                                                                                          |                                                         |       |       |         |     |       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|-------|-------|---------|-----|-------|
| R/W-0                                                                                                                                                                                     | R/W-0                                                                                                                                                    | R/W-0                                                   | R/W-0 | R/W-0 | R/W-0   | U-0 | R/W-0 |
| ADCS1                                                                                                                                                                                     | ADCS0                                                                                                                                                    | CHS2                                                    | CHS1  | CHS0  | GO/DONE | —   | ADON  |
| bit 7                                                                                                                                                                                     |                                                                                                                                                          |                                                         |       |       |         |     | bit 0 |
| bit 7-6 ADCS1:ADCS0: A/D Conversion Clock Select bits (ADCON0 bits in bold)                                                                                                               |                                                                                                                                                          |                                                         |       |       |         |     |       |
| ADCON1<br><ADCS2>                                                                                                                                                                         | ADCON0<br><ADCS1:ADCS0>                                                                                                                                  | Clock Conversion                                        |       |       |         |     |       |
| 0                                                                                                                                                                                         | 00                                                                                                                                                       | Fosc/2                                                  |       |       |         |     |       |
| 0                                                                                                                                                                                         | 01                                                                                                                                                       | Fosc/8                                                  |       |       |         |     |       |
| 0                                                                                                                                                                                         | 10                                                                                                                                                       | Fosc/32                                                 |       |       |         |     |       |
| 0                                                                                                                                                                                         | 11                                                                                                                                                       | FRC (clock derived from the internal A/D RC oscillator) |       |       |         |     |       |
| 1                                                                                                                                                                                         | 00                                                                                                                                                       | Fosc/4                                                  |       |       |         |     |       |
| 1                                                                                                                                                                                         | 01                                                                                                                                                       | Fosc/16                                                 |       |       |         |     |       |
| 1                                                                                                                                                                                         | 10                                                                                                                                                       | Fosc/64                                                 |       |       |         |     |       |
| 1                                                                                                                                                                                         | 11                                                                                                                                                       | FRC (clock derived from the internal A/D RC oscillator) |       |       |         |     |       |
| bit 5-3 CHS2:CHS0: Analog Channel Select bits                                                                                                                                             |                                                                                                                                                          |                                                         |       |       |         |     |       |
| 000                                                                                                                                                                                       | = Channel 0 (AN0)                                                                                                                                        |                                                         |       |       |         |     |       |
| 001                                                                                                                                                                                       | = Channel 1 (AN1)                                                                                                                                        |                                                         |       |       |         |     |       |
| 010                                                                                                                                                                                       | = Channel 2 (AN2)                                                                                                                                        |                                                         |       |       |         |     |       |
| 011                                                                                                                                                                                       | = Channel 3 (AN3)                                                                                                                                        |                                                         |       |       |         |     |       |
| 100                                                                                                                                                                                       | = Channel 4 (AN4)                                                                                                                                        |                                                         |       |       |         |     |       |
| 101                                                                                                                                                                                       | = Channel 5 (AN5)                                                                                                                                        |                                                         |       |       |         |     |       |
| 110                                                                                                                                                                                       | = Channel 6 (AN6)                                                                                                                                        |                                                         |       |       |         |     |       |
| 111                                                                                                                                                                                       | = Channel 7 (AN7)                                                                                                                                        |                                                         |       |       |         |     |       |
| <b>Note:</b> The PIC16F873A/876A devices only implement A/D channels 0 through 4; the unimplemented selections are reserved. Do not select any unimplemented channels with these devices. |                                                                                                                                                          |                                                         |       |       |         |     |       |
| bit 2                                                                                                                                                                                     | GO/DONE: A/D Conversion Status bit                                                                                                                       |                                                         |       |       |         |     |       |
| When ADON = 1:                                                                                                                                                                            |                                                                                                                                                          |                                                         |       |       |         |     |       |
| 1                                                                                                                                                                                         | = A/D conversion in progress (setting this bit starts the A/D conversion which is automatically cleared by hardware when the A/D conversion is complete) |                                                         |       |       |         |     |       |
| 0                                                                                                                                                                                         | = A/D conversion not in progress                                                                                                                         |                                                         |       |       |         |     |       |
| bit 1                                                                                                                                                                                     | Unimplemented: Read as '0'                                                                                                                               |                                                         |       |       |         |     |       |
| bit 0                                                                                                                                                                                     | ADON: A/D On bit                                                                                                                                         |                                                         |       |       |         |     |       |
| 1                                                                                                                                                                                         | = A/D converter module is powered up                                                                                                                     |                                                         |       |       |         |     |       |
| 0                                                                                                                                                                                         | = A/D converter module is shut-off and consumes no operating current                                                                                     |                                                         |       |       |         |     |       |

| ADCON1 REGISTER (ADDRESS 9Fh) |                                                                                        |                                   |                                                        |       |       |       |       |     |       |       |     |
|-------------------------------|----------------------------------------------------------------------------------------|-----------------------------------|--------------------------------------------------------|-------|-------|-------|-------|-----|-------|-------|-----|
| R/W-0                         | R/W-0                                                                                  | U-0                               | U-0                                                    | R/W-0 | R/W-0 | R/W-0 | R/W-0 |     |       |       |     |
| ADFM                          | ADCS2                                                                                  | —                                 | —                                                      | PCFG3 | PCFG2 | PCFG1 | PCFG0 |     |       |       |     |
| bit 7                         |                                                                                        |                                   |                                                        |       |       |       | bit 0 |     |       |       |     |
| bit 6                         | <b>ADCS2: A/D Conversion Clock Select bit (ADCON1 bits in shaded area and in bold)</b> |                                   |                                                        |       |       |       |       |     |       |       |     |
|                               | <b>ADCON1 &lt;ADCS2&gt;</b>                                                            | <b>ADCON0 &lt;ADCS1:ADCS0&gt;</b> | <b>Clock Conversion</b>                                |       |       |       |       |     |       |       |     |
| 0                             | 00                                                                                     |                                   | Fosc/2                                                 |       |       |       |       |     |       |       |     |
| 0                             | 01                                                                                     |                                   | Fosc/8                                                 |       |       |       |       |     |       |       |     |
| 0                             | 10                                                                                     |                                   | Fosc/32                                                |       |       |       |       |     |       |       |     |
| 0                             | 11                                                                                     |                                   | Fr (clock derived from the internal A/D RC oscillator) |       |       |       |       |     |       |       |     |
| 1                             | 00                                                                                     |                                   | Fosc/4                                                 |       |       |       |       |     |       |       |     |
| 1                             | 01                                                                                     |                                   | Fosc/16                                                |       |       |       |       |     |       |       |     |
| 1                             | 10                                                                                     |                                   | Fosc/64                                                |       |       |       |       |     |       |       |     |
| 1                             | 11                                                                                     |                                   | Fr (clock derived from the internal A/D RC oscillator) |       |       |       |       |     |       |       |     |
| bit 5-4                       | Unimplemented: Read as '0'                                                             |                                   |                                                        |       |       |       |       |     |       |       |     |
| bit 3-0                       | PCFG3:PCFG0: A/D Port Configuration Control bits                                       |                                   |                                                        |       |       |       |       |     |       |       |     |
|                               | PCFG<br>3:0>                                                                           | AN7                               | AN5                                                    | AN4   | AN3   | AN2   | AN1   | AN0 | VREF+ | VREF- | C/R |
| 0000                          | A                                                                                      | A                                 | A                                                      | A     | A     | A     | A     | A   | Vdd   | Vss   | 8/0 |
| 0001                          | A                                                                                      | A                                 | A                                                      | A     | VREF+ | A     | A     | A   | AN3   | Vss   | 7/1 |
| 0010                          | D                                                                                      | D                                 | D                                                      | A     | A     | A     | A     | A   | Vdd   | Vss   | 5/0 |
| 0011                          | D                                                                                      | D                                 | D                                                      | A     | VREF+ | A     | A     | A   | AN3   | Vss   | 4/1 |
| 0100                          | D                                                                                      | D                                 | D                                                      | D     | A     | D     | A     | A   | Vdd   | Vss   | 3/0 |
| 0101                          | D                                                                                      | D                                 | D                                                      | D     | VREF+ | D     | A     | A   | AN3   | Vss   | 2/1 |
| 0110                          | D                                                                                      | D                                 | D                                                      | D     | D     | D     | D     | D   | —     | —     | 0/0 |
| 1000                          | A                                                                                      | A                                 | A                                                      | A     | VREF+ | VREF- | A     | A   | AN3   | AN2   | 6/2 |
| 1001                          | D                                                                                      | D                                 | D                                                      | A     | A     | VREF+ | A     | A   | Vdd   | Vss   | 6/0 |
| 1010                          | D                                                                                      | D                                 | A                                                      | A     | VREF+ | A     | A     | A   | AN3   | Vss   | 5/1 |
| 1011                          | D                                                                                      | D                                 | A                                                      | A     | VREF+ | VREF- | A     | A   | AN3   | AN2   | 4/2 |
| 1100                          | D                                                                                      | D                                 | D                                                      | A     | VREF+ | VREF- | A     | A   | AN3   | AN2   | 3/2 |
| 1101                          | D                                                                                      | D                                 | D                                                      | D     | VREF+ | VREF- | A     | A   | AN3   | AN2   | 2/2 |
| 1110                          | D                                                                                      | D                                 | D                                                      | D     | D     | D     | D     | A   | Vdd   | Vss   | 1/0 |
| 1111                          | D                                                                                      | D                                 | D                                                      | D     | VREF+ | VREF- | D     | A   | AN3   | AN2   | 1/2 |

A = Analog input D = Digital I/O  
C/R = # of analog input channels/# of A/D voltage references

$$Vref+ = 5, Vref- = 0$$

then

$$(5 - 0) / 2^{10} = 0.005$$

then if the result is  
1000000000 = 512

then the voltage was  
512 \* 0.005 = 2.56 V

will read the analog value as voltage in range

[Vref-, Vref+]

A  $\rightarrow$  Vref



# Capture/compare/ PWM

Each Capture/Compare/PWM (CCP) module contains a 16-bit register which can operate as:

- 16-bit Capture register
- 16-bit Compare register
- PWM Master/Slave Duty Cycle register
- Both the CCP1 and CCP2 modules are identical in operation

for find the period of the signal that enter on portc CCP1 or CCP2 from rising to rising edge or from falling to falling edge and will save the value in CCPR1H, CCPR1L

## Capture mode



## Compare mode

Special event trigger will:  
reset Timer1, but not set interrupt flag bit TMR1IF (PIR1<0>)  
and set bit GO/DONE (ADCON0<2>).



Will compare the value in timer1 if it become as the value in  
CCPR1H and CCPR1L  
then will set/clear the portc CCP1 or CCP2

### CCP1CON REGISTER/CCP2CON REGISTER (ADDRESS 17h/1Dh)

| U-0 | U-0 | R/W-0 | R/W-0 | R/W-0  | R/W-0  | R/W-0  | R/W-0  |
|-----|-----|-------|-------|--------|--------|--------|--------|
| —   | —   | CCPxX | CCPxY | CCPxM3 | CCPxM2 | CCPxM1 | CCPxM0 |

bit 7

bit 0

bit 7-6 **Unimplemented:** Read as '0'

bit 5-4 **CCPxX:CCPxY:** PWM Least Significant bits

Capture mode:

Unused.

Compare mode:

Unused.

PWM mode:

These bits are the two LSbs of the PWM duty cycle. The eight MSbs are found in CCPRxL.

bit 3-0 **CCPxM3:CCPxM0:** CCPx Mode Select bits

0000 = Capture/Compare/PWM disabled (resets CCPx module)

0100 = Capture mode, every falling edge

0101 = Capture mode, every rising edge

0110 = Capture mode, every 4th rising edge

0111 = Capture mode, every 16th rising edge

1000 = Compare mode, set output on match (CCPxIF bit is set)

1001 = Compare mode, clear output on match (CCPxIF bit is set)

1010 = Compare mode, generate software interrupt on match (CCPxIF bit is set, CCPx pin is unaffected)

1011 = Compare mode, trigger special event (CCPxIF bit is set, CCPx pin is unaffected); CCP1 resets TMR1; CCP2 resets TMR1 and starts an A/D conversion (if A/D module is enabled)

11xx = PWM mode

PWM value we save it as 10 bit

in:

CCPR1L<7:0>:CCP1CON<5:4>

## PWM Mode (PWM)

- In Pulse Width Modulation mode, the CCPx pin produces up to a **10-bit resolution PWM** output. Since the CCP1 pin is multiplexed with the PORTC data latch, the **TRISC<2>** bit must be cleared to make the CCP1 pin an output

8-bit +

register

- PWM Period =  
$$[(PR2) + 1] \cdot 4 \cdot TOSC \cdot (\text{TMR2 Prescale Value})$$
- PWM Duty Cycle =  
$$(CCPR1L:CCP1CON<5:4>) \cdot TOSC \cdot (\text{TMR2 Prescale})$$

$$\text{Resolution} = \frac{\log\left(\frac{F_{OSC}}{F_{PWM}}\right)}{\log(2)} \text{ bits}$$

#### CMCON REGISTER

| R-0   | R-0   | R/W-0 | R/W-0 | R/W-0 | R/W-1 | R/W-1 | R/W-1 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| C2OUT | C1OUT | C2INV | C1INV | CIS   | CM2   | CM1   | CM0   |
| bit 7 |       |       |       |       |       |       | bit 0 |

bit 7      **C2OUT:** Comparator 2 Output bit

When C2INV = 0:

1 = C2 VIN+ > C2 VIN-  
0 = C2 VIN+ < C2 VIN-

When C2INV = 1:

1 = C2 VIN+ < C2 VIN-  
0 = C2 VIN+ > C2 VIN-

bit 6      **C1OUT:** Comparator 1 Output bit

When C1INV = 0:

1 = C1 VIN+ > C1 VIN-  
0 = C1 VIN+ < C1 VIN-

When C1INV = 1:

1 = C1 VIN+ < C1 VIN-  
0 = C1 VIN+ > C1 VIN-

bit 5      **C2INV:** Comparator 2 Output Inversion bit

1 = C2 output inverted  
0 = C2 output not inverted

bit 4      **C1INV:** Comparator 1 Output Inversion bit

1 = C1 output inverted  
0 = C1 output not inverted

bit 3      **CIS:** Comparator Input Switch bit

When CM2:CM0 = 110:

1 = C1 VIN- connects to RA3/AN3  
C2 VIN- connects to RA2/AN2  
0 = C1 VIN- connects to RA0/AN0  
C2 VIN- connects to RA1/AN1

bit 2      **CM2:CM0:** Comparator Mode bits

Figure 12-1 shows the Comparator modes and CM2:CM0 bit settings.

|                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p><b>Comparators Reset</b><br/>CM2:CM0 = 000</p> <p>RA0/AN0 A Vin- C1 Off (Read as '0')<br/>RA3/AN3 A Vin+ +<br/>RA1/AN1 A Vin- C2 Off (Read as '0')<br/>RA2/AN2 A Vin+ +</p>                              | <p><b>Comparators Off (POR Default Value)</b><br/>CM2:CM0 = 111</p> <p>RA0/AN0 D Vin- C1 Off (Read as '0')<br/>RA3/AN3 D Vin+ +<br/>RA1/AN1 D Vin- C2 Off (Read as '0')<br/>RA2/AN2 D Vin+ +</p>                                                                                         |
| <p><b>Two Independent Comparators</b><br/>CM2:CM0 = 010</p> <p>RA0/AN0 A Vin- C1 C1OUT<br/>RA3/AN3 A Vin+ +<br/>RA1/AN1 A Vin- C2 C2OUT<br/>RA2/AN2 A Vin+ +</p>                                            | <p><b>Two Independent Comparators with Outputs</b><br/>CM2:CM0 = 011</p> <p>RA0/AN0 A Vin- C1 C1OUT<br/>RA3/AN3 A Vin+ +<br/>RA4/T0CKU/C1OUT<br/>RA1/AN1 A Vin- C2 C2OUT<br/>RA2/AN2 A Vin+ +<br/>RA5/AN4/SS/C2OUT</p>                                                                   |
| <p><b>Two Common Reference Comparators</b><br/>CM2:CM0 = 100</p> <p>RA0/AN0 A Vin- C1 C1OUT<br/>RA3/AN3 A Vin+ +<br/>RA1/AN1 A Vin- C2 C2OUT<br/>RA2/AN2 D Vin+ +</p>                                       | <p><b>Two Common Reference Comparators with Outputs</b><br/>CM2:CM0 = 101</p> <p>RA0/AN0 A Vin- C1 C1OUT<br/>RA3/AN3 A Vin+ +<br/>RA4/T0CKU/C1OUT<br/>RA1/AN1 A Vin- C2 C2OUT<br/>RA2/AN2 D Vin+ +<br/>RA5/AN4/SS/C2OUT</p>                                                              |
| <p><b>One Independent Comparator with Output</b><br/>CM2:CM0 = 001</p> <p>RA0/AN0 A Vin- C1 C1OUT<br/>RA3/AN3 A Vin+ +<br/>RA4/T0CKU/C1OUT<br/>RA1/AN1 D Vin- C2 Off (Read as '0')<br/>RA2/AN2 D Vin+ +</p> | <p><b>Four Inputs Multiplexed to Two Comparators</b><br/>CM2:CM0 = 110</p> <p>RA0/AN0 A CIS = 0 CIS = 1 Vin- C1 C1OUT<br/>RA3/AN3 A CIS = 0 CIS = 1 Vin+ +<br/>RA1/AN1 A CIS = 0 CIS = 1 Vin- C2 C2OUT<br/>RA2/AN2 A CIS = 0 CIS = 1 Vin+ +</p> <p>CVREF From Comparator VREF Module</p> |
| <p>A = Analog Input, port reads zeros always. D = Digital Input.</p>                                                                                                                                        | <p>CIS (CMCON&lt;3&gt;) is the Comparator Input Switch.</p>                                                                                                                                                                                                                              |

| Instruction                | Instruction Code |     |     |     |     |     |     |     |     |     |  | Description                                                                                                                        | Execution time<br>(fosc=270Khz) |
|----------------------------|------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|--|------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
|                            | RS               | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |  |                                                                                                                                    |                                 |
| Clear Display              | 0                | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |  | Write “00H” to DDRAM and set DDRAM address to “00H” from AC                                                                        | 1.53ms                          |
| Return Home                | 0                | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   | —   |  | Set DDRAM address to “00H” from AC and return cursor to its original position if shifted. The contents of DDRAM are not changed.   | 1.53ms                          |
| Entry Mode Set             | 0                | 0   | 0   | 0   | 0   | 0   | 0   | 1   | I/D | SH  |  | Assign cursor moving direction and enable the shift of entire display.                                                             | 39 $\mu$ s                      |
| Display ON/OFF Control     | 0                | 0   | 0   | 0   | 0   | 0   | 1   | D   | C   | B   |  | Set display (D), cursor (C), and blinking of cursor (B) on/off control bit.                                                        | 39 $\mu$ s                      |
| Cursor or Display Shift    | 0                | 0   | 0   | 0   | 0   | 1   | S/C | R/L | —   | —   |  | Set cursor moving and display shift control bit, and the direction, without changing of DDRAM data.                                | 39 $\mu$ s                      |
| Function Set               | 0                | 0   | 0   | 0   | 1   | DL  | N   | F   | —   | —   |  | Set interface data length (DL:8-bit/4-bit), numbers of display line (N:2-line/1-line)and, display font type (F:5x11 dots/5x8 dots) | 39 $\mu$ s                      |
| Set CGRAM Address          | 0                | 0   | 0   | 1   | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 |  | Set CGRAM address in address counter.                                                                                              | 39 $\mu$ s                      |
| Set DDRAM Address          | 0                | 0   | 1   | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 |  | Set DDRAM address in address counter.                                                                                              | 39 $\mu$ s                      |
| Read Busy Flag and Address | 0                | 1   | BF  | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 |  | Whether during internal operation or not can be known by reading BF. The contents of address counter can also be read.             | 0 $\mu$ s                       |
| Write Data to RAM          | 1                | 0   | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |  | Write data into internal RAM (DDRAM/CGRAM).                                                                                        | 43 $\mu$ s                      |
| Read Data from RAM         | 1                | 1   | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |  | Read data from internal RAM (DDRAM/CGRAM).                                                                                         | 43 $\mu$ s                      |

[lcd016n002bcfhet.pdf \(vishay.com\)](http://lcd016n002bcfhet.pdf (vishay.com))

```
        BSF      STATUS,C    ; set carry for subtract
        MOVLW    D'100'       ; load 100
sub1     SUBWF   ADbin,1     ; and subtract from result
        INCF     huns        ; count number of loops
        BTFSC   STATUS,C    ; and check if done
        GOTO    sub1        ; no, carry on

        ADDWF   ADbin,1     ; yes, add 100 back on
        DECF     huns        ; and correct loop count

; Calculate tens digit..........
```

```
        BSF      STATUS,C    ; repeat process for tens
        MOVLW    D'10'        ; load 10
sub2     SUBWF   ADbin,1     ; and subtract from result
        INCF     tens         ; count number of loops
        BTFSC   STATUS,C    ; and check if done
        GOTO    sub2        ; no, carry on

        ADDWF   ADbin        ; yes, add 100 back on
        DECF     tens         ; and correct loop count
        MOVF    ADbin,W      ; load remainder
        MOVWF   ones         ; and store as ones digit

        RETURN             ; done
```