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 | 20MHz | | Connectivity | I <sup>2</sup> C, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, POR, PWM, WDT | | Number of I/O | 22 | | Program Memory Size | 7KB (4K x 14) | | Program Memory Type | OTP | | EEPROM Size | - | | RAM Size | 192 x 8 | | Voltage - Supply (Vcc/Vdd) | 4V ~ 6V | | Data Converters | A/D 5x8b | | Oscillator Type | External | | Operating Temperature | -40°C ~ 125°C (TA) | | Mounting Type | Through Hole | | Package / Case | 28-DIP (0.300", 7.62mm) | | Supplier Device Package | 28-SPDIP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16c73a-20e-sp | ### FIGURE 4-13: PIR1 REGISTER PIC16C73/73A/74/74A/76/77 (ADDRESS 0Ch) R/W-0 R/W-0 R/W-0 R/W-0 R-0 R-0 R/W-0 R/W-0 PSPIF<sup>(1)</sup> **ADIF RCIF TXIF SSPIF** CCP1IF TMR2IF TMR1IF = Readable bit W = Writable bit bit7 bit0 U = Unimplemented bit, read as '0' n = Value at POR reset bit 7: PSPIF<sup>(1)</sup>: Parallel Slave Port Read/Write Interrupt Flag bit 1 = A read or a write operation has taken place (must be cleared in software) 0 = No read or write has occurred bit 6: ADIF: A/D Converter Interrupt Flag bit 1 = An A/D conversion completed (must be cleared in software) 0 = The A/D conversion is not complete bit 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 bit 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 bit 3: SSPIF: Synchronous Serial Port Interrupt Flag bit 1 = The transmission/reception is complete (must be cleared in software) 0 = Waiting to transmit/receive bit 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 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 overflowed (must be cleared in software) 0 = TMR1 register did not overflow Note 1: PIC16C73/73A/76 devices do not have a Parallel Slave Port implemented, this bit location is reserved on these devices, always maintain this bit clear. 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. **NOTES:** #### 5.7 Parallel Slave Port Applicable Devices 72 | 73 | 73 | 74 | 74 | 76 | 77 PORTD operates as an 8-bit wide Parallel Slave Port, or microprocessor port when control bit PSPMODE (TRISE<4>) is set. In slave mode it is asynchronously readable and writable by the external world through $\overline{RD}$ control input pin RE0/ $\overline{RD}$ /AN5 and $\overline{WR}$ control input pin RE1/ $\overline{WR}$ /AN6. It can directly interface to an 8-bit microprocessor data bus. The external microprocessor can read or write the PORTD latch as an 8-bit latch. Setting bit PSPMODE enables port pin RE0/ $\overline{RD}$ /AN5 to be the $\overline{RD}$ input, RE1/ $\overline{WR}$ /AN6 to be the $\overline{WR}$ input and RE2/ $\overline{CS}$ /AN7 to be the $\overline{CS}$ (chip select) input. For this functionality, the corresponding data direction bits of the TRISE register (TRISE<2:0>) must be configured as inputs (set) and the A/D port configuration bits PCFG2:PCFG0 (ADCON1<2:0>) must be set, which will configure pins RE2:RE0 as digital I/O. There are actually two 8-bit latches, one for data-out (from the PIC16/17) and one for data input. The user writes 8-bit data to PORTD data latch and reads data from the port pin latch (note that they have the same address). In this mode, the TRISD register is ignored, since the microprocessor is controlling the direction of data flow. A write to the PSP occurs when both the $\overline{\text{CS}}$ and $\overline{\text{WR}}$ lines are first detected low. When either the $\overline{\text{CS}}$ or $\overline{\text{WR}}$ lines become high (level triggered), then the Input Buffer Full status flag bit IBF (TRISE<7>) is set on the Q4 clock cycle, following the next Q2 cycle, to signal the write is complete (Figure 5-12). The interrupt flag bit PSPIF (PIR1<7>) is also set on the same Q4 clock cycle. IBF can only be cleared by reading the PORTD input latch. The input Buffer Overflow status flag bit IBOV (TRISE<5>) is set if a second write to the Parallel Slave Port is attempted when the previous byte has not been read out of the buffer. A read from the PSP occurs when both the $\overline{\text{CS}}$ and $\overline{\text{RD}}$ lines are first detected low. The Output Buffer Full status flag bit OBF (TRISE<6>) is cleared immediately (Figure 5-13) indicating that the PORTD latch is waiting to be read by the external bus. When either the $\overline{\text{CS}}$ or $\overline{\text{RD}}$ pin becomes high (level triggered), the interrupt flag bit PSPIF is set on the Q4 clock cycle, following the next Q2 cycle, indicating that the read is complete. OBF remains low until data is written to PORTD by the user firmware. When not in Parallel Slave Port mode, the IBF and OBF bits are held clear. However, if flag bit IBOV was previously set, it must be cleared in firmware. An interrupt is generated and latched into flag bit PSPIF when a read or write operation is completed. PSPIF must be cleared by the user in firmware and the interrupt can be disabled by clearing the interrupt enable bit PSPIE (PIE1<7>). FIGURE 5-11: PORTD AND PORTE BLOCK DIAGRAM (PARALLEL SLAVE PORT) **NOTES:** ### 11.2 SPI Mode for PIC16C72/73/73A/74/74A This section contains register definitions and operational characteristics of the SPI module for the PIC16C72, PIC16C73, PIC16C73A, PIC16C74, PIC16C74A. # FIGURE 11-1: SSPSTAT: SYNC SERIAL PORT STATUS REGISTER (ADDRESS 94h) | U-0 | U-0 | R-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | |----------|----------|-------------------------------|------------|------------------------------------------------------|------------------------------|--------------|--------------|------------------------------------------------------------------------------| | _ | _ | D/Ā | Р | S | R/W | UA | BF | R = Readable bit | | bit7 | | | | | | | bit0 | W = Writable bit U = Unimplemented bit, read as '0' - n = Value at POR reset | | bit 7-6: | Unimpl | emented | : Read as | '0' | | | | | | bit 5: | 1 = Indi | cates that | the last b | | d or transmi<br>d or transmi | | | | | bit 4: | 1 = Indi | | a stop bit | has been | leared wher<br>detected las | | | abled, SSPEN is cleared)<br>T) | | bit 3: | 1 = Indi | | a start bi | has been | leared wher<br>detected las | | | abled, SSPEN is cleared)<br>T) | | bit 2: | This bit | holds the<br>o the next<br>ad | R/W bit i | ation (I <sup>2</sup> C nnformation stop bit, or | following the | e last addre | ess match. T | his bit is valid from the addres | | bit 1: | 1 = Indi | cates that | the user | t I <sup>2</sup> C mode<br>needs to up<br>to be upda | date the ad | dress in the | SSPADD re | egister | | bit 0: | BF: Buf | fer Full St | atus bit | | | | | | | | 1 = Rec | | olete, SSF | es)<br>PBUF is full<br>SSPBUF is | empty | | | | | | 1 = Trar | | ogress, S | SPBUF is f | | | | | ### TABLE 12-3: BAUD RATES FOR SYNCHRONOUS MODE | BAUD | Fosc = 2 | 20 MHz | SPBRG | 16 MHz | | SPBRG | 10 MHz | | SPBRG | 7.15909 | 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 M | Hz | 4 MHz | | | 3.579545 | 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 | 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 | 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 | 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 | 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 | #### 12.2.2 USART ASYNCHRONOUS RECEIVER The receiver block diagram is shown in Figure 12-10. The data is received on the RC7/RX/DT pin and drives the data recovery block. The data recovery block is actually a high speed shifter operating at x16 times the baud rate, whereas the main receive serial shifter operates at the bit rate or at Fosc. Once Asynchronous mode is selected, reception is enabled by setting bit CREN (RCSTA<4>). The heart of the receiver is the receive (serial) shift register (RSR). After sampling the STOP bit, the received data in the RSR is transferred to the RCREG register (if it is empty). If the transfer is complete, flag bit RCIF (PIR1<5>) is set. The actual interrupt can be enabled/ disabled by setting/clearing enable bit RCIE (PIE1<5>). Flag bit RCIF is a read only bit which is cleared by the hardware. It is cleared when the RCREG register has been read and is empty. The RCREG is a double buffered register, i.e. it is a two deep FIFO. It is possible for two bytes of data to be received and transferred to the RCREG FIFO and a third byte begin shifting to the RSR register. On the detection of the STOP bit of the third byte, if the RCREG register is still full then overrun error bit OERR (RCSTA<1>) will be set. The word in the RSR will be lost. The RCREG register can be read twice to retrieve the two bytes in the FIFO. Overrun bit OERR has to be cleared in software. This is done by resetting the receive logic (CREN is cleared and then set). If bit OERR is set, transfers from the RSR register to the RCREG register are inhibited, so it is essential to clear error bit OERR if it is set. Framing error bit FERR (RCSTA<2>) is set if a stop bit is detected as clear. Bit FERR and the 9th receive bit are buffered the same way as the receive data. Reading the RCREG, will load bits RX9D and FERR with new values, therefore it is essential for the user to read the RCSTA register before reading RCREG register in order not to lose the old FERR and RX9D information. #### FIGURE 12-10: USART RECEIVE BLOCK DIAGRAM #### FIGURE 12-11: ASYNCHRONOUS RECEPTION | CLRF | Clear f | | | | | | | | | | |-------------------|-----------------------------------------------------------------------|-------------------------|-----------------|-----------------------|--|--|--|--|--|--| | Syntax: | [label] C | LRF f | | | | | | | | | | Operands: | $0 \le f \le 12$ | 27 | | | | | | | | | | Operation: | $\begin{array}{c} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$ | | | | | | | | | | | Status Affected: | Z | | | | | | | | | | | Encoding: | 00 | 0001 | 1fff | ffff | | | | | | | | Description: | The contents of register 'f' are cleared and the Z bit is set. | | | | | | | | | | | Words: | 1 | | | | | | | | | | | Cycles: | 1 | | | | | | | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | | | | | | | Decode | Read<br>register<br>'f' | Process<br>data | Write<br>register 'f' | | | | | | | | Example | CLRF | FLAG | G_REG | | | | | | | | | | | FLAG_RE | | 0x5A | | | | | | | | | After Inst | ruction | | | | | | | | | $FLAG_REG = 0x00$ | CLRW | Clear W | | | | |-------------------|----------------------------------------------------------------------|------------------|-----------------|---------------| | Syntax: | [ label ] | CLRW | | | | Operands: | None | | | | | Operation: | $\begin{array}{c} 00h \rightarrow (V \\ 1 \rightarrow Z \end{array}$ | V) | | | | Status Affected: | Z | | | | | Encoding: | 00 | 0001 | 0xxx | xxxx | | Description: | W register set. | is cleared | . Zero bit ( | Z) is | | Words: | 1 | | | | | Cycles: | 1 | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | Decode | No-<br>Operation | Process<br>data | Write to<br>W | | Example | CLRW | | | | | | Before In | struction | | | | | | • • | 0x5A | | | | After Inst | | 0x00 | | | | | • • | 1 | | | CLRWDT | Clear Watchdog Timer | | | | | | | | | | |-------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|-------------------------|--|--|--|--|--|--| | Syntax: | [ label ] | CLRWD1 | Г | | | | | | | | | Operands: | None | | | | | | | | | | | Operation: | $00h \rightarrow W$ $0 \rightarrow WD$ $1 \rightarrow \overline{TO}$ $1 \rightarrow \overline{PD}$ | | er, | | | | | | | | | Status Affected: | $\overline{TO}$ , $\overline{PD}$ | | | | | | | | | | | Encoding: | 00 0000 0110 0100 | | | | | | | | | | | Description: | CLRWDT instruction resets the Watchdog Timer. It also resets the prescaler of the WDT. Status bits TO and PD are set. | | | | | | | | | | | Words: | 1 | | | | | | | | | | | Cycles: | 1 | | | | | | | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | | | | | | | Decode | No-<br>Operation | Process<br>data | Clear<br>WDT<br>Counter | | | | | | | | Example | CLRWDT | | | | | | | | | | | | Before In | struction<br>WDT cour | nter = | ? | | | | | | | | | After Instruction | | | | | | | | | | | GOTO | Unconditional Branch | | | | INCF | Increme | Increment f | | | | | |-------------------|--------------------------------------------------------|------------------------------------|--------------------------------------|---------------------------|-------------------|-------------------------|---------------------------------------------------------------|----------------------------|----------------------|--|--| | Syntax: | [ label ] | GOTO | k | | Syntax: | [ label ] | INCF 1 | ,d | | | | | Operands: | $0 \le k \le 20$ | 047 | | | Operands: | $0 \le f \le 12$ | 27 | | | | | | Operation: | $k \to PC <$ | 10:0> | | | | d ∈ [0,1] | | | | | | | | PCLATH- | <4:3> → I | PC<12:11 | > | Operation: | (f) + 1 → | $(f) + 1 \rightarrow (destination)$ | | | | | | Status Affected: | None | | | | Status Affected: | Z | | | | | | | Encoding: | 10 | 1kkk | kkkk | kkkk | Encoding: | 0.0 | 1010 | dfff | ffff | | | | Description: | GOTO is ar eleven bit into PC bit PC are loa GOTO is a | immediate<br>s <10:0>.<br>ded from | value is lo<br>The upper<br>PCLATH<4 | eaded<br>bits of<br>1:3>. | Description: | mented. It<br>the W reg | ents of reg<br>f 'd' is 0 th<br>ister. If 'd'<br>ock in regis | e result is<br>is 1 the re | placed in | | | | Words: | 1 | | | | Words: | 1 | | | | | | | Cycles: | 2 | | | | Cycles: | 1 | | | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | | 1st Cycle | Decode | Read<br>literal 'k' | Process<br>data | Write to PC | | Decode | Read<br>register | Process<br>data | Write to destination | | | | 2nd Cycle | No-<br>Operation | No-<br>Operation | No-<br>Operation | No-<br>Operation | Example | INCF | CNT, | 1 | | | | | Example | GOTO TI | ruction | Address | ГНЕКЕ | ZAMIPIO | | nstruction<br>CNT<br>Z | | | | | | | | | | | | | Z | = 1 | 0 | | | | RLF | Rotate L | eft f thre | ough Ca | rry | RRF | Rotate F | Right f th | rough C | arry | |-------------------|--------------------------------|-------------------------------------------------------------|------------------------------------------------------------------------|----------------------|-------------------|--------------------------------------------------------|----------------------------------------------|-----------------|------------------------------------| | Syntax: | [ label ] | RLF | f,d | | Syntax: | [ label ] | RRF f | ,d | | | Operands: | $0 \le f \le 12$ $d \in [0,1]$ | | | | Operands: | $0 \le f \le 12$ $d \in [0,1]$ | | | | | Operation: | See des | cription b | elow | | Operation: | See des | cription b | elow | | | Status Affected: | С | | | | Status Affected: | С | | | | | Encoding: | 0.0 | 1101 | dfff | ffff | Encoding: | 0.0 | 1100 | dfff | ffff | | Description: | one bit to<br>Flag. If 'd' | the left th<br>is 0 the re<br>r. If 'd' is 1<br>gister 'f'. | ister 'f' are<br>rough the<br>esult is pla<br>the result<br>Register f | Carry<br>ced in the | Description: | The conte one bit to Flag. If 'd' W registe back in re | the right t<br>is 0 the re<br>r. If 'd' is 1 | hrough the | e Carry<br>ced in the<br>is placed | | Words: | 1 | | | | <b>1</b> 07 | | | | | | | 1 | | | | Words: | 1 | | | | | Cycles: | 1 | | | | Cycles: | 1 | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | Decode | Read<br>register<br>'f' | Process<br>data | Write to destination | | Decode | Read<br>register<br>'f' | Process<br>data | Write to destination | | Example | RLF | REG | G1,0 | | Example | RRF | | REG1,0 | | | | Before In | struction | 1 | | | Before In | struction | 1 | | | | | REG1 | | 0 0110 | | | REG1 | = 111 | 0 0110 | | | After Ins | C<br>truction | = 0 | | | After Ins | C<br>truction | = 0 | | | | | REG1 | | 0 0110 | | | REG1 | = 111 | 0 0110 | | | | W<br>C | | 0 1100 | | | W | | 1 0011 | | | | C | = 1 | | | | С | = 0 | | DC CHARACTERISTICS # **Applicable Devices** 72 73 73A 74 74A 76 77 17.3 DC Characteristics: PIC16C72-04 (Commercial, Industrial, Extended) PIC16C72-10 (Commercial, Industrial, Extended) PIC16C72-20 (Commercial, Industrial, Extended) PIC16LC72-04 (Commercial, Industrial) Standard Operating Conditions (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \leq \text{Ta} \leq +125^{\circ}\text{C}$ for extended, $-40^{\circ}\text{C} \leq \text{Ta} \leq +85^{\circ}\text{C}$ for industrial and $0^{\circ}$ C $\leq TA \leq +70^{\circ}$ C for commercial Operating voltage VDD range as described in DC spec Section 17.1 and Section 17.2. | | and Section 17.2. | | | | | | | | | | | | |----------|------------------------------------|-------|---------|-----|---------|-------|----------------------------------------------|--|--|--|--|--| | Param | Characteristic | Sym | Min | Тур | Max | Units | Conditions | | | | | | | No. | | | | † | | | | | | | | | | | Input Low Voltage | | | | | | | | | | | | | | I/O ports | VIL | | | | | | | | | | | | D030 | with TTL buffer | | Vss | - | 0.15VDD | V | For entire VDD range | | | | | | | D030A | | | Vss | - | V8.0 | V | 4.5 ≤ VDD ≤ 5.5V | | | | | | | D031 | with Schmitt Trigger buffer | | Vss | - | 0.2Vdd | V | | | | | | | | D032 | MCLR, OSC1 (in RC mode) | | Vss | - | 0.2Vdd | V | | | | | | | | D033 | OSC1 (in XT, HS and LP) | | Vss | - | 0.3VDD | V | Note1 | | | | | | | | Input High Voltage | | | | | | | | | | | | | | I/O ports | Vih | | - | | | | | | | | | | D040 | with TTL buffer | | 2.0 | - | Vdd | V | 4.5 ≤ VDD ≤ 5.5V | | | | | | | D040A | | | 0.25VDD | - | Vdd | V | For entire VDD range | | | | | | | | | | + 0.8V | | | | | | | | | | | | | | | | | | | | | | | | | D041 | with Schmitt Trigger buffer | | 0.8VDD | - | Vdd | | For entire VDD range | | | | | | | D042 | MCLR | | 0.8VDD | - | Vdd | V | | | | | | | | D042A | OSC1 (XT, HS and LP) | | 0.7Vdd | - | Vdd | - | Note1 | | | | | | | D043 | OSC1 (in RC mode) | | 0.9Vdd | - | Vdd | V | | | | | | | | D070 | PORTB weak pull-up current | IPURB | 50 | 250 | †400 | μΑ | VDD = 5V, VPIN = VSS | | | | | | | | Input Leakage Current (Notes 2, 3) | | | | | | | | | | | | | D060 | I/O ports | lı∟ | - | - | ±1 | μΑ | Vss ≤ VPIN ≤ VDD, Pin at hi- | | | | | | | | | | | | | | impedance | | | | | | | D061 | MCLR, RA4/T0CKI | | - | - | ±5 | | Vss ≤ Vpin ≤ Vdd | | | | | | | D063 | OSC1 | | - | - | ±5 | μΑ | Vss ≤ VPIN ≤ VDD, XT, HS and | | | | | | | | | | | | | | LP osc configuration | | | | | | | | Output Low Voltage | | | | | | | | | | | | | D080 | I/O ports | Vol | - | - | 0.6 | V | IOL = 8.5 mA, VDD = 4.5V, | | | | | | | <b>D</b> | | | | | | ., | -40°C to +85°C | | | | | | | D080A | | | - | - | 0.6 | V | IOL = 7.0 mA, VDD = 4.5V, | | | | | | | Door | | | | | 0.0 | ,, | -40°C to +125°C | | | | | | | D083 | OSC2/CLKOUT (RC osc config) | | - | - | 0.6 | V | IOL = 1.6 mA, VDD = 4.5V, | | | | | | | D0024 | | | | | 0.6 | / | -40°C to +85°C | | | | | | | D083A | | | - | - | 0.6 | V | IOL = 1.2 mA, VDD = 4.5V,<br>-40°C to +125°C | | | | | | | | | | | | | | -40 C 10 +125 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: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt trigger input. It is not recommended that the PIC16C7X be driven with external clock in RC mode. - 2: 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. - 3: Negative current is defined as current sourced by the pin. #### **TABLE 17-10: A/D CONVERTER CHARACTERISTICS:** PIC16C72-04 (Commercial, Industrial, Extended) PIC16C72-10 (Commercial, Industrial, Extended) PIC16C72-20 (Commercial, Industrial, Extended) PIC16LC72-04 (Commercial, Industrial) | Param<br>No. | Sym | Characteristic | | Min | Тур† | Max | Units | Conditions | |--------------|------|------------------------------------------------|--------------------|-----------|------------|------------|-------|----------------------------------------------------------------------------------------------------| | A01 | NR | Resolution | | _ | _ | 8-bits | bit | VREF = VDD = 5.12V,<br>VSS ≤ VAIN ≤ VREF | | A02 | EABS | Total Absolute error | | _ | _ | < ± 1 | LSb | VREF = VDD = 5.12V,<br>VSS ≤ VAIN ≤ VREF | | A03 | EIL | Integral linearity error | | _ | _ | < ± 1 | LSb | VREF = VDD = 5.12V,<br>VSS ≤ VAIN ≤ VREF | | A04 | EDL | Differential linearity error | | _ | _ | < ± 1 | LSb | VREF = VDD = 5.12V,<br>VSS ≤ VAIN ≤ VREF | | A05 | EFS | Full scale error | | _ | _ | < ± 1 | LSb | VREF = VDD = 5.12V,<br>VSS ≤ VAIN ≤ VREF | | A06 | EOFF | Offset error | | _ | _ | < ± 1 | LSb | VREF = VDD = 5.12V,<br>VSS ≤ VAIN ≤ VREF | | A10 | _ | Monotonicity | | _ | guaranteed | _ | _ | VSS ≤ VAIN ≤ VREF | | A20 | VREF | Reference voltage | | 3.0V | _ | VDD + 0.3 | V | | | A25 | VAIN | Analog input voltage | | Vss - 0.3 | _ | VREF + 0.3 | V | | | A30 | ZAIN | Recommended impedance of analog voltage source | | _ | _ | 10.0 | kΩ | | | A40 | IAD | A/D conversion current (VDD) | PIC16 <b>C</b> 72 | _ | 180 | _ | μΑ | Average current consump- | | | | | PIC16 <b>LC</b> 72 | _ | 90 | _ | μΑ | tion when A/D is on.<br>(Note 1) | | A50 | IREF | VREF input current (Note 2) | | 10 | _ | 1000 | μА | During VAIN acquisition. Based on differential of VHOLD to VAIN to charge CHOLD, see Section 13.1. | | | | | | _ | _ | 10 | μА | During A/D Conversion cycle | 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: When A/D is off, it will not consume any current other than minor leakage current. The power-down current spec includes any such leakage from the A/D module. <sup>2:</sup> VREF current is from RA3 pin or VDD pin, whichever is selected as reference input. #### 18.0 ELECTRICAL CHARACTERISTICS FOR PIC16C73/74 #### **Absolute Maximum Ratings †** | Ambient temperature under bias | 55 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.3 to +7.5V | | Voltage on MCLR with respect to Vss (Note 2) | 0 to +14V | | Voltage on RA4 with respect to Vss | 0 to +14V | | Total power dissipation (Note 1) | 1.0W | | Maximum current out of Vss pin | 300 mA | | Maximum current into VDD pin | 250 mA | | Input clamp current, lik (VI < 0 or VI > VDD) | ±20 mA | | Output clamp current, loκ (Vo < 0 or Vo > VDD) | ±20 mA | | Maximum output current sunk by any I/O pin | 25 mA | | Maximum output current sourced by any I/O pin | 25 mA | | Maximum current sunk by PORTA, PORTB, and PORTE (combined) (Note 3) | 200 mA | | Maximum current sourced by PORTA, PORTB, and PORTE (combined) (Note 3) | 200 mA | | Maximum current sunk by PORTC and PORTD (combined) (Note 3) | 200 mA | | Maximum current sourced by PORTC and PORTD (combined) (Note 3) | 200 mA | | <b>Note 1:</b> Power dissipation is calculated as follows: Pdis = VDD x {IDD - $\Sigma$ IOH} + $\Sigma$ {(VDD - $\Sigma$ | VOH) $x$ IOH} + $\sum$ (VOI $x$ IOL) | - Note 2: Voltage spikes below VSS at the MCLR pin, inducing currents greater than 80 mA, may cause latch-up. Thus, a series resistor of 50-100 $\Omega$ should be used when applying a "low" level to the $\overline{MCLR}$ pin rather than pulling this pin directly to Vss. - Note 3: PORTD and PORTE are not implemented on the PIC16C73. † 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 18-1:** CROSS REFERENCE OF DEVICE SPECS FOR OSCILLATOR CONFIGURATIONS AND FREQUENCIES OF OPERATION (COMMERCIAL DEVICES) | osc | PIC16C73-04<br>PIC16C74-04 | PIC16C73-10<br>PIC16C74-10 | PIC16C73-20<br>PIC16C74-20 | PIC16LC73-04<br>PIC16LC74-04 | JW Devices | |-----|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------| | RC | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 21 μA max. at 4V<br>Freq: 4 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 2.7 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 2.7 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max. | VDD: 3.0V to 6.0V<br>IDD: 3.8 mA max. at 3.0V<br>IPD: 13.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: 21 μA max. at 4V<br>Freq: 4 MHz max. | | XT | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 21 μA max. at 4V<br>Freq: 4 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 2.7 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 2.7 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max. | VDD: 3.0V to 6.0V<br>IDD: 3.8 mA max. at 3.0V<br>IPD: 13.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: 21 μ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<br>IPD: 1.5 μA typ. at 4.5V<br>Freq: 4 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 15 mA max. at 5.5V<br>IPD: 1.5 μA typ. at 4.5V<br>Freq: 10 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 30 mA max. at 5.5V<br>IPD: 1.5 μA typ. at 4.5V<br>Freq: 20 MHz max. | Not recommended for use in HS mode | VDD: 4.5V to 5.5V<br>IDD: 30 mA max. at 5.5V<br>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. at<br>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: 3.0V to 6.0V<br>IDD: 48 µA max. at<br>32 kHz, 3.0V<br>IPD: 13.5 µA max. at 3.0V<br>Freq: 200 kHz max. | VDD: 3.0V to 6.0V<br>IDD: 48 μA max. at<br>32 kHz, 3.0V<br>IPD: 13.5 μA max. at 3.0V<br>Freq: 200 kHz max. | 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. DC CHARACTERISTICS ## **Applicable Devices** 72 73 73A 74 74A 76 77 18.3 DC Characteristics: PIC16C73/74-04 (Commercial, Industrial) PIC16C73/74-10 (Commercial, Industrial) PIC16C73/74-20 (Commercial, Industrial) PIC16LC73/74-04 (Commercial, Industrial) #### Standard Operating Conditions (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for industrial and $0^{\circ}$ C $\leq TA \leq +70^{\circ}$ C for commercial Operating voltage $\ensuremath{\text{VDD}}$ range as described in DC spec Section 18.1 and Section 18.2. | Param | Characteristic | Sym | Min | Тур | Max | Units | Conditions | |-------|-----------------------------|-------|-----------|-----|---------|-------|---------------------------------------| | No. | | | | ť | | | | | | Input Low Voltage | | | | | | | | | I/O ports | VIL | | | | | | | D030 | with TTL buffer | | Vss | - | 0.15Vpd | V | For entire VDD range | | D030A | | | Vss | - | 0.8V | V | 4.5V ≤ VDD ≤ 5.5V | | D031 | with Schmitt Trigger buffer | | Vss | - | 0.2VDD | V | | | D032 | MCLR, OSC1 (in RC mode) | | Vss | - | 0.2Vdd | V | | | D033 | OSC1 (in XT, HS and LP) | | Vss | - | 0.3Vdd | V | Note1 | | | Input High Voltage | | | | | | | | | I/O ports | ViH | | - | | | | | D040 | with TTL buffer | | 2.0 | - | Vdd | V | 4.5V ≤ VDD ≤ 5.5V | | D040A | | | 0.25VDD | - | Vdd | V | For entire VDD range | | | | | + 0.8V | | | | | | | | | | | | | | | D041 | with Schmitt Trigger buffer | | 0.8VDD | - | VDD | V | For entire VDD range | | D042 | MCLR | | 0.8VDD | - | VDD | V | | | D042A | OSC1 (XT, HS and LP) | | 0.7VDD | - | VDD | V | Note1 | | D043 | OSC1 (in RC mode) | | 0.9VDD | - | VDD | V | | | D070 | PORTB weak pull-up current | IPURB | 50 | 250 | 400 | μΑ | VDD = 5V, VPIN = VSS | | | Input Leakage Current | | | | | | | | Doco | (Notes 2, 3) | 1 | | | | | Vac < VDW < VDD Die et hi immed | | D060 | I/O ports | lıL | - | - | ±1 | μΑ | Vss ≤ VPIN ≤ VDD, Pin at hi-impedance | | D061 | MCLR, RA4/T0CKI | | _ | _ | ±5 | μA | Vss < Vpin < VDD | | D063 | OSC1 | | _ | _ | 5<br>±5 | μA | Vss ≤ VPIN ≤ VDD, XT, HS and LP osc | | D003 | 0361 | | _ | _ | | μΛ | configuration | | | Output Low Voltage | | | | | | - comigaration | | D080 | I/O ports | VOL | _ | _ | 0.6 | V | IOL = 8.5 mA, VDD = 4.5V, | | | | | | | | - | -40°C to +85°C | | D083 | OSC2/CLKOUT (RC osc config) | | - | - | 0.6 | V | loL = 1.6 mA, VDD = 4.5V, | | | | | | | | | -40°C to +85°C | | | Output High Voltage | | | | | | | | D090 | I/O ports (Note 3) | Voн | VDD - 0.7 | - | - | V | IOH = -3.0 mA, VDD = 4.5V, | | | | | | | | | -40°C to +85°C | | D092 | OSC2/CLKOUT (RC osc config) | | VDD - 0.7 | - | - | V | IOH = -1.3 mA, VDD = 4.5V, | | | | | | | | | -40°C to +85°C | | D150* | Open-Drain High Voltage | Vod | - | - | 14 | V | RA4 pin | <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 PIC16C7X be driven with external clock in RC mode. <sup>2:</sup> The leakage current on the MCLR 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** 72 73 73A 74 74A 76 77 ### 18.4 <u>Timing Parameter Symbology</u> The timing parameter symbols have been created following one of the following formats: 1. TppS2ppS 3. Tcc:st (I<sup>2</sup>C specifications only) 2. TppS 4. Ts (I<sup>2</sup>C specifications only) T Time Lowercase letters (pp) and their meanings: | рр | | | | |----|----------|-----|----------| | СС | CCP1 | osc | OSC1 | | ck | CLKOUT | rd | RD | | cs | CS | rw | RD or WR | | di | SDI | sc | SCK | | do | SDO | SS | SS | | dt | Data in | t0 | TOCKI | | io | I/O port | t1 | T1CKI | | mc | MCLR | wr | WR | Uppercase letters and their meanings: | S | | | | |-----------------------|------------------------|------|--------------| | F | Fall | Р | Period | | Н | High | R | Rise | | 1 | Invalid (Hi-impedance) | V | Valid | | L | Low | Z | Hi-impedance | | I <sup>2</sup> C only | | | | | AA | output access | High | High | | BUF | Bus free | Low | Low | Tcc:st (I<sup>2</sup>C specifications only) | CC | | | | |-----|-----------------|-----|----------------| | HD | Hold | SU | Setup | | ST | | | | | DAT | DATA input hold | STO | STOP condition | | STA | START condition | | | #### FIGURE 18-1: LOAD CONDITIONS FIGURE 18-9: I<sup>2</sup>C BUS START/STOP BITS TIMING TABLE 18-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 | _ | _ | 115 | condition | | | 91 | THD:STA | START condition | 100 kHz mode | 4000 | _ | _ | nc | 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 | _ | _ | ns | | | | | | Setup time | 400 kHz mode | 600 | _ | _ | 115 | | | | 93 | THD:STO | STOP condition | 100 kHz mode | 4000 | _ | _ | ns | | | | | | Hold time | 400 kHz mode | 600 | _ | _ | 115 | | | **Standard Operating Conditions (unless otherwise stated)** Operating temperature $-40^{\circ}\text{C} \leq \text{TA} \leq +125^{\circ}\text{C}$ for extended, -40°C ≤ TA ≤ +85°C for industrial and $0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial Operating voltage VDD range as described in DC spec Section 19.1 and Section 19.2. | | Section 19.2. | | | | | | | | |-------|-----------------------------------------|-------------------|-----------|-----|-----|-------|-------------------------------------------------------------------|--| | Param | Characteristic | Sym | Min | Тур | Max | Units | Conditions | | | No. | | _ | | † | | | | | | | Output High Voltage | | | | | | | | | D090 | I/O ports (Note 3) | Vон | VDD - 0.7 | - | - | V | IOH = $-3.0$ mA, VDD = $4.5$ V, $-40$ °C to $+85$ °C | | | D090A | | | VDD - 0.7 | - | - | V | IOH = $-2.5$ mA, VDD = $4.5$ V,<br>-40°C to $+125$ °C | | | D092 | OSC2/CLKOUT (RC osc config) | | VDD - 0.7 | - | - | V | IOH = -1.3 mA, VDD = $4.5$ V, $-40$ °C to $+85$ °C | | | D092A | | | VDD - 0.7 | - | - | V | IOH = -1.0 mA, VDD = $4.5$ V, $-40$ °C to $+125$ °C | | | D150* | Open-Drain High Voltage | Vod | - | - | 14 | V | RA4 pin | | | | Capacitive Loading Specs on | | | | | | | | | | Output Pins | | | | | | | | | D100 | OSC2 pin | Cosc <sub>2</sub> | - | - | 15 | pF | In XT, HS and LP modes when external clock is used to drive OSC1. | | | D101 | All I/O pins and OSC2 (in RC | Cıo | - | - | 50 | pF | | | | D102 | mode) SCL, SDA in I <sup>2</sup> C mode | Св | - | - | 400 | pF | | | \* These parameters are characterized but not tested. DC CHARACTERISTICS - † 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 PIC16C7X be driven with external clock in RC mode. - 2: The leakage current on the MCLR 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. - 3: Negative current is defined as current sourced by the pin. FIGURE 20-3: CLKOUT AND I/O TIMING TABLE 20-3: CLKOUT AND I/O TIMING REQUIREMENTS | Param<br>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 | | _ | 35 | 100 | ns | Note 1 | | 14* | TckL2ioV | CLKOUT ↓ to Port out valid | d | _ | _ | 0.5Tcy + 20 | ns | Note 1 | | 15* | TioV2ckH | Port in valid before CLKOL | Tosc + 200 | _ | _ | ns | Note 1 | | | 16* | TckH2ioI | Port in hold after CLKOUT | 0 | _ | _ | ns | Note 1 | | | 17* | TosH2ioV | OSC1 <sup>↑</sup> (Q1 cycle) to<br>Port out valid | | _ | 50 | 150 | ns | | | 18* | TosH2ioI | OSC1↑ (Q2 cycle) to | PIC16 <b>C</b> 76/77 | 100 | _ | _ | ns | | | | | Port input invalid (I/O in hold time) | PIC16 <b>LC</b> 76/77 | 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> 76/77 | _ | 10 | 40 | ns | | | | | | PIC16 <b>LC</b> 76/77 | _ | _ | 80 | ns | | | 21* | TioF | Port output fall time | PIC16 <b>C</b> 76/77 | _ | 10 | 40 | ns | | | | | | PIC16 <b>LC</b> 76/77 | _ | _ | 80 | ns | | | 22††* | Tinp | INT pin high or low time | | Tcy | _ | _ | ns | | | 23††* | Trbp | RB7:RB4 change INT high | or low time | Tcy | _ | _ | ns | | 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 edges. Note 1: Measurements are taken in RC Mode where CLKOUT output is 4 x Tosc. **Applicable Devices** | 72 | 73 | 73A | 74 | 74A | 76 | 77 FIGURE 21-22: TYPICAL XTAL STARTUP TIME vs. VDD (LP MODE, 25°C) FIGURE 21-23: TYPICAL XTAL STARTUP TIME vs. VDD (HS MODE, 25°C) FIGURE 21-24: TYPICAL XTAL STARTUP TIME vs. VDD (XT MODE, 25°C) TABLE 21-2: CAPACITOR SELECTION FOR CRYSTAL OSCILLATORS | Osc Type | Crystal<br>Freq | Cap. Range<br>C1 | Cap. Range<br>C2 | |------------------|-----------------|------------------|------------------| | LP | 32 kHz | 33 pF | 33 pF | | | 200 kHz | 15 pF | 15 pF | | XT | 200 kHz | 47-68 pF | 47-68 pF | | | 1 MHz | 15 pF | 15 pF | | | 4 MHz | 15 pF | 15 pF | | HS | 4 MHz | 15 pF | 15 pF | | | 8 MHz | 15-33 pF | 15-33 pF | | | 20 MHz | 15-33 pF | 15-33 pF | | | | | | | Crystals<br>Used | | | | | 32 kHz | Epson C-00 | 01R32.768K-A | ± 20 PPM | | 200 kHz | STD XTL 2 | 00.000KHz | ± 20 PPM | | 1 MHz | ECS ECS- | ± 50 PPM | | | 4 MHz | ECS ECS-4 | ± 50 PPM | | | 8 MHz | EPSON CA | ± 30 PPM | | | 20 MHz | EPSON CA | x-301 20.000M-C | ± 30 PPM | | CCP2IF bit38 | F | | |----------------------------------------------|----------------------------------------------|------| | CCPR1H Register25, 27, 29, 71 | Family of Devices | | | CCPR1L Register29, 71 | PIC12CXXX | 265 | | CCPR2H Register25, 27, 29, 71 | PIC14C000 | | | CCPR2L Register25, 27, 29, 71 | PIC16C15X | | | CCPxM0 bit72 | PIC16C55X | | | CCPxM1 bit72 | PIC16C5X | 266 | | CCPxM2 bit72 | PIC16C62X and PIC16C64X | | | CCPxM3 bit72 | PIC16C6X | | | CCPxX bit72 | PIC16C7XX | 6 | | CCPxY bit72 | PIC16C8X | 269 | | CKE83 | PIC16C9XX | 269 | | CKP79, 84 | PIC17CXX | 270 | | Clock Polarity Select bit, CKP79, 84 | FERR bit | 100 | | Clock Polarity, SPI Mode81 | FSR Register | , 41 | | Clocking Scheme17 | Fuzzy Logic Dev. System (fuzzyTECH®-MP) 163, | | | Code Examples | | | | Call of a Subroutine in Page 1 from Page 041 | G | | | Changing Between Capture Prescalers73 | General Description | 5 | | Changing Prescaler (Timer0 to WDT)63 | GIE bit | 141 | | Changing Prescaler (WDT to Timer0)63 | • | | | I/O Programming53 | I | | | Indirect Addressing41 | I/O Ports | | | Initializing PORTA43 | PORTA | 43 | | Initializing PORTB45 | PORTB | 45 | | Initializing PORTC48 | PORTC | 48 | | Loading the SSPBUF Register80, 85 | PORTD50 | , 54 | | Code Protection | PORTE | 51 | | Computed GOTO40 | Section | 43 | | Configuration Bits129 | I/O Programming Considerations | 53 | | Configuration Word129 | I <sup>2</sup> C | | | Connecting Two Microcontrollers81 | Addressing | 94 | | CREN bit100 | Addressing I <sup>2</sup> C Devices | 90 | | <u>CS</u> pin54 | Arbitration | 92 | | D | Block Diagram | 93 | | | Clock Synchronization | 92 | | D/Ā78, 83 | Combined Format | 91 | | Data/Address bit, D/A78, 83 | I <sup>2</sup> C Operation | 93 | | DC bit | I <sup>2</sup> C Overview | 89 | | DC Characteristics | Initiating and Terminating Data Transfer | 89 | | PIC16C72168 | Master Mode | 97 | | PIC16C73184 | Master-Receiver Sequence | 91 | | PIC16C73A202 | Master-Transmitter Sequence | 91 | | PIC16C74184 | Mode | 93 | | PIC16C74A202 | Mode Selection | 93 | | PIC16C76221 | Multi-master | 92 | | PIC16C77221 | Multi-Master Mode | | | Development Support | Reception | 95 | | Development Tools | Reception Timing Diagram | 95 | | Digit Carry bit9 | SCL and SDA pins | | | Direct Addressing41 | Slave Mode | | | E | START | 89 | | | STOP89 | , 90 | | Electrical Characteristics | Transfer Acknowledge | 90 | | PIC16C72 | Transmission | 96 | | PIC16C73 | IDLE_MODE | 98 | | PIC16C73A | In-Circuit Serial Programming | 146 | | PIC16C74 | INDF | | | PIC16C74A201 | INDF Register 24, 25, 26, 27, 28 | , 41 | | PIC16C76219 | Indirect Addressing | | | PIC16C77219 | Initialization Condition for all Register | | | External Brown-out Protection Circuit | Instruction Cycle | | | External Power-on Reset Circuit140 | Instruction Flow/Pipelining | | | | Instruction Format | |