



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| 2                          |                                                                         |
|----------------------------|-------------------------------------------------------------------------|
| Product Status             | Active                                                                  |
| Core Processor             | PIC                                                                     |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 20MHz                                                                   |
| Connectivity               | I <sup>2</sup> C, SPI                                                   |
| Peripherals                | Brown-out Detect/Reset, LCD, POR, PWM, WDT                              |
| Number of I/O              | 25                                                                      |
| Program Memory Size        | 14KB (8K x 14)                                                          |
| Program Memory Type        | OTP                                                                     |
| EEPROM Size                | -                                                                       |
| RAM Size                   | 336 x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                               |
| Data Converters            | A/D 5x10b                                                               |
| Oscillator Type            | External                                                                |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                       |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 68-LCC (J-Lead)                                                         |
| Supplier Device Package    | 68-PLCC (24.23x24.23)                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c926-i-l |
|                            |                                                                         |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

#### **Pin Diagrams**





### **REGISTER FILE MAP — DSTEMP**

|                     | Address   |                                | Address    |                       | Address |                   | Addre |
|---------------------|-----------|--------------------------------|------------|-----------------------|---------|-------------------|-------|
| Indirect addr.(*)   | 00h       | Indirect addr.(*)              | 80h        | Indirect addr.(*)     | 100h    | Indirect addr.(*) | 180   |
| TMR0                | 01h       | OPTION                         | 81h        | TMR0                  | 101h    | OPTION            | 181   |
| PCL                 | 02h       | PCL                            | 82h        | PCL                   | 102h    | PCL               | 182   |
| STATUS              | 03h       | STATUS                         | 83h        | STATUS                | 103h    | STATUS            | 183   |
| FSR                 | 04h       | FSR                            | 84h        | FSR                   | 104h    | FSR               | 184   |
| PORTA               | 05h       | TRISA                          | 85h        |                       | 105h    |                   | 185   |
| PORTB               | 06h       | TRISB                          | 86h        | PORTB                 | 106h    | TRISB             | 186   |
| PORTC               | 07h       | TRISC                          | 87h        | PORTF                 | 107h    | TRISF             | 187   |
| PORTD               | 08h       | TRISD                          | 88h        | PORTG                 | 108h    | TRISG             | 188   |
| PORTE               | 09h       | TRISE                          | 89h        |                       | 109h    |                   | 189   |
| PCLATH              | 0Ah       | PCLATH                         | 8Ah        | PCLATH                | 10Ah    | PCLATH            | 18A   |
| INTCON              | 0Bh       | INTCON                         | 8Bh        | INTCON                | 10Bh    | INTCON            | 18B   |
| PIR1                | 0Ch       | PIE1                           | 8Ch        | PMCON1                | 10Ch    | PMDATA            | 18C   |
|                     | 0Dh       |                                | 8Dh        | LCDSE                 | 10Dh    | PMADR             | 18D   |
| TMR1L               | 0Eh       | PCON                           | 8Eh        | LCDPS                 | 10Eh    | PMDATH            | 18E   |
| TMR1H               | 0Fh       |                                | 8Fh        | LCDCON                | 10Fh    | PMADRH            | 18F   |
| T1CON               | 10h       |                                | 90h        | LCDD00                | 110h    |                   | 190   |
| TMR2                | 11h       |                                | 91h        | LCDD01                | 111h    |                   | 191   |
| T2CON               | 12h       | PR2                            | 92h        | LCDD02                | 112h    |                   | 192   |
| SSPBUF              | 13h       | SSPADD                         | 93h        | LCDD03                | 113h    |                   | 193   |
| SSPCON              | 14h       | SSPSTAT                        | 94h        | LCDD04                | 114h    |                   | 194   |
| CCPR1L              | 15h       |                                | 95h        | LCDD05                | 115h    |                   | 195   |
| CCPR1H              | 16h       |                                | 96h        | LCDD06                | 116h    |                   | 196   |
| CCP1CON             | 17h       |                                | 97h        | LCDD07                | 117h    |                   | 197   |
|                     | 18h       |                                | 98h        | LCDD08                | 118h    |                   | 198   |
|                     | 19h       |                                | 99h        | LCDD09                | 119h    |                   | 199   |
|                     | 1Ah       |                                | 9Ah        | LCDD10                | 11Ah    |                   | 19A   |
|                     | 1Bh       |                                | 9Bh        | LCDD11                | 11Bh    |                   | 19B   |
|                     | 1Ch       |                                | 9Ch        | LCDD12                | 11Ch    |                   | 19C   |
|                     | 1Dh       |                                | 9Dh        | LCDD13                | 11Dh    |                   | 19D   |
| ADRESH              | 1Eh       | ADRESL                         | 9Eh        | LCDD14                | 11Eh    |                   | 19E   |
| ADCON0              | 1Fh       | ADCON1                         | 9Fh        | LCDD15                | 11Fh    |                   | 19F   |
|                     | 20h       |                                | A0h        |                       | 120h    |                   | 1A0   |
| General             |           | General<br>Purpose<br>Register |            |                       |         |                   |       |
| Purpose<br>Register |           |                                | EFh        |                       | 16Fh    |                   | 1EF   |
|                     |           |                                | F0h        | 00000000              | 170h    | accesses          | 1F0   |
|                     |           | accesses<br>70h - 7Fh          | 1.011      | accesses<br>70h - 7Fh |         | 70h - 7Fh         |       |
|                     | 7Fh       |                                | FFh        |                       | 17Fh    |                   | 1FF   |
| Bank 0              |           | Bank 1                         |            | Bank 2                |         | Bank 3            |       |
| Unimplement         | ed data m | emory locations, r             | ead as '0' |                       |         |                   |       |

| Address | Name   | Bit 7                        | Bit 6                        | Bit 5                        | Bit 4          | Bit 3         | Bit 2           | Bit 1          | Bit 0         | Value on<br>Power-on<br>Reset | Details on page |
|---------|--------|------------------------------|------------------------------|------------------------------|----------------|---------------|-----------------|----------------|---------------|-------------------------------|-----------------|
| Bank 2  |        | •                            |                              | •                            |                |               |                 |                | •             |                               | •               |
| 100h    | INDF   | Addressing                   | this location                | uses content                 | ts of FSR to a | address data  | memory (no      | t a physical r | egister)      | 0000 0000                     | 26              |
| 101h    | TMR0   | Timer0 Mod                   | ule Register                 |                              |                |               |                 |                |               | xxxx xxxx                     | 41              |
| 102h    | PCL    | Program Co                   | ounter (PC) L                | east Signific.               | ant Byte       |               |                 |                |               | 0000 0000                     | 25              |
| 103h    | STATUS | IRP                          | RP1                          | RP0                          | TO             | PD            | Z               | DC             | С             | 0001 1xxx                     | 19              |
| 104h    | FSR    | Indirect Data                | a Memory A                   | ddress Pointe                | ər             |               |                 |                |               | xxxx xxxx                     | 26              |
| 105h    | —      | Unimpleme                    | nted                         |                              |                |               |                 |                |               | —                             | —               |
| 106h    | PORTB  | PORTB Dat                    | a Latch whe                  | n written: PO                | RTB pins wh    | en read       |                 |                |               | xxxx xxxx                     | 31              |
| 107h    | PORTF  | PORTF pins                   | s when read                  |                              |                |               |                 |                |               | 0000 0000                     | 37              |
| 108h    | PORTG  | PORTG pin                    | s when read                  |                              |                |               |                 |                |               | 0000 0000                     | 38              |
| 109h    | _      | Unimpleme                    | nted                         |                              |                |               |                 |                |               | —                             | _               |
| 10Ah    | PCLATH | —                            | —                            | —                            | Write Buffer   | for the uppe  | r 5 bits of the | PC             |               | 0 0000                        | 25              |
| 10Bh    | INTCON | GIE                          | PEIE                         | TMR0IE                       | INTE           | RBIE          | TMR0IF          | INTF           | RBIF          | 0000 000x                     | 21              |
| 10Ch    | PMCON1 | reserved                     | —                            | _                            | —              | —             | —               | —              | RD            | 10                            | 27              |
| 10Dh    | LCDSE  | SE29                         | SE27                         | SE20                         | SE16           | SE12          | SE9             | SE5            | SE0           | 1111 1111                     | 94              |
| 10Eh    | LCDPS  | _                            | _                            | _                            | _              | LP3           | LP2             | LP1            | LP0           | 0000                          | 84              |
| 10Fh    | LCDCON | LCDEN                        | SLPEN                        | _                            | VGEN           | CS1           | CS0             | LMUX1          | LMUX0         | 00-0 0000                     | 83              |
| 110h    | LCDD00 | SEG07<br>COM0                | SEG06<br>COM0                | SEG05<br>COM0                | SEG04<br>COM0  | SEG03<br>COM0 | SEG02<br>COM0   | SEG01<br>COM0  | SEG00<br>COM0 | xxxx xxxx                     | 92              |
| 111h    | LCDD01 | SEG15<br>COM0                | SEG14<br>COM0                | SEG13<br>COM0                | SEG12<br>COM0  | SEG11<br>COM0 | SEG10<br>COM0   | SEG09<br>COM0  | SEG08<br>COM0 | XXXX XXXX                     | 92              |
| 112h    | LCDD02 | SEG23<br>COM0                | SEG22<br>COM0                | SEG21<br>COM0                | SEG20<br>COM0  | SEG19<br>COM0 | SEG18<br>COM0   | SEG17<br>COM0  | SEG16<br>COM0 | XXXX XXXX                     | 92              |
| 113h    | LCDD03 | SEG31<br>COM0                | SEG30<br>COM0                | SEG29<br>COM0                | SEG28<br>COM0  | SEG27<br>COM0 | SEG26<br>COM0   | SEG25<br>COM0  | SEG24<br>COM0 | XXXX XXXX                     | 92              |
| 114h    | LCDD04 | SEG07<br>COM1                | SEG06<br>COM1                | SEG05<br>COM1                | SEG04<br>COM1  | SEG03<br>COM1 | SEG02<br>COM1   | SEG01<br>COM1  | SEG00<br>COM1 | XXXX XXXX                     | 92              |
| 115h    | LCDD05 | SEG15<br>COM1                | SEG14<br>COM1                | SEG13<br>COM1                | SEG12<br>COM1  | SEG11<br>COM1 | SEG10<br>COM1   | SEG09<br>COM1  | SEG08<br>COM1 | XXXX XXXX                     | 92              |
| 116h    | LCDD06 | SEG23<br>COM1                | SEG22<br>COM1                | SEG21<br>COM1                | SEG20<br>COM1  | SEG19<br>COM1 | SEG18<br>COM1   | SEG17<br>COM1  | SEG16<br>COM1 | XXXX XXXX                     | 92              |
| 117h    | LCDD07 | SEG31<br>COM1 <sup>(1)</sup> | SEG30<br>COM1                | SEG29<br>COM1                | SEG28<br>COM1  | SEG27<br>COM1 | SEG26<br>COM1   | SEG25<br>COM1  | SEG24<br>COM1 | XXXX XXXX                     | 92              |
| 118h    | LCDD08 | SEG07<br>COM2                | SEG06<br>COM2                | SEG05<br>COM2                | SEG04<br>COM2  | SEG03<br>COM2 | SEG02<br>COM2   | SEG01<br>COM2  | SEG00<br>COM2 | XXXX XXXX                     | 92              |
| 119h    | LCDD09 | SEG15<br>COM2                | SEG14<br>COM2                | SEG13<br>COM2                | SEG12<br>COM2  | SEG11<br>COM2 | SEG10<br>COM2   | SEG09<br>COM2  | SEG08<br>COM2 | XXXX XXXX                     | 92              |
| 11Ah    | LCDD10 | SEG23<br>COM2                | SEG22<br>COM2                | SEG21<br>COM2                | SEG20<br>COM2  | SEG19<br>COM2 | SEG18<br>COM2   | SEG17<br>COM2  | SEG16<br>COM2 | XXXX XXXX                     | 92              |
| 11Bh    | LCDD11 | SEG31<br>COM2 <sup>(1)</sup> | SEG30<br>COM2 <sup>(1)</sup> | SEG29<br>COM2                | SEG28<br>COM2  | SEG27<br>COM2 | SEG26<br>COM2   | SEG25<br>COM2  | SEG24<br>COM2 | XXXX XXXX                     | 92              |
| 11Ch    | LCDD12 | SEG07<br>COM3                | SEG06<br>COM3                | SEG05<br>COM3                | SEG04<br>COM3  | SEG03<br>COM3 | SEG02<br>COM3   | SEG01<br>COM3  | SEG00<br>COM3 | XXXX XXXX                     | 92              |
| 11Dh    | LCDD13 | SEG15<br>COM3                | SEG14<br>COM3                | SEG13<br>COM3                | SEG12<br>COM3  | SEG11<br>COM3 | SEG10<br>COM3   | SEG09<br>COM3  | SEG08<br>COM3 | XXXX XXXX                     | 92              |
| 11Eh    | LCDD14 | SEG23<br>COM3                | SEG22<br>COM3                | SEG21<br>COM3                | SEG20<br>COM3  | SEG19<br>COM3 | SEG18<br>COM3   | SEG17<br>COM3  | SEG16<br>COM3 | XXXX XXXX                     | 92              |
| 11Fh    | LCDD15 | SEG31<br>COM3 <sup>(1)</sup> | SEG30<br>COM3 <sup>(1)</sup> | SEG29<br>COM3 <sup>(1)</sup> | SEG28<br>COM3  | SEG27<br>COM3 | SEG26<br>COM3   | SEG25<br>COM3  | SEG24<br>COM3 | xxxx xxxx                     | 92              |

TABLE 2-1. SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED)

Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0'. Shaded locations are unimplemented, read as '0'. Note 1: These pixels do not display, but can be used as general purpose RAM.

## 2.4 PCL and PCLATH

The program counter (PC) is 13-bits wide. The low byte comes from the PCL register, which is a readable and writable register. The upper bits (PC<12:8>) are not readable, but are indirectly writable through the PCLATH register. On any RESET, the upper bits of the PC will be cleared. Figure 2-5 shows the two situations for the loading of the PC. The upper example in the figure shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). The lower example in the figure shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).

#### FIGURE 2-5: LOADING OF PC IN DIFFERENT SITUATIONS



#### 2.4.1 COMPUTED GOTO

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block). Refer to the application note *"Implementing a Table Read"* (AN556).

#### 2.4.2 STACK

The PIC16CXXX family has an 8-level deep x 13-bit wide hardware stack. The stack space is not part of either program or data space and the stack pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed, or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation.

The stack operates as a circular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on).

- **Note 1:** There are no status bits to indicate stack overflow or stack underflow conditions.
  - 2: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW, and RETFIE instructions, or the vectoring to an interrupt address.

## 2.5 Program Memory Paging

PIC16C925/926 devices are capable of addressing a continuous 8K word block of program memory. The CALL and GOTO instructions provide only 11-bits of address to allow branching within any 2K program memory page. When doing a CALL or GOTO instruction, the upper 2-bits of the address are provided by PCLATH<4:3>. When doing a CALL or GOTO instruction, the user must ensure that the page select bits are programmed so that the desired program memory page is addressed. If a return from a CALL instruction (or interrupt) is executed, the entire 13-bit PC is pushed onto the stack. Therefore, manipulation of the PCLATH<4:3> bits is not required for the RETURN instructions (which POPs the address from the stack).

| Note: | The contents of the PCLATH register are |
|-------|-----------------------------------------|
|       | unchanged after a RETURN or RETFIE      |
|       | instruction is executed. The user must  |
|       | rewrite the PCLATH for any subsequent   |
|       | CALL or GOTO instructions.              |

Example 2-1 shows the calling of a subroutine in page 1 of the program memory. This example assumes that PCLATH is saved and restored by the Interrupt Service Routine (if interrupts are used).

#### EXAMPLE 2-1: CALL OF A SUBROUTINE IN PAGE 1 FROM PAGE 0

| ORG 0x | 500      |                            |
|--------|----------|----------------------------|
| BCF    | PCLATH,4 |                            |
| BSF    | PCLATH,3 | ;Select page 1 (800h-FFFh) |
| CALL   | SUB1_P1  | ;Call subroutine in        |
|        | :        | ;page 1 (800h-FFFh)        |
|        | :        |                            |
|        | :        |                            |
| ORG 0x | 900      |                            |
| SUB1_P | 1:       | ;called subroutine         |
|        | :        | ;page 1 (800h-FFFh)        |
|        | :        |                            |
| RETURN |          | ;return to Call subroutine |
|        |          | ;in page 0 (000h-7FFh)     |
|        |          |                            |

© 2001-2013 Microchip Technology Inc.

#### 2.6 Indirect Addressing, INDF and FSR Registers

The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing.

Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses the register pointed to by the File Select Register (FSR). Reading the INDF register itself, indirectly (FSR = '0'), will produce 00h. Writing to the INDF register indirectly results in a no operation (although status bits may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS<7>), as shown in Figure 2-6. A simple program to clear RAM locations 20h-2Fh using indirect addressing is shown in Example 2-2.

| EXAMPLE 2-2: | NDIRECT ADDRESSING |
|--------------|--------------------|
|--------------|--------------------|

|          | MOVLW | 0x20  | ;initialize pointer  |
|----------|-------|-------|----------------------|
|          | MOVWF | FSR   | ;to RAM              |
| NEXT     | CLRF  | INDF  | ;clear INDF register |
|          | INCF  | FSR,F | ;inc pointer         |
|          | BTFSS | FSR,4 | ;all done?           |
|          | GOTO  | NEXT  | ;no clear next       |
| CONTINUE |       |       |                      |
|          | :     |       | ;yes continue        |
|          | •     |       | ,,,                  |



#### FIGURE 2-6: DIRECT/INDIRECT ADDRESSING

#### 4.6 **PORTF and TRISF Register**

PORTF is a digital input only port. Each pin is multiplexed with an LCD segment driver. These pins have Schmitt Trigger input buffers.

- **Note 1:** On a Power-on Reset, these pins are configured as LCD segment drivers.
  - 2: To configure the pins as a digital port, the corresponding bits in the LCDSE register must be cleared. Any bit set in the LCDSE register overrides any bit settings in the corresponding TRIS register.

| BCF STATUS, | RP0  | ;Select Bank2   |  |
|-------------|------|-----------------|--|
| BSF STATUS, | RP1  | ;               |  |
| BCF LCDSE,  | SE16 | ;Make all PORTF |  |
| BCF LCDSE,  | SE12 | ;digital inputs |  |



#### TABLE 4-11: PORTF FUNCTIONS

| Name      | Bit# | Buffer Type | Function                           |
|-----------|------|-------------|------------------------------------|
| RF0/SEG12 | bit0 | ST          | Digital input or Segment Driver12. |
| RF1/SEG13 | bit1 | ST          | Digital input or Segment Driver13. |
| RF2/SEG14 | bit2 | ST          | Digital input or Segment Driver14. |
| RF3/SEG15 | bit3 | ST          | Digital input or Segment Driver15. |
| RF4/SEG16 | bit4 | ST          | Digital input or Segment Driver16. |
| RF5/SEG17 | bit5 | ST          | Digital input or Segment Driver17. |
| RF6/SEG18 | bit6 | ST          | Digital input or Segment Driver18. |
| RF7/SEG19 | bit7 | ST          | Digital input or Segment Driver19. |

Legend: ST = Schmitt Trigger input

#### TABLE 4-12: SUMMARY OF REGISTERS ASSOCIATED WITH PORTF

| Address | Name  | Bit 7   | Bit 6                                 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0     | Value on<br>Power-on<br>Reset | Value on all<br>other<br>RESETS |
|---------|-------|---------|---------------------------------------|-------|-------|-------|-------|-------|-----------|-------------------------------|---------------------------------|
| 107h    | PORTF | RF7     | RF6                                   | RF5   | RF4   | RF3   | RF2   | RF1   | RF0       | 0000 0000                     | 0000 0000                       |
| 187h    | TRISF | PORTF [ | PORTF Data Direction Control Register |       |       |       |       |       | 1111 1111 | 1111 1111                     |                                 |
| 10Dh    | LCDSE | SE29    | SE27                                  | SE20  | SE16  | SE12  | SE9   | SE5   | SE0       | 1111 1111                     | 1111 1111                       |

Legend: Shaded cells are not used by PORTF.

© 2001-2013 Microchip Technology Inc.

## 4.7 PORTG and TRISG Register

PORTG is a digital input only port. Each pin is multiplexed with an LCD segment driver. These pins have Schmitt Trigger input buffers.

- **Note 1:** On a Power-on Reset, these pins are configured as LCD segment drivers.
  - 2: To configure the pins as a digital port, the corresponding bits in the LCDSE register must be cleared. Any bit set in the LCDSE register overrides any bit settings in the corresponding TRIS register.

| EXAMF | PLE 4-7: | INITIAL | INITIALIZING PORTG |  |  |  |  |
|-------|----------|---------|--------------------|--|--|--|--|
| BCF   | STATUS,  | RP0     | ;Select Bank2      |  |  |  |  |
| BSF   | STATUS,  | RP1     | i                  |  |  |  |  |
| BCF   | LCDSE,   | SE27    | ;Make all PORTG    |  |  |  |  |
| BCF   | LCDSE,   | SE20    | ;and PORTE<7>      |  |  |  |  |
|       |          |         | ;digital inputs    |  |  |  |  |



#### TABLE 4-13: PORTG FUNCTIONS

| Name      | Bit# | Buffer Type | Function                                                             |
|-----------|------|-------------|----------------------------------------------------------------------|
| RG0/SEG20 | bit0 | ST          | Digital input or Segment Driver20.                                   |
| RG1/SEG21 | bit1 | ST          | Digital input or Segment Driver21.                                   |
| RG2/SEG22 | bit2 | ST          | Digital input or Segment Driver22.                                   |
| RG3/SEG23 | bit3 | ST          | Digital input or Segment Driver23.                                   |
| RG4/SEG24 | bit4 | ST          | Digital input or Segment Driver24.                                   |
| RG5/SEG25 | bit5 | ST          | Digital input or Segment Driver25.                                   |
| RG6/SEG26 | bit6 | ST          | Digital input or Segment Driver26.                                   |
| RG7/SEG28 | bit7 | ST          | Digital input or Segment Driver28 (not available on 64-pin devices). |

Legend: ST = Schmitt Trigger input

#### TABLE 4-14: SUMMARY OF REGISTERS ASSOCIATED WITH PORTG

| Address | Name  | Bit 7 | Bit 6                                 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1     | Bit 0     | Value on<br>Power-on<br>Reset | Value on all<br>other<br>RESETS |
|---------|-------|-------|---------------------------------------|-------|-------|-------|-------|-----------|-----------|-------------------------------|---------------------------------|
| 108h    | PORTG | RG7   | RG6                                   | RG5   | RG4   | RG3   | RG2   | RG1       | RG0       | 0000 0000                     | 0000 0000                       |
| 188h    | TRISG | PORTG | PORTG Data Direction Control Register |       |       |       |       | 1111 1111 | 1111 1111 |                               |                                 |
| 10Dh    | LCDSE | SE29  | SE27                                  | SE20  | SE16  | SE12  | SE9   | SE5       | SE0       | 1111 1111                     | 1111 1111                       |

Legend: Shaded cells are not used by PORTG.

#### 5.2 Using Timer0 with an External Clock

When an external clock input is used for Timer0, it must meet certain requirements. The requirements ensure the external clock can be synchronized with the internal phase clock (Tosc). Also, there is a delay in the actual incrementing of Timer0 after synchronization.

#### 5.2.1 EXTERNAL CLOCK SYNCHRONIZATION

When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of T0CKI with the internal phase clocks is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks (Figure 5-5). Therefore, it is necessary for T0CKI to be high for at least 2Tosc (and a small RC delay of 20 ns) and low for at least 2Tosc (and a small RC delay of 20 ns). Refer to the electrical specification of the desired device. When a prescaler is used, the external clock input is divided by the asynchronous ripple counter type prescaler, so that the prescaler output is symmetrical. For the external clock to meet the sampling requirement, the ripple counter must be taken into account. Therefore, it is necessary for TOCKI to have a period of at least 4Tosc (and a small RC delay of 40 ns) divided by the prescaler value. The only requirement on TOCKI high and low time is that they do not violate the minimum pulse width requirement of 10 ns. Refer to parameters 40, 41 and 42 in the electrical specification of the desired device.

### 5.2.2 TMR0 INCREMENT DELAY

Since the prescaler output is synchronized with the internal clocks, there is a small delay from the time the external clock edge occurs to the time the Timer0 module is actually incremented. Figure 5-5 shows the delay from the external clock edge to the timer incrementing.



## 6.0 TIMER1 MODULE

Timer1 is a 16-bit timer/counter consisting of two 8-bit registers (TMR1H and TMR1L), which are readable and writable. The TMR1 Register pair (TMR1H:TMR1L) increments from 0000h to FFFFh and rolls over to 0000h. The TMR1 Interrupt, if enabled, is generated on overflow, which is latched in interrupt flag bit, TMR1IF (PIR1<0>). This interrupt can be enabled/disabled by setting/clearing TMR1 interrupt enable bit, TMR1IE (PIE1<0>).

Timer1 can operate in one of two modes:

- As a timer
- As a counter

The operating mode is determined by the clock select bit, TMR1CS (T1CON<1>).

In Timer mode, Timer1 increments every instruction cycle. In Counter mode, it increments on every rising edge of the external clock input.

Timer1 can be turned on and off using the control bit TMR1ON (T1CON<0>).

Timer1 also has an internal "RESET input". This RESET can be generated by the CCP module (Section 8.0). Register 6-1 shows the Timer1 control register.

When the Timer1 oscillator is enabled (T1OSCEN is set), the RC1/T1OSI and RC0/T1OSO/T1CKI pins become inputs, regardless of the TRISC<1:0>. RC1 and RC0 will be read as '0'.

|         |                                                                                        |                              |                | •               |                 | -           |               |        |  |  |
|---------|----------------------------------------------------------------------------------------|------------------------------|----------------|-----------------|-----------------|-------------|---------------|--------|--|--|
|         | 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         | T1SYNC      | TMR1CS        | TMR10N |  |  |
|         | bit 7                                                                                  |                              |                |                 |                 |             |               | bit 0  |  |  |
|         |                                                                                        |                              |                |                 |                 |             |               |        |  |  |
| oit 7-6 | Unimplem                                                                               | ented: Rea                   | ad as '0'      |                 |                 |             |               |        |  |  |
| oit 5-4 | T1CKPS1:                                                                               | T1CKPS0:                     | Timer1 Input   | Clock Presc     | ale Select bits | S           |               |        |  |  |
|         | 11 = 1:8 Pi                                                                            |                              |                |                 |                 |             |               |        |  |  |
|         | 10 = 1:4 Pi                                                                            | rescale valı<br>rescale valı |                |                 |                 |             |               |        |  |  |
|         |                                                                                        | rescale valu                 |                |                 |                 |             |               |        |  |  |
| oit 3   | T10SCEN                                                                                | : Timer1 Os                  | scillator Enab | le Control bit  |                 |             |               |        |  |  |
|         | 1 = Oscilla                                                                            | ator is enab                 | led            |                 |                 |             |               |        |  |  |
|         | 0 = Oscilla                                                                            | 0 = Oscillator is shut-off   |                |                 |                 |             |               |        |  |  |
|         | Nete: The                                                                              | oo oillotor in               | warter and fo  | adhaak raaia    | or ore turned   | off to alim | inata nawa    | drain  |  |  |
| oit 2   |                                                                                        |                              |                | edback resist   |                 |             | inate power   | urain. |  |  |
| JILZ    | <b>T1SYNC</b> : Timer1 External Clock Input Synchronization Control bit<br>TMR1CS = 1: |                              |                |                 |                 |             |               |        |  |  |
|         |                                                                                        |                              | ze external c  | lock input      |                 |             |               |        |  |  |
|         |                                                                                        | •                            | rnal clock inp | •               |                 |             |               |        |  |  |
|         | TMR1CS =                                                                               | <u>= 0:</u>                  |                |                 |                 |             |               |        |  |  |
|         | This bit is i                                                                          | gnored. Tin                  | ner1 uses the  | e internal cloc | k when TMR      | 1CS = 0.    |               |        |  |  |
| oit 1   | TMR1CS:                                                                                | Timer1 Clo                   | ck Source Se   | lect bit        |                 |             |               |        |  |  |
|         |                                                                                        |                              |                | (on the rising  | edge)           |             |               |        |  |  |
|         |                                                                                        | I clock (Fos                 |                |                 |                 |             |               |        |  |  |
| oit 0   | TMR10N:                                                                                |                              | bit            |                 |                 |             |               |        |  |  |
|         | 1 = Enable                                                                             |                              |                |                 |                 |             |               |        |  |  |
|         | 0 = Stops                                                                              | Imeri                        |                |                 |                 |             |               |        |  |  |
|         | Legend:                                                                                |                              |                |                 |                 |             |               |        |  |  |
|         | R = Reada                                                                              | ble bit                      | W = W          | ritable bit     | U = Unimpl      | emented b   | it. read as ' | D'     |  |  |
|         | - n = Value                                                                            |                              |                | it is set       | '0' = Bit is c  |             | x = Bit is ur |        |  |  |
|         |                                                                                        |                              | i – D          | 11 10 301       | 0 - 01.150      |             |               |        |  |  |

#### REGISTER 6-1: T1CON: TIMER1 CONTROL REGISTER (ADDRESS 10h)

### 6.3 Timer1 Operation in Asynchronous Counter Mode

If control bit  $\overline{T1SYNC}$  (T1CON<2>) is set, the external clock input is not synchronized. The timer continues to increment asynchronous to the internal phase clocks. The timer will continue to run during SLEEP and can generate an interrupt-on-overflow which will wake-up the processor. However, special precautions in software are needed to read from, or write to the Timer1 register pair (TMR1H:TMR1L) (Section 6.3.2).

In Asynchronous Counter mode, Timer1 cannot be used as a time-base for capture or compare operations.

#### 6.3.1 EXTERNAL CLOCK INPUT TIMING WITH UNSYNCHRONIZED CLOCK

If control bit  $\overline{T1SYNC}$  is set, the timer will increment completely asynchronously. The input clock must meet certain minimum high time and low time requirements, as specified in timing parameters 45, 46, and 47.

#### 6.3.2 READING AND WRITING TMR1 IN ASYNCHRONOUS COUNTER MODE

Reading TMR1H or TMR1L, while the timer is running from an external asynchronous clock, will ensure a valid read (taken care of in hardware). However, the user should keep in mind that reading the 16-bit timer in two 8-bit values itself, poses certain problems, since the timer may overflow between the reads.

For writes, it is recommended that the user simply stop the timer and write the desired values. A write contention may occur by writing to the timer registers while the register is incrementing. This may produce an unpredictable value in the timer register.

Reading the 16-bit value requires some care. Example 6-1 is an example routine to read the 16-bit timer value. This is useful if the timer cannot be stopped.

EXAMPLE 6-1: READING A 16-BIT FREE-RUNNING TIMER

```
; All interrupts are disabled
;
                  TMR1H, W
           MOVF
                              ;Read high byte
           MOVWF
                 TMPH
                              ;
           MOVF
                  TMR1L, W
                              ;Read low byte
           MOVWF
                 TMPL
                              ;
                  TMR1H, W
                             ;Read high byte
           MOVF
           SUBWF TMPH, W
                             ;Sub 1st read with 2nd read
           BTFSC STATUS,Z
                             ; Is result = 0
           GOTO
                  CONTINUE
                             ;Good 16-bit read
; TMR1L may have rolled over between the read of the high and low bytes.
; Reading the high and low bytes now will read a good value.
           MOVF
                  TMR1H, W
                              ;Read high byte
           MOVWF TMPH
                             ;
           MOVF
                 TMR1L, W
                             ;Read low byte
           MOVWF TMPL
                             ;
; Re-enable the Interrupt (if required)
CONTINUE
                              ;Continue with your code
```

## 8.0 CAPTURE/COMPARE/PWM (CCP) MODULE

The CCP (Capture/Compare/PWM) module contains a 16-bit register which can operate as a 16-bit capture register, as a 16-bit compare register, or as a PWM master/slave duty cycle register. Table 8-1 shows the timer resources used by the CCP module.

The Capture/Compare/PWM Register1 (CCPR1) is comprised of two 8-bit registers: CCPR1L (low byte) and CCPR1H (high byte). The CCP1CON register controls the operation of CCP1. All three are readable and writable. Register 8-1 shows the CCP1CON register.

For use of the CCP module, refer to the *Embedded Control Handbook*, "Using the CCP Modules" (AN594).

## TABLE 8-1:CCP MODE - TIMER<br/>RESOURCE

| CCP Mode | Timer Resource |
|----------|----------------|
| Capture  | Timer1         |
| Compare  | Timer1         |
| PWM      | Timer2         |

## REGISTER 8-1: CCP1CON REGISTER (ADDRESS 17h)

| ER 8-1: | CCP1CON                                                                                                     | REGISTE                                                  | R (ADDRE     | ESS 17h)    |              |             |               |         |  |  |  |  |
|---------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--------------|-------------|--------------|-------------|---------------|---------|--|--|--|--|
|         | U-0                                                                                                         | U-0                                                      | R/W-0        | R/W-0       | R/W-0        | R/W-0       | R/W-0         | R/W-0   |  |  |  |  |
|         | —                                                                                                           | —                                                        | CCP1X        | CCP1Y       | CCP1M3       | CCP1M2      | CCP1M1        | CCP1M0  |  |  |  |  |
|         | bit 7                                                                                                       |                                                          |              |             |              |             |               | bit 0   |  |  |  |  |
| bit 7-6 | Unimpleme                                                                                                   | ented: Read                                              | 1 as '0'     |             |              |             |               |         |  |  |  |  |
| bit 5-4 | CCP1X:CC                                                                                                    | <b>P1Y</b> : PWM                                         | Least Signit | icant bits  |              |             |               |         |  |  |  |  |
|         | <u>Capture mo</u><br>Unused                                                                                 | ode:                                                     | -            |             |              |             |               |         |  |  |  |  |
|         | <u>Compare mode:</u><br>Unused                                                                              |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | PWM mode:                                                                                                   |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | These bits a                                                                                                | are the two l                                            | LSbs of the  | PWM duty    | cycle. The e | ight MSbs a | re found in ( | CCPR1L. |  |  |  |  |
| bit 3-0 | CCP1M3:CCP1M0: CCP1 Mode Select bits                                                                        |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | •                                                                                                           | 0000 = Capture/Compare/PWM disabled (resets CCP1 module) |              |             |              |             |               |         |  |  |  |  |
|         |                                                                                                             | oture mode,                                              |              |             |              |             |               |         |  |  |  |  |
|         | 0101 = Capture mode, every rising edge                                                                      |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | 0110 = Capture mode, every 4th rising edge                                                                  |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | 0111 = Capture mode, every 16th rising edge<br>1000 = Compare mode, set output on match (bit CCP1IF is set) |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | 1001 = Compare mode, clear output on match (bit CCP1IF is set)                                              |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | 1010 = Compare mode, generate software interrupt-on-match (bit CCP1IF is set, CCP1 pin is unaffected)       |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | 1011 = Compare mode, trigger special event (CCP1IF bit is set; CCP1 resets TMR1)                            |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | 11xx = PW                                                                                                   | 11xx = PWM mode                                          |              |             |              |             |               |         |  |  |  |  |
|         |                                                                                                             |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | Legend:                                                                                                     |                                                          |              |             |              |             |               |         |  |  |  |  |
|         | R = Readat                                                                                                  | ole bit                                                  | W = W        | ritable bit | U = Unin     | nplemented  | bit, read as  | '0'     |  |  |  |  |
|         | - n = Value                                                                                                 | at POR                                                   | '1' = B      | it is set   | '0' = Bit i  | s cleared   | x = Bit is u  | inknown |  |  |  |  |

To enable the serial port, SSP enable bit, SSPEN (SSPCON<5>) must be set. To reset or reconfigure SPI mode, clear bit SSPEN, re-initialize the SSPCON register, and then set bit SSPEN. This configures the SDI, SDO, SCK, and SS pins as serial port pins. For the pins to behave as the serial port function, they must have their data direction bits (in the TRISC register) appropriately programmed. That is:

- SDI must have TRISC<4> set
- SDO must have TRISC<5> cleared
- SCK (Master mode) must have TRISC<3> cleared
- SCK (Slave mode) must have TRISC<3> set
- SS must have TRISA<5> set and ADCON must be configured such that RA5 is a digital I/O

Any serial port function that is not desired may be overridden by programming the corresponding data direction (TRIS) register to the opposite value. An example would be in Master mode, where you are only sending data (to a display driver), then both SDI and SS could be used as general purpose outputs by clearing their corresponding TRIS register bits.

Figure 9-2 shows a typical connection between two microcontrollers. The master controller (Processor 1) initiates the data transfer by sending the SCK signal. Data is shifted out of both shift registers on their programmed clock edge, and latched on the opposite edge of the clock. Both processors should be programmed to same Clock Polarity (CKP), then both controllers would send and receive data at the same time. Whether the data is meaningful (or dummy data), depends on the application software. This leads to three scenarios for data transmission:

- Master sends data Slave sends dummy data
- Master sends data Slave sends data

• Master sends dummy data - Slave sends data

The master can initiate the data transfer at any time because it controls the SCK. The master determines when the slave (Processor 2) is to broadcast data by the firmware protocol.

In Master mode, the data is transmitted/received as soon as the SSPBUF register is written to. If the SPI is only going to receive, the SCK output could be disabled (programmed as an input). The SSPSR register will continue to shift in the signal present on the SDI pin at the programmed clock rate. As each byte is received, it will be loaded into the SSPBUF register as if a normal received byte (interrupts and status bits appropriately set). This could be useful in receiver applications as a "line activity monitor" mode.

In Slave mode, the data is transmitted and received as the external clock pulses appear on SCK. When the last bit is latched, the interrupt flag bit SSPIF (PIR1<3>) is set.

The clock polarity is selected by appropriately programming bit CKP (SSPCON<4>). This then, would give waveforms for SPI communication as shown in Figure 9-3, Figure 9-4, and Figure 9-5, where the MSB is transmitted first. In Master mode, the SPI clock rate (bit rate) is user programmable to be one of the following:

- Fosc/4 (or Tcy)
- Fosc/16 (or 4 Tcy)
- Fosc/64 (or 16 Tcy)
- Timer2 output/2

This allows a maximum bit clock frequency (at 8 MHz) of 2 MHz. When in Slave mode, the external clock must meet the minimum high and low times.

In SLEEP mode, the slave can transmit and receive data and wake the device from SLEEP.



#### FIGURE 9-2: SPI MASTER/SLAVE CONNECTION

#### 9.3.2 MASTER MODE

Master mode of operation is supported, in firmware, using interrupt generation on the detection of the START and STOP conditions. The STOP (P) and START (S) bits are cleared from a RESET, or when the SSP module is disabled. The STOP and START bits will toggle based on the START and STOP conditions. Control of the  $I^2C$  bus may be taken when the P bit is set, or the bus is idle with both the S and P bits clear.

In Master mode, the SCL and SDA lines are manipulated by clearing the corresponding TRISC<4:3> bit(s). The output level is always low, irrespective of the value(s) in PORTC<4:3>. So when transmitting data, a '1' data bit must have the TRISC<4> bit set (input) and a '0' data bit must have the TRISC<4> bit cleared (output). The same scenario is true for the SCL line with the TRISC<3> bit.

The following events will cause SSP Interrupt Flag bit, SSPIF, to be set (SSP Interrupt if enabled):

- START condition
- STOP condition
- Data transfer byte transmitted/received

Master mode of operation can be done with either the Slave mode idle (SSPM3:SSPM0 = 1011), or with the slave active. When both Master and Slave modes are enabled, the software needs to differentiate the source(s) of the interrupt.

### 9.3.3 MULTI-MASTER MODE

In Multi-Master mode, the interrupt generation on the detection of the START and STOP conditions allows the determination of when the bus is free. The STOP (P) and START (S) bits are cleared from a RESET or when the SSP module is disabled. The STOP and START bits will toggle based on the START and STOP conditions. Control of the I<sup>2</sup>C bus may be taken when bit P (SSPSTAT<4>) is set, or the bus is idle, with both the S and P bits clear. When the bus is busy, enabling the SSP interrupt will generate the interrupt when the STOP condition occurs.

In multi-master operation, the SDA line must be monitored to see if the signal level is the expected output level. This check only needs to be done when a high level is output. If a high level is expected and a low level is present, the device needs to release the SDA and SCL lines (set TRISC<4:3>). There are two stages where this arbitration can be lost, they are:

- Address Transfer
- Data Transfer

When the slave logic is enabled, the slave continues to receive. If arbitration was lost during the address transfer stage, communication to the device may be in progress. If addressed, an ACK pulse will be generated. If arbitration was lost during the data transfer stage, the device will need to re-transfer the data at a later time.

| Address                 | Name    | Bit 7     | Bit 6       | Bit 5                    | Bit 4       | Bit 3       | Bit 2                                | Bit 1  | Bit 0  | Value on<br>Power-on<br>Reset | Value on all<br>other<br>RESETS |
|-------------------------|---------|-----------|-------------|--------------------------|-------------|-------------|--------------------------------------|--------|--------|-------------------------------|---------------------------------|
| 0Bh, 8Bh,<br>10Bh, 18Bh | INTCON  | GIE       | PEIE        | TMR0IE                   | INTE        | RBIE        | TMR0IF                               | INTF   | RBIF   | 0000 000x                     | 0000 000u                       |
| 0Ch                     | PIR1    | LCDIF     | ADIF        | —                        | —           | SSPIF       | CCP1IF                               | TMR2IF | TMR1IF | 00 0000                       | 00 0000                         |
| 8Ch                     | PIE1    | LCDIE     | ADIE        | —                        | —           | SSPIE       | CCP1IE                               | TMR2IE | TMR1IE | 00 0000                       | 00 0000                         |
| 13h                     | SSPBUF  | Synchrono | us Serial F | Port Receiv              | /e Buffer/1 | ransmit R   | egister                              |        |        | xxxx xxxx                     | uuuu uuuu                       |
| 93h                     | SSPADD  | Synchrono | us Serial F | Port (I <sup>2</sup> C m | ode) Addr   | ess Regis   | ster                                 |        |        | 0000 0000                     | 0000 0000                       |
| 14h                     | SSPCON  | WCOL      | SSPOV       | SSPEN                    | CKP         | SSPM3       | SSPM2                                | SSPM1  | SSPM0  | 0000 0000                     | 0000 0000                       |
| 94h                     | SSPSTAT | SMP       | CKE         | D/A                      | Р           | S           | R/W                                  | UA     | BF     | 0000 0000                     | 0000 0000                       |
| 87h                     | TRISC   | —         | —           | PORTC D                  | ata Direct  | tion Contro | ORTC Data Direction Control Register |        |        |                               |                                 |

#### TABLE 9-4:REGISTERS ASSOCIATED WITH I<sup>2</sup>C OPERATION

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by SSP in I<sup>2</sup>C mode.

NOTES:

| BCF                | Bit Clear                                                           | f                       |                 |                       |  |  |
|--------------------|---------------------------------------------------------------------|-------------------------|-----------------|-----------------------|--|--|
| Syntax:            | [ label ] B                                                         | SCF f[                  | ,b]             |                       |  |  |
| Operands:          | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ |                         |                 |                       |  |  |
| Operation:         | $0 \rightarrow (f < b;$                                             | >)                      |                 |                       |  |  |
| Status Affected:   | None                                                                |                         |                 |                       |  |  |
| Encoding:          | 01                                                                  | 00bb                    | bfff            | ffff                  |  |  |
| Description:       | Bit 'b' in register 'f' is cleared.                                 |                         |                 |                       |  |  |
| Words:             | 1                                                                   |                         |                 |                       |  |  |
| Cycles:            | 1                                                                   |                         |                 |                       |  |  |
| Q Cycle Activity:  | Q1                                                                  | Q2                      | Q3              | Q4                    |  |  |
|                    | Decode                                                              | Read<br>register<br>'f' | Process<br>data | Write<br>register 'f' |  |  |
| Example            | BCF                                                                 | FLAG_                   | REG, 7          |                       |  |  |
| After Instruction: | $AG_REG = 0xC7$                                                     |                         |                 |                       |  |  |
| FLAG_RE            | :G = (                                                              | )x47                    |                 |                       |  |  |

| BTFSC                                                                                              | Bit Test,                                              | Skip if Cl                                                                                                                                                                                                                         | ear                |                 |  |  |  |
|----------------------------------------------------------------------------------------------------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------|--|--|--|
| Syntax:                                                                                            | [ <i>label</i> ] E                                     | STFSC f                                                                                                                                                                                                                            | ,b]                |                 |  |  |  |
| Operands:                                                                                          | $0 \le f \le 12$                                       | 27                                                                                                                                                                                                                                 |                    |                 |  |  |  |
|                                                                                                    | $0 \le b \le 7$                                        |                                                                                                                                                                                                                                    |                    |                 |  |  |  |
| Operation:                                                                                         | skip if (f<                                            | b>) = 0                                                                                                                                                                                                                            |                    |                 |  |  |  |
| Status Affected:                                                                                   | None                                                   |                                                                                                                                                                                                                                    |                    |                 |  |  |  |
| Encoding:                                                                                          | 01                                                     | 10bb                                                                                                                                                                                                                               | bfff               | ffff            |  |  |  |
| Description:                                                                                       | next instr<br>If bit 'b' in<br>next instr<br>NOP is ex | If bit 'b' in register 'f' is '1', then the<br>next instruction is executed.<br>If bit 'b' in register 'f' is '0', then the<br>next instruction is discarded, and a<br>NOP is executed instead, making this a<br>2Tcy instruction. |                    |                 |  |  |  |
| Words:                                                                                             | 1                                                      | 1                                                                                                                                                                                                                                  |                    |                 |  |  |  |
| Cycles:                                                                                            | 1(2)                                                   |                                                                                                                                                                                                                                    |                    |                 |  |  |  |
| Q Cycle Activity:                                                                                  | Q1                                                     | Q2                                                                                                                                                                                                                                 | Q3                 | Q4              |  |  |  |
|                                                                                                    | Decode                                                 | Read<br>register 'f'                                                                                                                                                                                                               | Process<br>data    | No<br>Operation |  |  |  |
| If Skip:                                                                                           | (2nd Cyc                                               | le)                                                                                                                                                                                                                                |                    |                 |  |  |  |
|                                                                                                    | Q1                                                     | Q2                                                                                                                                                                                                                                 | Q3                 | Q4              |  |  |  |
|                                                                                                    | No<br>Operation                                        | No<br>Operation                                                                                                                                                                                                                    | No<br>Operation    | No<br>Operation |  |  |  |
| Example                                                                                            |                                                        | BTFSC<br>GOTO<br>•<br>•                                                                                                                                                                                                            | FLAG,1<br>PROCESS_ | CODE            |  |  |  |
| Before Instru<br>PC                                                                                |                                                        | SS HERE                                                                                                                                                                                                                            |                    |                 |  |  |  |
| PC = address HERE<br>After Instruction:<br>if FLAG<1> = 0,<br>PC = address TRUE<br>if FLAG<1> = 1, |                                                        |                                                                                                                                                                                                                                    |                    |                 |  |  |  |

PC = address FALSE

| BSF                                                             | Bit Set f                                                          |                         |                 |                       |  |  |
|-----------------------------------------------------------------|--------------------------------------------------------------------|-------------------------|-----------------|-----------------------|--|--|
| Syntax:                                                         | [ <i>label</i> ] B                                                 | SFf[,                   | b]              |                       |  |  |
| Operands:                                                       | $\begin{array}{l} 0 \leq f \leq 12 \\ 0 \leq b \leq 7 \end{array}$ | 7                       |                 |                       |  |  |
| Operation:                                                      | $1 \rightarrow (f < b;$                                            | >)                      |                 |                       |  |  |
| Status Affected:                                                | None                                                               |                         |                 |                       |  |  |
| Encoding:                                                       | 01                                                                 | 01bb                    | bfff            | ffff                  |  |  |
| Description:                                                    | Bit 'b' in register 'f' is set.                                    |                         |                 |                       |  |  |
| Words:                                                          | 1                                                                  |                         |                 |                       |  |  |
| Cycles:                                                         | 1                                                                  |                         |                 |                       |  |  |
| Q Cycle Activity:                                               | Q1                                                                 | Q2                      | Q3              | Q4                    |  |  |
|                                                                 | Decode                                                             | Read<br>register<br>'f' | Process<br>data | Write<br>register 'f' |  |  |
| Example                                                         | BSF                                                                | FLAG RE                 | G, 7            | L]                    |  |  |
| Before Instruction:<br>FLAG_RI<br>After Instruction:<br>FLAG_RI |                                                                    | –<br>x0A<br>x8A         |                 |                       |  |  |

| Q4 |  |
|----|--|

| DECF                      | Decreme                                                               | ent f                   |                 |                                         |
|---------------------------|-----------------------------------------------------------------------|-------------------------|-----------------|-----------------------------------------|
| Syntax:                   | [ label ]                                                             | DECF f                  | [,d]            |                                         |
| Operands:                 | $\begin{array}{l} 0\leq f\leq 12\\ d\in \left[0,1\right] \end{array}$ | 27                      |                 |                                         |
| Operation:                | (f) - 1 $\rightarrow$                                                 | (destina                | tion)           |                                         |
| Status Affected:          | Z                                                                     |                         |                 |                                         |
| Encoding:                 | 0 0                                                                   | 0011                    | dfff            | ffff                                    |
| Description:              | result is s                                                           | stored in<br>result is  |                 | ' is 0, the<br>gister. If 'd'<br>ick in |
| Words:                    | 1                                                                     |                         |                 |                                         |
| Cycles:                   | 1                                                                     |                         |                 |                                         |
| Q Cycle Activity:         | Q1                                                                    | Q2                      | Q3              | Q4                                      |
|                           | Decode                                                                | Read<br>register<br>'f' | Process<br>data | Write to destination                    |
| Example                   | DECF                                                                  | CNT,                    | 1               |                                         |
| Before Instruct           | tion:                                                                 |                         |                 |                                         |
| CNT =<br>Z =              |                                                                       |                         |                 |                                         |
| After Instructio<br>CNT = | n:<br>= 0x00                                                          |                         |                 |                                         |

| DECFSZ                   | Decreme                                                                                                                                                                                                                                                                                                                   | ent f, Skip                | o if O          |                      |  |  |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-----------------|----------------------|--|--|
| Syntax:                  | [ label ]                                                                                                                                                                                                                                                                                                                 | DECFSZ                     | f [,d]          |                      |  |  |
| Operands:                | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                                                                                                                                                           |                            |                 |                      |  |  |
| Operation:               | (f) - 1 $\rightarrow$ skip if res                                                                                                                                                                                                                                                                                         | (destinatio<br>sult = 0    | on);            |                      |  |  |
| Status Affected:         | None                                                                                                                                                                                                                                                                                                                      |                            |                 |                      |  |  |
| Encoding:                | 0 0                                                                                                                                                                                                                                                                                                                       | 1011                       | dfff            | ffff                 |  |  |
| Description:             | The contents of register 'f' are decre-<br>mented. If 'd' is 0, the result is placed<br>in the W register. If 'd' is 1, the result<br>is placed back in register 'f'.<br>If the result is 1, the next instruction is<br>executed. If the result is 0, then a NOP<br>is executed instead, making it a 2TCY<br>instruction. |                            |                 |                      |  |  |
| Words:                   | 1                                                                                                                                                                                                                                                                                                                         |                            |                 |                      |  |  |
| Cycles:                  | 1(2)                                                                                                                                                                                                                                                                                                                      |                            |                 |                      |  |  |
| Q Cycle Activity:        | Q1                                                                                                                                                                                                                                                                                                                        | Q2                         | Q3              | Q4                   |  |  |
|                          | Decode                                                                                                                                                                                                                                                                                                                    | Read<br>register 'f'       | Process<br>data | Write to destination |  |  |
| If Skip: (2nd C          | ycle)                                                                                                                                                                                                                                                                                                                     |                            |                 |                      |  |  |
|                          | Q1                                                                                                                                                                                                                                                                                                                        | Q2                         | Q3              | Q4                   |  |  |
|                          | No<br>Operation                                                                                                                                                                                                                                                                                                           | No<br>Operation            | No<br>Operation | No<br>Operation      |  |  |
| Example                  | HERE<br>CONTINUE                                                                                                                                                                                                                                                                                                          | DECFSZ<br>GOTO<br>E •<br>• | CNT,<br>LOOP    | 1                    |  |  |
| Before Instruc<br>PC = a | uction:<br>address HERE                                                                                                                                                                                                                                                                                                   |                            |                 |                      |  |  |
| if CNT =<br>PC =         |                                                                                                                                                                                                                                                                                                                           |                            |                 |                      |  |  |

PC = address HERE+1

| GOTO              | Unconditional Branch                                                                                                                             | INCF                   | Increment f                                                                                                                                                           |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] GOTO k                                                                                                                          | Syntax:                | [label] INCF f[,d]                                                                                                                                                    |
| Operands:         | $0 \le k \le 2047$                                                                                                                               | Operands:              | $0 \leq f \leq 127$                                                                                                                                                   |
| Operation:        | $k \rightarrow PC < 10:0 >$                                                                                                                      |                        | d ∈ [0,1]                                                                                                                                                             |
|                   | $PCLATH<4:3> \rightarrow PC<12:11>$                                                                                                              | Operation:             | (f) + 1 $\rightarrow$ (destination)                                                                                                                                   |
| Status Affected:  | None                                                                                                                                             | Status Affected:       | Z                                                                                                                                                                     |
| Encoding:         | 10 1kkk kkkk kkkk                                                                                                                                | Encoding:              | 00 1010 dfff ffff                                                                                                                                                     |
| Description:      | GOTO is an unconditional branch. The eleven-bit immediate value is loaded into PC bits <10:0>. The upper bits of PC are loaded from PCLATH<4:3>. | Description:           | The contents of register 'f' are incre-<br>mented. If 'd' is 0, the result is placed<br>in the W register. If 'd' is 1, the result<br>is placed back in register 'f'. |
|                   | GOTO is a two-cycle instruction.                                                                                                                 | Words:                 | 1                                                                                                                                                                     |
| Words:            | 1                                                                                                                                                | Cycles:                | 1                                                                                                                                                                     |
| Cycles:           | 2                                                                                                                                                | Q Cycle Activity:      | Q1 Q2 Q3 Q4                                                                                                                                                           |
| Q Cycle Activity: | Q1 Q2 Q3 Q4                                                                                                                                      | Q Oycle Adimity.       | Bead                                                                                                                                                                  |
| 1st Cycle         | Decode Read Process Write to<br>literal 'k' data PC                                                                                              |                        | Decode register<br>'f' Process Write to<br>data destination                                                                                                           |
| 2nd Cycle         | NoNoNoOperationOperationOperation                                                                                                                | Example                | INCF CNT, 1                                                                                                                                                           |
|                   |                                                                                                                                                  | Before Instru          | ction:                                                                                                                                                                |
| Example           | GOTO THERE                                                                                                                                       | CNT                    | = 0xFF                                                                                                                                                                |
| After Instruct    |                                                                                                                                                  | Z                      | = 0                                                                                                                                                                   |
| PC =              | Address THERE                                                                                                                                    | After Instructi<br>CNT | ion:<br>= 0x00                                                                                                                                                        |

Z = 1

| SUBLW                 | Subtract W from Literal                                                                          | SUBWF                 | Subtract W from f                                                                                                                                                                   |
|-----------------------|--------------------------------------------------------------------------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:               | [ <i>label</i> ] SUBLW k                                                                         | Syntax:               | [ <i>label</i> ] SUBWF f [,d]                                                                                                                                                       |
| Operands:             | $0 \leq k \leq 255$                                                                              | Operands:             | 0 ≤ f ≤ 127<br>d ∈ [0,1]                                                                                                                                                            |
| Operation:            | $k - (W) \to (W)$                                                                                | Operation:            |                                                                                                                                                                                     |
| Status Affected:      | C, DC, Z                                                                                         | -                     | (f) - (W) $\rightarrow$ (destination)                                                                                                                                               |
| Encoding:             | 11 110x kkkk kkkk                                                                                | Status Affected:      | C, DC, Z                                                                                                                                                                            |
| Description:          | The W register is subtracted (2's                                                                | Encoding:             | 00 0010 dfff ffff                                                                                                                                                                   |
|                       | complement method) from the eight-<br>bit literal 'k'. The result is placed in th<br>W register. |                       | Subtract (2's complement method) W<br>register from register 'f'. If 'd' is 0, the<br>result is stored in the W register. If 'd' is<br>1, the result is stored back in register 'f' |
| Words:                | 1                                                                                                | Words:                |                                                                                                                                                                                     |
| Cycles:               | 1                                                                                                | Cycles:               | 1                                                                                                                                                                                   |
| Q Cycle Activity:     | Q1 Q2 Q3 Q4                                                                                      | -                     | ' Q1 Q2 Q3 Q4                                                                                                                                                                       |
|                       | Decode Read Process<br>literal 'k' data Write to                                                 | Q Cycle Activity:     | Read Process Write to                                                                                                                                                               |
|                       |                                                                                                  |                       | Decode register 'f' data destination                                                                                                                                                |
| Example 1:            | SUBLW 0x02                                                                                       |                       |                                                                                                                                                                                     |
| Before Instru         |                                                                                                  | Example 1:            | SUBWF REG1,1                                                                                                                                                                        |
| W =                   | 1                                                                                                | Before Instru         | uction:                                                                                                                                                                             |
| C =                   | ?                                                                                                | REG1                  | = 3                                                                                                                                                                                 |
| Z =                   | ?                                                                                                | W<br>C                | = 2<br>= ?                                                                                                                                                                          |
| After Instruct<br>W = | 1                                                                                                | Z                     | = ?                                                                                                                                                                                 |
| C =                   | 1; result is positive                                                                            | After Instruc         | tion:                                                                                                                                                                               |
| Z =                   | 0                                                                                                | REG1<br>W             | = 1<br>= 2                                                                                                                                                                          |
| Example 2:            |                                                                                                  | C                     | <ul><li>= 2</li><li>= 1; result is positive</li></ul>                                                                                                                               |
| Before Instru<br>W =  | iction:<br>2                                                                                     | Z                     | = 0                                                                                                                                                                                 |
| C =                   | ?                                                                                                | Example 2:            |                                                                                                                                                                                     |
| Z =                   | ?                                                                                                | Before Instru         |                                                                                                                                                                                     |
| After Instruct        |                                                                                                  | REG1<br>W             | = 2<br>= 2                                                                                                                                                                          |
| W =<br>C =            | 0<br>1; result is zero                                                                           | С                     | = ?                                                                                                                                                                                 |
| Z =                   | 1                                                                                                | Z                     | = ?                                                                                                                                                                                 |
| Example 3:            |                                                                                                  | After Instruc         |                                                                                                                                                                                     |
| Before Instru         | iction:                                                                                          | REG1<br>W             | = 0<br>= 2                                                                                                                                                                          |
| W =<br>C =            | 3<br>?                                                                                           | С                     | = 1; result is zero                                                                                                                                                                 |
| Z =                   |                                                                                                  | Z                     | = 1                                                                                                                                                                                 |
| After Instruct        | tion:                                                                                            | Example 3:            |                                                                                                                                                                                     |
| W =                   | 0xFF                                                                                             | Before Instru<br>REG1 | uction:<br>= 1                                                                                                                                                                      |
| C =<br>Z =            | , 0                                                                                              | W                     | = 2                                                                                                                                                                                 |
|                       | 0                                                                                                | C                     | = ?                                                                                                                                                                                 |
|                       |                                                                                                  | Z<br>After Instrue    | = ?                                                                                                                                                                                 |
|                       |                                                                                                  | After Instruc<br>REG1 | tion:<br>= 0xFF                                                                                                                                                                     |
|                       |                                                                                                  | W                     | = 2                                                                                                                                                                                 |
|                       |                                                                                                  | C<br>Z                | <ul><li>= 0; result is negative</li><li>= 0</li></ul>                                                                                                                               |
|                       |                                                                                                  | ۷.                    | - 0                                                                                                                                                                                 |

| scription:     | reg<br>res | ister fr<br>ult is s | om registe<br>tored in the<br>ult is store | er 'f'. If 'd' i<br>e W regist | s 0, the             |
|----------------|------------|----------------------|--------------------------------------------|--------------------------------|----------------------|
| ds:            | 1          |                      |                                            |                                |                      |
| les:           | 1          |                      |                                            |                                |                      |
| ycle Activity: |            | Q1                   | Q2                                         | Q3                             | Q4                   |
|                | De         | ecode                | Read<br>register 'f'                       | Process<br>data                | Write to destination |
| mple 1:        | SUI        | BWF                  | reg1,1                                     |                                |                      |
| Before Instru  | ctior      | า:                   |                                            |                                |                      |
| REG1           | =          | 3                    |                                            |                                |                      |
| W              | =          | 2                    |                                            |                                |                      |
| C              | =          | ?                    |                                            |                                |                      |
| Z              | =          | ?                    |                                            |                                |                      |
| After Instruct | ion:       |                      |                                            |                                |                      |
| REG1           | =          | 1                    |                                            |                                |                      |
| W              | =          | 2                    |                                            |                                |                      |
| C              | =          |                      | sult is posi                               | tive                           |                      |
| Z              | =          | 0                    |                                            |                                |                      |
| mple 2:        |            |                      |                                            |                                |                      |
| Before Instru  | ctior      | า:                   |                                            |                                |                      |
| REG1           | =          | 2                    |                                            |                                |                      |
| W              | =          | 2                    |                                            |                                |                      |
| С              | =          | ?                    |                                            |                                |                      |
| Z              | =          | ?                    |                                            |                                |                      |
| After Instruct | ion:       |                      |                                            |                                |                      |
| REG1           | =          | 0                    |                                            |                                |                      |
| W              | =          | 2                    |                                            |                                |                      |
| C              | =          |                      | sult is zero                               | )                              |                      |
| Z              | =          | 1                    |                                            |                                |                      |
| mple 3:        |            |                      |                                            |                                |                      |
| Before Instru  | ctior      | า:                   |                                            |                                |                      |
| REG1           | =          | 1                    |                                            |                                |                      |
| W              | =          | 2                    |                                            |                                |                      |
| С              | =          | ?                    |                                            |                                |                      |
| Z              | =          | ?                    |                                            |                                |                      |
| After Instruct | ion:       |                      |                                            |                                |                      |
| REG1           | =          | 0xFF                 |                                            |                                |                      |
| \٨/            | _          | 2                    |                                            |                                |                      |

|                                                                      | PIC12CX | PIC14000 | PIC16C5 | DICI6C     | (Cabrolq | PIC16F6 | D910Iq     | 2091019 | PIC16C | PIC16F8 | PIC16C9 | PIC17C4 | 2271219 | PIC18CX | 83CXX<br>52CXX<br>54CXX | кххээн | МСКЕХХ | MCP2510 |
|----------------------------------------------------------------------|---------|----------|---------|------------|----------|---------|------------|---------|--------|---------|---------|---------|---------|---------|-------------------------|--------|--------|---------|
| MPLAB <sup>®</sup> Integrated<br>Development Environment             | >       | ^        | >       | >          | ~        | ~       | ~          | ~       | ~      | >       | >       | >       | >       | >       |                         |        |        |         |
| MPLAB <sup>®</sup> C17 C Compiler                                    |         |          |         |            |          |         |            |         |        |         |         | >       | >       |         |                         |        |        |         |
| MPLAB <sup>®</sup> C18 C Compiler                                    |         |          |         |            |          |         |            |         |        |         |         |         |         | `       |                         |        |        |         |
| MPASM <sup>TM</sup> Assembler/<br>MPLINK <sup>TM</sup> Object Linker | >       | ^        | >       | >          | ^        | ^       | ~          | ~       | ~      | >       | >       | >       | >       | >       | `                       | >      |        |         |
| MPLAB <sup>®</sup> ICE In-Circuit Emulator                           | ~       | ~        | >       | >          | >        | **/     | >          | >       | 1      | `       | ~       | >       | >       | >       |                         |        |        |         |
| ICEPIC <sup>TM</sup> In-Circuit Emulator                             | >       |          | >       | >          | >        |         | ~          | ~       | >      |         | >       |         |         |         |                         |        |        |         |
| MPLAB® ICD In-Circuit<br>Debugger                                    |         |          |         | *          |          |         | *>         |         |        | >       |         |         |         |         |                         |        |        |         |
| PICSTART® Plus Entry Level<br>Development Programmer                 | >       | >        | >       | >          | >        | **/     | >          | >       | ~      | >       | >       | >       | >       | >       |                         |        |        |         |
| PRO MATE <sup>®</sup> II<br>Universal Device Programmer              | >       | ~        | >       | >          | >        | **/     | ~          | >       | >      | >       | >       | >       | >       | >       | >                       | >      |        |         |
| PICDEM <sup>TM</sup> 1 Demonstration<br>Board                        |         |          | >       |            | >        |         | + <b>,</b> |         | ~      |         |         | >       |         |         |                         |        |        |         |
| PICDEM <sup>TM</sup> 2 Demonstration<br>Board                        |         |          |         | <b>^</b> + |          |         | <b>*</b> + |         |        |         |         |         |         | >       |                         |        |        |         |
| PICDEM <sup>TM</sup> 3 Demonstration<br>Board                        |         |          |         |            |          |         |            |         |        |         | >       |         |         |         |                         |        |        |         |
| PICDEM <sup>TM</sup> 14A Demonstration<br>Board                      |         | >        |         |            |          |         |            |         |        |         |         |         |         |         |                         |        |        |         |
| PICDEM <sup>TM</sup> 17 Demonstration<br>Board                       |         |          |         |            |          |         |            |         |        |         |         |         | >       |         |                         |        |        |         |
| KEELoq <sup>®</sup> Evaluation Kit                                   |         |          |         |            |          |         |            |         |        |         |         |         |         |         |                         | >      |        |         |
| KEELoa <sup>®</sup> Transponder Kit                                  |         |          |         |            |          |         |            |         |        |         |         |         |         |         |                         | ~      |        |         |
| microlD™ Programmer's Kit                                            |         |          | _       |            |          |         |            |         |        |         |         |         |         |         |                         |        | ~      |         |
| 125 kHz microlD™<br>Developer's Kit                                  |         |          |         |            |          |         |            |         |        |         |         |         |         |         |                         |        | >      |         |
| 125 kHz Anticollision microlD™<br>Developer's Kit                    |         |          |         |            |          |         |            |         |        |         |         |         |         |         |                         |        | `      |         |
| 13.56 MHz Anticollision<br>microlD™ Developer's Kit                  |         |          |         |            |          |         |            |         |        |         |         |         |         |         |                         |        | >      |         |
| MCP2510 CAN Developer's Kit                                          |         |          |         |            |          |         |            |         |        |         |         |         |         |         |                         |        |        | >       |

TABLE 14-1: DEVELOPMENT TOOLS FROM MICROCHIP

© 2001-2013 Microchip Technology Inc.

| Param<br>No. | Symbol                | Characteristic                                                        |             | Min          | Тур†     | Max              | Units | Conditions |
|--------------|-----------------------|-----------------------------------------------------------------------|-------------|--------------|----------|------------------|-------|------------|
| 70           | TssL2scH,<br>TssL2scL | $\overline{SS}\downarrow$ to SCK $\downarrow$ or SCK $\uparrow$ input |             | Тсү          | —        | —                | ns    |            |
| 71           | TscH                  | SCK input high time (Slave                                            | Continuous  | 1.25Tcy + 30 | _        |                  | ns    |            |
| 71A          |                       | mode)                                                                 | Single Byte | 40           | —        | —                | ns    |            |
| 72           | TscL                  | SCK input low time (Slave                                             | Continuous  | 1.25Tcy + 30 | —        | $\leq 1$         | ns    |            |
| 72A          |                       | mode)                                                                 | Single Byte | 40           | D        | $) \leq \langle$ |       |            |
| 73           | TdiV2scH,<br>TdiV2scL | Setup time of SDI data input                                          | to SCK edge | 50           | X H      | $\sum$           | ns    |            |
| 74           | TscH2diL,<br>TscL2diL | Hold time of SDI data input to                                        | o SCIK edge | 50           | <u> </u> | —                | ns    |            |
| 75           | TdoR                  | SDO data output rise time                                             | UVAUT D     | <u> </u>     | 10       | 25               | ns    |            |
| 76           | TdoF                  | SDO data output fall time                                             | U.          | —            | 10       | 25               | ns    |            |
| 77           | TssH2doZ              | to SDO output hi-imped                                                | ance        | 10           | —        | 50               | ns    |            |
| 78           | TscR                  | SCK output rise time (Master                                          | r mode)     | —            | 10       | 25               | ns    |            |
| 79           | TscF                  | SCK output fall time (Master mode)                                    |             | —            | 10       | 25               | ns    |            |
| 80           | TscH2doV,<br>TscL2doV | SDO data output valid after SCK edge                                  |             | —            | —        | 50               | ns    |            |
| 81           | TdoV2scH,<br>TdoV2scL | SDO data output setup to SCK edge                                     |             | Тсү          | —        | —                | ns    |            |
| 82           | TssL2doV              | SDO data output valid after S                                         | SS↓ edge    | —            | —        | 50               | ns    |            |
| 83           | TscH2ssH,<br>TscL2ssH | SS ↑ after SCK edge                                                   |             | 1.5Tcy + 40  | —        | —                | ns    |            |
| 84           | Tb2b                  | Delay between consecutive b                                           | oytes       | 1.5TCY + 40  |          |                  | ns    |            |

#### TABLE 15-8: SPI MODE REQUIREMENTS

† Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.