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 | - | | Peripherals | Brown-out Detect/Reset, POR, WDT | | Number of I/O | 13 | | Program Memory Size | 896B (512 x 14) | | Program Memory Type | OTP | | EEPROM Size | - | | RAM Size | 36 x 8 | | Voltage - Supply (Vcc/Vdd) | 4V ~ 6V | | Data Converters | A/D 4x8b | | Oscillator Type | External | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Through Hole | | Package / Case | 18-DIP (0.300", 7.62mm) | | Supplier Device Package | 18-PDIP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16c710-20i-p | TABLE 1-1: PIC16C71X FAMILY OF DEVICES | | | PIC16C710 | PIC16C71 | PIC16C711 | PIC16C715 | PIC16C72 | PIC16CR72 <sup>(1)</sup> | |-------------|-------------------------------------------------|-------------------------------------|---------------------|-------------------------------------|-------------------------------------|----------------------------|----------------------------| | Clock | Maximum Frequency of Operation (MHz) | 20 | 20 | 20 | 20 | 20 | 20 | | | EPROM Program Memory (x14 words) | 512 | 1K | 1K | 2K | 2K | _ | | Memory | ROM Program Memory<br>(14K words) | _ | _ | _ | _ | _ | 2K | | | Data Memory (bytes) | 36 | 36 | 68 | 128 | 128 | 128 | | | Timer Module(s) | TMR0 | TMR0 | TMR0 | TMR0 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | | Peripherals | Capture/Compare/PWM<br>Module(s) | _ | _ | _ | _ | 1 | 1 | | | Serial Port(s)<br>(SPI/I <sup>2</sup> C, USART) | _ | _ | _ | _ | SPI/I <sup>2</sup> C | SPI/I <sup>2</sup> C | | | Parallel Slave Port | _ | _ | _ | _ | _ | _ | | | A/D Converter (8-bit) Channels | 4 | 4 | 4 | 4 | 5 | 5 | | | Interrupt Sources | 4 | 4 | 4 | 4 | 8 | 8 | | | I/O Pins | 13 | 13 | 13 | 13 | 22 | 22 | | | Voltage Range (Volts) | 2.5-6.0 | 3.0-6.0 | 2.5-6.0 | 2.5-5.5 | 2.5-6.0 | 3.0-5.5 | | Features | In-Circuit Serial Programming | Yes | Yes | Yes | Yes | Yes | Yes | | | Brown-out Reset | Yes | _ | Yes | Yes | Yes | Yes | | | Packages | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 28-pin SDIP,<br>SOIC, SSOP | 28-pin SDIP,<br>SOIC, SSOP | | | | PIC16C73A | PIC16C74A | PIC16C76 | PIC16C77 | |-------------|-------------------------------------------------|-----------------------------|-------------------------------------------|-----------------------------|-------------------------------------------| | Clock | Maximum Frequency of Operation (MHz) | 20 | 20 | 20 | 20 | | Memory | EPROM Program Memory (x14 words) | 4K | 4K | 8K | 8K | | | Data Memory (bytes) | 192 | 192 | 376 | 376 | | | Timer Module(s) | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | TMR0,<br>TMR1,<br>TMR2 | | Peripherals | Capture/Compare/PWM<br>Module(s) | 2 | 2 | 2 | 2 | | | Serial Port(s)<br>(SPI/I <sup>2</sup> C, USART) | SPI/I <sup>2</sup> C, USART | SPI/I <sup>2</sup> C, USART | SPI/I <sup>2</sup> C, USART | SPI/I <sup>2</sup> C, USART | | | Parallel Slave Port | _ | Yes | _ | Yes | | | A/D Converter (8-bit) Channels | 5 | 8 | 5 | 8 | | | Interrupt Sources | 11 | 12 | 11 | 12 | | | I/O Pins | 22 | 33 | 22 | 33 | | | Voltage Range (Volts) | 2.5-6.0 | 2.5-6.0 | 2.5-6.0 | 2.5-6.0 | | Features | In-Circuit Serial Programming | Yes | Yes | Yes | Yes | | | Brown-out Reset | Yes | Yes | Yes | Yes | | | Packages | 28-pin SDIP,<br>SOIC | 40-pin DIP;<br>44-pin PLCC,<br>MQFP, TQFP | 28-pin SDIP,<br>SOIC | 40-pin DIP;<br>44-pin PLCC,<br>MQFP, TQFP | All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC16C7XX Family devices use serial programming with clock pin RB6 and data pin RB7. Note 1: Please contact your local Microchip sales office for availability of these devices. #### 3.0 ARCHITECTURAL OVERVIEW The high performance of the PIC16CXX family can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC16CXX uses a Harvard architecture, in which, program and data are accessed from separate memories using separate buses. This improves bandwidth over traditional von Neumann architecture in which program and data are fetched from the same memory using the same bus. Separating program and data buses further allows instructions to be sized differently than the 8-bit wide data word. Instruction opcodes are 14-bits wide making it possible to have all single word instructions. A 14-bit wide program memory access bus fetches a 14-bit instruction in a single cycle. A twostage pipeline overlaps fetch and execution of instructions (Example 3-1). Consequently, all instructions (35) execute in a single cycle (200 ns @ 20 MHz) except for program branches. The table below lists program memory (EPROM) and data memory (RAM) for each PIC16C71X device. | Device | Program<br>Memory | Data Memory | |-----------|-------------------|-------------| | PIC16C710 | 512 x 14 | 36 x 8 | | PIC16C71 | 1K x 14 | 36 x 8 | | PIC16C711 | 1K x 14 | 68 x 8 | | PIC16C715 | 2K x 14 | 128 x 8 | The PIC16CXX can directly or indirectly address its register files or data memory. All special function registers, including the program counter, are mapped in the data memory. The PIC16CXX has an orthogonal (symmetrical) instruction set that makes it possible to carry out any operation on any register using any addressing mode. This symmetrical nature and lack of 'special optimal situations' make programming with the PIC16CXX simple yet efficient. In addition, the learning curve is reduced significantly. PIC16CXX devices contain an 8-bit ALU and working register. The ALU is a general purpose arithmetic unit. It performs arithmetic and Boolean functions between the data in the working register and any register file. The ALU is 8-bits wide and capable of addition, subtraction, shift and logical operations. Unless otherwise mentioned, arithmetic operations are two's complement in nature. In two-operand instructions, typically one operand is the working register (W register). The other operand is a file register or an immediate constant. In single operand instructions, the operand is either the W register or a file register. The W register is an 8-bit working register used for ALU operations. It is not an addressable register. Depending on the instruction executed, the ALU may affect the values of the Carry (C), Digit Carry (DC), and Zero (Z) bits in the STATUS register. The C and DC bits operate as a borrow bit and a digit borrow out bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples. #### 4.2.2 SPECIAL FUNCTION REGISTERS The Special Function Registers are registers used by the CPU and Peripheral Modules for controlling the desired operation of the device. These registers are implemented as static RAM. The special function registers can be classified into two sets (core and peripheral). Those registers associated with the "core" functions are described in this section, and those related to the operation of the peripheral features are described in the section of that peripheral feature. TABLE 4-1: PIC16C710/71/711 SPECIAL FUNCTION REGISTER SUMMARY | 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 all other resets (1) | |----------------------|---------------------------------------------|---------------------|--------------------|---------------|--------------|---------------|------------------|---------------|-----------|--------------------------|-------------------------------| | Bank 0 | | | | | | | | | | | | | 00h <sup>(3)</sup> | INDF | Addressing | this location | uses conter | ts 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>(3)</sup> | PCL | Program Co | ounter's (PC) | Least Signif | ficant Byte | | | | | 0000 0000 | 0000 0000 | | 03h <sup>(3)</sup> | STATUS | IRP <sup>(5)</sup> | RP1 <sup>(5)</sup> | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 000q quuu | | 04h <sup>(3)</sup> | FSR | Indirect data | a memory ac | Idress pointe | er | | | | | xxxx xxxx | uuuu uuuu | | 05h | PORTA | _ | _ | _ | PORTA Dat | a Latch whe | n written: PO | RTA pins wh | en read | x 0000 | u 0000 | | 06h | PORTB | PORTB Dat | a Latch whe | n written: PC | RTB pins wl | nen read | | | | xxxx xxxx | uuuu uuuu | | 07h | _ | Unimpleme | nted | | | | | | | _ | _ | | 08h | ADCON0 | ADCS1 | ADCS0 | (6) | CHS1 | CHS0 | GO/DONE | ADIF | ADON | 00-0 0000 | 00-0 0000 | | 09h <sup>(3)</sup> | ADRES | A/D Result Register | | | | | | | | xxxx xxxx | uuuu uuuu | | 0Ah <sup>(2,3)</sup> | PCLATH | _ | _ | _ | Write Buffer | for the uppe | er 5 bits of the | e Program C | ounter | 0 0000 | 0 0000 | | 0Bh <sup>(3)</sup> | INTCON | GIE | ADIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | Bank 1 | | | | | | | | | | | | | 80h <sup>(3)</sup> | INDF | Addressing | this location | uses conter | ts of FSR to | address data | a memory (n | ot a physical | register) | 0000 0000 | 0000 0000 | | 81h | OPTION | RBPU | INTEDG | TOCS | T0SE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 1111 1111 | | 82h <sup>(3)</sup> | PCL | Program Co | ounter's (PC) | Least Signif | ficant Byte | | | | | 0000 0000 | 0000 0000 | | 83h <sup>(3)</sup> | STATUS | IRP <sup>(5)</sup> | RP1 <sup>(5)</sup> | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 000q quuu | | 84h <sup>(3)</sup> | FSR | Indirect data | a memory ac | ldress pointe | er | | | | | xxxx xxxx | uuuu uuuu | | 85h | TRISA | _ | _ | _ | PORTA Dat | a Direction F | Register | | | 1 1111 | 1 1111 | | 86h | TRISB | PORTB Dat | a Direction ( | Control Regis | ster | | | | | 1111 1111 | 1111 1111 | | 87h <sup>(4)</sup> | PCON | _ | _ | _ | _ | _ | _ | POR | BOR | qq | uu | | 88h | ADCON1 | _ | _ | _ | _ | _ | _ | PCFG1 | PCFG0 | 00 | 00 | | 89h <sup>(3)</sup> | 9h <sup>(3)</sup> ADRES A/D Result Register | | | | | | | | | xxxx xxxx | uuuu uuuu | | 8Ah(2,3) | PCLATH | _ | _ | _ | Write Buffer | for the uppe | er 5 bits of the | e Program C | ounter | 0 0000 | 0 0000 | | 8Bh <sup>(3)</sup> | INTCON | GIE | ADIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | | | | | | | | | | | | | Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented read as '0'. Shaded locations are unimplemented, read as '0'. - Note 1: Other (non power-up) resets include external reset through MCLR and Watchdog Timer Reset. - 2: The upper byte of the program counter is not directly accessible. PCLATH is a holding register for the PC<12:8> whose contents are transferred to the upper byte of the program counter. - 3: These registers can be addressed from either bank. - 4: The PCON register is not physically implemented in the PIC16C71, read as '0'. - 5: The IRP and RP1 bits are reserved on the PIC16C710/71/711, always maintain these bits clear. - 6: Bit5 of ADCON0 is a General Purpose R/W bit for the PIC16C710/711 only. For the PIC16C71, this bit is unimplemented, read as '0'. TABLE 4-2: PIC16C715 SPECIAL FUNCTION REGISTER SUMMARY | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR, PER | Value on all other resets (3) | |----------------------|--------|--------------------|------------------------------------------------------------------------------------------------|---------------|--------------|----------------|------------------|-------------|---------|-------------------------------|-------------------------------| | Bank 0 | Bank 0 | | | | | | | | | | | | 00h <sup>(1)</sup> | INDF | Addressing | Addressing this location uses contents of FSR to address data memory (not a physical register) | | | | | | | | 0000 0000 | | 01h | TMR0 | Timer0 mod | dule's register | r | | | | | | xxxx xxxx | uuuu uuuu | | 02h <sup>(1)</sup> | PCL | Program Co | ounter's (PC) | Least Signif | ficant Byte | | | | | 0000 0000 | 0000 0000 | | 03h <sup>(1)</sup> | STATUS | IRP <sup>(4)</sup> | RP1 <sup>(4)</sup> | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 000q quuu | | 04h <sup>(1)</sup> | FSR | Indirect data | a memory ad | dress pointe | er | | | | | xxxx xxxx | uuuu uuuu | | 05h | PORTA | _ | _ | _ | PORTA Dat | a Latch whe | n written: PO | RTA pins wh | en read | x 0000 | u 0000 | | 06h | PORTB | PORTB Da | ta Latch whe | n written: PC | RTB pins wl | nen read | | | | xxxx xxxx | uuuu uuuu | | 07h | _ | Unimpleme | nted | | | | | | | _ | _ | | 08h | _ | Unimpleme | nted | | | | | | | _ | _ | | 09h | _ | Unimpleme | nted | | | | | | | _ | _ | | 0Ah <sup>(1,2)</sup> | PCLATH | _ | _ | _ | Write Buffer | r for the uppe | er 5 bits of the | e Program C | ounter | 0 0000 | 0 0000 | | 0Bh <sup>(1)</sup> | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | 0Ch | PIR1 | _ | ADIF | _ | _ | _ | _ | _ | _ | -0 | -0 | | 0Dh | _ | Unimpleme | nted | | | | | | | _ | _ | | 0Eh | _ | Unimpleme | nted | | | | | | | _ | _ | | 0Fh | _ | Unimpleme | nted | | | | | | | _ | _ | | 10h | _ | Unimpleme | nted | | | | | | | _ | _ | | 11h | _ | Unimpleme | nted | | | | | | | _ | _ | | 12h | _ | Unimpleme | nted | | | | | | | _ | _ | | 13h | _ | Unimpleme | nted | | | | | | | _ | _ | | 14h | _ | Unimpleme | nted | | | | | | | _ | _ | | 15h | _ | Unimpleme | nted | | | | | | | _ | _ | | 16h | _ | Unimpleme | nted | | | | | | | _ | _ | | 17h | _ | Unimpleme | nted | | | | | | | _ | _ | | 18h | _ | Unimpleme | nted | | | | | | | _ | _ | | 19h | _ | Unimpleme | nted | | | | | | | _ | _ | | 1Ah | _ | Unimpleme | nted | | | | | | | _ | _ | | 1Bh | _ | Unimpleme | nted | | | | | | | _ | _ | | 1Ch | _ | Unimpleme | nted | | | | | | | _ | _ | | 1Dh | | Unimpleme | nted | | | | | | | _ | _ | | 1Eh | ADRES | A/D Result | Register | | | | | | | xxxx xxxx | uuuu uuuu | | 1Fh | ADCON0 | ADCS1 | ADCS0 | CHS2 | CHS1 | CHS0 | GO/DONE | _ | ADON | 0000 00-0 | 0000 00-0 | Legend: x = unknown, u = unchanged, q = value depends on condition, -= unimplemented read as '0'. 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 is not directly accessible. PCLATH is a holding register for the PC<12:8> whose contents are transferred to the upper byte of the program counter. - 3: Other (non power-up) resets include external reset through $\overline{\text{MCLR}}$ and Watchdog Timer Reset. - 4: The IRP and RP1 bits are reserved on the PIC16C715, always maintain these bits clear. #### 4.2.2.1 STATUS REGISTER #### **Applicable Devices** | 710 | 71 | 711 | 715 The STATUS register, shown in Figure 4-7, contains the arithmetic status of the ALU, the RESET status and the bank select bits for data memory. The STATUS register can be the destination for any instruction, as with any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the $\overline{\text{TO}}$ and $\overline{\text{PD}}$ bits are not writable. Therefore, the result of an instruction with the STATUS register as destination may be different than intended. For example, CLRF STATUS will clear the upper-three bits and set the Z bit. This leaves the STATUS register as 000u uluu (where u = unchanged). It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register because these instructions do not affect the Z, C or DC bits from the STATUS register. For other instructions, not affecting any status bits, see the "Instruction Set Summary." - **Note 1:** For those devices that do not use bits IRP and RP1 (STATUS<7:6>), maintain these bits clear to ensure upward compatibility with future products. - Note 2: The C and DC bits operate as a borrow and digit borrow bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples. #### FIGURE 4-7: STATUS REGISTER (ADDRESS 03h, 83h) | R/W-0 | R/W-0 | R/W-0 | R-1 | R-1 | R/W-x | R/W-x | R/W-x | | |-------------|---------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------|------------------------------------------|-----------------------------|------------------------------------------|------------------------------|-----------------------------------------------------------------------------------------------| | IRP<br>bit7 | RP1 | RP0 | TO | PD | Z | DC | bit0 | R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' - n = Value at POR reset | | bit 7: | 1 = Bank | ister Bank<br>2, 3 (100h<br>0, 1 (00h - | - 1FFh) | (used for | indirect add | dressing) | | | | bit 6-5: | 11 = Bank<br>10 = Bank<br>01 = Bank<br>00 = Bank | : Register<br>k 3 (180h -<br>k 2 (100h -<br>k 1 (80h - 7<br>k 0 (00h - 7<br>k is 128 by | · 1FFh)<br>· 17Fh)<br>FFh)<br>7Fh) | ect bits (u | sed for dire | ct address | ing) | | | bit 4: | | | | | or SLEEP in | nstruction | | | | bit 3: | 1 = After | er-down bit<br>power-up o<br>ecution of | or by the | | | | | | | bit 2: | | esult of an | | • | operation is | | | | | bit 1: | 1 = A carr | ry-out from | the 4th le | ow order b | W,SUBLW,S<br>bit of the res | sult occurre | | borrow the polarity is reversed | | bit 0: | 1 = A carr<br>0 = No ca<br>Note: For<br>the secon | ry-out from<br>arry-out from<br>borrow the | n the most<br>m the mo<br>e polarity<br>l. For rota | significar<br>st significa<br>is reverse | | result occu<br>result occ<br>ction is ex | urred<br>curred<br>ecuted by | adding the two's complement of with either the high or low orde | #### 5.2 PORTB and TRISB Registers 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 input 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** ``` BCF STATUS, RP0 CLRF ; Initialize PORTB by PORTR ; clearing output ; data latches BSF STATUS, RPO ; Select Bank 1 MOVLW 0xCF ; Value used to ; initialize data ; direction MOVWF TRISB ; 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 $\overline{\text{RBPU}}$ (OPTION<7>). The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on a Power-on Reset. FIGURE 5-3: BLOCK DIAGRAM OF RB3:RB0 PINS 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, "Implementing Wake-Up on Key Stroke" (AN552). Note: For the PIC16C71 if a change on the I/O pin should occur when the 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. #### 7.2 Selecting the A/D Conversion Clock The A/D conversion time per bit is defined as TAD. The A/D conversion requires 9.5TAD per 8-bit conversion. The source of the A/D conversion clock is software selectable. The four possible options for TAD are: - 2Tosc - 8Tosc - 32Tosc - · Internal RC oscillator For correct A/D conversions, the A/D conversion clock (TAD) must be selected to ensure a minimum TAD time of: 2.0 us for the PIC16C71 1.6 µs for all other PIC16C71X devices Table 7-1 and Table 7-2 and show the resultant TAD times derived from the device operating frequencies and the A/D clock source selected. #### 7.3 Configuring Analog Port Pins The ADCON1 and TRISA registers control the operation of the A/D port pins. The port pins that are desired as analog inputs must have their corresponding TRIS bits set (input). If the TRIS bit is cleared (output), the digital output level (VOH or VOL) will be converted. The A/D operation is independent of the state of the CHS2:CHS0 bits and the TRIS bits. Note 1: When reading the port register, all pins configured as analog input channels will read as cleared (a low level). Pins configured as digital inputs, will convert an analog input. Analog levels on a digitally configured input will not affect the conversion accuracy. Note 2: Analog levels on any pin that is defined as a digital input (including the AN7:AN0 pins), may cause the input buffer to consume current that is out of the devices specification. TABLE 7-1: TAD vs. DEVICE OPERATING FREQUENCIES, PIC16C71 | AD Cloc | k Source (TAD) | Device Frequency | | | | | | |-------------------|----------------|---------------------------|---------------------------|---------------------------|-------------------------|-------------------------|--| | Operation | ADCS1:ADCS0 | 20 MHz | 20 MHz 16 MHz 4 MHz 1 MHz | | | | | | 2Tosc | 00 | 100 ns <sup>(2)</sup> | 125 ns <sup>(2)</sup> | 500 ns <sup>(2)</sup> | 2.0 μs | 6 μs | | | 8Tosc | 01 | 400 ns <sup>(2)</sup> | 500 ns <sup>(2)</sup> | 2.0 μs | 8.0 μs | 24 μs <sup>(3)</sup> | | | 32Tosc | 10 | 1.6 μs <sup>(2)</sup> | 2.0 μs | 8.0 µs | 32.0 μs <sup>(3)</sup> | 96 μs <sup>(3)</sup> | | | RC <sup>(5)</sup> | 11 | 2 - 6 μs <sup>(1,4)</sup> | 2 - 6 μs <sup>(1,4)</sup> | 2 - 6 μs <sup>(1,4)</sup> | 2 - 6 μs <sup>(1)</sup> | 2 - 6 μs <sup>(1)</sup> | | Legend: Shaded cells are outside of recommended range. - Note 1: The RC source has a typical TAD time of 4 μs. - 2: These values violate the minimum required TAD time. - 3: For faster conversion times, the selection of another clock source is recommended. - 4: When device frequency is greater than 1 MHz, the RC A/D conversion clock source is recommended for sleep operation only. - 5: For extended voltage devices (LC), please refer to Electrical Specifications section. TABLE 7-2: TAD vs. DEVICE OPERATING FREQUENCIES, PIC16C710/711, PIC16C715 | AD Clock | Source (TAD) | Device Frequency | | | | | | |-------------------|--------------|---------------------------|---------------------------|---------------------------|-------------------------|--|--| | Operation | ADCS1:ADCS0 | 20 MHz | 5 MHz | 1.25 MHz | 333.33 kHz | | | | 2Tosc | 00 | 100 ns <sup>(2)</sup> | 400 ns <sup>(2)</sup> | 1.6 μs | 6 μs | | | | 8Tosc | 01 | 400 ns <sup>(2)</sup> | 1.6 μs | 6.4 μs | 24 μs <sup>(3)</sup> | | | | 32Tosc | 10 | 1.6 µs | 6.4 μs | 25.6 μs <sup>(3)</sup> | 96 μs <sup>(3)</sup> | | | | RC <sup>(5)</sup> | 11 | 2 - 6 μs <sup>(1,4)</sup> | 2 - 6 μs <sup>(1,4)</sup> | 2 - 6 μs <sup>(1,4)</sup> | 2 - 6 μs <sup>(1)</sup> | | | Legend: Shaded cells are outside of recommended range. - Note 1: The RC source has a typical TAD time of 4 µs. - 2: These values violate the minimum required TAD time. - 3: For faster conversion times, the selection of another clock source is recommended. - 4: When device frequency is greater than 1 MHz, the RC A/D conversion clock source is recommended for sleep operation only. - 5: For extended voltage devices (LC), please refer to Electrical Specifications section. ## 7.4.1 FASTER CONVERSION - LOWER RESOLUTION TRADE-OFF Not all applications require a result with 8-bits of resolution, but may instead require a faster conversion time. The A/D module allows users to make the trade-off of conversion speed to resolution. Regardless of the resolution required, the acquisition time is the same. To speed up the conversion, the clock source of the A/D module may be switched so that the TAD time violates the minimum specified time (see the applicable electrical specification). Once the TAD time violates the minimum specified time, all the following A/D result bits are not valid (see A/D Conversion Timing in the Electrical Specifications section.) The clock sources may only be switched between the three oscillator versions (cannot be switched from/to RC). The equation to determine the time before the oscillator can be switched is as follows: Conversion time = $2TAD + N \cdot TAD + (8 - N)(2TOSC)$ Where: N = number of bits of resolution required. Since the TAD is based from the device oscillator, the user must use some method (a timer, software loop, etc.) to determine when the A/D oscillator may be changed. Example 7-3 shows a comparison of time required for a conversion with 4-bits of resolution, versus the 8-bit resolution conversion. The example is for devices operating at 20 MHz and 16 MHz (The A/D clock is programmed for 32Tosc), and assumes that immediately after 6TAD, the A/D clock is programmed for 2Tosc. The 2Tosc violates the minimum TAD time since the last 4-bits will not be converted to correct values. **EXAMPLE 7-3: 4-BIT vs. 8-BIT CONVERSION TIMES** | | _ (1) | Reso | lution | |---------------------------------|----------------------------|---------|---------| | | Freq. (MHz) <sup>(1)</sup> | 4-bit | 8-bit | | TAD | 20 | 1.6 μs | 1.6 μs | | | 16 | 2.0 μs | 2.0 μs | | Tosc | 20 | 50 ns | 50 ns | | | 16 | 62.5 ns | 62.5 ns | | 2TAD + N • TAD + (8 - N)(2TOSC) | 20 | 10 μs | 16 μs | | | 16 | 12.5 μs | 20 μs | Note 1: The PIC16C71 has a minimum TAD time of 2.0 μs. All other PIC16C71X devices have a minimum TAD time of 1.6 μs. | SUBWF | Subtract | W from f | | | |-------------------|--------------------------------|-------------------------------|------------------------------------------------------------------|------------------| | Syntax: | [ label ] | SUBWF | f,d | | | Operands: | $0 \le f \le 12$ $d \in [0,1]$ | 7 | | | | Operation: | (f) - (W) - | → (dest) | | | | Status Affected: | C, DC, Z | | | | | Encoding: | 00 | 0010 | dfff | ffff | | Description: | ister from r<br>stored in th | egister 'f'. I<br>ne W regist | nent metho<br>f 'd' is 0 the<br>er. If 'd' is 1<br>n register 'f | result is<br>the | | Words: | 1 | | | | | Cycles: | 1 | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | Decode | Read<br>register 'f' | Process<br>data | Write to dest | | Example 1: | SUBWF | REG1,1 | | | | | Before In: | struction | | | | | REG1 | | 3 | | | | W<br>C | = | 2 | | | | Z | = | ? | | | | After Inst | ruction | | | | | REG1 | | 1 | | | | W<br>C | = | 2<br>1; result is | positive | | | Z | = | 0 | | | Example 2: | Before In: | struction | | | | | REG1<br>W | | 2 | | | | C | = | ? | | | | Z | = | ? | | | | After Inst | ruction | | | | | REG1<br>W | = | 0 | | | | C | = | 1; result is | zero | | | Z | = | 1 | | | Example 3: | Before In: | struction | | | | | REG1<br>W | = | 1 | | | | C | = | ? | | | | Z | = | ? | | | | After Inst | ruction | | | | | REG1<br>W | = | 0xFF<br>2 | | | | С | = | 0; result is | negative | | | Z | = | 0 | | | | | | | | | SWAPF | Swap Ni | bbles in | f | | |-------------------|--------------------------------|----------------------|----------------------------|-------------------| | Syntax: | [ label ] | SWAPF 1 | f,d | | | Operands: | $0 \le f \le 12$ $d \in [0,1]$ | 27 | | | | Operation: | | $\rightarrow$ (dest< | | | | Status Affected: | None | | | | | Encoding: | 00 | 1110 | dfff | ffff | | Description: | ter 'f' are e | aced in W | . If 'd' is 0 register. It | the<br>f 'd' is 1 | | Words: | 1 | | | | | Cycles: | 1 | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | Decode | Read<br>register 'f' | Process<br>data | Write to dest | | Example | SWAPF | REG, | 0 | | | | Before In | struction | | | | | | REG1 | = 0xA | <b>\</b> 5 | | | After Inst | ruction | | | | | | REG1<br>W | = 0x/<br>= 0x5 | | | TRIS | Load TRIS Register | | | | | | | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Syntax: | [label] TRIS f | | | | | | | | Operands: | $5 \le f \le 7$ | | | | | | | | Operation: | $\text{(W)} \rightarrow \text{TRIS register f;}$ | | | | | | | | Status Affected: | None | | | | | | | | Encoding: | 00 0000 0110 Offf | | | | | | | | Description: | The instruction is supported for code compatibility with the PIC16C5X products. Since TRIS registers are readable and writable, the user can directly address them. | | | | | | | | Words: | 1 | | | | | | | | Cycles: | 1 | | | | | | | | Example | | | | | | | | | | To maintain upward compatibility with future PIC16CXX products, do not use this instruction. | | | | | | | | | | | | | | | | #### 10.0 DEVELOPMENT SUPPORT #### 10.1 <u>Development Tools</u> The PICmicro<sup>™</sup> microcontrollers are supported with a full range of hardware and software development tools: - PICMASTER/PICMASTER CE Real-Time In-Circuit Emulator - ICEPIC Low-Cost PIC16C5X and PIC16CXXX In-Circuit Emulator - PRO MATE® II Universal Programmer - PICSTART<sup>®</sup> Plus Entry-Level Prototype Programmer - PICDEM-1 Low-Cost Demonstration Board - PICDEM-2 Low-Cost Demonstration Board - PICDEM-3 Low-Cost Demonstration Board - MPASM Assembler - MPLAB™ SIM Software Simulator - MPLAB-C (C Compiler) - Fuzzy Logic Development System (fuzzyTECH<sup>®</sup>–MP) # 10.2 PICMASTER: High Performance Universal In-Circuit Emulator with MPLAB IDE The PICMASTER Universal In-Circuit Emulator is intended to provide the product development engineer with a complete microcontroller design tool set for all microcontrollers in the PIC12CXXX, PIC14C000, PIC16C5X, PIC16CXXX and PIC17CXX families. PICMASTER is supplied with the MPLAB™ Integrated Development Environment (IDE), which allows editing, "make" and download, and source debugging from a single environment. Interchangeable target probes allow the system to be easily reconfigured for emulation of different processors. The universal architecture of the PICMASTER allows expansion to support all new Microchip microcontrollers. The PICMASTER Emulator System has been designed as a real-time emulation system with advanced features that are generally found on more expensive development tools. The PC compatible 386 (and higher) machine platform and Microsoft Windows<sup>®</sup> 3.x environment were chosen to best make these features available to you, the end user. A CE compliant version of PICMASTER is available for European Union (EU) countries. #### 10.3 <u>ICEPIC: Low-Cost PIC16CXXX</u> In-Circuit Emulator ICEPIC is a low-cost in-circuit emulator solution for the Microchip PIC16C5X and PIC16CXXX families of 8-bit OTP microcontrollers. ICEPIC is designed to operate on PC-compatible machines ranging from 286-AT<sup>®</sup> through Pentium™ based machines under Windows 3.x environment. ICEPIC features real time, non-intrusive emulation. #### 10.4 PRO MATE II: Universal Programmer The PRO MATE II Universal Programmer is a full-featured programmer capable of operating in stand-alone mode as well as PC-hosted mode. The PRO MATE II has programmable VDD and VPP supplies which allows it to verify programmed memory at VDD min and VDD max for maximum reliability. It has an LCD display for displaying error messages, keys to enter commands and a modular detachable socket assembly to support various package types. In standalone mode the PRO MATE II can read, verify or program PIC12CXXX, PIC14C000, PIC16C5X, PIC16CXXX and PIC17CXX devices. It can also set configuration and code-protect bits in this mode. #### 10.5 <u>PICSTART Plus Entry Level</u> <u>Development System</u> The PICSTART programmer is an easy-to-use, low-cost prototype programmer. It connects to the PC via one of the COM (RS-232) ports. MPLAB Integrated Development Environment software makes using the programmer simple and efficient. PICSTART Plus is not recommended for production programming. PICSTART Plus supports all PIC12CXXX, PIC14C000, PIC16C5X, PIC16CXXX and PIC17CXX devices with up to 40 pins. Larger pin count devices such as the PIC16C923 and PIC16C924 may be supported with an adapter socket. 11.3 DC Characteristics: PIC16C710-04 (Commercial, Industrial, Extended) PIC16C711-04 (Commercial, Industrial, Extended) PIC16C710-10 (Commercial, Industrial, Extended) PIC16C711-10 (Commercial, Industrial, Extended) PIC16C710-20 (Commercial, Industrial, Extended) PIC16C711-20 (Commercial, Industrial, Extended) PIC16LC710-04 (Commercial, Industrial, Extended) PIC16LC711-04 (Commercial, Industrial, Extended) Standard Operating Conditions (unless otherwise stated) Operating temperature $0^{\circ}C \le TA \le +70^{\circ}C$ (commercial) -40°C $\le TA \le +85^{\circ}C$ (industrial) **DC CHARACTERISTICS** $-40^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C (industrial)}$ $-40^{\circ}\text{C} \leq \text{TA} \leq +125^{\circ}\text{C (extended)}$ Operating voltage VDD range as described in DC spec Section 11.1 and Section 11.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 | - | 0.8V | V | 4.5 ≤ VDD ≤ 5.5V | | D031 | with Schmitt Trigger buffer | | Vss | - | 0.2Vdd | V | | | D032 | MCLR, OSC1 | | Vss | - | 0.2Vdd | V | | | | (in RC mode) | | | | | | | | 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 | V | For entire VDD range | | D042 | MCLR, RB0/INT | | 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 (Notes 2, 3) | | | | | | | | D060 | I/O ports | II∟ | - | - | ±1 | μΑ | Vss ≤ Vpin ≤ Vdd, Pin at hi- | | | | | | | | | impedance | | D061 | MCLR, RA4/T0CKI | | - | - | ±5 | μΑ | Vss ≤ Vpin ≤ Vdd | | D063 | OSC1 | | - | - | ±5 | μΑ | $Vss \le VPIN \le VDD$ , XT, HS and LP | | | | | | | | | osc configuration | - \* 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 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. # 12.0 DC AND AC CHARACTERISTICS GRAPHS AND TABLES FOR PIC16C710 AND PIC16C711 The graphs and tables provided in this section are for design guidance and are not tested or guaranteed. In some graphs or tables the data presented are outside specified operating range (i.e., outside specified VDD range). This is for information only and devices are guaranteed to operate properly only within the specified range. **Note:** The data presented in this section is a statistical summary of data collected on units from different lots over a period of time and matrix samples. 'Typical' represents the mean of the distribution at, $25^{\circ}$ C, while 'max' or 'min' represents (mean +3 $\sigma$ ) and (mean -3 $\sigma$ ) respectively where $\sigma$ is standard deviation. FIGURE 12-1: TYPICAL IPD vs. VDD (WDT DISABLED, RC MODE) FIGURE 12-2: MAXIMUM IPD vs. VDD (WDT DISABLED, RC MODE) FIGURE 12-14: TYPICAL IDD vs. FREQUENCY (RC MODE @ 100 pF, 25°C) FIGURE 12-15: MAXIMUM IDD vs. FREQUENCY (RC MODE @ 100 pF, -40°C TO 85°C) #### 13.4 <u>Timing Parameter Symbology</u> The timing parameter symbols have been created following one of the following formats: 1. TppS2ppS 2. TppS #### 15.0 ELECTRICAL CHARACTERISTICS FOR PIC16C71 #### **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) | | | Maximum current out of Vss pin | 150 mA | | Maximum current into VDD pin | 100 mA | | Input clamp current, Iik (VI < 0 or VI > VDD) | ± 20 mA | | Output clamp current, Iok (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 | 20 mA | | Maximum current sunk by PORTA | 80 mA | | Maximum current sourced by PORTA | 50 mA | | Maximum current sunk by PORTB | 150 mA | | Maximum current sourced by PORTB | 100 mA | **Note 1:** Power dissipation is calculated as follows: Pdis = VDD x {IDD - $\Sigma$ IOH} + $\Sigma$ {(VDD-VOH) x IOH} + $\Sigma$ (Vol x IOL) **Note 2:** Voltage spikes below Vss at the $\overline{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. † 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 15-1: CROSS REFERENCE OF DEVICE SPECS FOR OSCILLATOR CONFIGURATIONS AND FREQUENCIES OF OPERATION (COMMERCIAL DEVICES) | osc | PIC16C71-04 | PIC16C71-20 | PIC16LC71-04 | JW Devices | |-----|-----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------| | RC | VDD: 4.0V to 6.0V<br>IDD: 3.3 mA max. at 5.5V<br>IPD: 14 μA max. at 4V<br>Freq:4 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 1.8 mA typ. at 5.5V<br>IPD: 1.0 μA typ. at 4V<br>Freq: 4 MHz max. | VDD: 3.0V to 6.0V<br>IDD: 1.4 mA typ. at 3.0V<br>IPD: 0.6 μA typ. at 3V<br>Freq: 4 MHz max. | VDD: 4.0V to 6.0V<br>IDD: 3.3 mA max. at 5.5V<br>IPD: 14 μA max. at 4V<br>Freq:4 MHz max. | | хт | VDD: 4.0V to 6.0V<br>IDD: 3.3 mA max. at 5.5V<br>IPD: 14 μA max. at 4V<br>Freq: 4 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 1.8 mA typ. at 5.5V<br>IPD: 1.0 μA typ. at 4V<br>Freq: 4 MHz max. | VDD: 3.0V to 6.0V<br>IDD: 1.4 mA typ. at 3.0V<br>IPD: 0.6 μA typ. at 3V<br>Freq: 4 MHz max. | VDD: 4.0V to 6.0V<br>IDD: 3.3 mA max. at 5.5V<br>IPD: 14 μ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.0 μA typ. at 4.5V<br>Freq: 4 MHz max. | 13.5 mA typ. at 5.5V 1.0 μA typ. at 4.5V IDD: 30 mA max. at 5.5V IPD: 1.0 μA typ. at 4.5V | | VDD: 4.5V to 5.5V IDD: 30 mA max. at 5.5V IPD: 1.0 μA typ. at 4.5V Freq: 20 MHz max. | | LP | VDD: 4.0V to 6.0V<br>IDD: 15 μA typ. at 32 kHz,<br>4.0V<br>IPD: 0.6 μA typ. at 4.0V<br>Freq: 200 kHz max. | Not recommended for use in LP mode | VDD: 3.0V to 6.0V<br>IDD: 32 μA max. at 32 kHz,<br>3.0V<br>IPD: 9 μA max. at 3.0V<br>Freq: 200 kHz max. | VDD: 3.0V to 6.0V<br>IDD: 32 μA max. at 32 kHz,<br>3.0V<br>IPD: 9 μ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. ### PIC16C71X #### Applicable Devices 710 71 711 715 15.1 DC Characteristics: PIC16C71-04 (Commercial, Industrial) PIC16C71-20 (Commercial, Industrial) | DC CH | ARACTERISTICS | | <b>Standa</b><br>Operat | - | | ure 0° | litions (unless otherwise stated) $^{\circ}C \leq TA \leq +70^{\circ}C$ (commercial) $^{\circ}C \leq TA \leq +85^{\circ}C$ (industrial) | |-----------------------|------------------------------------------------------------|------|-------------------------|-----------------|----------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------| | Param<br>No. | Characteristic | Sym | Min | Typ† | Max | Units | Conditions | | D001<br>D001A | Supply Voltage | VDD | 4.0<br>4.5 | - | 6.0<br>5.5 | V | XT, RC and LP osc configuration<br>HS osc configuration | | D002* | RAM Data Retention<br>Voltage (Note 1) | VDR | - | 1.5 | - | V | | | D003 | VDD start voltage to ensure internal Power-on Reset signal | VPOR | - | Vss | - | V | See section on Power-on Reset for details | | D004* | VDD rise rate to ensure internal Power-on Reset signal | SVDD | 0.05 | - | - | V/ms | See section on Power-on Reset for details | | D010 | Supply Current (Note 2) | IDD | - | 1.8 | 3.3 | mA | XT, RC osc configuration<br>FOSC = 4 MHz, VDD = 5.5V (Note 4) | | D013 | | | - | 13.5 | 30 | mA | HS osc configuration<br>Fosc = 20 MHz, VDD = 5.5V | | D020<br>D021<br>D021A | Power-down Current (Note 3) | IPD | | 7<br>1.0<br>1.0 | 28<br>14<br>16 | μΑ<br>μΑ<br>μΑ | VDD = 4.0V, WDT enabled, -40°C to +85°C<br>VDD = 4.0V, WDT disabled, -0°C to +70°C<br>VDD = 4.0V, WDT disabled, -40°C to +85°C | - \* These parameters are characterized but not tested. - † Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. - Note 1: This is the limit to which VDD can be lowered without losing RAM data. - 2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an impact on the current consumption. - The test conditions for all IDD measurements in active operation mode are: - OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD - MCLR = VDD; WDT enabled/disabled as specified. - 3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and Vss. - 4: For RC osc configuration, current through Rext is not included. The current through the resistor can be estimated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm. #### 15.5 <u>Timing Diagrams and Specifications</u> #### FIGURE 15-2: EXTERNAL CLOCK TIMING TABLE 15-2: EXTERNAL CLOCK TIMING REQUIREMENTS | Parameter No. | Sym | Characteristic | Min | Тур† | Max | Units | Conditions | |---------------|-------|----------------------------------|-----|------|--------|-------|-------------------| | | Fosc | External CLKIN Frequency | DC | _ | 4 | MHz | XT osc mode | | | | (Note 1) | DC | _ | 4 | MHz | HS osc mode (-04) | | | | | 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 | | | | | 1 | _ | 4 | MHz | HS osc mode | | | | | 1 | _ | 20 | MHz | HS osc mode | | 1 | Tosc | External CLKIN Period | 250 | _ | _ | ns | XT osc mode | | | | (Note 1) | 250 | _ | _ | ns | HS osc mode (-04) | | | | | 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 | _ | 1,000 | ns | HS osc mode (-04) | | | | | 50 | _ | 1,000 | ns | HS osc mode (-20) | | | | | 5 | _ | _ | μs | LP osc mode | | 2 | Tcy | Instruction Cycle Time (Note 1) | 1.0 | Tcy | DC | μs | Tcy = 4/Fosc | | 3 | TosL, | External Clock in (OSC1) High or | 50 | _ | _ | ns | XT oscillator | | | TosH | Low Time | 2.5 | _ | _ | μs | LP oscillator | | | | | 10 | _ | _ | ns | HS oscillator | | 4 | TosR, | External Clock in (OSC1) Rise or | 25 | _ | _ | ns | XT oscillator | | | TosF | Fall Time | 50 | _ | _ | ns | LP oscillator | | | | | 15 | _ | _ | ns | HS oscillator | <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. Note 1: Instruction cycle period (TcY) equals four times the input oscillator time-base period. All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "min." values with an external clock applied to the OSC1/CLKIN pin. When an external clock input is used, the "Max." cycle time limit is "DC" (no clock) for all devices. OSC2 is disconnected (has no loading) for the PIC16C71. #### FIGURE 15-6: A/D CONVERSION TIMING Note 1: If the A/D clock source is selected as RC, a time of Tcy is added before the A/D clock starts. This allows the SLEEP instruction to be executed. #### TABLE 15-7: A/D CONVERSION REQUIREMENTS | Param<br>No. | Sym | Characteristic | | Min | Тур† | Max | Units | Conditions | |--------------|------|---------------------------------------------------|--------------------|--------|---------|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 130 TAD | | A/D clock period PIC16 <b>C</b> 71 | | 2.0 | _ | _ | μs | Tosc based, VREF ≥ 3.0V | | | | | PIC16 <b>LC</b> 71 | 2.0 | _ | _ | μs | Tosc based, VREF full range | | | | | PIC16 <b>C</b> 71 | 2.0 | 4.0 | 6.0 | μs | A/D RC Mode | | | | | PIC16 <b>LC</b> 71 | 3.0 | 6.0 | 9.0 | μs | A/D RC Mode | | 131 | TCNV | Conversion time (not including S/H time) (Note 1) | | _ | 9.5 | _ | TAD | | | 132 | TACQ | Acquisition time | | Note 2 | 20 | _ | μs | | | | | | | 5* | _ | _ | μѕ | The minimum time is the amplifier settling time. This may be used if the "new" input voltage has not changed by more than 1 LSb (i.e., 19.5 mV @ 5.12V) from the last sampled voltage (as stated on CHOLD). | | 134 | Tgo | Q4 to A/D clock start | | _ | Tosc/2§ | _ | _ | If the A/D clock source is selected as RC, a time of Tcy is added before the A/D clock starts. This allows the SLEEP instruction to be executed. | | 135 | Tswc | Switching from convert → sample time | | 1.5§ | _ | _ | TAD | | <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. These specifications ensured by design. Note 1: ADRES register may be read on the following TcY cycle. <sup>2:</sup> See Section 7.1 for min conditions. #### 17.2 <u>18-Lead Plastic Dual In-line (300 mil) (P)</u> | | Package Group: Plastic Dual In-Line (PLA) | | | | | | | | |--------|-------------------------------------------|-------------|-----------|--------|-------|-----------|--|--| | | | Millimeters | | Inches | | | | | | Symbol | Min | Max | Notes | Min | Max | Notes | | | | α | 0° | 10° | | 0° | 10° | | | | | Α | _ | 4.064 | | _ | 0.160 | | | | | A1 | 0.381 | _ | | 0.015 | _ | | | | | A2 | 3.048 | 3.810 | | 0.120 | 0.150 | | | | | В | 0.355 | 0.559 | | 0.014 | 0.022 | | | | | B1 | 1.524 | 1.524 | Reference | 0.060 | 0.060 | Reference | | | | С | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical | | | | D | 22.479 | 23.495 | | 0.885 | 0.925 | | | | | D1 | 20.320 | 20.320 | Reference | 0.800 | 0.800 | Reference | | | | E | 7.620 | 8.255 | | 0.300 | 0.325 | | | | | E1 | 6.096 | 7.112 | | 0.240 | 0.280 | | | | | e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical | | | | eA | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference | | | | eB | 7.874 | 9.906 | | 0.310 | 0.390 | | | | | L | 3.048 | 3.556 | | 0.120 | 0.140 | | | | | N | 18 | 18 | | 18 | 18 | | | | | S | 0.889 | _ | | 0.035 | _ | | | | | S1 | 0.127 | _ | | 0.005 | _ | | | | #### 17.5 Package Marking Information #### 18-Lead PDIP #### 18-Lead SOIC #### 18-Lead CERDIP Windowed #### 20-Lead SSOP #### Example #### Example #### Example #### Example | Legend: | MMM | Microchip part number information | | | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--|--| | | XXX | Customer specific information* | | | | | AA | Year code (last 2 digits of calender year) | | | | | BB | Week code (week of January 1 is week '01') | | | | | С | Facility code of the plant at which wafer is manufactured. C = Chandler, Arizona, U.S.A. S = Tempe, Arizona, U.S.A. | | | | | $D_1$ | Mask revision number for microcontroller | | | | | E | Assembly code of the plant or country of origin in which part was assembled. | | | | Note: | In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line thus limiting the number of available characters for customer specific information. | | | | <sup>\*</sup> Standard OTP marking consists of Microchip part number, year code, week code, facility code, mask revision number, and assembly code. For OTP marking beyond this, certain price adders apply. Please check with your Microchip Sales Office. For QTP devices, any special marking adders are included in QTP price.