Welcome to **E-XFL.COM** What is "Embedded - Microcontrollers"? "Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications. Applications of "<u>Embedded - Microcontrollers</u>" | Details | | |----------------------------|-----------------------------------------------------------------------------| | Product Status | Active | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 4MHz | | Connectivity | - | | Peripherals | Brown-out Detect/Reset, POR, WDT | | Number of I/O | 13 | | Program Memory Size | 3.5KB (2K x 14) | | Program Memory Type | OTP | | EEPROM Size | - | | RAM Size | 128 x 8 | | Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V | | Data Converters | A/D 4x8b | | Oscillator Type | External | | Operating Temperature | -40°C ~ 125°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 20-SSOP (0.209", 5.30mm Width) | | Supplier Device Package | 20-SSOP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16c715t-04e-ss | **TABLE 3-1: PIC16C710/71/711/715 PINOUT DESCRIPTION** | Pin Name | DIP<br>Pin# | SSOP<br>Pin# <sup>(4)</sup> | SOIC<br>Pin# | I/O/P<br>Type | Buffer<br>Type | Description | |--------------|-------------|-----------------------------|--------------|---------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OSC1/CLKIN | 16 | 18 | 16 | - | ST/CMOS <sup>(3)</sup> | Oscillator crystal input/external clock source input. | | OSC2/CLKOUT | 15 | 17 | 15 | 0 | _ | Oscillator crystal output. Connects to crystal or resonator in crystal oscillator mode. In RC mode, OSC2 pin outputs CLKOUT which has 1/4 the frequency of OSC1, and denotes the instruction cycle rate. | | MCLR/VPP | 4 | 4 | 4 | I/P | ST | Master clear (reset) input or programming voltage input. This pin is an active low reset to the device. | | | | | | | | PORTA is a bi-directional I/O port. | | RA0/AN0 | 17 | 19 | 17 | I/O | TTL | RA0 can also be analog input0 | | RA1/AN1 | 18 | 20 | 18 | I/O | TTL | RA1 can also be analog input1 | | RA2/AN2 | 1 | 1 | 1 | I/O | TTL | RA2 can also be analog input2 | | RA3/AN3/VREF | 2 | 2 | 2 | I/O | TTL | RA3 can also be analog input3 or analog reference voltage | | RA4/T0CKI | 3 | 3 | 3 | I/O | ST | RA4 can also be the clock input to the Timer0 module. Output is open drain type. | | | | | | | | PORTB is a bi-directional I/O port. PORTB can be software programmed for internal weak pull-up on all inputs. | | RB0/INT | 6 | 7 | 6 | I/O | TTL/ST <sup>(1)</sup> | RB0 can also be the external interrupt pin. | | RB1 | 7 | 8 | 7 | I/O | TTL | The dan also be the external interrupt pin. | | RB2 | 8 | 9 | 8 | I/O | TTL | | | RB3 | 9 | 10 | 9 | I/O | TTL | | | RB4 | 10 | 11 | 10 | I/O | TTL | Interrupt on change pin. | | RB5 | 11 | 12 | 11 | I/O | TTL | Interrupt on change pin. | | RB6 | 12 | 13 | 12 | I/O | TTL/ST <sup>(2)</sup> | Interrupt on change pin. Serial programming clock. | | RB7 | 13 | 14 | 13 | I/O | TTL/ST <sup>(2)</sup> | Interrupt on change pin. Serial programming data. | | Vss | 5 | 4, 6 | 5 | Р | _ | Ground reference for logic and I/O pins. | | VDD | 14 | 15, 16 | 14 | Р | _ | Positive supply for logic and I/O pins. | Legend: I = input O = output — = Not used I/O = input/output TTL = TTL input P = power ST = Schmitt Trigger input Note 1: This buffer is a Schmitt Trigger input when configured as the external interrupt. 2: This buffer is a Schmitt Trigger input when used in serial programming mode. <sup>3:</sup> This buffer is a Schmitt Trigger input when configured in RC oscillator mode and a CMOS input otherwise.4: The PIC16C71 is not available in SSOP package. # 3.1 Clocking Scheme/Instruction Cycle The clock input (from OSC1) is internally divided by four to generate four non-overlapping quadrature clocks namely Q1, Q2, Q3 and Q4. Internally, the program counter (PC) is incremented every Q1, the instruction is fetched from the program memory and latched into the instruction register in Q4. The instruction is decoded and executed during the following Q1 through Q4. The clocks and instruction execution flow is shown in Figure 3-2. # 3.2 <u>Instruction Flow/Pipelining</u> An "Instruction Cycle" consists of four Q cycles (Q1, Q2, Q3 and Q4). The instruction fetch and execute are pipelined such that fetch takes one instruction cycle while decode and execute takes another instruction cycle. However, due to the pipelining, each instruction effectively executes in one cycle. If an instruction causes the program counter to change (e.g. GOTO) then two cycles are required to complete the instruction (Example 3-1). A fetch cycle begins with the program counter (PC) incrementing in Q1. In the execution cycle, the fetched instruction is latched into the "Instruction Register" (IR) in cycle Q1. This instruction is then decoded and executed during the Q2, Q3, and Q4 cycles. Data memory is read during Q2 (operand read) and written during Q4 (destination write). ### **EXAMPLE 3-1: INSTRUCTION PIPELINE FLOW** All instructions are single cycle, except for any program branches. These take two cycles since the fetch instruction is "flushed" from the pipeline while the new instruction is being fetched and then executed. # 7.0 ANALOG-TO-DIGITAL CONVERTER (A/D) MODULE Applicable Devices 710 71 711 715 The analog-to-digital (A/D) converter module has four analog inputs. The A/D allows conversion of an analog input signal to a corresponding 8-bit digital number (refer to Application Note AN546 for use of A/D Converter). The output of the sample and hold is the input into the converter, which generates the result via successive approximation. The analog reference voltage is software selectable to either the device's positive supply voltage (VDD) or the voltage level on the RA3/AN3/VREF pin. The A/D converter has a unique feature of being able to operate while the device is in SLEEP mode. To operate in sleep, the A/D conversion clock must be derived from the A/D's internal RC oscillator. The A/D module has three registers. These registers are: - A/D Result Register (ADRES) - A/D Control Register 0 (ADCON0) - A/D Control Register 1 (ADCON1) The ADCON0 register, shown in Figure 7-1 and Figure 7-2, controls the operation of the A/D module. The ADCON1 register, shown in Figure 7-3 configures the functions of the port pins. The port pins can be configured as analog inputs (RA3 can also be a voltage reference) or as digital I/O. ### FIGURE 7-1: ADCONO REGISTER (ADDRESS 08h), PIC16C710/71/711 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R = Readable bit | |-------|-------|-----|-------|-------|---------|-------|-------|------------------------------------------------------------------------------| | ADCS1 | ADCS0 | (1) | CHS1 | CHS0 | GO/DONE | ADIF | ADON | | | bit7 | | | | | | | bit0 | W = Writable bit U = Unimplemented bit, read as '0' - n = Value at POR reset | bit 7-6: ADCS1:ADCS0: A/D Conversion Clock Select bits 00 = Fosc/2 01 = Fosc/8 10 = Fosc/32 11 = FRC (clock derived from an RC oscillation) bit 5: Unimplemented: Read as '0'. bit 4-3: CHS1:CHS0: Analog Channel Select bits 00 = channel 0, (RA0/AN0) 01 = channel 1, (RA1/AN1) 10 = channel 2, (RA2/AN2) 11 = channel 3, (RA3/AN3) bit 2: GO/DONE: A/D Conversion Status bit If ADON = 1: 1 = A/D conversion in progress (setting this bit starts the A/D conversion) 0 = A/D conversion not in progress (This bit is automatically cleared by hardware when the A/D conversion is complete) bit 1: ADIF: A/D Conversion Complete Interrupt Flag bit 1 = conversion is complete (must be cleared in software) 0 = conversion is not complete bit 0: ADON: A/D On bit 1 = A/D converter module is operating 0 = A/D converter module is shutoff and consumes no operating current **Note 1:** 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'. # 8.5 Interrupts # **Applicable Devices** | 710 | 71 | 711 | 715 The PIC16C71X family has 4 sources of interrupt. | Interrupt Sources | | | | | | | |----------------------------------------|--|--|--|--|--|--| | External interrupt RB0/INT | | | | | | | | TMR0 overflow interrupt | | | | | | | | PORTB change interrupts (pins RB7:RB4) | | | | | | | | A/D Interrupt | | | | | | | The interrupt control register (INTCON) records individual interrupt requests in flag bits. It also has individual and global interrupt enable bits. Note: Individual interrupt flag bits are set regardless of the status of their corresponding mask bit or the GIE bit. A global interrupt enable bit, GIE (INTCON<7>) enables (if set) all un-masked interrupts or disables (if cleared) all interrupts. When bit GIE is enabled, and an interrupt's flag bit and mask bit are set, the interrupt will vector immediately. Individual interrupts can be disabled through their corresponding enable bits in various registers. Individual interrupt bits are set regardless of the status of the GIE bit. The GIE bit is cleared on reset. The "return from interrupt" instruction, RETFIE, exits the interrupt routine as well as sets the GIE bit, which re-enables interrupts. The RB0/INT pin interrupt, the RB port change interrupt and the TMR0 overflow interrupt flags are contained in the INTCON register. The peripheral interrupt flags are contained in the special function registers PIR1 and PIR2. The corresponding interrupt enable bits are contained in special function registers PIE1 and PIE2, and the peripheral interrupt enable bit is contained in special function register INTCON. When an interrupt is responded to, the GIE bit is cleared to disable any further interrupt, the return address is pushed onto the stack and the PC is loaded with 0004h. Once in the interrupt service routine the source(s) of the interrupt can be determined by polling the interrupt flag bits. The interrupt flag bit(s) must be cleared in software before re-enabling interrupts to avoid recursive interrupts. For external interrupt events, such as the INT pin or PORTB change interrupt, the interrupt latency will be three or four instruction cycles. The exact latency depends when the interrupt event occurs (Figure 8-19). The latency is the same for one or two cycle instructions. Individual interrupt flag bits are set regardless of the status of their corresponding mask bit or the GIE bit. #### Note: For the PIC16C71 If an interrupt occurs while the Global Interrupt Enable (GIE) bit is being cleared, the GIE bit may unintentionally be re-enabled by the user's Interrupt Service Routine (the RETFIE instruction). The events that would cause this to occur are: - An instruction clears the GIE bit while an interrupt is acknowledged. - The program branches to the Interrupt vector and executes the Interrupt Service Routine. - The Interrupt Service Routine completes with the execution of the RET-FIE instruction. This causes the GIE bit to be set (enables interrupts), and the program returns to the instruction after the one which was meant to disable interrupts. Perform the following to ensure that interrupts are globally disabled: ``` LOOP BCF INTCON, GIE; Disable global; interrupt bit BTFSC INTCON, GIE; Global interrupt; disabled? GOTO LOOP; NO, try again; Yes, continue; with program; flow ``` # 8.6 <u>Context Saving During Interrupts</u> During an interrupt, only the return PC value is saved on the stack. Typically, users may wish to save key registers during an interrupt i.e., W register and STATUS register. This will have to be implemented in software. Example 8-1 stores and restores the STATUS and W registers. The user register, STATUS\_TEMP, must be defined in bank 0. The example: - a) Stores the W register. - b) Stores the STATUS register in bank 0. - c) Executes the ISR code. - Restores the STATUS register (and bank select bit). - e) Restores the W register. #### **EXAMPLE 8-1: SAVING STATUS AND W REGISTERS IN RAM** ``` MOVWF W_TEMP ;Copy W to TEMP register, could be bank one or zero SWAPF STATUS, W ;Swap status to be saved into W MOVWF STATUS_TEMP ; Save status to bank zero STATUS_TEMP register :(ISR) SWAPF STATUS_TEMP,W ;Swap STATUS_TEMP register into W ; (sets bank to original state) MOVWF STATUS ; Move W into STATUS register SWAPF W_TEMP,F ;Swap W_TEMP W_TEMP,W ;Swap W_TEMP into W SWAPF ``` # 8.7 Watchdog Timer (WDT) # Applicable Devices 710 71 711 715 The Watchdog Timer is as a free running on-chip RC oscillator which does not require any external components. This RC oscillator is separate from the RC oscillator of the OSC1/CLKIN pin. That means that the WDT will run, even if the clock on the OSC1/CLKIN and OSC2/CLKOUT pins of the device has been stopped, for example, by execution of a SLEEP instruction. During normal operation, a WDT time-out generates a device RESET (Watchdog Timer Reset). If the device is in SLEEP mode, a WDT time-out causes the device to wake-up and continue with normal operation (Watchdog Timer Wake-up). The WDT can be permanently disabled by clearing configuration bit WDTE (Section 8.1). #### 8.7.1 WDT PERIOD The WDT has a nominal time-out period of 18 ms, (with no prescaler). The time-out periods vary with temperature, VDD and process variations from part to part (see DC specs). If longer time-out periods are desired, a prescaler with a division ratio of up to 1:128 can be assigned to the WDT under software control by writing to the OPTION register. Thus, time-out periods up to 2.3 seconds can be realized. The CLRWDT and SLEEP instructions clear the WDT and the postscaler, if assigned to the WDT, and prevent it from timing out and generating a device RESET condition. The TO bit in the STATUS register will be cleared upon a Watchdog Timer time-out. #### 8.7.2 WDT PROGRAMMING CONSIDERATIONS It should also be taken into account that under worst case conditions (VDD = Min., Temperature = Max., and max. WDT prescaler) it may take several seconds before a WDT time-out occurs. Note: When a CLRWDT instruction is executed and the prescaler is assigned to the WDT, the prescaler count will be cleared, but the prescaler assignment is not changed. FIGURE 8-20: WATCHDOG TIMER BLOCK DIAGRAM FIGURE 8-21: SUMMARY OF WATCHDOG TIMER REGISTERS | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |----------|--------------|-------|----------------------|-------|-------|----------------------|-------|-------|-------| | 2007h | Config. bits | (1) | BODEN <sup>(1)</sup> | CP1 | CP0 | PWRTE <sup>(1)</sup> | WDTE | FOSC1 | FOSC0 | | 81h,181h | OPTION | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | Legend: Shaded cells are not used by the Watchdog Timer. Note 1: See Figure 8-1, Figure 8-2 and Figure 8-3 for operation of these bits. **BCF** Bit Clear f Syntax: [label] BCF f,b Operands: $0 \le f \le 127$ $0 \le b \le 7$ Operation: $0 \rightarrow (f < b >)$ Status Affected: None 00bb bfff ffff Encoding: 01 Description: Bit 'b' in register 'f' is cleared. Words: Cycles: Q Cycle Activity: Q1 Q2 Q3 Q4 Decode Read Process Write register 'f' register 'f' data Example BCF FLAG\_REG, 7 Before Instruction After Instruction | BSF | Bit Set f | | | | | | | |------------------|-----------------------------------|---------------------------|--|--|--|--|--| | Syntax: | [ <i>label</i> ] BS | [label] BSF f,b | | | | | | | Operands: | $0 \le f \le 127$ $0 \le b \le 7$ | | | | | | | | Operation: | $1 \rightarrow (f < b)$ | $1 \rightarrow (f < b >)$ | | | | | | | Status Affected: | None | None | | | | | | | Encoding: | 01 01bb bfff ffff | | | | | | | | Description: | Bit 'b' in register 'f' is set. | | | | | | | Words: 1 Cycles: Q Cycle Activity: Q1 Q2 Q3 Q4 | Decode | Read<br>register<br>'f' | Process<br>data | Write<br>register 'f' | |--------|-------------------------|-----------------|-----------------------| $FLAG_REG = 0xC7$ $FLAG_REG = 0x47$ Example BSF FLAG\_REG, 7 Before Instruction $FLAG_REG = 0x0A$ After Instruction $FLAG_REG = 0x8A$ | BTFSC | Bit Test, | Skip if Cl | ear | | | | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|-------|--|--| | Syntax: | [ <i>label</i> ] BT | FSC f,b | | | | | | Operands: | $0 \le f \le 12$ $0 \le b \le 7$ | 27 | | | | | | Operation: | skip if (f< | b>) = 0 | | | | | | Status Affected: | None | | | | | | | Encoding: | 01 | 10bb | bfff | ffff | | | | Description: | If bit 'b' in register 'f' is '1' then the next instruction is executed. If bit 'b', in register 'f', is '0' then the next instruction is discarded, and a NOP is executed instead, making this a 2Tcy instruction. | | | | | | | Words: | 1 | | | | | | | Cycles: | 1(2) | | | | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | | | | Decode | Read register 'f' | Process<br>data | NOP | | | | If Skip: | (2nd Cycle) | | | | | | | | Q1 | Q2 | Q3 | Q4 | | | | | NOP | NOP | NOP | NOP | | | | Example | HERE<br>FALSE<br>TRUE | BTFSC<br>GOTO<br>• | FLAG,1<br>PROCESS_ | _CODE | | | | | Before In | struction | | | | | | | | PC = a | ddress H | ERE | | | After Instruction if FLAG<1>=0, PC = address TRUE if FLAG<1>=1, PC = address FALSE | BTFSS | Bit Test f, Skip if Set | | | _ | CALL | Call Sub | routine | | | | |-------------------|-------------------------|--------------------------------------------------|--------------------|---------|------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-------------------------------------------|----------------------------------| | Syntax: | [label] BTFSS f,b | | | | | Syntax: | [label] CALL k | | | | | Operands: | - | $0 \le f \le 127$ | | | | Operands: | $0 \le k \le 2047$ | | | | | | $0 \le b < 7$ | | | | | Operation: | (PC)+ 1- | → TOS, | | | | Operation: | skip if (f< | :b>) = 1 | | | | | $k \rightarrow PC <$ | | | | | Status Affected: | None | | | | | | • | 1<4:3>) - | → PC<12 | :11> | | Encoding: | 01 | 11bb | bfff | ffff | | Status Affected: | None | | 1 | | | Description: | | register 'f' i | | he next | - | Encoding: | 10 | 0kkk | kkkk | kkkk | | | If bit 'b' is discarded | n is execute '1', then the and a NOF naking this | next instr | ed | | Description: | Call Subroutine. First, return address (PC+1) is pushed onto the stack. The eleven bit immediate address is loaded into PC bits <10:0>. The upper bits of | | | ck. The<br>s loaded<br>r bits of | | Words: | 1 | | | | | | | | rom PCLAT | | | Cycles: | 1(2) | | | | | Words: | 1 | • | | | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | Cycles: | 2 | | | | | | Decode | Read<br>register 'f' | Process<br>data | NOP | | Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | | If Skip: | (2nd Cyc | cle) | | | | 1st Cycle | Decode | Read<br>literal 'k', | Process<br>data | Write to PC | | · | Q1 | Q2 | Q3 | Q4 | 7 | | Push F<br>to Sta | | <b>:</b> | | | | NOP | NOP | NOP | NOP | | 2nd Cycle | NOP | NOP | NOP | NOP | | Example | After Inst | truction | FLAG, 1<br>PROCESS | | | Example | After Inst | PC = A<br>truction<br>PC = A | THERE Address HE Address TH Address HE | HERE | | | | if FLAG<1: | address F | | | | | | | | | 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: | $(f<3:0>) \rightarrow (dest<7:4>),$<br>$(f<7:4>) \rightarrow (dest<3:0>)$ | | | | | | 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. | | | | | | | | | | # 11.0 ELECTRICAL CHARACTERISTICS FOR PIC16C710 AND PIC16C711 # **Absolute Maximum Ratings †** | Austication | 55 to 1405°O | |-----------------------------------------------------------------------------------------------------------------|------------------------------------| | Ambient temperature under bias | | | 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 | | | 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, IiK (VI < 0 or VI > VDD) | ± 20 mA | | Output clamp current, lok (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 | 200 mA | | Maximum current sourced by PORTA | 200 mA | | Maximum current sunk by PORTB | 200 mA | | Maximum current sourced by PORTB | 200 mA | | <b>Note 1:</b> Power dissipation is calculated as follows: Pdis = VDD x {IDD - $\Sigma$ IOH} + $\Sigma$ {(VDD - | VOH) x IOH} + $\Sigma$ (VOI x IOL) | † 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 11-1: CROSS REFERENCE OF DEVICE SPECS FOR OSCILLATOR CONFIGURATIONS AND FREQUENCIES OF OPERATION (COMMERCIAL DEVICES) | osc | PIC16C710-04<br>PIC16C711-04 | PIC16C710-10<br>PIC16C711-10 | PIC16C710-20<br>PIC16C711-20 | PIC16LC710-04<br>PIC16LC711-04 | PIC16C710/JW<br>PIC16C711/JW | |-----|------------------------------|------------------------------|------------------------------|--------------------------------|------------------------------| | | VDD: 4.0V to 6.0V | VDD: 4.5V to 5.5V | VDD: 4.5V to 5.5V | VDD: 2.5V to 6.0V | VDD: 4.0V to 6.0V | | RC | IDD: 5 mA max. at 5.5V | IDD: 2.7 mA typ. at 5.5V | IDD: 2.7 mA typ. at 5.5V | IDD: 3.8 mA typ. at 3.0V | IDD: 5 mA max. at 5.5V | | | IPD: 21 μA max. at 4V | IPD: 1.5 μA typ. at 4V | IPD: 1.5 μA typ. at 4V | IPD: 5.0 μA typ. at 3V | IPD: 21 μA max. at 4V | | | Freq:4 MHz max. | Freq: 4 MHz max. | Freq: 4 MHz max. | Freq: 4 MHz max. | Freq:4 MHz max. | | | VDD: 4.0V to 6.0V | VDD: 4.5V to 5.5V | VDD: 4.5V to 5.5V | VDD: 2.5V to 6.0V | VDD: 4.0V to 6.0V | | XT | IDD: 5 mA max. at 5.5V | IDD: 2.7 mA typ. at 5.5V | IDD: 2.7 mA typ. at 5.5V | IDD: 3.8 mA typ. at 3.0V | IDD: 5 mA max. at 5.5V | | 1 | IPD: 21 μA max. at 4V | IPD: 1.5 μA typ. at 4V | IPD: 1.5 μA typ. at 4V | IPD: 5.0 μA typ. at 3V | IPD: 21 μA max. at 4V | | | Freq: 4 MHz max. | Freq: 4 MHz max. | Freq: 4 MHz max. | Freq: 4 MHz max. | Freq: 4 MHz max. | | | VDD: 4.5V to 5.5V | VDD: 4.5V to 5.5V | VDD: 4.5V to 5.5V | | VDD: 4.5V to 5.5V | | | IDD: 13.5 mA typ. at | IDD: 30 mA max. at | IDD: 30 mA max. at | Not recommended for | IDD: 30 mA max. at | | HS | 5.5V | 5.5V | 5.5V | use in HS mode | 5.5V | | | IPD: 1.5 μA typ. at 4.5V | IPD: 1.5 μA typ. at 4.5V | IPD: 1.5 μA typ. at 4.5V | use iii i is iiiode | IPD: 1.5 μA typ. at 4.5V | | | Freq: 4 MHz max. | Freq: 10 MHz max. | Freq:20 MHz max. | | Freq: 10 MHz max. | | | VDD: 4.0V to 6.0V | | | VDD: 2.5V to 6.0V | VDD: 2.5V to 6.0V | | | IDD: 52.5 μA typ. at | | | IDD: 48 μA max. at | IDD: 48 μA max. at | | LP | 32 kHz, 4.0V | Not recommended for | Not recommended for | 32 kHz, 3.0V | 32 kHz, 3.0V | | | IPD: 0.9 μA typ. at 4.0V | use in LP mode | use in LP mode | IPD: 5.0 μA max. at 3.0V | IPD: 5.0 μA max. at | | | Freq: 200 kHz max. | | | Freq: 200 kHz max. | 3.0V | | | | | | | Freq: 200 kHz max. | # 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) FIGURE 12-22: TYPICAL XTAL STARTUP TIME vs. Vdd (LP MODE, 25°C) FIGURE 12-23: TYPICAL XTAL STARTUP TIME vs. VdD (HS MODE, $25^{\circ}$ C) FIGURE 12-24: TYPICAL XTAL STARTUP TIME vs. VDD (XT MODE, 25°C) TABLE 12-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-0 | Epson C-001R32.768K-A | | | | | 200 kHz | STD XTL 2 | ± 20 PPM | | | | | 1 MHz | ECS ECS- | ECS ECS-10-13-1 | | | | | 4 MHz | ECS ECS- | ECS ECS-40-20-1 | | | | | 8 MHz | EPSON CA | EPSON CA-301 8.000M-C | | | | | 20 MHz | EPSON CA | ± 30 PPM | | | | TABLE 13-6: A/D CONVERTER CHARACTERISTICS: PIC16C715-04 (COMMERCIAL, INDUSTRIAL, EXTENDED) PIC16C715-10 (COMMERCIAL, INDUSTRIAL, EXTENDED) PIC16C715-20 (COMMERCIAL, INDUSTRIAL, EXTENDED) | Parameter No. | Sym | Characteristic | Min | Тур† | Max | Units | Conditions | |---------------|------|------------------------------------------------|-----------|------------|---------------------|----------|------------------------------------------------------| | | NR | Resolution | _ | _ | 8-bits | _ | VREF = VDD, VSS ≤ AIN ≤ VREF | | | NINT | Integral error | _ | _ | less than<br>±1 LSb | _ | VREF = VDD, VSS ≤ AIN ≤ VREF | | | NDIF | Differential error | _ | | less than<br>±1 LSb | _ | VREF = VDD, VSS ≤ AIN \$ VREF | | | NFS | Full scale error | _ | _ | less than<br>±1 LSb | _ | VREF = VDD, VSS \( \le AIN \( \le \)VREF | | | Noff | Offset error | _ | _ | less than<br>±1 LSb | _ | VREF = VDØ, VSS & AIN ≤ VREF | | | _ | Monotonicity | _ | guaranteed | _ | _ | VSS S AIN VREF | | | VREF | Reference voltage | 2.5V | _ | VDD + 0.3 | ٧/ | | | | Vain | Analog input voltage | Vss - 0.3 | _ | VREF + 0.3 | V\ | | | | Zain | Recommended impedance of analog voltage source | _ | _ | 10.0 | kΩ | | | | lad | A/D conversion current (VDD) | _ | 180 | | | Average current consumption when A/D is on. (Note 1) | | | IREF | VREF input current (Note 2) | _ | | 1 10 | mA<br>μA | During sampling All other times | - \* 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: 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. - 2: VREF current is from RA3 pin or VDD pin, whichever is selected as reference input. FIGURE 14-3: TYPICAL IPD vs. VDD @ 25°C (WDT ENABLED, RC MODE) FIGURE 14-4: MAXIMUM IPD vs. VDD (WDT ENABLED, RC MODE) FIGURE 14-5: TYPICAL RC OSCILLATOR FREQUENCY vs. VDD FIGURE 14-6: TYPICAL RC OSCILLATOR FREQUENCY vs. VDD FIGURE 14-7: TYPICAL RC OSCILLATOR FREQUENCY vs. VDD FIGURE 14-8: TYPICAL IPD vs. VDD BROWN-OUT DETECT ENABLED (RC MODE) FIGURE 14-9: MAXIMUM IPD vs. VDD BROWN-OUT DETECT ENABLED (85°C TO -40°C, RC MODE) FIGURE 14-10: TYPICAL IPD vs. TIMER1 ENABLED (32 kHz, RC0/RC1 = 33 pF/33 pF, RC MODE) FIGURE 14-11: MAXIMUM IPD vs. TIMER1 ENABLED (32 kHz, RC0/RC1 = 33 pF/33 pF, 85°C TO -40°C, RC MODE) # Applicable Devices 710 71 711 715 15.1 DC Characteristics: PIC16C71-04 (Commercial, Industrial) PIC16C71-20 (Commercial, 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 | -<br>-<br>- | 7<br>1.0<br>1.0 | 28<br>14<br>16 | μΑ<br>μΑ<br>μΑ | $\label{eq:decomposition} \begin{split} \text{VDD} &= 4.0\text{V}, \text{WDT enabled, -}40^{\circ}\text{C to +}85^{\circ}\text{C} \\ \text{VDD} &= 4.0\text{V}, \text{WDT disabled, -}0^{\circ}\text{C to +}70^{\circ}\text{C} \\ \text{VDD} &= 4.0\text{V}, \text{WDT disabled, -}40^{\circ}\text{C to +}85^{\circ}\text{C} \end{split}$ | - \* 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. FIGURE 16-14: MAXIMUM IDD VS. FREQ WITH A/D OFF (EXT CLOCK, -55° TO +125°C) FIGURE 16-15: WDT TIMER TIME-OUT PERIOD vs. VDD FIGURE 16-16: TRANSCONDUCTANCE (gm) OF HS OSCILLATOR vs. VDD | 1 | | TMR0 Overflow | 61 | |-----------------------------------------------|--------|-------------------------------------------------------|--------------------| | I/O Ports | | INTF bit | 19 | | PORTA | 25 | IRP bit | 17 | | PORTB | _ | 17 | | | Section | | K | | | | | KeeLoq® Evaluation and Programming Tools | 87 | | I/O Programming Considerations | | | | | ICEPIC Low-Cost PIC16CXXX In-Circuit Emulator | | L | | | In-Circuit Serial Programming | | Loading of PC | 23 | | INDF Register14 | | LP | 54 | | Indirect Addressing | | | | | Instruction Cycle | | M | | | Instruction Flow/Pipelining | | MCLR | 52, 56 | | Instruction Format | 69 | Memory | | | Instruction Set | | Data Memory | 12 | | ADDLW | 71 | Program Memory | | | ADDWF | 71 | Register File Maps | | | ANDLW | 71 | PIC16C71 | 12 | | ANDWF | 71 | PIC16C710 | | | BCF | 72 | PIC16C711 | | | BSF | 72 | | | | BTFSC | | PIC16C715 | | | BTFSS | | MP-DriveWay <sup>™</sup> - Application Code Generator | | | CALL | _ | MPEEN bit | | | CLRF | _ | MPLAB™ C | 87 | | CLRW | | MPLAB™ Integrated Development Environment | | | | | Software | 86 | | CLRWDT | | 0 | | | COMF | | O | | | DECF | _ | OPCODE | | | DECFSZ | - | OPTION Register | 18 | | GOTO | | Orthogonal | 7 | | INCF | 76 | OSC selection | 47 | | INCFSZ | 77 | Oscillator | | | IORLW | 77 | HS | 49. 54 | | IORWF | 78 | LP | 49 <sup>°</sup> 54 | | MOVF | 78 | RC | 49 | | MOVLW | 78 | XT4 | 49.54 | | MOVWF | 78 | Oscillator Configurations | , | | NOP | 79 | Oscillator Start-up Timer (OST) | | | OPTION | 79 | | | | RETFIE | 79 | P | | | RETLW | 80 | Packaging | | | RETURN | 80 | 18-Lead CERDIP w/Window | 155 | | RLF | 81 | 18-Lead PDIP | | | RRF | - | 18-Lead SOIC | | | SLEEP | 00 | 20-Lead SSOP | | | SUBLW | 82 | Paging, Program Memory | | | SUBWF | | PCL Register14, 15, | | | SWAPF | | | | | TRIS | | PCLATH | | | | | PCLATH Register 14, 15, 7 | - | | XORLW | | PCON Register | - | | XORWF | | PD bit 17, 5 | , | | Section | | PER bit | | | Summary Table | | PIC16C71 | | | INT Interrupt | | AC Characteristics | | | INTCON Register | | PICDEM-1 Low-Cost PIC16/17 Demo Board | 86 | | INTE bit | 19 | PICDEM-2 Low-Cost PIC16CXX Demo Board | 86 | | INTEDG bit | 18, 63 | PICDEM-3 Low-Cost PIC16CXXX Demo Board | 86 | | Internal Sampling Switch (Rss) Impedence | 40 | PICMASTER® In-Circuit Emulator | 85 | | Interrupts | 47 | PICSTART® Plus Entry Level Development System | 85 | | A/D | 61 | PIE1 Register | | | External | 61 | Pin Functions | | | PORTB Change | 61 | MCLR/VPP | <u> </u> | | PortB Change | | OSC1/CLKIN | | | RB7:RB4 Port Change | | OSC2/CLKOUT | | | Section | | RAO/ANO | | | TMR0 | | RA1/AN1 | | | | 50 | TM 11/1 W 1 1 | | | RA2/AN2 | 9 | PIC16C711 | 13 | |--------------------------------------------|--------|----------------------------------------|------------------| | RA3/AN3/VREF | 9 | PIC16C715 | | | RA4/T0CKI | | Reset Conditions | | | RB0/INT | | Summary | | | RB1 | | Reset | | | RB2 | | Reset Conditions for Special Registers | | | RB3 | | | | | | | RP0 bit | • | | RB4 | | RP1 bit | 17 | | RB5 | | S | | | RB6 | | _ | | | RB7 | 9 | SEEVAL® Evaluation and Programming Sy | /stem87 | | VDD | 9 | Services | | | Vss | 9 | One-Time-Programmable (OTP) Devi | | | Pinout Descriptions | | Quick-Turnaround-Production (QTP) I | Devices5 | | PIC16C71 | 9 | Serialized Quick-Turnaround Producti | on (SQTP) | | PIC16C710 | | Devices | 5 | | PIC16C711 | | SLEEP | 47. 52 | | PIC16C715 | | Software Simulator (MPLAB™ SIM) | | | PIR1 Register | - | Special Features of the CPU | | | | | Special Function Registers | 77 | | POP | | PIC16C71 | 1.1 | | POR | / - | | | | Oscillator Start-up Timer (OST) | | PIC16C710 | | | Power Control Register (PCON) | | PIC16C711 | | | Power-on Reset (POR) | | Special Function Registers, Section | | | Power-up Timer (PWRT) | 47, 53 | Stack | 23 | | Time-out Sequence | 54 | Overflows | 23 | | Time-out Sequence on Power-up | 59 | Underflow | 23 | | TO | 52. 55 | STATUS Register | 17 | | POR bit | - , | _ | | | Port RB Interrupt | | T | | | PORTA | | T0CS bit | 18 | | | · · | TOIE bit | | | PORTA Register | | TOIF bit | _ | | PORTB | | TAD | | | PORTB Register | | | 41 | | Power-down Mode (SLEEP) | | Timer0 | 57.50 | | Prescaler, Switching Between Timer0 and WD | | RTCC | 57, 58 | | PRO MATE® II Universal Programmer | 85 | Timers | | | Program Branches | 7 | Timer0 | | | Program Memory | | Block Diagram | | | Paging | 23 | External Clock | | | Program Memory Maps | | External Clock Timing | 33 | | PIC16C71 | 11 | Increment Delay | 33 | | PIC16C710 | | Interrupt | 31 | | PIC16C711 | | Interrupt Timing | | | PIC16C715 | | Prescaler | | | | | Prescaler Block Diagram | | | Program Verification | | Section | | | PS0 bit | | | | | PS1 bit | | Switching Prescaler Assignment | | | PS2 bit | 18 | Synchronization | | | PSA bit | 18 | T0CKI | | | PUSH | 23 | T0IF | | | PWRT | | Timing | 31 | | Power-up Timer (PWRT) | 53 | TMR0 Interrupt | 63 | | PWRTE bit | | Timing Diagrams | | | · · · · · · · · · · · · · · · · · · · | | A/D Conversion | 100, 124, 146 | | R | | Brown-out Reset | | | | 10 | CLKOUT and I/O | , | | RBIE bit | | | , , | | RBIF bit | · · | External Clock Timing | | | RBPU bit | | Power-up Timer | • | | RC | | Reset | • | | RC Oscillator | 51, 54 | Start-up Timer | | | Read-Modify-Write | 30 | Time-out Sequence | | | Register File | | Timer0 | 31, 98, 121, 144 | | Registers | | Timer0 Interrupt Timing | | | Maps | | Timer0 with External Clock | | | PIC16C71 | 12 | Wake-up from SLEEP through Interru | | | PIC16C71 | | Watchdog Timer | | | FIG100/10 | 1∠ | **atonaog 1111101 | 31, 143 |