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 - Microcontrollers</u>" | D-4-11- | | |----------------------------|--------------------------------------------------------------------------| | Details | | | Product Status | Active | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 4MHz | | Connectivity | I <sup>2</sup> C, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, POR, PWM, WDT | | Number of I/O | 33 | | Program Memory Size | 14KB (8K x 14) | | Program Memory Type | OTP | | EEPROM Size | - | | RAM Size | 368 x 8 | | Voltage - Supply (Vcc/Vdd) | 4V ~ 6V | | Data Converters | - | | Oscillator Type | External | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Through Hole | | Package / Case | 40-DIP (0.600", 15.24mm) | | Supplier Device Package | 40-PDIP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16c67-04i-p | TABLE 4-3: SPECIAL FUNCTION REGISTERS FOR THE PIC16C63/R63 | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on<br>all other<br>resets <sup>(3)</sup> | |----------------------|---------|--------------------|-----------------------------------|---------------|----------------|---------------|-----------------|---------------|-----------|--------------------------|------------------------------------------------| | Bank 0 | | | | | | | | | | | | | 00h <sup>(1)</sup> | INDF | Addressing | this location | uses conter | nts of FSR to | address data | a memory (n | ot a physical | register) | 0000 0000 | 0000 0000 | | 01h | TMR0 | Timer0 mod | lule's registe | r | | | | | | xxxx xxxx | uuuu uuuu | | 02h <sup>(1)</sup> | PCL | Program Co | ounter's (PC) | Least Signi | ficant Byte | | | | | 0000 0000 | 0000 0000 | | 03h <sup>(1)</sup> | STATUS | IRP <sup>(4)</sup> | RP1 <sup>(4)</sup> | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 000q quuu | | 04h <sup>(1)</sup> | FSR | Indirect data | a memory ad | dress pointe | er | | | | | xxxx xxxx | uuuu uuuu | | 05h | PORTA | _ | _ | PORTA Dat | a Latch wher | written: PO | RTA pins wh | en read | | xx xxxx | uu uuuu | | 06h | PORTB | PORTB Dat | a Latch whe | n written: P0 | ORTB pins wi | nen read | | | | xxxx xxxx | uuuu uuuu | | 07h | PORTC | PORTC Dat | ta Latch whe | n written: Po | ORTC pins w | hen read | | | | xxxx xxxx | uuuu uuuu | | 08h | - | Unimpleme | nted | | | | | | | _ | _ | | 09h | _ | Unimpleme | nted | | | | | | | _ | _ | | 0Ah <sup>(1,2)</sup> | PCLATH | _ | _ | _ | Write Buffer | for the uppe | r 5 bits of the | e Program C | ounter | 0 0000 | 0 0000 | | 0Bh <sup>(1)</sup> | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | 0Ch | PIR1 | (5) | (5) | TMR1IF | 0000 0000 | 0000 0000 | | | | | | | 0Dh | PIR2 | _ | _ | _ | | _ | _ | _ | CCP2IF | 0 | 0 | | 0Eh | TMR1L | Holding reg | ister for the L | east Signific | cant Byte of t | he 16-bit TM | R1 register | | | xxxx xxxx | uuuu uuuu | | 0Fh | TMR1H | Holding reg | ister for the N | Nost Signific | ant Byte of th | ne 16-bit TMI | R1 register | | | xxxx xxxx | uuuu uuuu | | 10h | T1CON | _ | _ | T1CKPS1 | T1CKPS0 | T1OSCEN | T1SYNC | TMR1CS | TMR10N | 00 0000 | uu uuuu | | 11h | TMR2 | Timer2 mod | lule's registe | r | | | | | | 0000 0000 | 0000 0000 | | 12h | T2CON | _ | TOUTPS3 | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000 0000 | -000 0000 | | 13h | SSPBUF | Synchronou | ıs Serial Port | Receive Bu | ıffer/Transmit | Register | | | | xxxx xxxx | uuuu uuuu | | 14h | SSPCON | WCOL | SSPOV | SSPEN | CKP | SSPM3 | SSPM2 | SSPM1 | SSPM0 | 0000 0000 | 0000 0000 | | 15h | CCPR1L | Capture/Co | mpare/PWM | 1 (LSB) | | | | | | xxxx xxxx | uuuu uuuu | | 16h | CCPR1H | Capture/Co | mpare/PWM | 1 (MSB) | | | | | | xxxx xxxx | uuuu uuuu | | 17h | CCP1CON | _ | - | CCP1X | CCP1Y | CCP1M3 | CCP1M2 | CCP1M1 | CCP1M0 | 00 0000 | 00 0000 | | 18h | RCSTA | SPEN | SPEN RX9 SREN CREN — FERR OERR RX | | | | | | | | 0000 -00x | | 19h | TXREG | USART Trai | JSART Transmit Data Register | | | | | | | 0000 0000 | 0000 0000 | | 1Ah | RCREG | USART Red | ceive Data R | egister | | | | | | 0000 0000 | 0000 0000 | | 1Bh | CCPR2L | Capture/Co | mpare/PWM | 2 (LSB) | | | | | | xxxx xxxx | uuuu uuuu | | 1Ch | CCPR2H | Capture/Co | mpare/PWM | 2 (MSB) | | | | | | xxxx xxxx | uuuu uuuu | | 1Dh | CCP2CON | - | _ | CCP2X | CCP2Y | ССР2М3 | CCP2M2 | CCP2M1 | CCP2M0 | 00 0000 | 00 0000 | | 1Eh-1Fh | _ | Unimpleme | Unimplemented | | | | | | | | _ | $\label{eq:location} \textbf{Legend:} \quad \textbf{x} = \textbf{unknown}, \ \textbf{u} = \textbf{unchanged}, \ \textbf{q} = \textbf{value} \ \textbf{depends} \ \textbf{on condition}, \ \textbf{-} = \textbf{unimplemented} \ \textbf{location} \ \textbf{read} \ \textbf{as} \ \textbf{'0'}.$ - Note 1: These registers can be addressed from either bank. - 2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose contents are transferred to the upper byte of the program counter. (PC<12:8>) - 3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset. - 4: The IRP and RP1 bits are reserved on the PIC16C63/R63, always maintain these bits clear. - $5: \quad \text{PIE1} < 7:6 \text{> and PIR1} < 7:6 \text{> are reserved on the PIC16C63/R63, always maintain these bits clear.} \\$ TABLE 4-4: SPECIAL FUNCTION REGISTERS FOR THE PIC16C64/64A/R64 | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on<br>all other<br>resets <sup>(3)</sup> | | |----------------------|---------|--------------------|--------------------|----------------|----------------|--------------|-----------------|---------------|-----------|--------------------------|------------------------------------------------|--| | Bank 0 | | | | | | | | | • | | | | | 00h <sup>(1)</sup> | INDF | Addressing | this location | uses conter | nts of FSR to | address data | a memory (n | ot a physical | register) | 0000 0000 | 0000 0000 | | | 01h | TMR0 | Timer0 mod | lule's registe | r | | | | | | xxxx xxxx | uuuu uuuu | | | 02h <sup>(1)</sup> | PCL | Program Co | ounter's (PC) | Least Signi | ficant Byte | | | | | 0000 0000 | 0000 0000 | | | 03h <sup>(1)</sup> | STATUS | IRP <sup>(5)</sup> | RP1 <sup>(5)</sup> | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 000q quuu | | | 04h <sup>(1)</sup> | FSR | Indirect dat | a memory ac | Idress pointe | er | | | | | xxxx xxxx | uuuu uuuu | | | 05h | PORTA | _ | _ | PORTA Dat | a Latch wher | written: PO | RTA pins wh | en read | | xx xxxx | uu uuuu | | | 06h | PORTB | PORTB Da | ta Latch whe | n written: PC | ORTB pins wh | nen read | | | | xxxx xxxx | uuuu uuuu | | | 07h | PORTC | PORTC Da | ta Latch whe | n written: PO | ORTC pins w | nen read | | | | xxxx xxxx | uuuu uuuu | | | 08h | PORTD | PORTD Da | ta Latch whe | | xxxx xxxx | uuuu uuuu | | | | | | | | 09h | PORTE | _ | _ | RE0 | xxx | uuu | | | | | | | | 0Ah <sup>(1,2)</sup> | PCLATH | _ | _ | - | Write Buffer | for the uppe | r 5 bits of the | Program C | ounter | 0 0000 | 0 0000 | | | 0Bh <sup>(1)</sup> | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | | 0Ch | PIR1 | PSPIF | (6) | - | _ | SSPIF | CCP1IF | TMR2IF | TMR1IF | 00 0000 | 00 0000 | | | 0Dh | _ | Unimpleme | nted | | | • | | | | _ | _ | | | 0Eh | TMR1L | Holding reg | ister for the I | _east Signific | ant Byte of t | he 16-bit TM | R1 register | | | xxxx xxxx | uuuu uuuu | | | 0Fh | TMR1H | Holding reg | ister for the I | Most Signific | ant Byte of th | e 16-bit TMF | R1 register | | | xxxx xxxx | uuuu uuuu | | | 10h | T1CON | _ | _ | T1CKPS1 | T1CKPS0 | T10SCEN | T1SYNC | TMR1CS | TMR10N | 00 0000 | uu uuuu | | | 11h | TMR2 | Timer2 mod | lule's registe | r | • | • | | | | 0000 0000 | 0000 0000 | | | 12h | T2CON | _ | TOUTPS3 | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000 0000 | -000 0000 | | | 13h | SSPBUF | Synchronou | ıs Serial Por | | xxxx xxxx | uuuu uuuu | | | | | | | | 14h | SSPCON | WCOL | SSPOV | SSPM0 | 0000 0000 | 0000 0000 | | | | | | | | 15h | CCPR1L | Capture/Co | mpare/PWM | 1 (LSB) | | | | | | xxxx xxxx | uuuu uuuu | | | 16h | CCPR1H | Capture/Co | mpare/PWM | 1 (MSB) | | | | | | xxxx xxxx | uuuu uuuu | | | 17h | CCP1CON | _ | _ | CCP1X | CCP1Y | CCP1M3 | CCP1M2 | CCP1M1 | CCP1M0 | 00 0000 | 00 0000 | | | 18h-1Fh | _ | Unimpleme | nimplemented | | | | | | | | | | $\begin{tabular}{ll} Legend: & $x=$ unknown, $u=$ unchanged, $q=$ value depends on condition, $-=$ unimplemented location read as '0'. \end{tabular}$ - Note 1: These registers can be addressed from either bank. - 2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose contents are transferred to the upper byte of the program counter. (PC<12:8>) - 3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset. - 4: The BOR bit is reserved on the PIC16C64, always maintain this bit set. - 5: The IRP and RP1 bits are reserved on the PIC16C64/64A/R64, always maintain these bits clear. - $\hbox{6:} \quad \hbox{PIE1<6> and PIR1<6> are reserved on the PIC16C64/64A/R64, always maintain these bits clear. } \\$ TABLE 4-4: SPECIAL FUNCTION REGISTERS FOR THE PIC16C64/64A/R64 (Cont.'d) | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on<br>all other<br>resets <sup>(3)</sup> | |----------------------|---------|--------------------|--------------------|---------------------------|---------------|--------------|-----------------|----------------|--------------------|--------------------------|------------------------------------------------| | Bank 1 | | | | | | | | | | | | | 80h <sup>(1)</sup> | INDF | Addressing | this location | uses conter | nts of FSR to | address data | a memory (n | ot a physical | register) | 0000 0000 | 0000 0000 | | 81h | OPTION | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 1111 1111 | | 82h <sup>(1)</sup> | PCL | Program Co | ounter's (PC) | Least Sigr | nificant Byte | | | | | 0000 0000 | 0000 0000 | | 83h <sup>(1)</sup> | STATUS | IRP <sup>(5)</sup> | RP1 <sup>(5)</sup> | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 000q quuu | | 84h <sup>(1)</sup> | FSR | Indirect data | a memory ac | Idress pointe | er | | | | | xxxx xxxx | uuuu uuuu | | 85h | TRISA | _ | _ | PORTA Dat | a Direction R | egister | | | | 11 1111 | 11 1111 | | 86h | TRISB | PORTB Date | ta Direction F | Register | | | | | | 1111 1111 | 1111 1111 | | 87h | TRISC | PORTC Da | ta Direction F | Register | | | | | | 1111 1111 | 1111 1111 | | 88h | TRISD | PORTD Da | ta Direction F | Register | | 1111 1111 | 1111 1111 | | | | | | 89h | TRISE | IBF | OBF | IBOV | PSPMODE | _ | PORTE Da | ta Direction I | Bits | 0000 -111 | 0000 -111 | | 8Ah <sup>(1,2)</sup> | PCLATH | _ | _ | _ | Write Buffer | for the uppe | r 5 bits of the | Program C | ounter | 0 0000 | 0 0000 | | 8Bh <sup>(1)</sup> | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | 8Ch | PIE1 | PSPIE | (6) | _ | _ | SSPIE | CCP1IE | TMR2IE | TMR1IE | 00 0000 | 00 0000 | | 8Dh | _ | Unimpleme | nted | | | | | | | - | _ | | 8Eh | PCON | _ | _ | _ | _ | _ | _ | POR | BOR <sup>(4)</sup> | qq | uu | | 8Fh | _ | Unimpleme | nted | | | | | | | _ | - | | 90h | _ | Unimpleme | nted | | | | | | | _ | _ | | 91h | _ | Unimpleme | Jnimplemented | | | | | | | | _ | | 92h | PR2 | Timer2 Peri | od Register | | | · | · | · | | 1111 1111 | 1111 1111 | | 93h | SSPADD | Synchronou | us Serial Port | t (I <sup>2</sup> C mode) | Address Reg | gister | | | | 0000 0000 | 0000 0000 | | 94h | SSPSTAT | _ | _ | D/Ā | Р | S | R/W | UA | BF | 00 0000 | 00 0000 | | 95h-9Fh | _ | Unimpleme | nted | | | _ | _ | | | | | $\label{eq:location} \textbf{Legend:} \quad \textbf{x} = \textbf{unknown}, \ \textbf{u} = \textbf{unchanged}, \ \textbf{q} = \textbf{value} \ \textbf{depends} \ \textbf{on condition}, \ \textbf{-} = \textbf{unimplemented} \ \textbf{location} \ \textbf{read} \ \textbf{as} \ \textbf{'0'}.$ - Note 1: These registers can be addressed from either bank. - 2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose contents are transferred to the upper byte of the program counter. (PC<12:8>) - 3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset. - 4: The BOR bit is reserved on the PIC16C64, always maintain this bit set. - 5: The IRP and RP1 bits are reserved on the PIC16C64/64A/R64, always maintain these bits clear. - 6: PIE1<6> and PIR1<6> are reserved on the PIC16C64/64A/R64, always maintain these bits clear. TABLE 4-6: SPECIAL FUNCTION REGISTERS FOR THE PIC16C66/67 (Cont.'d) | | | | | | | | | | • | • | | | | | |----------------------|---------|----------------------|----------------|---------------------------|----------------|--------------|-----------------|----------------|-----------|--------------------------|------------------------------------------------|--|--|--| | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on<br>all other<br>resets <sup>(3)</sup> | | | | | Bank 1 | | | 1 | | | | | | 1 | | | | | | | 80h <sup>(1)</sup> | INDF | Addressing | this location | uses conte | nts of FSR to | address dat | a memory (n | ot a physical | register) | 0000 0000 | 0000 0000 | | | | | 81h | OPTION | RBPU | INTEDG | T0CS | TOSE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 1111 1111 | | | | | 82h <sup>(1)</sup> | PCL | Program Co | ounter's (PC) | Least Sigr | nificant Byte | | | | | 0000 0000 | 0000 0000 | | | | | 83h <sup>(1)</sup> | STATUS | IRP | RP1 | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 000q quuu | | | | | 84h <sup>(1)</sup> | FSR | Indirect data | a memory ad | Idress pointe | er | | | | | xxxx xxxx | uuuu uuuu | | | | | 85h | TRISA | _ | _ | PORTA Da | ta Direction R | egister | | | | 11 1111 | 11 1111 | | | | | 86h | TRISB | PORTB Dat | ta Direction F | Register | | | | | | 1111 1111 | 1111 1111 | | | | | 87h | TRISC | PORTC Da | ta Direction F | Register | | | | | | 1111 1111 | 1111 1111 | | | | | 88h <sup>(5)</sup> | TRISD | PORTD Da | ta Direction F | Register | | | | | | 1111 1111 | 1111 1111 | | | | | 89h <sup>(5)</sup> | TRISE | IBF | OBF | IBOV | PSPMODE | _ | PORTE Da | ta Direction I | Bits | 0000 -111 | 0000 -111 | | | | | 8Ah <sup>(1,2)</sup> | PCLATH | _ | _ | _ | Write Buffer | for the uppe | r 5 bits of the | Program C | ounter | 0 0000 | 0 0000 | | | | | 8Bh <sup>(1)</sup> | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | | | | 8Ch | PIE1 | PSPIE <sup>(6)</sup> | (4) | RCIE | TMR1IE | 0000 0000 | 0000 0000 | | | | | | | | | 8Dh | PIE2 | _ | _ | _ | CCP2IE | 0 | 0 | | | | | | | | | 8Eh | PCON | _ | _ | - | _ | _ | _ | POR | BOR | qq | uu | | | | | 8Fh | _ | Unimpleme | nted | | | • | • | • | | _ | _ | | | | | 90h | _ | Unimpleme | nted | | | | | | | _ | _ | | | | | 91h | _ | Unimpleme | nted | | | | | | | _ | _ | | | | | 92h | PR2 | Timer2 Peri | od Register | | | | | | | 1111 1111 | 1111 1111 | | | | | 93h | SSPADD | Synchronou | ıs Serial Port | t (I <sup>2</sup> C mode) | Address Reg | gister | | | | 0000 0000 | 0000 0000 | | | | | 94h | SSPSTAT | SMP | CKE | D/Ā | Р | S | R/W | UA | BF | 0000 0000 | 0000 0000 | | | | | 95h | _ | Unimpleme | nted | | | | | | | _ | _ | | | | | 96h | _ | Unimpleme | nted | | | | | | | _ | _ | | | | | 97h | _ | Unimpleme | nted | | | | | | | _ | _ | | | | | 98h | TXSTA | CSRC | TX9 | TXEN | SYNC | _ | BRGH | TRMT | TX9D | 0000 -010 | 0000 -010 | | | | | 99h | SPBRG | Baud Rate | Generator Re | egister | | 0000 0000 | 0000 0000 | | | | | | | | | 9Ah | _ | Unimpleme | nted | | _ | _ | | | | | | | | | | 9Bh | _ | Unimpleme | mplemented | | | | | | | | | | | | | 9Ch | _ | Unimpleme | mplemented — | | | | | | | | | | | | | 9Dh | _ | Unimpleme | nted | | | | | | | _ | _ | | | | | 9Eh | _ | Unimpleme | nted | | | | | | | _ | _ | | | | | 9Fh | _ | Unimpleme | nted | | | | | | | _ | _ | | | | | | | | ala anana a | | | | | | | 101 | | | | | $\label{eq:location} \textbf{Legend:} \quad \textbf{x} = \textbf{unknown}, \ \textbf{u} = \textbf{unchanged}, \ \textbf{q} = \textbf{value depends on condition}, \ \textbf{-} = \textbf{unimplemented location read as '0'}.$ - Note 1: These registers can be addressed from any bank. - 2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose contents are transferred to the upper byte of the program counter. (PC<12:8>) - 3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset. - 4: PIE1<6> and PIR1<6> are reserved on the PIC16C66/67, always maintain these bits clear. - 5: PORTD, PORTE, TRISD, and TRISE are not implemented on the PIC16C66, read as '0'. - 6: PSPIF (PIR1<7>) and PSPIE (PIE1<7>) are reserved on the PIC16C66, maintain these bits clear. ## FIGURE 4-17: PIR1 REGISTER FOR PIC16C63/R63/66 (ADDRESS 0Ch) | U = Unimplemented bit, read as '0' - n = Value at POR reset 1.7-6: Reserved: Always maintain these bits clear. RCIF: USART Receive Interrupt Flag bit 1 = The USART receive buffer is full (cleared by reading RCREG) 0 = The USART receive buffer is empty 1.4: TXIF: USART Transmit Interrupt Flag bit 1 = The USART transmit buffer is empty (cleared by writing to TXREG) 0 = The USART transmit buffer is full 1.3: SSPIF: Synchronous Serial Port Interrupt Flag bit 1 = The transmission/reception is complete (must be cleared in software) 0 = Waiting to transmit/receive 1.2: CCP1IF: CCP1 Interrupt Flag bit Capture Mode 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM Mode Unused in this mode 1. TMR2IF: TMR2 to PR2 Match Interrupt Flag bit 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR2 to PR2 match occurred | R/W-0 | R/W-0 | R-0 | R-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------|---------------------------------------|---------------|---------------|----------|------------------------------------| | U = Unimplemented bit, read as '0' - n = Value at POR reset RCIF: USART Receive Interrupt Flag bit 1 = The USART receive buffer is full (cleared by reading RCREG) 0 = The USART receive buffer is empty TXIF: USART transmit Interrupt Flag bit 1 = The USART transmit buffer is empty (cleared by writing to TXREG) 0 = The USART transmit buffer is empty (cleared by writing to TXREG) 0 = The USART transmit buffer is full SSPIF: Synchronous Serial Port Interrupt Flag bit 1 = The transmission/reception is complete (must be cleared in software) 0 = Waiting to transmit/receive CCP1IF: CCP1 Interrupt Flag bit Capture Mode 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM Mode Unused in this mode 1 : TMR2IF: TMR2 to PR2 Match Interrupt Flag bit 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR1 to PR2 match occurred (must be cleared in software) 1 : TMR1F: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflow occurred (must be cleared in software) | _ | _ | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF | | | t 5: RCIF: USART Receive Interrupt Flag bit 1 = The USART receive buffer is full (cleared by reading RCREG) 0 = The USART receive buffer is empty 44: TXIF: USART Transmit Interrupt Flag bit 1 = The USART transmit buffer is empty (cleared by writing to TXREG) 0 = The USART transmit buffer is empty (cleared by writing to TXREG) 0 = The USART transmit buffer is full 1 = The transmission/reception is complete (must be cleared in software) 0 = Waiting to transmit/receive 1 = CCP1IF: CCP1 Interrupt Flag bit Capture Mode 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register capture occurred Compare Mode 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM Mode Unused in this mode 1 = TMR2IF: TMR2 to PR2 Match Interrupt Flag bit 1 = TMR2IF: TMR2 to PR2 match occurred 0 = No TMR1 to PR2 match occurred (must be cleared in software) 0 = No TMR2 to PR2 match occurred 1 O: TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflow occurred (must be cleared in software) | oit7 | | | | | | | bit0 | U = Unimplemented bit, read as '0' | | 1 = The USART receive buffer is full (cleared by reading RCREG) 0 = The USART receive buffer is empty 14: TXIF: USART Transmit Interrupt Flag bit 1 = The USART transmit buffer is empty (cleared by writing to TXREG) 0 = The USART transmit buffer is empty (cleared by writing to TXREG) 0 = The USART transmit buffer is full SSPIF: Synchronous Serial Port Interrupt Flag bit 1 = The transmission/reception is complete (must be cleared in software) 0 = Waiting to transmit/receive 2: CCP1IF: CCP1 Interrupt Flag bit Capture Mode 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register capture occurred Compare Mode 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM Mode Unused in this mode 1: TMR2IF: TMR2 to PR2 Match Interrupt Flag bit 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR1 to PR2 match occurred 1: 1: TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflow loccurred (must be cleared in software) | bit 7-6: | Reserved: | Always ma | intain thes | e bits clear. | | | | | | 1 = The USART transmit buffer is empty (cleared by writing to TXREG) 0 = The USART transmit buffer is full 3: SSPIF: Synchronous Serial Port Interrupt Flag bit 1 = The transmission/reception is complete (must be cleared in software) 0 = Waiting to transmit/receive 4: 2: CCP1IF: CCP1 Interrupt Flag bit Capture Mode 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register capture occurred Compare Mode 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM Mode Unused in this mode 4: 1: TMR2IF: TMR2 to PR2 Match Interrupt Flag bit 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR1 to PR2 match occurred 1: TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflow occurred (must be cleared in software) | bit 5: | 1 = The US | ART receiv | e buffer is | full (cleared | d by reading | RCREG) | | | | 1 = The transmission/reception is complete (must be cleared in software) 0 = Waiting to transmit/receive 2 : CCP1IF: CCP1 Interrupt Flag bit Capture Mode 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register capture occurred Compare Mode 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM Mode Unused in this mode 1 = TMR2IF: TMR2 to PR2 Match Interrupt Flag bit 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR1 to PR2 match occurred 1 to: TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflow occurred (must be cleared in software) | bit 4: | 1 = The US | ART transi | nit buffer is | empty (cle | ared by writi | ng to TXRE | G) | | | Capture Mode 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register capture occurred Compare Mode 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM Mode Unused in this mode 1 : TMR2IF: TMR2 to PR2 Match Interrupt Flag bit 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR2 to PR2 match occurred 1 : TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflow occurred (must be cleared in software) | bit 3: | 1 = The tra | nsmission/i | reception is | | | ared in softv | vare) | | | 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR2 to PR2 match occurred t 0: TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflow occurred (must be cleared in software) | bit 2: | Capture Mo 1 = A TMR 0 = No TMI Compare M 1 = A TMR 0 = No TMI PWM Mode | ode<br>1 register c<br>R1 register<br><u>lode</u><br>1 register c<br>R1 register | apture occ<br>capture oc<br>ompare ma | urred (must<br>curred<br>atch occurre | ed (must be o | , | oftware) | | | 1 = TMR1 register overflow occurred (must be cleared in software) | bit 1: | 1 = TMR2 t | o PR2 mat | ch occurre | d (must be | | oftware) | | | | | bit 0: | 1 = TMR1 ı | egister ove | rflow occu | rred (must l | oe cleared in | software) | | | Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt. ## 7.2 <u>Using Timer0 with External Clock</u> Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 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. ### 7.2.1 EXTERNAL CLOCK SYNCHRONIZATION When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of TOCKI with the internal phase clocks is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks (Figure 7-5). Therefore, it is necessary for TOCKI 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. #### 7.2.2 TIMERO 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 7-5 shows the delay from the external clock edge to the timer incrementing. FIGURE 7-5: TIMERO TIMING WITH EXTERNAL CLOCK ## 11.4.2 ADDRESSING I2C DEVICES There are two address formats. The simplest is the 7-bit address format with a $R\overline{W}$ bit (Figure 11-15). The more complex is the 10-bit address with a $R\overline{W}$ bit (Figure 11-16). For 10-bit address format, two bytes must be transmitted with the first five bits specifying this to be a 10-bit address. #### FIGURE 11-15: 7-BIT ADDRESS FORMAT ### FIGURE 11-16: I2C 10-BIT ADDRESS FORMAT #### 11.4.3 TRANSFER ACKNOWLEDGE All data must be transmitted per byte, with no limit to the number of bytes transmitted per data transfer. After each byte, the slave-receiver generates an acknowledge bit ( $\overline{ACK}$ ) (Figure 11-17). When a slave-receiver doesn't acknowledge the slave address or received data, the master must abort the transfer. The slave must leave SDA high so that the master can generate the STOP condition (Figure 11-14). ## FIGURE 11-17: SLAVE-RECEIVER ACKNOWLEDGE If the master is receiving the data (master-receiver), it generates an acknowledge signal for each received byte of data, except for the last byte. To signal the end of data to the slave-transmitter, the master does not generate an acknowledge (not acknowledge). The slave then releases the SDA line so the master can generate the STOP condition. The master can also generate the STOP condition during the acknowledge pulse for valid termination of data transfer. If the slave needs to delay the transmission of the next byte, holding the SCL line low will force the master into a wait state. Data transfer continues when the slave releases the SCL line. This allows the slave to move the received data or fetch the data it needs to transfer before allowing the clock to start. This wait state technique can also be implemented at the bit level, Figure 11-18. The slave will inherently stretch the clock, when it is a transmitter, but will not when it is a receiver. The slave will have to clear the SSPCON<4> bit to enable clock stretching when it is a receiver. ### FIGURE 11-18: DATA TRANSFER WAIT STATE ## 12.1 USART Baud Rate Generator (BRG) | Αp | pli | cable | e Dev | vice | es | | | | | | | | | |----|-----|-------|-------|------|-----|----|-----|-----|----|-----|-----|----|----| | 61 | 62 | 62A | R62 | 63 | R63 | 64 | 64A | R64 | 65 | 65A | R65 | 66 | 67 | The BRG supports both the Asynchronous and Synchronous modes of the USART. It is a dedicated 8-bit baud rate generator. The SPBRG register controls the period of a free running 8-bit timer. In asynchronous mode bit BRGH (TXSTA<2>) also controls the baud rate. In synchronous mode bit BRGH is ignored. Table 12-1 shows the formula for computation of the baud rate for different USART modes which only apply in master mode (internal clock). Given the desired baud rate and Fosc, the nearest integer value for the SPBRG register can be calculated using the formula in Table 12-1. From this, the error in baud rate can be determined. Example 12-1 shows the calculation of the baud rate error for the following conditions: Fosc = 16 MHz Desired Baud Rate = 9600 BRGH = 0 SYNC = 0 ## EXAMPLE 12-1: CALCULATING BAUD RATE FRROR Desired Baud rate = Fosc / (64 (X + 1)) 9600 = 16000000 / (64 (X + 1)) $X = \lfloor 25.042 \rfloor = 25$ Calculated Baud Rate=16000000 / (64 (25 + 1)) = 9615 Error = (Calculated Baud Rate - Desired Baud Rate) Desired Baud Rate = (9615 - 9600) / 9600 = 0.16% It may be advantageous to use the high baud rate (BRGH = 1) even for slower baud clocks. This is because the FOSC/(16(X+1)) equation can reduce the baud rate error in some cases. Note: For the PIC16C63/R63/65/65A/R65 the asynchronous high speed mode (BRGH = 1) may experience a high rate of receive errors. It is recommended that BRGH = 0. If you desire a higher baud rate than BRGH = 0 can support, refer to the device errata for additional information or use the PIC16C66/67. Writing a new value to the SPBRG register, causes the BRG timer to be reset (or cleared), this ensures that the BRG does not wait for a timer overflow before outputting the new baud rate. #### TABLE 12-1: BAUD RATE FORMULA | SYNC | BRGH = 0 (Low Speed) | BRGH = 1 (High Speed) | |------|-------------------------------------------|----------------------------| | 0 | (Asynchronous) Baud Rate = Fosc/(64(X+1)) | Baud Rate = Fosc/(16(X+1)) | | 1 | (Synchronous) Baud Rate = Fosc/(4(X+1)) | N/A | X = value in SPBRG (0 to 255) #### TABLE 12-2: REGISTERS ASSOCIATED WITH BAUD RATE GENERATOR | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR,<br>BOR | Value on<br>all other<br>Resets | |---------|-------|----------|-----------|-------------|-------|-------|-------|-------|-------|-------------------------|---------------------------------| | 98h | TXSTA | CSRC | TX9 | TXEN | SYNC | - | BRGH | TRMT | TX9D | 0000 -010 | 0000 -010 | | 18h | RCSTA | SPEN | RX9 | SREN | CREN | _ | FERR | OERR | RX9D | 0000 -00x | 0000 -00x | | 99h | SPBRG | Baud Rat | te Genera | tor Registe | er | | | | | 0000 0000 | 0000 0000 | Legend: x = unknown, - = unimplemented read as '0'. Shaded cells are not used by the BRG. ## TABLE 12-3: BAUD RATES FOR SYNCHRONOUS MODE | BAUD | Fosc = 2 | 20 MHz | SPBRG | 16 MHz | | SPBRG | 10 MHz | | SPBRG | 7.15909 I | MHz | SPBRG | |-------------|----------|------------|--------------------|--------|------------|--------------------|--------|------------|--------------------|-----------|------------|--------------------| | RATE<br>(K) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | | 0.3 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | 1.2 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | 2.4 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | 9.6 | NA | - | - | NA | - | - | 9.766 | +1.73 | 255 | 9.622 | +0.23 | 185 | | 19.2 | 19.53 | +1.73 | 255 | 19.23 | +0.16 | 207 | 19.23 | +0.16 | 129 | 19.24 | +0.23 | 92 | | 76.8 | 76.92 | +0.16 | 64 | 76.92 | +0.16 | 51 | 75.76 | -1.36 | 32 | 77.82 | +1.32 | 22 | | 96 | 96.15 | +0.16 | 51 | 95.24 | -0.79 | 41 | 96.15 | +0.16 | 25 | 94.20 | -1.88 | 18 | | 300 | 294.1 | -1.96 | 16 | 307.69 | +2.56 | 12 | 312.5 | +4.17 | 7 | 298.3 | -0.57 | 5 | | 500 | 500 | 0 | 9 | 500 | 0 | 7 | 500 | 0 | 4 | NA | - | - | | HIGH | 5000 | - | 0 | 4000 | - | 0 | 2500 | - | 0 | 1789.8 | - | 0 | | LOW | 19.53 | - | 255 | 15.625 | - | 255 | 9.766 | - | 255 | 6.991 | - | 255 | | | Fosc = | 5.0688 MI | Нz | 4 MHz | | | 3.579545 | MHz | | 1 MHz | | | 32.768 k | Hz | | |---------------------|--------|------------|-----------------------------|--------|------------|-----------------------------|----------|------------|-----------------------------|--------|------------|-----------------------------|----------|------------|-----------------------------| | BAUD<br>RATE<br>(K) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | | 0.3 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | 0.303 | +1.14 | 26 | | 1.2 | NA | - | - | NA | - | - | NA | - | - | 1.202 | +0.16 | 207 | 1.170 | -2.48 | 6 | | 2.4 | NA | - | - | NA | - | - | NA | - | - | 2.404 | +0.16 | 103 | NA | - | - | | 9.6 | 9.6 | 0 | 131 | 9.615 | +0.16 | 103 | 9.622 | +0.23 | 92 | 9.615 | +0.16 | 25 | NA | - | - | | 19.2 | 19.2 | 0 | 65 | 19.231 | +0.16 | 51 | 19.04 | -0.83 | 46 | 19.24 | +0.16 | 12 | NA | - | - | | 76.8 | 79.2 | +3.13 | 15 | 76.923 | +0.16 | 12 | 74.57 | -2.90 | 11 | 83.34 | +8.51 | 2 | NA | - | - | | 96 | 97.48 | +1.54 | 12 | 1000 | +4.17 | 9 | 99.43 | +3.57 | 8 | NA | - | - | NA | - | - | | 300 | 316.8 | +5.60 | 3 | NA | - | - | 298.3 | -0.57 | 2 | NA | - | - | NA | - | - | | 500 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | HIGH | 1267 | - | 0 | 100 | - | 0 | 894.9 | - | 0 | 250 | - | 0 | 8.192 | - | 0 | | LOW | 4.950 | - | 255 | 3.906 | - | 255 | 3.496 | - | 255 | 0.9766 | - | 255 | 0.032 | - | 255 | ## TABLE 12-4: BAUD RATES FOR ASYNCHRONOUS MODE (BRGH = 0) | BAUD | Fosc = 2 | 0 MHz | SPBRG | 16 MHz | | SPBRG | 10 MHz | | SPBRG | 7.15909 I | MHz | SPBRG | |-------------|----------|------------|--------------------|--------|------------|--------------------|--------|------------|--------------------|-----------|------------|--------------------| | RATE<br>(K) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | KBAUD | %<br>ERROR | value<br>(decimal) | | 0.3 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | 1.2 | 1.221 | +1.73 | 255 | 1.202 | +0.16 | 207 | 1.202 | +0.16 | 129 | 1.203 | +0.23 | 92 | | 2.4 | 2.404 | +0.16 | 129 | 2.404 | +0.16 | 103 | 2.404 | +0.16 | 64 | 2.380 | -0.83 | 46 | | 9.6 | 9.469 | -1.36 | 32 | 9.615 | +0.16 | 25 | 9.766 | +1.73 | 15 | 9.322 | -2.90 | 11 | | 19.2 | 19.53 | +1.73 | 15 | 19.23 | +0.16 | 12 | 19.53 | +1.73 | 7 | 18.64 | -2.90 | 5 | | 76.8 | 78.13 | +1.73 | 3 | 83.33 | +8.51 | 2 | 78.13 | +1.73 | 1 | NA | - | - | | 96 | 104.2 | +8.51 | 2 | NA | - | - | NA | - | - | NA | - | - | | 300 | 312.5 | +4.17 | 0 | NA | - | - | NA | - | - | NA | - | - | | 500 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | HIGH | 312.5 | - | 0 | 250 | - | 0 | 156.3 | - | 0 | 111.9 | - | 0 | | LOW | 1.221 | - | 255 | 0.977 | - | 255 | 0.6104 | - | 255 | 0.437 | - | 255 | | | Fosc = | 5.0688 MI | Ηz | 4 MHz | | | 3.57954 | 5 MHz | | 1 MHz | | | 32.768 k | Hz | | |---------------------|--------|------------|-----------------------------|--------|------------|-----------------------------|---------|------------|-----------------------------|--------|------------|-----------------------------|----------|------------|-----------------------------| | BAUD<br>RATE<br>(K) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | | 0.3 | 0.31 | +3.13 | 255 | 0.3005 | -0.17 | 207 | 0.301 | +0.23 | 185 | 0.300 | +0.16 | 51 | 0.256 | -14.67 | 1 | | 1.2 | 1.2 | 0 | 65 | 1.202 | +1.67 | 51 | 1.190 | -0.83 | 46 | 1.202 | +0.16 | 12 | NA | - | - | | 2.4 | 2.4 | 0 | 32 | 2.404 | +1.67 | 25 | 2.432 | +1.32 | 22 | 2.232 | -6.99 | 6 | NA | - | - | | 9.6 | 9.9 | +3.13 | 7 | NA | - | - | 9.322 | -2.90 | 5 | NA | - | - | NA | - | - | | 19.2 | 19.8 | +3.13 | 3 | NA | - | - | 18.64 | -2.90 | 2 | NA | - | - | NA | - | - | | 76.8 | 79.2 | +3.13 | 0 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | 96 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | 300 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | 500 | NA | - | - | NA | - | - | NA | - | - | NA | - | - | NA | - | - | | HIGH | 79.2 | - | 0 | 62.500 | - | 0 | 55.93 | - | 0 | 15.63 | - | 0 | 0.512 | - | 0 | | LOW | 0.3094 | - | 255 | 3.906 | - | 255 | 0.2185 | - | 255 | 0.0610 | - | 255 | 0.0020 | - | 255 | # 13.0 SPECIAL FEATURES OF THE CPU Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 What sets a microcontroller apart from other processors are special circuits to deal with the needs of real-time applications. The PIC16CXX family has a host of such features intended to maximize system reliability, minimize cost through elimination of external components, provide power saving operating modes and offer code protection. These are: - · Oscillator selection - Reset - Power-on Reset (POR) - Power-up Timer (PWRT) - Oscillator Start-up Timer (OST) - Brown-out Reset (BOR) - Interrupts - · Watchdog Timer (WDT) - SLEEP mode - · Code protection - · ID locations - · In-circuit serial programming The PIC16CXX has a Watchdog Timer which can be shut off only through configuration bits. It runs off its own RC oscillator for added reliability. There are two timers that offer necessary delays on power-up. One is the Oscillator Start-up Timer (OST), intended to keep the chip in RESET until the crystal oscillator is stable. The other is the Power-up Timer (PWRT), which provides a fixed delay of 72 ms (nominal) on power-up only, designed to keep the part in reset while the power supply stabilizes. With these two timers on-chip, most applications need no external reset circuitry. SLEEP mode is designed to offer a very low current power-down mode. The user can wake from SLEEP through external reset, Watchdog Timer Wake-up or through an interrupt. Several oscillator options are also made available to allow the part to fit the application. The RC oscillator option saves system cost while the LP crystal option saves power. A set of configuration bits are used to select various options. ## 13.1 Configuration Bits Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 The configuration bits can be programmed (read as '0') or left unprogrammed (read as '1') to select various device configurations. These bits are mapped in program memory location 2007h. The user will note that address 2007h is beyond the user program memory space. In fact, it belongs to the special test/configuration memory space (2000h - 3FFFh), which can be accessed only during programming ## FIGURE 13-1: CONFIGURATION WORD FOR PIC16C61 | — -<br>bit13 | - - | _ | _ | _ | _ | _ | _ | CP0 | PWRTE | WDTE | FOSC1 | FOSC0<br>bit0 | Register:<br>Address | CONFIG<br>2007h | |--------------|-----------------------------------------------------|-------------------------------------|-------------|---------|----------|----------|----------|--------|-------|------|-------|---------------|----------------------|-----------------| | bit 13-5: | Unimple | mented: | Read | as '1' | | | | | | | | | 1 | | | bit 4: | <b>CP0</b> : Code<br>1 = Code<br>0 = All me | protecti | on off | | d, but ( | 00h - 3f | =h is wr | itable | | | | | | | | bit 3: | PWRTE:<br>1 = Powe<br>0 = Powe | r-up Tim | ner ena | bled | e bit | | | | | | | | | | | bit 2: | <b>WDTE</b> : W<br>1 = WDT<br>0 = WDT | enabled | ĺ | Enable | e bit | | | | | | | | | | | bit 1-0: | FOSC1:F<br>11 = RC<br>10 = HS<br>01 = XT<br>00 = LP | oscillato<br>oscillato<br>oscillato | r<br>r<br>r | or Sele | ction b | its | | | | | | | | | ### 13.6 Context Saving During Interrupts **Applicable Devices** 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 During an interrupt, only the return PC value is saved on the stack. Typically, users may wish to save key registers during an interrupt i.e., W register and STATUS register. This will have to be implemented in software. Example 13-1 stores and restores the STATUS and W registers. Example 13-2 stores and restores the STATUS, W, and PCLATH registers (Devices with paged program memory). For all PIC16C6X devices with greater than 1K of program memory (all devices except PIC16C61), the register, W\_TEMP, must be defined in banks and must be defined at the same offset from the bank base address (i.e., if W\_TEMP is defined at 0x20 in bank 0, it must also be defined at 0xA0 in bank 1. 0x120 in bank 2. and 0x1A0 in bank 3). #### The examples: - a) Stores the W register - b) Stores the STATUS register in bank 0 - c) Stores PCLATH - d) Executes ISR code - e) Restores PCLATH - f) Restores STATUS register (and bank select bit) - g) Restores W register ### **EXAMPLE 13-1: SAVING STATUS AND W REGISTERS IN RAM (PIC16C61)** ``` MOVWF W TEMP ;Copy W to TEMP register, could be bank one or zero SWAPF STATUS, W ;Swap status to be saved into W MOVWE STATUS TEMP ; Save status to bank zero STATUS TEMP register : (ISR) SWAPF STATUS TEMP, W ;Swap STATUS TEMP register into W ; (sets bank to original state) MOVWF STATUS ; Move W into STATUS register SWAPF W TEMP, F ;Swap W TEMP ;Swap W TEMP into W SWAPF W TEMP, W ``` ## EXAMPLE 13-2: SAVING STATUS, W, AND PCLATH REGISTERS IN RAM (ALL OTHER PIC16C6X DEVICES) ``` ;Copy W to TEMP register, could be bank one or zero MOVWF W TEMP SWAPF STATUS, W ;Swap status to be saved into W CLRF STATUS ;bank 0, regardless of current bank, Clears IRP, RP1, RP0 MOVWF STATUS TEMP ; Save status to bank zero STATUS TEMP register PCLATH, W MOVE ;Only required if using pages 1, 2 and/or 3 ;Save PCLATH into W PCLATH TEMP MOVWF CLRF PCLATH ; Page zero, regardless of current page BCF STATUS, IRP ;Return to Bank 0 FSR, W ;Copy FSR to W MOVWF FSR TEMP ;Copy FSR from W to FSR TEMP · (TSR) MOVF PCLATH TEMP, W ;Restore PCLATH MOVWF PCLATH ; Move W into PCLATH SWAPF STATUS TEMP, W ;Swap STATUS TEMP register into W : (sets bank to original state) MOVWF STATUS ; Move W into STATUS register SWAPF W TEMP,F ;Swap W TEMP W_TEMP,W SWAPF ;Swap W TEMP into W ``` ## Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 ### 19.2 DC Characteristics: PIC16LC65-04 (Commercial, Industrial) | DC CH | | Standard Operating Conditions (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \leq \text{Ta} \leq +85^{\circ}\text{C}$ for industrial and $0^{\circ}\text{C} \leq \text{Ta} \leq +70^{\circ}\text{C}$ for commercial | | | | | | | | |--------------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-----|-------|---------------------------------------------------------------|--|--| | Param<br>No. | Characteristic | Sym | Min | Typ† | Max | Units | Conditions | | | | D001 | Supply Voltage | VDD | 3.0 | - | 6.0 | V | LP, XT, RC osc configuration (DC - 4 MHz) | | | | D002* | RAM Data Retention<br>Voltage (Note 1) | VDR | - | 1.5 | - | V | | | | | D003 | VDD start voltage to<br>ensure internal Power-on<br>Reset signal | VPOR | - | Vss | - | V | See section on Power-on Reset for details | | | | D004* | VDD rise rate to ensure internal Power-on Reset signal | SVDD | 0.05 | - | - | V/ms | See section on Power-on Reset for details | | | | D010 | Supply Current (Note 2, 5) | IDD | - | 2.0 | 3.8 | mA | XT, RC osc configuration<br>FOSC = 4 MHz, VDD = 3.0V (Note 4) | | | | D010A | | | - | 22.5 | 105 | μА | LP osc configuration FOSC = 32 kHz, VDD = 4.0V, WDT disabled | | | | D020 | Power-down Current | IPD | - | 7.5 | 800 | μΑ | VDD = 3.0V, WDT enabled, -40°C to +85°C | | | | D021 | (Note 3, 5) | | - | 0.9 | 800 | μA | VDD = 3.0V, WDT disabled, 0°C to +70°C | | | | D021A | | | - | 0.9 | 800 | μΑ | VDD = 3.0V, WDT disabled, -40°C to +85°C | | | - \* These parameters are characterized but not tested. - † Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. - Note 1: This is the limit to which VDD can be lowered without losing RAM data. - 2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an impact on the current consumption. - The test conditions for all IDD measurements in active operation mode are: - OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD, - MCLR = VDD; WDT enabled/disabled as specified. - 3: The power down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and Vss. - 4: For RC osc configuration, current through Rext is not included. The current through the resistor can be estimated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm. - 5: Timer1 oscillator (when enabled) adds approximately 20 μA to the specification. This value is from characterization and is for design guidance only. This is not tested. Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 ## 19.5 Timing Diagrams and Specifications FIGURE 19-2: EXTERNAL CLOCK TIMING TABLE 19-2: EXTERNAL CLOCK TIMING REQUIREMENTS | Parameter<br>No. | Sym | Characteristic | Min | Тур† | Max | Units | Conditions | |------------------|-------|----------------------------------|-----|------|--------|-------|--------------------| | | Fosc | External CLKIN Frequency | DC | _ | 4 | MHz | XT and RC osc mode | | | | (Note 1) | DC | _ | 4 | MHz | HS osc mode (-04) | | | | | DC | _ | 10 | MHz | HS osc mode (-10) | | | | | DC | _ | 20 | MHz | HS osc mode (-20) | | | | | DC | _ | 200 | kHz | LP osc mode | | | | Oscillator Frequency | DC | _ | 4 | MHz | RC osc mode | | | | (Note 1) | 0.1 | _ | 4 | MHz | XT osc mode | | | | | 4 | _ | 20 | MHz | HS osc mode | | | | | 5 | _ | 200 | kHz | LP osc mode | | 1 | Tosc | External CLKIN Period | 250 | _ | _ | ns | XT and RC osc mode | | | | (Note 1) | 250 | _ | _ | ns | HS osc mode (-04) | | | | | 100 | _ | _ | ns | HS osc mode (-10) | | | | | 50 | _ | _ | ns | HS osc mode (-20) | | | | | 5 | _ | _ | μS | LP osc mode | | | | Oscillator Period | 250 | _ | _ | ns | RC osc mode | | | | (Note 1) | 250 | _ | 10,000 | ns | XT osc mode | | | | | 250 | _ | 250 | ns | HS osc mode (-04) | | | | | 100 | _ | 250 | ns | HS osc mode (-10) | | | | | 50 | _ | 250 | ns | HS osc mode (-20) | | | | | 5 | _ | _ | μS | LP osc mode | | 2 | Tcy | Instruction Cycle Time (Note 1) | 200 | Tcy | DC | ns | Tcy = 4/Fosc | | 3 | TosL, | External Clock in (OSC1) High or | 50 | _ | _ | ns | XT oscillator | | | TosH | Low Time | 2.5 | _ | _ | μS | LP oscillator | | | | | 15 | _ | _ | ns | HS oscillator | | 4 | TosR, | External Clock in (OSC1) Rise or | _ | _ | 25 | ns | XT oscillator | | | TosF | Fall Time | _ | _ | 50 | ns | LP oscillator | | | | | _ | | 15 | ns | HS oscillator | <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. Note 1: Instruction cycle period (TcY) equals four times the input oscillator time-base period. All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "min." values with an external clock applied to the OSC1/CLKIN pin. When an external clock input is used, the "Max." cycle time limit is "DC" (no clock) for all devices. Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 FIGURE 19-5: TIMERO AND TIMER1 EXTERNAL CLOCK TIMINGS TABLE 19-5: TIMERO AND TIMER1 EXTERNAL CLOCK REQUIREMENTS | Param<br>No. | Sym | Characteristic | | | Min | Typ† | Max | Units | Conditions | |--------------|-------|-----------------------|-------------------|-----------------------------|------------------------------------|------|-------|----------|------------------------------------| | 40* | Tt0H | T0CKI High Pulse V | Vidth | No Prescaler | 0.5Tcy + 20 | | | ns | Must also meet | | 40 | 11011 | Tooki riigiri uise v | Vidiri | With Prescaler | 10 | | | | parameter 42 | | 41* | TtOL | T0CKI Low Pulse W | | | 0.5Tcy + 20 | _ | _ | ns<br>ns | Must also meet | | 41 | TIOL | TOCKI LOW Fulse W | /Idili | No Prescaler With Prescaler | 10 | | | ns | parameter 42 | | 42* | Tt0P | T0CKI Period | | No Prescaler | Tcy + 40 | H | | ns | paramotor 12 | | | 1.0. | | | | Greater of: | _ | _ | ns | N = prescale value | | | | | | With Freedomen | 20 or Tcy + 40 | | | 110 | (2, 4,, 256) | | | | | | | N | | | | , , , , | | 45* | Tt1H | T1CKI High Time | Synchronous, P | rescaler = 1 | 0.5Tcy + 20 | _ | _ | ns | Must also meet | | | | | Synchronous, | PIC16 <b>C</b> 6X | 15 | _ | _ | ns | parameter 47 | | | | | Prescaler = 2,4,8 | PIC16 <b>LC</b> 6X | 25 | _ | _ | ns | | | | | | Asynchronous | PIC16 <b>C</b> 6X | 30 | _ | _ | ns | | | | | | | PIC16 <b>LC</b> 6X | 50 | _ | _ | ns | | | 46* | Tt1L | T1CKI Low Time | Synchronous, P | rescaler = 1 | 0.5TCY + 20 | _ | _ | ns | Must also meet | | | | | Synchronous, | PIC16 <b>C</b> 6X | 15 | _ | _ | ns | parameter 47 | | | | | Prescaler = 2,4,8 | PIC16 <b>LC</b> 6X | 25 | _ | _ | ns | | | | | | Asynchronous | PIC16 <b>C</b> 6X | 30 | _ | _ | ns | | | | | | | PIC16 <b>LC</b> 6X | 50 | _ | _ | ns | | | 47* | Tt1P | T1CKI input period | Synchronous | PIC16 <b>C</b> 6X | Greater of:<br>30 OR TCY + 40<br>N | _ | _ | ns | N = prescale value<br>(1, 2, 4, 8) | | | | | | PIC16 <b>LC</b> 6X | Greater of:<br>50 OR TCY + 40<br>N | | | | N = prescale value<br>(1, 2, 4, 8) | | | | | Asynchronous | PIC16 <b>C</b> 6X | 60 | _ | _ | ns | | | | | | | PIC16 <b>LC</b> 6X | 100 | _ | _ | ns | | | | Ft1 | Timer1 oscillator inp | | | DC | _ | 200 | kHz | | | | | (oscillator enabled b | | | | | | | | | 48 | | Delay from external | | | 2Tosc | _ | 7Tosc | _ | | These parameters are characterized but not tested. <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. ## PIC16C6X ## Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 ## FIGURE 20-3: CLKOUT AND I/O TIMING ### TABLE 20-3: CLKOUT AND I/O TIMING REQUIREMENTS | Parameter No. | Sym | Characteristic | | Min | Тур† | Max | Units | Conditions | |---------------|----------|------------------------------------|------------------------|------------|------|-------------|--------|------------| | 10* | TosH2ckL | OSC1↑ to CLKOUT↓ | _ | 75 | 200 | ns | Note 1 | | | 11* | TosH2ckH | OSC1↑ to CLKOUT↑ | | _ | 75 | 200 | ns | Note 1 | | 12* | TckR | CLKOUT rise time | | _ | 35 | 100 | ns | Note 1 | | 13* | TckF | CLKOUT fall time | CLKOUT fall time | | 35 | 100 | ns | Note 1 | | 14* | TckL2ioV | CLKOUT ↓ to Port out valid | | _ | - | 0.5Tcy + 20 | ns | Note 1 | | 15* | TioV2ckH | Port in valid before CLKOUT ↑ | | Tosc + 200 | _ | _ | ns | Note 1 | | 16* | TckH2iol | Port in hold after CLKOUT ↑ | | 0 | | _ | ns | Note 1 | | 17* | TosH2ioV | OSC1↑ (Q1 cycle) to Port out valid | | _ | 50 | 150 | ns | | | 18* | TosH2iol | OSC1↑ (Q2 cycle) to Port input | PIC16 <b>C</b> 63/65A | 100 | | _ | ns | | | | | invalid (I/O in hold time) | PIC16 <b>LC</b> 63/65A | 200 | _ | _ | ns | | | 19* | TioV2osH | Port input valid to OSC1↑ (I/O in | setup time) | 0 | _ | _ | ns | | | 20* | TioR | Port output rise time | PIC16 <b>C</b> 63/65A | _ | 10 | 40 | ns | | | | | | PIC16 <b>LC</b> 63/65A | _ | _ | 80 | ns | | | 21* | TioF | Port output fall time | PIC16 <b>C</b> 63/65A | _ | 10 | 40 | ns | | | | | | PIC16 <b>LC</b> 63/65A | _ | _ | 80 | ns | | | 22††* | Tinp | INT pin high or low time | | Tcy | _ | _ | ns | | | 23††* | Trbp | RB7:RB4 change INT high or lov | v time | Tcy | _ | _ | ns | | <sup>\*</sup> These parameters are characterized but not tested. <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested <sup>††</sup> These parameters are asynchronous events not related to any internal clock edge. Note 1: Measurements are taken in RC Mode where CLKOUT output is 4 x Tosc. ## F.7 PIC16C7XX Family of Devces | | | PIC16C710 | PIC16C71 | PIC16C711 | PIC16C715 | PIC16C72 | PIC16CR72 <sup>(1)</sup> | |-------------|-------------------------------------------------|-------------------------------------|---------------------|-------------------------------------|-------------------------------------|----------------------------|----------------------------| | Clock | Maximum Frequency of Operation (MHz) | 20 | 20 | 20 | 20 | 20 | 20 | | | EPROM Program Memory (x14 words) | 512 | 1K | 1K | 2K | 2K | _ | | Memory | ROM Program Memory<br>(14K words) | _ | _ | _ | _ | _ | 2K | | | Data Memory (bytes) | 36 | 36 | 68 | 128 | 128 | 128 | | | Timer Module(s) | TMR0 | TMR0 | TMR0 | TMR0 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | | Peripherals | Capture/Compare/<br>PWM Module(s) | _ | _ | _ | _ | 1 | 1 | | | Serial Port(s)<br>(SPI/I <sup>2</sup> C, USART) | _ | _ | _ | _ | SPI/I <sup>2</sup> C | SPI/I <sup>2</sup> C | | | Parallel Slave Port | _ | _ | _ | _ | _ | _ | | | A/D Converter (8-bit) Channels | 4 | 4 | 4 | 4 | 5 | 5 | | | Interrupt Sources | 4 | 4 | 4 | 4 | 8 | 8 | | | I/O Pins | 13 | 13 | 13 | 13 | 22 | 22 | | | Voltage Range (Volts) | 3.0-6.0 | 3.0-6.0 | 3.0-6.0 | 3.0-5.5 | 2.5-6.0 | 3.0-5.5 | | Features | In-Circuit Serial Programming | Yes | Yes | Yes | Yes | Yes | Yes | | | Brown-out Reset | Yes | _ | Yes | Yes | Yes | Yes | | | Packages | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 28-pin SDIP,<br>SOIC, SSOP | 28-pin SDIP,<br>SOIC, SSOP | | | | PIC16C73A | PIC16C74A | PIC16C76 | PIC16C77 | |-------------|----------------------------------------------|-----------------------------|-------------------------------------------|-----------------------------|-------------------------------------------| | Clock | Maximum Frequency of Operation (MHz) | 20 | 20 | 20 | 20 | | Memory | EPROM Program Memory (x14 words) | 4K | 4K | 8K | 8K | | | Data Memory (bytes) | 192 | 192 | 368 | 368 | | | Timer Module(s) | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | | Peripherals | Capture/Compare/PWM Mod-<br>ule(s) | 2 | 2 | 2 | 2 | | | Serial Port(s) (SPI/I <sup>2</sup> C, USART) | SPI/I <sup>2</sup> C, USART | SPI/I <sup>2</sup> C, USART | SPI/I <sup>2</sup> C, USART | SPI/I <sup>2</sup> C, USART | | | Parallel Slave Port | _ | Yes | _ | Yes | | | A/D Converter (8-bit) Channels | 5 | 8 | 5 | 8 | | | Interrupt Sources | 11 | 12 | 11 | 12 | | | I/O Pins | 22 | 33 | 22 | 33 | | | Voltage Range (Volts) | 2.5-6.0 | 2.5-6.0 | 2.5-6.0 | 2.5-6.0 | | Features | In-Circuit Serial Programming | Yes | Yes | Yes | Yes | | | Brown-out Reset | Yes | Yes | Yes | Yes | | | Packages | 28-pin SDIP,<br>SOIC | 40-pin DIP;<br>44-pin PLCC,<br>MQFP, TQFP | 28-pin SDIP,<br>SOIC | 40-pin DIP;<br>44-pin PLCC,<br>MQFP, TQFP | All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC16C7XX Family devices use serial programming with clock pin RB6 and data pin RB7. Note 1: Please contact your local Microchip sales office for availability of these devices. NOTES: #### SPI Master/Slave Connection...... 87 INDEX Numerics Timer0 ...... 65 9-bit Receive Enable bit, RX9......106 Timer1 ...... 72 Timer2 ...... 75 USART Receive ...... 114 USART Transmit ...... 112 Α Watchdog Timer ...... 140 Absolute Maximum Ratings.......163, 183, 199, 215, 231, 247, 263 BOR ...... 47. 131 ACK.......96, 100, 101 BRGH ...... 105 ALU ......9 AN552 (Implementing Wake-up on Key Stroke) ....... 53 Buffer Full Status bit, BF...... 84, 89 AN556 (Implementing a Table Read) ......48 AN594 (Using the CCP Modules) ......77 C Capture Baud Rate Formula......107 **Baud Rates** Pin Configuration ...... 78 Asynchronous Mode ......108 Prescaler ...... 79 Error, Calculating .......107 RX Pin Sampling, Timing Diagrams...... 110, 111 Capture Interrupt ...... 78 Sampling......110 Capture/Compare/PWM (CCP) Synchronous Mode......108 Capture Mode...... 78 Capture Mode Block Diagram ...... 78 **Block Diagrams** CCP1......77 Capture Mode Operation ......78 CCP2......77 Compare Mode Block Diagram ...... 79 Overview...... 63 External Parallel Resonant Crystal Circuit .................. 127 PWM Block Diagram ...... 80 External Series Resonant Crystal Circuit.......127 I<sup>2</sup>C Mode......99 PWM, Example Frequencies/Resolutions ...... 81 In-circuit Programming Connections......142 Parallel Slave Port, PORTD-PORTE ......61 PIC16C62 11 PIC16C63 ...... 12 CCP1 Interrupt Flag bit, CCP1IF......41 PIC16C64 ......11 CCP1 Mode Select bits......78 PIC16C64A ......11 CCP1CON......24, 26, 28, 30, 32, 34 CCP1IE 38 CCP1IF.......41 PIC16C66 13 CCP1M3:CCM1M0......78 CCP1X:CCP1Y.......78 PIC16CR62......11 CCP2 Interrupt Enable bit, CCP2IE.......45 PIC16CR63......12 CCP2 Interrupt Flag bit, CCP2IF.......46 PIC16CR64......11 CCP2 Mode Select bits......78 PIC16CR65......12 CCP2CON ...... 24, 26, 28, 30, 32, 34 CCP2IE......45 PORTD (I/O Mode) .......57 PORTE (I/O Mode) ......58 PWM ......80 CCP2X:CCP2Y......78 RA3:RA0 pins ......51 CCPR1H......24, 26, 28, 30, 32, 34 RA4/T0CKI pin ......51 CCPR1L ...... 24, 26, 28, 30, 32, 34 RA5 pin ......51 CCPR2L ...... 24, 26, 28, 30, 32, 34 CKE ...... 89 RC Oscillator Mode......127 CKP ...... 85, 90 # PIC16C6X | Clearing Interrupts53 | 44-Lead Plastic Surface Mount (MQFP | |------------------------------------------------------|---------------------------------------------------------------| | Clock Polarity Select bit, CKP85, 90 | 10x10 mm Body 1.6/0.15 mm Lead Form) 302, 303 | | Clock Polarity, SPI Mode87 | Device Varieties | | Clock Source Select bit, CSRC105 | Digit Carry | | Clocking Scheme | Digit Carry bit39 | | Code Examples | Direct Addressing49 | | Changing Between Capture Prescalers79 | F | | Ensuring Interrupts are Globally Disabled136 | E | | Indirect Addressing49 | Electrical Characteristics 163, 183, 199, 215, 231, 247, 263 | | Initializing PORTA51 | External Clock Synchronization, TMR0 67 | | Initializing PORTB53 | F | | Initializing PORTC55 | г | | Loading the SSPBUF Register86 | Family of Devices | | Loading the SSPBUF register91 | PIC12CXXX309 | | Reading a 16-bit Free-running Timer73 | PIC14C000309 | | Read-Modify-Write on an I/O Port60 | PIC16C15X310 | | Saving Status, W, and PCLATH Registers139 | PIC16C55X31 | | Subroutine Call, Page0 to Page149 | PIC16C5X310 | | Code Protection142 | PIC16C62X and PIC16C64X31 | | Compare | PIC16C6X | | Block Diagram79 | PIC16C7XX | | Mode79 | PIC16C8X313 | | Pin Configuration79 | PIC16C9XX313 | | Software Interrupt79 | PIC17CXX | | Special Event Trigger79 | FERR100 | | Computed GOTO48 | Framing Error bit, FERR106 | | Configuration Bits123 | FSR24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34 | | Configuration Word, Diagram124 | Fuzzy Logic Dev. System (fuzzyTECH®-MP) 159, 16 <sup>-1</sup> | | Connecting Two Microcontrollers87 | ^ | | Continuous Receive Enable bit, CREN106 | G | | CREN | General Description | | CSRC | General Purpose Registers | | | GIE3 | | D | Global Interrupt Enable bit, GIE3 | | D/A84, 89 | Graphs | | Data/Address bit, D/A84, 89 | PIC16C6X28 | | Data Memory | PIC16C61 173 | | Organization20 | ш | | Section | Н | | Data Sheet | High Baud Rate Select bit, BRGH105 | | Compatibility307 | 1 | | Modifications307 | • | | What's New308 | I/O Ports, Section5 | | DC35 | I <sup>2</sup> C | | DC CHARACTERISTICS 164, 184, 200, 216, 232, 248, 264 | Addressing100 | | Development Support159 | Addressing I <sup>2</sup> C Devices96 | | Development Tools | Arbitration | | Device Drawings | Block Diagram99 | | 18-Lead Ceramic CERDIP Dual In-line | Clock Synchronization98 | | with Window (300 mil)296 | Combined Format9 | | 18-Lead Plastic Dual In-line (300 mil) | I <sup>2</sup> C Operation99 | | 18-Lead Plastic Surface Mount | I <sup>2</sup> C Overview99 | | (SOIC - Wide, 300 mil Body)294 | Initiating and Terminating Data Transfer 95 | | 28-Lead Ceramic CERDIP Dual In-line with | Master Mode103 | | Window (300 mil))297 | Master-Receiver Sequence 97 | | 28-Lead Ceramic Side Brazed Dual In-Line | Master-Transmitter Sequence | | | Mode99 | | with Window (300 mil) | Mode Selection99 | | 28-Lead Plastic Dual In-line (300 mil)292 | Multi-master98 | | 28-Lead Plastic Surface Mount | Multi-Master Mode | | (SOIC - Wide, 300 mil Body) | Reception | | 28-Lead Plastic Surface Mount | Reception Timing Diagram10 | | (SSOP - 209 mil Body 5.30 mm)300 | SCL and SDA pins | | 40-Lead Ceramic CERDIP Dual In-line | Slave Mode | | with Window (600 mil) | START 99 | | 40-Lead Plastic Dual In-line (600 mil) | STOP | | 44-Lead Plastic Leaded Chip Carrier (Square)301 | 0.0. | | gisters | | PORTD | | |---------------------|--------------------------|---------|------------------------| | CCP1CON | | Section | 57 | | Diagram | 78 | Summary | 28, 30, 32 | | Section | 78 | PORTE | | | Summary | | Section | 58 | | CCP2CON | 2 1, 20, 20, 00, 02 | | 28, 30, 32 | | Diagram | 70 | PR2 | 20, 00, 02 | | • | | | 05 07 00 01 00 | | Section | | | 25, 27, 29, 31, 33 | | Summary | 26, 30, 32 | RCREG | | | CCPR1H | | • | 26, 30, 32 | | Summary | 24, 26, 28, 30, 32 | RCSTA | | | CCPR1L | | Diagram | 106 | | Summary | 24, 26, 28, 30, 32 | Summary | 26, 30, 32 | | CCPR2H | | SPBRG | • | | Summary | 26 30 32 | | 27, 31, 33 | | CCPR2L | 20, 00, 02 | • | | | | | SSPBUF | | | Summary | 26, 30, 32 | | 86 | | FSR | | Summary | 24, 26, 28, 30, 32 | | Indirect Addressing | 49 | SSPCON | | | Summary | | Diagram | 85 | | INDF | , -, -, -, - | | 24, 26, 28, 30, 32 | | Indirect Addressing | 49 | SSPSR | | | | | | 96 | | Summary | 24, 26, 28, 30, 32, 34 | | 86 | | INTCON | | | 89 | | Diagram | 37 | Diagram | 84 | | Section | 37 | Section | 84 | | Summary | . 24, 26, 28, 30, 32, 34 | Summary | 25, 27, 29, 31, 33 | | OPTION | | STATUS | | | Diagram | 36 | | 35 | | · · | | • | | | Section | | | 35 | | Summary | 25, 27, 29, 31, 33, 34 | • | 24, 26, 28, 30, 32, 34 | | PCL | | T1CON | | | Section | 48 | Diagram | 71 | | Summary | . 24, 26, 28, 30, 32, 34 | Section | 71 | | PCLATH | | Summary | 24, 26, 28, 30, 32 | | Section | 48 | T2CON | | | Summary | | | 75 | | | 24, 20, 26, 30, 32, 34 | · · | | | PCON | | | | | Diagram | 47 | Summary | 24, 26, 28, 30, 32 | | Section | 47 | TMR0 | | | Summary | 25, 27, 29, 31, 33 | Summary | 24, 26, 28, 30, 32, 34 | | PIE1 | | TMR1H | | | Diagram | 40 | | 24, 26, 28, 30, 32 | | Section | | TMR1L | 24, 20, 20, 00, 02 | | | | | 04 00 00 00 00 | | Summary | 25, 27, 29, 31, 33 | • | 24, 26, 28, 30, 32 | | PIE2 | | TMR2 | 75 | | Diagram | 45 | Summary | 24, 26, 28, 30, 32 | | Section | 45 | TRISA | | | Summary | | Section | 51 | | PIR1 | | | 25, 27, 29, 31, 33 | | | 4.4 | • | 25, 27, 29, 31, 33 | | Diagram | | TRISB | | | Section | | | 53 | | Summary | 24, 26, 28, 30, 32 | Summary | 25, 27, 29, 31, 33, 34 | | PIR2 | | TRISC | | | Diagram | 46 | | 55 | | Section | | | 25, 27, 29, 31, 33 | | | | | 25, 21, 29, 51, 55 | | Summary | 20, 30, 32 | TRISD | | | PORTA | | | 57 | | Section | | Summary | 29, 31, 33 | | Summary | 24, 26, 28, 30, 32 | TRISE | | | PORTB | | | 58 | | Section | 53 | • | 58 | | Summary | | | | | • | 44, 20, 20, 30, 32, 34 | | 29, 31, 33 | | PORTC | | TXREG | | | Section | 55 | Summary | 26, 30, 32 | | Summary | 24 26 28 30 32 | | |