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>" | 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) | 2.5V ~ 6V | | Data Converters | - | | Oscillator Type | External | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 44-LCC (J-Lead) | | Supplier Device Package | 44-PLCC (16.59x16.59) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16lc67-04i-l | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong TABLE 1-1: PIC16C6X FAMILY OF DEVICES | | | PIC16C61 | PIC16C62A | PIC16CR62 | PIC16C63 | PIC16CR63 | |-------------|-------------------------------------------------|----------------|----------------------------|----------------------------|--------------------------------|-------------------------------| | Clock | Maximum Frequency of Operation (MHz) | 20 | 20 | 20 | 20 | 20 | | | EPROM Program Memory<br>(x14 words) | 1K | 2K | | 4K | _ | | Memory | ROM Program Memory<br>(x14 words) | | _ | 2K | _ | 4K | | | Data Memory (bytes) | 36 | 128 | 128 | 192 | 192 | | | Timer Module(s) | TMR0 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | | Peripherals | Capture/Compare/<br>PWM Module(s) | _ | 1 | 1 | 2 | 2 | | | Serial Port(s)<br>(SPI/I <sup>2</sup> C, USART) | | SPI/I <sup>2</sup> C | SPI/I <sup>2</sup> C | SPI/I <sup>2</sup> C,<br>USART | SPI/I <sup>2</sup> C<br>USART | | | Parallel Slave Port | _ | _ | _ | _ | _ | | | Interrupt Sources | 3 | 7 | 7 | 10 | 10 | | | I/O Pins | 13 | 22 | 22 | 22 | 22 | | | Voltage Range (Volts) | 3.0-6.0 | 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 | Yes | | | Brown-out Reset | _ | Yes | Yes | Yes | Yes | | | Packages | 18-pin DIP, SO | 28-pin SDIP,<br>SOIC, SSOP | 28-pin SDIP,<br>SOIC, SSOP | 28-pin SDIP,<br>SOIC | 28-pin SDIP,<br>SOIC | | | | PIC16C64A | PIC16CR64 | PIC16C65A | PIC16CR65 | PIC16C66 | PIC16C67 | |-------------|----------------------------------------------|------------------------|-------------------------------------------|--------------------------------|-------------------------------------------------|--------------------------------|-------------------------------------------------| | Clock | Maximum Frequency of Operation (MHz) | 20 | 20 | 20 | 20 | 20 | 20 | | | EPROM Program Memory (x14 words) | 2K | _ | 4K | _ | 8K | 8K | | Memory | ROM Program Memory (x14 words) | _ | 2K | _ | 4K | _ | _ | | | Data Memory (bytes) | 128 | 128 | 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 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | | Peripherals | Capture/Compare/PWM Mod-<br>ule(s) | 1 | 1 | 2 | 2 | 2 | 2 | | | Serial Port(s) (SPI/I <sup>2</sup> C, USART) | SPI/I <sup>2</sup> C | SPI/I <sup>2</sup> C | SPI/I <sup>2</sup> C,<br>USART | SPI/I <sup>2</sup> C,<br>USART | SPI/I <sup>2</sup> C,<br>USART | SPI/I <sup>2</sup> C,<br>USART | | | Parallel Slave Port | Yes | Yes | Yes | Yes | _ | Yes | | | Interrupt Sources | 8 | 8 | 11 | 11 | 10 | 11 | | | I/O Pins | 33 | 33 | 33 | 33 | 22 | 33 | | | Voltage Range (Volts) | 2.5-6.0 | 2.5-6.0 | 2.5-6.0 | 2.5-6.0 | 2.5-6.0 | 2.5-6.0 | | | In-Circuit Serial Programming | Yes | Yes | Yes | Yes | Yes | Yes | | Features | Brown-out Reset | Yes | Yes | Yes | Yes | Yes | Yes | | | Packages | | 40-pin DIP;<br>44-pin PLCC,<br>MQFP, TQFP | | 40-pin DIP;<br>44-pin<br>PLCC,<br>MQFP,<br>TQFP | 28-pin SDIP,<br>SOIC | 40-pin DIP;<br>44-pin<br>PLCC,<br>MQFP,<br>TQFP | All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC16C6X Family devices use serial programming with clock pin RB6 and data pin RB7. TABLE 4-2: SPECIAL FUNCTION REGISTERS FOR THE PIC16C62/62A/R62 (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 | RBPUINTEDGTOCSTOSEPSAPS2PS1PS0 | | | | | | | | 1111 1111 | | 82h <sup>(1)</sup> | PCL | Program Counter's (PC) Least Significant Byte | | | | | | | | | 0000 0000 | | 83h <sup>(1)</sup> | STATUS IRP <sup>(5)</sup> RP1 <sup>(5)</sup> RP0 TO PD Z DC C | | | | | | | | | 0001 1xxx | 000q quuu | | 84h <sup>(1)</sup> | FSR | Indirect dat | a memory ac | Idress pointe | er | 1 | | | 1 | xxxx xxxx | uuuu uuuu | | 85h | TRISA | _ | _ | PORTA Dat | ta Direction R | egister | | | | 11 1111 | 11 1111 | | 86h | TRISB | PORTB Da | ta Direction F | Register | | | | | | 1111 1111 | 1111 1111 | | 87h | TRISC | PORTC Da | ta Direction F | Register | | | | | | 1111 1111 | 1111 1111 | | 88h | _ | Unimpleme | nted | | | | | | | _ | _ | | 89h | _ | Unimpleme | nted | | | | | | | _ | _ | | 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 | (6) | (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 | _ | — Unimplemented | | | | | | | | _ | _ | | 92h | PR2 | Timer2 Period Register | | | | | | | | 1111 1111 | 1111 1111 | | 93h | SSPADD | DD Synchronous Serial Port (I <sup>2</sup> C mode) Address Register | | | | | | | | 0000 0000 | 0000 0000 | | 94h | SSPSTAT | | | | | | | | | 00 0000 | 00 0000 | | 95h-9Fh | _ | Unimpleme | nted | | | | | | | _ | _ | | | | | | | | | | | | | | $\begin{tabular}{ll} Legend: & $x=$ unknown, $u=$ unchanged, $q=$ value depends on condition, $-=$ unimplemented location read as '0'. \\ & Shaded locations are unimplemented, 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 PIC16C62, always maintain this bit set. - 5: The IRP and RP1 bits are reserved on the PIC16C62/62A/R62, always maintain these bits clear. - 6: PIE1<7:6> and PIR1<7:6> are reserved on the PIC16C62/62A/R62, 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 | TUS $IRP^{(5)}$ $RP1^{(5)}$ $RP0$ $\overline{TO}$ $\overline{PD}$ $Z$ $DC$ $C$ | | | | | | | 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 | n written: PO | ORTD pins w | nen read | | | | xxxx xxxx | uuuu uuuu | | 09h | PORTE | _ | _ | _ | _ | _ | RE2 | RE1 | 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 | t 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/Compare/PWM1 (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 | h — Unimplemented | | | | | | | | _ | _ | | $\begin{tabular}{ll} Legend: & $x=$ unknown, $u=$ unchanged, $q=$ value depends on condition, $-=$ unimplemented location read as '0'. \end{tabular}$ Shaded locations are unimplemented, read as '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. - $\hbox{6:} \quad \hbox{PIE1<6> and PIR1<6> are reserved on the PIC16C64/64A/R64, always maintain these bits clear. } \\$ ### FIGURE 4-18: PIR1 REGISTER FOR PIC16C64/64A/R64 (ADDRESS 0Ch) | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | |----------|------------|--------------|---------------|------------------|--------------|--------------|----------|---------------------------------------| | PSPIF | _ | _ | _ | SSPIF | CCP1IF | TMR2IF | TMR1IF | R = Readable bit | | bit7 | | | | W = Writable bit | | | | | | | | | | | | | | U = Unimplemented bit,<br>read as '0' | | | | | | | | | | - n = Value at POR reset | | bit 7: | PSPIF: Par | rallel Slave | Port Interru | ıpt Flag bit | | | | | | | | | • | | ice (must be | cleared in s | oftware) | | | | 0 = No rea | a or write o | peration na | is taken pia | ce | | | | | bit 6: | Reserved: | Always ma | intain this l | oit clear. | | | | | | bit 5-4: | Unimplem | ented: Rea | ad as '0' | | | | | | 0 = Waiting to transmit/receive Capture Mode bit 3: bit 2: 1 = A TMR1 register capture occurred (must be cleared in software) 1 = The transmission/reception is complete (must be cleared in software) 0 = No TMR1 register capture occurred CCP1IF: CCP1 Interrupt Flag bit Compare Mode 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred SSPIF: Synchronous Serial Port Interrupt Flag bit PWM Mode Unused in this mode bit 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 bit 0: TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflow occurred (must be cleared in software) 0 = No TMR1 register occurred 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. # PIC16C6X NOTES: ### **5.0 I/O PORTS** ### Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 Some pins for these I/O ports are multiplexed with an alternate function(s) for the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin. ### 5.1 PORTA and TRISA Register #### Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 All devices have a 6-bit wide PORTA, except for the PIC16C61 which has a 5-bit wide PORTA. Pin RA4/T0CKI is a Schmitt Trigger input and an open drain output. All other RA port pins have TTL input levels and full CMOS output drivers. All pins have data direction bits (TRIS registers) which can configure these pins as output or input. Setting a bit in the TRISA register puts the corresponding output driver in a hi-impedance mode. Clearing a bit in the TRISA register puts the contents of the output latch on the selected pin. Reading PORTA register reads the status of the pins whereas writing to it will write to the port latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, this value is modified, and then written to the port data latch Pin RA4 is multiplexed with Timer0 module clock input to become the RA4/T0CKI pin. #### **EXAMPLE 5-1: INITIALIZING PORTA** ``` BCF STATUS, RP0 BCF STATUS, RP1 ; PIC16C66/67 only ; Initialize PORTA by CLRE PORTA : clearing output ; data latches BSF STATUS, RPO ; Select Bank 1 ; Value used to MOVLW 0xCF : initialize data : direction MOVWF TRISA ; Set RA<3:0> as inputs ; RA<5:4> as outputs ; TRISA<7:6> are always ; read as '0'. ``` # FIGURE 5-1: BLOCK DIAGRAM OF THE RA3:RA0 PINS AND THE RA5 PIN # FIGURE 5-2: BLOCK DIAGRAM OF THE ### 5.2 PORTB and TRISB Register Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 PORTB is an 8-bit wide bi-directional port. The corresponding data direction register is TRISB. Setting a bit in the TRISB register puts the corresponding output driver in a hi-impedance mode. Clearing a bit in the TRISB register puts the contents of the output latch on the selected pin(s). #### **EXAMPLE 5-2: INITIALIZING PORTB** ``` STATUS, RPO CLRF PORTB ; Initialize PORTB by ; clearing output ; data latches BSF STATUS, RPO ; Select Bank 1 MOVLW ; Value used to ; initialize data ; direction MOVWE TRISE ; Set RB<3:0> as inputs ; RB<5:4> as outputs ; RB<7:6> as inputs ``` Each of the PORTB pins has a weak internal pull-up. A single control bit can turn on all the pull-ups. This is performed by clearing bit RBPU (OPTION<7>). The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are also disabled on a Power-on Reset. Four of PORTB's pins, RB7:RB4, have an interrupt on change feature. Only pins configured as inputs can cause this interrupt to occur (i.e., any RB7:RB4 pin configured as an output is excluded from the interrupt on change comparison). The input pins (of RB7:RB4) are compared with the old value latched on the last read of PORTB. The "mismatch" outputs of RB7:RB4 are OR'ed together to generate the RB port change interrupt with flag bit RBIF (INTCON<0>). This interrupt can wake the device from SLEEP. The user, in the interrupt service routine, can clear the interrupt in the following manner: - a) Any read or write of PORTB. This will end the mismatch condition. - b) Clear flag bit RBIF. A mismatch condition will continue to set flag bit RBIF. Reading PORTB will end the mismatch condition, and allow flag bit RBIF to be cleared. This interrupt on mismatch feature, together with software configurable pull-ups on these four pins allow easy interface to a keypad and make it possible for wake-up on key-depression. Refer to the Embedded Control Handbook, Application Note, "Implementing Wake-up on Key Stroke" (AN552). Note: For PIC16C61/62/64/65, if a change on the I/O pin should occur when a read operation is being executed (start of the Q2 cycle), then interrupt flag bit RBIF may not get set. The interrupt on change feature is recommended for wake-up on key depression operation and operations where PORTB is only used for the interrupt on change feature. Polling of PORTB is not recommended while using the interrupt on change feature. FIGURE 5-3: BLOCK DIAGRAM OF THE RB7:RB4 PINS FOR PIC16C61/62/64/65 Note 1: I/O pins have diode protection to VDD and VSS. 2: To enable weak pull-ups, set the appropriate TRIS bit(s) and clear the RPBU bit (OPTION<7>). ## TABLE 9-1: REGISTERS ASSOCIATED WITH TIMER2 AS A TIMER/COUNTER | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value<br>PC<br>BC | , | Valu<br>all o<br>res | | |--------------------------------|--------|----------------------|--------------------------|---------------------|---------------------|---------|--------|---------|---------|-------------------|------|----------------------|------| | 0Bh,8Bh<br>10Bh,18Bh | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 | 000x | 0000 | 000u | | 0Ch | PIR1 | PSPIF <sup>(2)</sup> | (3) | RCIF <sup>(1)</sup> | TXIF <sup>(1)</sup> | SSPIF | CCP1IF | TMR2IF | TMR1IF | 0000 | 0000 | 0000 | 0000 | | 8Ch | PIE1 | PSPIE <sup>(2)</sup> | (3) | RCIE <sup>(1)</sup> | TXIE <sup>(1)</sup> | SSPIE | CCP1IE | TMR2IE | TMR1IE | 0000 | 0000 | 0000 | 0000 | | 11h | TMR2 | Timer2 m | Timer2 module's register | | | | | | | 0000 | 0000 | 0000 | 0000 | | 12h | T2CON | _ | TOUTPS3 | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000 | 0000 | -000 | 0000 | | 92h PR2 Timer2 Period register | | | | | | | | | 1111 | 1111 | 1111 | 1111 | | Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by Timer2. Note 1: The USART is implemented on the PIC16C63/R63/65/65A/R65/66/67 only. <sup>2:</sup> Bits PSPIE and PSPIF are reserved on the PIC16C62/62A/R62/63/R63/66, always maintain these bits clear. <sup>3:</sup> PIR1<6> and PIE1<6> are reserved, always maintain these bits clear. To enable the serial port, SSP enable bit SSPEN (SSPCON<5>) must be set. To reset or reconfigure SPI mode, clear enable bit SSPEN, re-initialize SSPCON register, and then set enable bit SSPEN. This configures the SDI, SDO, SCK, and \$\overline{SP}\$ pins as serial port pins. For the pins to behave as the serial port function, they must have their data direction bits (in the TRIS 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 (if implemented) 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 11-4 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 the 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 software 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 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 11-5 and Figure 11-6 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 20 MHz) of 5 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 11-4: SPI MASTER/SLAVE CONNECTION Steps to follow when setting up an Asynchronous Transmission: - Initialize the SPBRG register for the appropriate baud rate. If a high speed baud rate is desired, then set bit BRGH. (Section 12.1). - Enable the asynchronous serial port by clearing bit SYNC and setting bit SPEN. - If interrupts are desired, then set enable bit TXIE. - If 9-bit transmission is desired, then set transmit bit TX9. - Enable the transmission by setting bit TXEN, which will also set bit TXIF. - If 9-bit transmission is selected, the ninth bit should be loaded in bit TX9D. - Load data to the TXREG register (starts transmission). ### FIGURE 12-8: ASYNCHRONOUS MASTER TRANSMISSION ### FIGURE 12-9: ASYNCHRONOUS MASTER TRANSMISSION (BACK TO BACK) ### TABLE 12-6: REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION | 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 | |---------|----------------------------------------|----------------------|----------|---------|-------|-------|--------|--------|--------|-------------------------|---------------------------------| | 0Ch | PIR1 | PSPIF <sup>(1)</sup> | (2) | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF | 0000 0000 | 0000 0000 | | 18h | RCSTA | SPEN | RX9 | SREN | CREN | - | FERR | OERR | RX9D | 0000 -00x | 0000 -00x | | 19h | TXREG | USART Tra | ansmit R | egister | | | | | | 0000 0000 | 0000 0000 | | 8Ch | PIE1 | PSPIE <sup>(1)</sup> | (2) | RCIE | TXIE | SSPIE | CCP1IE | TMR2IE | TMR1IE | 0000 0000 | 0000 0000 | | 98h | TXSTA | CSRC | TX9 | TXEN | SYNC | | BRGH | TRMT | TX9D | 0000 -010 | 0000 -010 | | 99h | 99h SPBRG Baud Rate Generator Register | | | | | | | | | 0000 0000 | 0000 0000 | Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Asynchronous Transmission. Note 1: PSPIF and PSPIE are reserved on the PIC16C63/R63/66, always maintain these bits clear. 2: PIR1<6> and PIE1<6> are reserved, always maintain these bits clear. # PIC16C6X Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 # FIGURE 17-9: I<sup>2</sup>C BUS START/STOP BITS TIMING # TABLE 17-9: I<sup>2</sup>C BUS START/STOP BITS REQUIREMENTS | Parameter No. | Sym | Characteristic | | Min | Тур | Max | Units | Conditions | | |---------------|---------|-----------------|--------------|------|-----|-----|-------|-----------------------------------|--| | 90 | Tsu:sta | START condition | 100 kHz mode | 4700 | _ | _ | | Only relevant for repeated START | | | | | Setup time | 400 kHz mode | 600 | _ | _ | ns | condition | | | 91 | THD:STA | START condition | 100 kHz mode | 4000 | _ | _ | | After this period the first clock | | | | | Hold time | 400 kHz mode | 600 | _ | _ | ns | pulse is generated | | | 92 | Tsu:sto | STOP condition | 100 kHz mode | 4700 | _ | _ | | | | | | | Setup time | 400 kHz mode | 600 | _ | _ | ns | | | | 93 | THD:STO | STOP condition | 100 kHz mode | 4000 | _ | _ | | | | | | | Hold time | 400 kHz mode | 600 | _ | _ | ns | | | Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 FIGURE 19-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING TABLE 19-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER REQUIREMENTS | Parameter No. | Sym | Characteristic | Min | Typ† | Max | Units | Conditions | |---------------|-------|-----------------------------------------------|-----|----------|-----|-------|--------------------------| | 30* | TmcL | MCLR Pulse Width (low) | 100 | _ | - | ns | VDD = 5V, -40°C to +85°C | | 31* | Twdt | Watchdog Timer Time-out Period (No Prescaler) | 7 | 18 | 33 | ms | VDD = 5V, -40°C to +85°C | | 32 | Tost | Oscillation Start-up Timer Period | _ | 1024Tosc | | _ | TOSC = OSC1 period | | 33* | Tpwrt | Power-up Timer Period or WDT reset | 28 | 72 | 132 | ms | VDD = 5V, -40°C to +85°C | | 34 | Tıoz | I/O Hi-impedance from MCLR Low | _ | _ | 100 | ns | | <sup>\*</sup> 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. DC CHARACTERISTICS Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 20.3 DC Characteristics: PIC16C63/65A-04 (Commercial, Industrial, Extended) PIC16C63/65A-10 (Commercial, Industrial, Extended) PIC16C63/65A-20 (Commercial, Industrial, Extended) PIC16LC63/65A-04 (Commercial, Industrial) Standard Operating Conditions (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for extended, -40°C $\leq$ TA $\leq$ +85°C for industrial and 0°C < TA < +70°C for commercial Operating voltage VDD range as described in DC spec Section 20.1 and Section 20.2 | Section 20.2 Param Characteristic Sym Min Typ Max Units Conditions | | | | | | | | | | | |---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------|--|--|--|--| | Characteristic | Sym | Min | | Max | Units | Conditions | | | | | | | | | † | | | | | | | | | Input Low Voltage | | | | | | | | | | | | I/O ports | VIL | | | | | | | | | | | with TTL buffer | | Vss | - | 0.15VDD | V | For entire VDD range | | | | | | | | Vss | - | V8.0 | V | $4.5V \le V_{DD} \le 5.5V$ | | | | | | with Schmitt Trigger buffer | | Vss | - | 0.2VDD | V | | | | | | | MCLR, OSC1 (in RC mode) | | Vss | - | 0.2VDD | V | | | | | | | OSC1 (in XT, HS and LP) | | Vss | - | 0.3VDD | V | Note1 | | | | | | Input High Voltage | | | | | | | | | | | | I/O ports | VIH | | - | | | | | | | | | with TTL buffer | | 2.0 | - | VDD | V | $4.5V \le V_{DD} \le 5.5V$ | | | | | | | | 0.25VDD | - | VDD | V | For entire VDD range | | | | | | | | + 0.8V | | | | | | | | | | with Schmitt Trigger buffer | | 0.8Vpp | _ | Vpp | V | For entire VDD range | | | | | | | | 0.8Vpp | _ | Vpp | V | 3 | | | | | | | | | _ | VDD | V | Note1 | | | | | | , | | 0.9Vpp | _ | VDD | V | | | | | | | PORTB weak pull-up current | IPURB | 50 | 250 | 400 | μΑ | VDD = 5V, VPIN = VSS | | | | | | Input Leakage Current (Notes 2, 3) | | | | | | | | | | | | I/O ports | lı∟ | - | - | ±1 | μΑ | Vss ≤ VPIN ≤ VDD, Pin at hi- | | | | | | | | | | | - | impedance | | | | | | MCLR, RA4/T0CKI | | - | - | ±5 | μΑ | $Vss \le VPIN \le VDD$ | | | | | | OSC1 | | - | - | ±5 | μΑ | Vss ≤ VPIN ≤ VDD, XT, HS and | | | | | | | | | | | | LP osc configuration | | | | | | Output Low Voltage | | | | | | | | | | | | I/O ports | VOL | - | - | 0.6 | V | IOL = 8.5 mA, VDD = 4.5V, | | | | | | | | | | | ., | -40°C to +85°C | | | | | | | | - | - | 0.6 | V | IOL = $7.0 \text{ mA}$ , VDD = $4.5 \text{V}$ , $-40^{\circ}\text{C}$ to $+125^{\circ}\text{C}$ | | | | | | OSC2/CLKOUT (RC osc config) | | - | - | 0.6 | V | IOL = 1.6 mA, VDD = 4.5V, | | | | | | | | | | | | -40°C to +85°C | | | | | | | | - | - | 0.6 | V | IOL = $1.2 \text{ mA}$ , VDD = $4.5 \text{V}$ , $-40^{\circ}\text{C}$ to $+125^{\circ}\text{C}$ | | | | | | | Input Low Voltage I/O ports with TTL buffer with Schmitt Trigger buffer MCLR, OSC1 (in RC mode) OSC1 (in XT, HS and LP) Input High Voltage I/O ports with TTL buffer with Schmitt Trigger buffer MCLR OSC1 (XT, HS and LP) OSC1 (in RC mode) PORTB weak pull-up current Input Leakage Current (Notes 2, 3) I/O ports MCLR, RA4/T0CKI OSC1 Output Low Voltage I/O ports | Input Low Voltage I/O ports with TTL buffer with Schmitt Trigger buffer MCLR, OSC1 (in RC mode) OSC1 (in XT, HS and LP) Input High Voltage I/O ports with TTL buffer with Schmitt Trigger buffer MCLR OSC1 (XT, HS and LP) OSC1 (in RC mode) PORTB weak pull-up current Input Leakage Current (Notes 2, 3) I/O ports MCLR, RA4/T0CKI OSC1 Output Low Voltage I/O ports VIL VIL VIH VIH VIH VIH VIH VIH | Characteristic Sym Min | Characteristic Sym Min Typ | Characteristic Sym Min Typ Max | Characteristic Sym Min Typ Max Units | | | | | <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. Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the PIC16C6X be driven with external clock in RC mode. <sup>2:</sup> The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages. <sup>3:</sup> Negative current is defined as current sourced by the pin. Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 ### 20.5 Timing Diagrams and Specifications FIGURE 20-2: EXTERNAL CLOCK TIMING TABLE 20-2: EXTERNAL CLOCK TIMING REQUIREMENTS | Param | Sym | Characteristic | Min | Typ† | Max | Units | Conditions | |-------|-------|----------------------------------|-----|------|--------|-------|--------------------| | No. | | | | | | | | | | 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 | 100 | _ | _ | 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> 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. 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 ### 22.0 ELECTRICAL CHARACTERISTICS FOR PIC16C66/67 ## Absolute Maximum Ratings (†) | · · · · · · · · · · · · · · · · · · · | | |------------------------------------------------------------------------|----------------------| | Ambient temperature under bias | 55°C to +125°C | | Storage temperature | 65°C to +150°C | | Voltage on any pin with respect to Vss (except VDD, MCLR, and RA4) | 0.3V to (VDD + 0.3V) | | Voltage on VDD with respect to VSS | -0.3V to +7.5V | | Voltage on MCLR with respect to Vss (Note 2) | 0V to +14V | | Voltage on RA4 with respect to Vss | | | Total power dissipation (Note 1) | | | Maximum current out of Vss pin | 300 mA | | Maximum current into VDD pin | | | Input clamp current, Iικ (Vι < 0 or Vι > VDD) | ±20 mA | | Output clamp current, loк (Vo < 0 or Vo > VDD) | ±20 mA | | Maximum output current sunk by any I/O pin | | | Maximum output current sourced by any I/O pin | 25 mA | | Maximum current sunk by PORTA, PORTB, and PORTE (Note 3) (combined) | 200 mA | | Maximum current sourced by PORTA, PORTB, and PORTE (Note 3) (combined) | 200 mA | | Maximum current sunk by PORTC and PORTD (Note 3) (combined) | 200 mA | | Maximum current sourced by PORTC and PORTD (Note 3) (combined) | 200 mA | | | | - Note 1: Power dissipation is calculated as follows: Pdis = VDD x {IDD $\sum$ IOH} + $\sum$ {(VDD-VOH) x IOH} + $\sum$ (Vol x IOL) - Note 2: Voltage spikes below Vss at the MCLR/VPP pin, inducing currents greater than 80 mA, may cause latch-up. Thus, a series resistor of 50-100Ω should be used when applying a "low" level to the MCLR/VPP pin rather than pulling this pin directly to Vss. - Note 3: PORTD and PORTE not available on the PIC16C66. † NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. TABLE 22-1: CROSS REFERENCE OF DEVICE SPECS FOR OSCILLATOR CONFIGURATIONS AND FREQUENCIES OF OPERATION (COMMERCIAL DEVICES) | osc | PIC16C66-04<br>PIC16C67-04 | PIC16C66-10<br>PIC16C67-10 | PIC16C66-20<br>PIC16C67-20 | PIC16LC66-04<br>PIC16LC67-04 | JW Devices | |-----|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RC | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq: 4 MHz max. | VDD: 4.5V to 5.5V IDD: 2.7 mA typ. at 5.5V IPD: 1.5 $\mu$ A typ. at 4V Freq: 4 MHz max. | VDD: 4.5V to 5.5V IDD: 2.7 mA typ. at 5.5V IPD: 1.5 $\mu$ A typ. at 4V Freq: 4 MHz max. | VDD: 2.5V to 6.0V<br>IDD: 3.8 mA max. at 3V<br>IPD: 5 μA max. at 3V<br>Freq: 4 MHz max. | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq: 4 MHz max. | | XT | VDD: 4.0V to 6.0V IDD: 5 mA max. at 5.5V IPD: 16 $\mu$ A max. at 4V Freq: 4 MHz max. | VDD: 4.5V to 5.5V IDD: 2.7 mA typ. at 5.5V IPD: 1.5 $\mu$ A typ. at 4V Freq: 4 MHz max. | VDD: 4.5V to 5.5V IDD: 2.7 mA typ. at 5.5V IPD: 1.5 $\mu$ A typ. at 4V Freq: 4 MHz max. | VDD: 2.5V to 6.0V<br>IDD: 3.8 mA max. at 3V<br>IPD: 5 μA max. at 3V<br>Freq: 4 MHz max. | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq: 4 MHz max. | | HS | VDD: 4.5V to 5.5V<br>IDD: 13.5 mA typ. at 5.5V | VDD: 4.5V to 5.5V<br>IDD: 10 mA max. at 5.5V | VDD: 4.5V to 5.5V<br>IDD: 20 mA max. at 5.5V | Not recommended for use in HS mode | VDD: 4.5V to 5.5V<br>IDD: 20 mA max. at 5.5V | | | IPD: $1.5 \mu A$ typ. at $4.5 V$ Freq: $4 MHz$ max. | IPD 1.5 μA typ. at 4.5V<br>Freq: 10 MHz max. | IPD: 1.5 μA typ. at 4.5V Freq: 20 MHz max. | use iii no iiiode | IPD: 1.5 μA typ. at 4.5V<br>Freq: 20 MHz max. | | LP | VDD: 4.0V to 6.0V<br>IDD: 52.5 μA typ.<br>at 32 kHz, 4.0V<br>IPD: 0.9 μA typ. at 4.0V<br>Freq: 200 kHz max. | Not recommended for use in LP mode | Not recommended for use in LP mode | VDD: 2.5V to 6.0V<br>IDD: 48 μA max. at 32<br>kHz, 3.0V<br>IPD: 5 μA max. at 3.0V<br>Freq: 200 kHz max. | $\begin{array}{c} \text{VDD: } 2.5 \text{V to } 6.0 \text{V} \\ \text{IDD: } 48 \ \mu\text{A max.} \\ \text{at } 32 \ \text{kHz, } 3.0 \text{V} \\ \text{IPD: } 5 \ \mu\text{A max. at } 3.0 \text{V} \\ \text{Freq: } 200 \ \text{kHz max.} \\ \end{array}$ | The shaded sections indicate oscillator selections which are tested for functionality, but not for MIN/MAX specifications. It is recommended that the user select the device type that ensures the specifications required. # PIC16C6X Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 # FIGURE 22-13: I<sup>2</sup>C BUS START/STOP BITS TIMING # TABLE 22-9: I<sup>2</sup>C BUS START/STOP BITS REQUIREMENTS | Parameter No. | Sym | Characteristic | | Min | Тур | Max | Units | Conditions | |---------------|---------|-----------------|--------------|------|-----|-----|-------|-----------------------------------| | 90* | Tsu:sta | START condition | 100 kHz mode | 4700 | _ | _ | ns | Only relevant for repeated START | | | | Setup time | 400 kHz mode | 600 | _ | _ | 113 | condition | | 91* | THD:STA | START condition | 100 kHz mode | 4000 | _ | _ | ns | After this period the first clock | | | | Hold time | 400 kHz mode | 600 | _ | _ | 115 | pulse is generated | | 92* | Tsu:sto | STOP condition | 100 kHz mode | 4700 | _ | _ | ns | | | | | Setup time | 400 kHz mode | 600 | _ | _ | 113 | | | 93 | THD:STO | STOP condition | 100 kHz mode | 4000 | _ | _ | ns | | | | | Hold time | 400 kHz mode | 600 | _ | _ | 113 | | These parameters are characterized but not tested. Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 FIGURE 23-18: TYPICAL IDD vs. CAPACITANCE @ 500 kHz (RC MODE) TABLE 23-1: RC OSCILLATOR FREQUENCIES | Cext | Rext | Average | | | | |--------|------|-----------------|--------|--|--| | Cext | next | Fosc @ 5V, 25°C | | | | | 22 pF | 5k | 4.12 MHz | ± 1.4% | | | | | 10k | 2.35 MHz | ± 1.4% | | | | | 100k | 268 kHz | ± 1.1% | | | | 100 pF | 3.3k | 1.80 MHz | ± 1.0% | | | | | 5k | 1.27 MHz | ± 1.0% | | | | | 10k | 688 kHz | ± 1.2% | | | | | 100k | 77.2 kHz | ± 1.0% | | | | 300 pF | 3.3k | 707 kHz | ± 1.4% | | | | | 5k | 501 kHz | ± 1.2% | | | | | 10k | 269 kHz | ± 1.6% | | | | | 100k | 28.3 kHz | ± 1.1% | | | The percentage variation indicated here is part to part variation due to normal process distribution. The variation indicated is ±3 standard deviation from average value for VDD = 5V. FIGURE 23-19: TRANSCONDUCTANCE(gm) OF HS OSCILLATOR vs. VDD FIGURE 23-20: TRANSCONDUCTANCE(gm) OF LP OSCILLATOR vs. VDD # FIGURE 23-21: TRANSCONDUCTANCE(gm) OF XT OSCILLATOR vs. VDD ## 24.5 28-Lead Plastic Surface Mount (SOIC - Wide, 300 mil Body) (SO) Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | Package Group: Plastic SOIC (SO) | | | | | | | | | |----------------------------------|--------|-------------|-------------|-------|--------|---------|--|--| | | | Millimeters | Millimeters | | Inches | | | | | Symbol | Min | Max | Notes | Min | Max | Notes | | | | α | 0° | 8° | | 0° | 8° | | | | | Α | 2.362 | 2.642 | | 0.093 | 0.104 | | | | | A1 | 0.101 | 0.300 | | 0.004 | 0.012 | | | | | В | 0.355 | 0.483 | | 0.014 | 0.019 | | | | | С | 0.241 | 0.318 | | 0.009 | 0.013 | | | | | D | 17.703 | 18.085 | | 0.697 | 0.712 | | | | | E | 7.416 | 7.595 | | 0.292 | 0.299 | | | | | е | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical | | | | Н | 10.007 | 10.643 | | 0.394 | 0.419 | | | | | h | 0.381 | 0.762 | | 0.015 | 0.030 | | | | | L | 0.406 | 1.143 | | 0.016 | 0.045 | | | | | N | 28 | 28 | | 28 | 28 | | | | | CP | _ | 0.102 | | _ | 0.004 | | | | ## F.3 PIC16C15X Family of Devices | | | PIC16C154 | PIC16CR154 | PIC16C156 | PIC16CR156 | PIC16C158 | PIC16CR158 | |-------------|--------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------| | Clock | Maximum Frequency of Operation (MHz) | 20 | 20 | 20 | 20 | 20 | 20 | | | EPROM Program Memory (x12 words) | 512 | _ | 1K | _ | 2K | _ | | Memory | ROM Program Memory (x12 words) | _ | 512 | _ | 1K | _ | 2K | | | RAM Data Memory (bytes) | 25 | 25 | 25 | 25 | 73 | 73 | | Peripherals | Timer Module(s) | TMR0 | TMR0 | TMR0 | TMR0 | TMR0 | TMR0 | | | I/O Pins | 12 | 12 | 12 | 12 | 12 | 12 | | | Voltage Range (Volts) | 3.0-5.5 | 2.5-5.5 | 3.0-5.5 | 2.5-5.5 | 3.0-5.5 | 2.5-5.5 | | Features | Number of Instructions | 33 | 33 | 33 | 33 | 33 | 33 | | | Packages | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. ## F.4 PIC16C5X Family of Devices | | | PIC16C52 | PIC16C54 | PIC16C54A | PIC16CR54A | PIC16C55 | PIC16C56 | |-------------|--------------------------------------|---------------------|-------------------------------------|-------------------------------------|-------------------------------------|------------------------------|-------------------------------------| | Clock | Maximum Frequency of Operation (MHz) | 4 | 20 | 20 | 20 | 20 | 20 | | | EPROM Program Memory (x12 words) | 384 | 512 | 512 | _ | 512 | 1K | | Memory | ROM Program Memory<br>(x12 words) | _ | _ | _ | 512 | _ | _ | | | RAM Data Memory (bytes) | 25 | 25 | 25 | 25 | 24 | 25 | | Peripherals | Timer Module(s) | TMR0 | TMR0 | TMR0 | TMR0 | TMR0 | TMR0 | | | I/O Pins | 12 | 12 | 12 | 12 | 20 | 12 | | | Voltage Range (Volts) | 2.5-6.25 | 2.5-6.25 | 2.0-6.25 | 2.0-6.25 | 2.5-6.25 | 2.5-6.25 | | Features | Number of Instructions | 33 | 33 | 33 | 33 | 33 | 33 | | | Packages | 18-pin DIP,<br>SOIC | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 28-pin DIP,<br>SOIC,<br>SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | | | | PIC16C57 | PIC16CR57B | PIC16C58A | PIC16CR58A | |-------------|--------------------------------------|------------------------------|---------------------------|----------------------------------|----------------------------------| | Clock | Maximum Frequency of Operation (MHz) | 20 | 20 | 20 | 20 | | | EPROM Program Memory (x12 words) | 2K | _ | 2K | _ | | Memory | ROM Program Memory (x12 words) | _ | 2K | _ | 2K | | | RAM Data Memory (bytes) | 72 | 72 | 73 | 73 | | Peripherals | Timer Module(s) | TMR0 | TMR0 | TMR0 | TMR0 | | | I/O Pins | 20 | 20 | 12 | 12 | | | Voltage Range (Volts) | 2.5-6.25 | 2.5-6.25 | 2.0-6.25 | 2.5-6.25 | | Features | Number of Instructions | 33 | 33 | 33 | 33 | | | Packages | 28-pin DIP,<br>SOIC,<br>SSOP | 28-pin DIP, SOIC,<br>SSOP | 18-pin DIP, SOIC;<br>20-pin SSOP | 18-pin DIP, SOIC;<br>20-pin SSOP | All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer (except PIC16C52), selectable code protect and high I/O current capability. # PIC16C6X | TMR024, 26, 28, 30, 32, TMR0 Clock Source Select bit, T0CS | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------| | TMR0 Interrupt | | | TMR0 Overflow Interrupt Enable bit, T0IE | | | TMR0 Overflow Interrupt Flag bit, T0IF | | | TMR0 Prescale Selection Table | | | TMR0 Source Edge Select bit, T0SE | | | TMR1 Overflow Interrupt Enable bit, TMR1IE | | | TMR1 Overflow Interrupt Flag bit, TMR1IF | | | TMR1CS | | | TMR1H24, 26, 28, 30, 32, | | | TMR1IE | | | TMR1IF | 41 | | TMR1L24, 26, 28, 30, 32, 3 | 34 | | TMR10N | 71 | | TMR224, 26, 28, 30, 32, 3 | 34 | | TMR2 Register | 75 | | TMR2 to PR2 Match Interrupt Enable bit, TMR2IE | | | TMR2 to PR2 Match Interrupt Flag bit, TMR2IF | 41 | | TMR2IE | 38 | | TMR2IF | 41 | | TMR2ON | 75 | | TO35, 15 | 31 | | TOUTPS3:TOUTPS0 | | | Transmit Enable bit, TXEN10 | | | Transmit Shift Register Status bit, TRMT 10 | | | Transmit Status and Control Register10 | | | TRISA25, 27, 29, 31, 33, 34, | | | TRISB25, 27, 29, 31, 33, 34, 5 | | | TRISC25, 27, 29, 31, 33, 34, 55, | | | TRISD | | | TRISE | | | TRMT10 | | | | | | TX910 | 05 | | TX910 | 05<br>05 | | TX9 | 05<br>05<br>05 | | TX9 10 TX9D 10 TXEN 10 TXIE | 05<br>05<br>05<br>39 | | TX9 11 TX9D 10 TXEN 10 TXIE TXIF | 05<br>05<br>05<br>39<br>42 | | TX9 10 TX9D 11 TXEN 11 TXIE 5 TXIF 24, 26, 28, 30, 32, 32, 32, 33 | 05<br>05<br>05<br>39<br>42<br>34 | | TX9 11 TX9D 10 TXEN 10 TXIE TXIF | 05<br>05<br>05<br>39<br>42<br>34 | | TX9 10 TX9D. 11 TXEN 11 TXIE 11 TXIE 24, 26, 28, 30, 32, 31 TXSTA 25, 27, 29, 31, 33, 34, 10 U | 05<br>05<br>05<br>39<br>42<br>34<br>05 | | TX9 10 TX9D 11 TXEN 11 TXIE 11 TXIE 12 TXIE 24, 26, 28, 30, 32, 31 TXSTA 25, 27, 29, 31, 33, 34, 10 U UA 84, 8 | 05<br>05<br>05<br>39<br>42<br>34<br>05 | | TX9 10 TX9D 11 TXEN 11 TXEN 11 TXIE 12 TXIE 24, 26, 28, 30, 32, 32, 33 TXSTA 25, 27, 29, 31, 33, 34, 10 U UA 84, 84, 84, 84, 94, 95, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96 | 05<br>05<br>05<br>39<br>42<br>34<br>05 | | TX9 10 TX9D 11 TXEN 11 TXEN 11 TXIE 5 TXIE 5 TXIF 5 TXREG 24, 26, 28, 30, 32, 11 TXSTA 25, 27, 29, 31, 33, 34, 10 U UA 84, 4 Universal Synchronous Asynchronous Receiver Transmitt (USART) | 05<br>05<br>05<br>39<br>42<br>34<br>05 | | TX9 | 05<br>05<br>39<br>42<br>34<br>05<br>89 | | TX9 10 TX9D 11 TX9D 11 TXEN 10 TXIE | 05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter | | TX9 | 05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter | | TX9 | 05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter<br>13<br>12 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter<br>13<br>12 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter<br>13<br>12 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter<br>13<br>13<br>14 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter<br>13<br>14<br>14 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter<br>13<br>14<br>14 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter<br>13<br>13<br>14<br>14<br>05 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>11<br>11<br>14<br>14<br>14<br>10<br>15<br>18 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>11<br>11<br>14<br>14<br>10<br>15<br>16 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>ter<br>13<br>14<br>14<br>14<br>16<br>18 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>er<br>13<br>14<br>14<br>14<br>16<br>18<br>16 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>11<br>11<br>11<br>14<br>14<br>16<br>16<br>11<br>19 | | TX9 | 05<br>05<br>05<br>39<br>42<br>34<br>05<br>89<br>11<br>11<br>11<br>14<br>14<br>16<br>16<br>11<br>17 | | Synchronous Slave Mode | | |-------------------------------------------|--------| | Reception | 120 | | Section | 120 | | Setting Up Reception | 120 | | Setting Up Transmission | 120 | | Transmit | 120 | | Transmit Block Diagram | 112 | | Jpdate Address bit, UA | 84, 89 | | JSART Receive Interrupt Enable bit, RCIE | 39 | | JSART Receive Interrupt Flag bit, RCIF | 42 | | JSART Transmit Interrupt Enable bit, TXIE | 39 | | JSART Transmit Interrupt Flag bit, TXIF | 42 | | JV Erasable Devices | 7 | | W | | | •• | | | Wake-up from Sleep | | | Wake-up on Key Depression | | | Wake-up Using Interrupts | 141 | | Watchdog Timer (WDT) | | | Block Diagram | 140 | | Period | | | Programming Considerations | | | Section | | | WCOL | | | Weak Internal Pull-ups | | | Write Collision Detect bit, WCOL | 85, 90 | | x | | | XMIT MODE | 104 | | XT | | | z | | | Z | 35 | | Zero bit | | | | 5, 00 |