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, PWM, WDT | | Number of I/O | 17 | | Program Memory Size | 3.5KB (2K x 14) | | Program Memory Type | FLASH | | EEPROM Size | 256 x 8 | | RAM Size | 128 x 8 | | Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V | | Data Converters | A/D 14x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°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/pic16f785-i-ss | #### 3.4 Internal Clock Modes The PIC16F785/HV785 has two independent, internal oscillators that can be configured or selected as the system clock source. - The HFINTOSC (High-frequency Internal Oscillator) is factory calibrated and operates at 8 MHz. The frequency of the HFINTOSC can be user adjusted ±12% via software using the OSCTUNE register (Register 3-1). - The LFINTOSC (Low-frequency Internal Oscillator) is uncalibrated and operates at approximately 31 kHz. The system clock speed can be selected via software using the Internal Oscillator Frequency Select (IRCF) bits. The system clock can be selected between external or internal clock sources via the System Clock Selection (SCS) bit (see **Section 3.5 "Clock Switching"**). #### 3.4.1 INTRC AND INTRCIO MODES The INTRC and INTRCIO modes configure the internal oscillators as the system clock source when the device is programmed using the Oscillator Selection (FOSC) bits in the Configuration Word (Register 12-1). In **INTRC** mode, the OSC1 pin is available for general purpose I/O. The OSC2/CLKOUT pin outputs the selected internal oscillator frequency divided by 4. The CLKOUT signal may be used to provide a clock for external circuitry, synchronization, calibration, test or other application requirements. In **INTRCIO** mode, the OSC1 and OSC2 pins are available for general purpose I/O. #### 3.4.2 HFINTOSC The High-frequency Internal Oscillator (HFINTOSC) is a factory calibrated 8 MHz internal clock source. The frequency of the HFINTOSC can be altered approximately ±12% via software using the OSCTUNE register (Register 3-1). The output of the HFINTOSC connects to a postscaler and multiplexer (see Figure 3-1). One of seven frequencies can be selected via software using the IRCF bits (see Section 3.4.4 "Frequency Select Bits (IRCF)"). The HFINTOSC is enabled by selecting any frequency between 8 MHz and 125 kHz (IRCF $\neq$ 000) as the system clock source (SCS = 1) or when Two-Speed Start-up is enabled (IESO = 1 and IRCF $\neq$ 000). The HF Internal Oscillator (HTS) bit, in the OSCCON Register, indicates whether the HFINTOSC is stable or not. #### 3.4.2.1 Calibration Bits Note: The 8 MHz High-frequency Internal Oscillator (HFINTOSC) is factory calibrated. The HFINTOSC calibration bits are stored in the Calibration Word (CALIB) located in program memory location 2008h. The Calibration Word is not erased using the specified bulk erase sequence in the "PIC16F785/HV785 Memory Programming Specification" (DS41237) and does not require reprogramming. Reference the "PIC16F785/HV785 Memory Programming Specification" (DS41237) for more information on the Calibration Word register. Address 2008h is beyond the user program memory space. It belongs to the special Configuration Memory space (2000h-3FFFh), which can be accessed only during programming. See "PIC16F785/HV785 Memory Programming Specification" (DS41237) for more information. #### 3.4.3 LFINTOSC The Low-frequency Internal Oscillator (LFINTOSC) is an uncalibrated (approximate) 31 kHz internal clock source. The output of the LFINTOSC connects to a postscaler and multiplexer (see Figure 3-1). 31 kHz can be selected via software using the IRCF bits (see Section 3.4.4 "Frequency Select Bits (IRCF)"). The LFINTOSC is also the frequency for the Power-up Timer (PWRT), Watchdog Timer (WDT) and Fail-Safe Clock Monitor (FSCM). The LFINTOSC is enabled by selecting 31 kHz (IRCF = 000) as the system clock source (SCS = 1), or when any of the following are enabled: - Two-Speed Start-up (IESO = 1 and IRCF = 000) - Power-up Timer (PWRT) - Watchdog Timer (WDT) - Fail-Safe Clock Monitor (FSCM) The LF Internal Oscillator (LTS) bit, in the OSCCON register, indicates whether the LFINTOSC is stable or not. #### 3.4.4 FREQUENCY SELECT BITS (IRCF) The output of the 8 MHz HFINTOSC and 31 kHz LFINTOSC connect to a postscaler and multiplexer (see Figure 3-1). The Internal Oscillator Frequency select bits IRCF<2:0> in the OSCCON Register select the frequency output of the internal oscillators. One of eight frequencies can be selected via software: - 8 MHz - 4 MHz (Default after Reset) - 2 MHz - 1 MHz - 500 kHz - 250 kHz - 125 kHz - 31 kHz Note: Following any Reset, the IRCF bits are set to '110' and the frequency selection is forced to 4 MHz. The user can modify the IRCF bits to select a different frequency. ### 3.4.5 HF AND LF INTOSC CLOCK SWITCH TIMING When switching between the LFINTOSC and the HFINTOSC, the new oscillator may already be shut down to save power. If this is the case, there is a 10 $\mu s$ delay after the IRCF bits are modified before the frequency selection takes place. The LTS/HTS bits will reflect the current active status of the LFINTOSC and the HFINTOSC oscillators. The timing of a frequency selection is as follows: - IRCF bits are modified. - 2. If the new clock is shut down, a 10 $\mu s$ clock start-up delay is started. - Clock switch circuitry waits for a falling edge of the current clock. - CLKOUT is held low and the clock switch circuitry waits for a rising edge in the new clock. - CLKOUT is now connected with the new clock. HTS/LTS bits are updated as required. - 6. Clock switch is complete. If the internal oscillator speed selected is between 8 MHz and 125 kHz, there is no start-up delay before the new frequency is selected. This is because the old and the new frequencies are derived from the HFINTOSC via the postscaler and multiplexer. Note: Care must be taken to ensure an invalid voltage or frequency selection is not selected. An example of an invalid configuration is selecting 8 MHz when VDD is 2.0V. ## 6.5 Timer1 Operation in Asynchronous Counter Mode If control bit T1SYNC of the T1CON Register is set, the external clock input is not synchronized. The timer continues to increment asynchronous to the internal phase clocks. The timer will continue to run during Sleep and can generate an interrupt on overflow, which will wake-up the processor. However, special precautions in software are needed to read/write the timer (Section 6.5.1 "Reading and Writing Timer1 in Asynchronous Counter Mode"). | Note: | The ANSEL0 (91h) register must be initial- | |-------|--------------------------------------------| | | ized to configure an analog channel as a | | | digital input. Pins configured as analog | | | inputs will read '0'. | # 6.5.1 READING AND WRITING TIMER1 IN ASYNCHRONOUS COUNTER MODE Reading TMR1H or TMR1L while the timer is running from an external asynchronous clock will ensure a valid read (taken care of in hardware). However, the user should keep in mind that reading the 16-bit timer in two 8-bit values itself, poses certain problems, since the timer may overflow between the reads. For writes, it is recommended that the user simply stop the timer and write the desired values. A write contention may occur by writing to the timer registers, while the register is incrementing. This may produce an unpredictable value in the timer register. #### 6.6 Timer1 Oscillator A crystal oscillator circuit is built-in between pins OSC1 (input) and OSC2 (amplifier output). It is enabled by setting control bit T1OSCEN of the T1CON Register. The oscillator is a low power oscillator rated for 32.768 kHz. It will continue to run during Sleep. It is primarily intended for a 32.768 kHz tuning fork crystal. The Timer1 oscillator is shared with the system LP oscillator. Thus, Timer1 can use this mode only when the primary system clock is also the LP oscillator or is derived from the internal oscillator. As with the system LP oscillator, the user must provide a software time delay to ensure proper oscillator start-up. Sleep mode will not disable the system clock when the system clock and Timer1 share the LP oscillator. TRISA<5> and TRISA<4> bits are set when the Timer1 oscillator is enabled. RA5 and RA4 read as '0' and TRISA<5> and TRISA<4> bits read as '1'. | Note: | The oscillator requires a start-up and | |-------|------------------------------------------| | | stabilization time before use. Thus, | | | T1OSCEN should be set and a suitable | | | delay observed prior to enabling Timer1. | #### 6.7 Timer1 Operation During Sleep Timer1 can only operate during Sleep when setup in Asynchronous Counter mode. In this mode, an external crystal or clock source can be used to increment the counter. To setup the timer to wake the device: - Timer1 of the T1CON Register must be on - TMR1IE bit of the PIE1 Register must be set - PEIE bit of the INTCON Register must be set The device will wake-up on an overflow. If the GIE bit of the INTCON Register is set, the device will wake-up and jump to the Interrupt Service Routine (0004h) on an overflow. If the GIE bit is clear, execution will continue with the next instruction. TABLE 6-1: REGISTERS ASSOCIATED WITH TIMER1 | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR, BOR | Value on all other Resets | |---------|------------|-----------------------------------------------------------------------------|-------------|-----------------|---------------|--------------|--------|--------|----------------------|---------------------------| | ANSEL0 | ANS7 | ANS6 | ANS5 | ANS4 | ANS3 | ANS2 | ANS1 | ANS0 | 1111 1111 | 1111 1111 | | CM2CON1 | MC1OUT | MC2OUT | _ | _ | _ | _ | T1GSS | C2SYNC | 0010 | 0010 | | INTCON | GIE | PEIE | TOIE | INTE | RAIE | T0IF | INTF | RAIF | 0000 0000 | 0000 0000 | | PIE1 | EEIE | ADIE | CCP1IE | C2IE | C1IE | OSFIE | TMR2IE | TMR1IE | 0000 0000 | 0000 0000 | | PIR1 | EEIF | ADIF | CCP1IF | C2IF | C1IF | OSFIF | TMR2IF | TMR1IF | 0000 0000 | 0000 0000 | | T1CON | T1GINV | T1GINV TMR1GE T1CKPS1 T1CKPS0 T1OSCEN T1SYNC TMR1CS TMR1ON | | | | | | | 0000 0000 | uuuu uuuu | | TMR1L | Holding Re | Holding Register for the Least Significant Byte of the 16-bit TMR1 Register | | | | | | | xxxx xxxx | uuuu uuuu | | TMR1H | Holding Re | egister for th | e Most Sign | ificant Byte of | the 16-bit TN | /IR1 Registe | r | | xxxx xxxx | uuuu uuuu | Legend: -x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the Timer1 module. #### 7.2 Timer2 Interrupt The Timer2 module has an 8-bit period register, PR2. Timer2 increments from 00h until it matches PR2 and then resets to 00h on the next increment cycle. PR2 is a readable and writable register. The PR2 register is initialized to FFh upon Reset. FIGURE 7-1: TIMER2 BLOCK DIAGRAM TABLE 7-1: REGISTERS ASSOCIATED WITH TIMER2 | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR, BOR | Value on all other Resets | |--------|----------------------------------------------------------|-----------------|------------|----------|-------|-------|--------|--------|----------------------|---------------------------| | INTCON | GIE | PEIE | TOIE | INTE | RAIE | TOIF | INTF | RAIF | 0000 0000 | 0000 0000 | | PIE1 | EEIE | ADIE | CCP1IE | C2IE | C1IE | OSFIE | TMR2IE | TMR1IE | 0000 0000 | 0000 0000 | | PIR1 | EEIF | ADIF | CCP1IF | C2IF | C1IF | OSFIF | TMR2IF | TMR1IF | 0000 0000 | 0000 0000 | | PR2 | Timer2 Mo | dule Period r | egister | | | | | | 1111 1111 | 1111 1111 | | T2CON | - TOUTPS3 TOUTPS2 TOUTPS1 TOUTPS0 TMR2ON T2CKPS1 T2CKPS0 | | | | | | | | -000 0000 | -000 0000 | | TMR2 | Holding Re | egister for the | 8-bit TMR2 | Register | | | | | 0000 0000 | 0000 0000 | Legend: - x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the Timer2 module. #### REGISTER 9-1: CM1CON0: COMPARATOR C1 CONTROL REGISTER 0 | R/W-0 | R-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-------|-------|-------|-------|-------|-------|-------| | C1ON | C1OUT | C1OE | C1POL | C1SP | C1R | C1CH1 | C1CH0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7 C1ON: Comparator C1 Enable bit 1 = C1 Comparator is enabled 0 = C1 Comparator is disabled bit 6 C10UT: Comparator C1 Output bit $\frac{\text{If C1POL} = 1 \text{ (inverted polarity):}}{\text{C1OUT} = 1, \text{C1VP} < \text{C1VN}}$ C1OUT = 0, C1VP > C1VN If C1POL = 0 (non-inverted polarity): C1OUT = 1, C1VP > C1VN C1OUT = 0, C1VP < C1VN bit 5 C10E: Comparator C1 Output Enable bit 1 = C1OUT is present on the RA2/AN2/T0CKI/INT/C1OUT pin(1) 0 = C1OUT is internal only bit 4 C1POL: Comparator C1 Output Polarity Select bit 1 = C1OUT logic is inverted 0 = C1OUT logic is not inverted bit 3 C1SP: Comparator C1 Speed Select bit 1 = C1 operates in normal speed mode 0 = C1 operates in low-power, slow speed mode bit 2 C1R: Comparator C1 Reference Select bit (non-inverting input) 1 = C1VP connects to C1VREF output 0 = C1VP connects to RA0/AN0/C1IN+/ICSPDAT bit 1-0 C1CH<1:0>: Comparator C1 Channel Select bits 00 = C1VN of C1 connects to RA1/AN1/C12IN0-/VREF/ICSPCLK 01 = C1VN of C1 connects to RC1/AN5/C12IN1-/PH1 10 = C1VN of C1 connects to RC2/AN6/C12IN2-/OP2 11 = C1VN of C1 connects to RC3/AN7/C12IN3-/OP1 Note 1: C1OUT will only drive RA2/AN2/T0CKI/INT/C1OUT if: (C1OE = 1) and (C1ON = 1) and (TRISA<2> = 0). #### 9.1.2.2 Control Register CM2CON1 Comparator C2 has one additional feature: its output can be synchronized to the Timer1 clock input. Setting C2SYNC of the CM2CON1 Register synchronizes the output of Comparator 2 to the falling edge of the Timer1 clock input (see Figure 9-2 and Register 9-3). The CM2CON1 register also contains mirror copies of both comparator outputs, MC1OUT and MC2OUT of the CM2CON1 Register. The ability to read both outputs simultaneously from a single register eliminates the timing skew of reading separate registers. **Note:** Obtaining the status of C1OUT or C2OUT by reading CM2CON1 does not affect the comparator interrupt mismatch registers. #### REGISTER 9-3: CM2CON1: COMPARATOR C2 CONTROL REGISTER 1 | R-0 | R-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | |--------|--------|-----|-----|-----|-----|-------|--------| | MC1OUT | MC2OUT | _ | _ | _ | _ | T1GSS | C2SYNC | | bit 7 | | | | | | | bit 0 | | Legend: | | | | |-------------------|------------------|-----------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, read | d as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 7 MC1OUT: Mirror Copy of C1OUT bit (CM1CON0<6>) bit 6 MC2OUT: Mirror Copy of C2OUT bit (CM2CON0<6>) bit 5-2 **Unimplemented:** Read as '0' bit 1 T1GSS: Timer1 Gate Source Select bit 1 = Timer1 gate source is RA4/AN3/T1G/OSC2/CLKOUT 0 = Timer1 gate source is SYNCC2OUT. bit 0 C2SYNC: C2 Output Synchronous Mode bit 1 = C2 output is synchronous to falling edge of TMR1 clock 0 = C2 output is asynchronous **NOTES:** #### 12.1 A/D Configuration and Operation There are four registers available to control the functionality of the A/D module: - 1. ANSEL0 (Register 12-1) - 2. ANSEL1 (Register 12-2) - 3. ADCON0 (Register 12-3) - 4. ADCON1 (Register 12-4) #### 12.1.1 ANALOG PORT PINS The ANS<11:0> bits, of the ANSEL1 and ANSEL0 Registers, and the TRISA<4,2:0>, TRISB<5:4> and TRISC<7:6,3:0>> bits control the operation of the A/D port pins. Set the corresponding TRISx bits to '1' to set the pin output driver to its high-impedance state. Likewise, set the corresponding ANSx bit to disable the digital input buffer. Note: Analog voltages on any pin that is defined as a digital input may cause the input buffer to conduct excess current. #### 12.1.2 CHANNEL SELECTION There are fourteen analog channels on the PIC16F785/ HV785. The CHS<3:0> bits of the ADCON0 Register control which channel is connected to the sample and hold circuit. #### 12.1.3 VOLTAGE REFERENCE There are two options for the voltage reference to the A/D converter: either VDD is used or an analog voltage applied to VREF is used. The VCFG bit of the ADCON0 Register controls the voltage reference selection. If VCFG is set, then the voltage on the VREF pin is the reference; otherwise, VDD is the reference. #### 12.1.4 CONVERSION CLOCK The A/D conversion cycle requires 11 TAD. The source of the conversion clock is software selectable via the ADCS bits of the ADCON1 Register. There are seven possible clock options: - Fosc/2 - Fosc/4 - Fosc/8 - Fosc/16 - Fosc/32 - Fosc/64 - · FRC (dedicated internal oscillator) For correct conversion, the A/D conversion clock (1/TAD) must be selected to ensure a minimum TAD of 1.6 $\mu$ s. Table 12-1 shows a few TAD calculations for selected frequencies. TABLE 12-1: TAD VS. DEVICE OPERATING FREQUENCIES | A/D Clock | Source (TAD) | Device Frequency | | | | | | | | |-----------|--------------|----------------------------|----------------------------|----------------------------|----------------------------|--|--|--|--| | Operation | ADCS2:ADCS0 | 20 MHz | 5 MHz | 4 MHz | 1.25 MHz | | | | | | 2 Tosc | 000 | 100 ns <sup>(2)</sup> | 400 ns <sup>(2)</sup> | 500 ns <sup>(2)</sup> | 1.6 μs | | | | | | 4 Tosc | 100 | 200 ns <sup>(2)</sup> | 800 ns <sup>(2)</sup> | 1.0 μs <sup>(2)</sup> | 3.2 μs | | | | | | 8 Tosc | 001 | 400 ns <sup>(2)</sup> | 1.6 μs | 2.0 μs | 6.4 μs | | | | | | 16 Tosc | 101 | 800 ns <sup>(2)</sup> | 3.2 μs | 4.0 μs | 12.8 μs <sup>(3)</sup> | | | | | | 32 Tosc | 010 | 1.6 μs | 6.4 μs | 8.0 μs <sup>(3)</sup> | 25.6 μs <sup>(3)</sup> | | | | | | 64 Tosc | 110 | 3.2 μs | 12.8 μs <sup>(3)</sup> | 16.0 μs <sup>(3)</sup> | 51.2 μs <sup>(3)</sup> | | | | | | A/D RC | x11 | 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), (4)</sup> | | | | | Legend: Shaded cells are outside of recommended range. - **Note 1:** The A/D RC source has a typical TAD time of 4 $\mu$ s for VDD > 3.0V. - 2: These values violate the minimum required TAD time. - 3: For faster conversion times, the selection of another clock source is recommended. - **4:** When the device frequency is greater than 1 MHz, the A/D RC clock source is only recommended if the conversion will be performed during Sleep. #### REGISTER 12-3: ADCON0: A/D CONTROL REGISTER | R/W-0 |-------|-------|-------|-------|-------|-------|---------|-------| | ADFM | VCFG | CHS3 | CHS2 | CHS1 | CHS0 | GO/DONE | ADON | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7 ADFM: A/D Result Formed Select bit 1 = Right justified 0 = Left justified bit 6 VCFG: Voltage Reference bit 1 = VREF pin 0 = VDD bit 5-2 CHS<3:0>: Analog Channel Select bits 0000 = Channel 00 (AN0) 0001 = Channel 01 (AN1) 0010 = Channel 02 (AN2) 0011 = Channel 03 (AN3) 0100 = Channel 04 (AN4) 0101 = Channel 05 (AN5) 0110 = Channel 06 (AN6) 0111 = Channel 07 (AN7) 1000 = Channel 08 (AN8) 1001 = Channel 09 (AN9) 1010 = Channel 10 (AN10) 1011 = Channel 11 (AN11) 1100 = CVREF 1101 = VR 1110 = Reserved. Do not use. 1111 = Reserved. Do not use. bit 1 GO/DONE: A/D Conversion Status bit 1 = A/D conversion cycle in progress. Setting this bit starts an A/D conversion cycle. This bit is automatically cleared by hardware when the A/D conversion has completed. 0 = A/D conversion completed/not in progress bit 0 ADON: A/D Enable bit 1 = A/D converter module is enabled 0 = A/D converter is shut-off and consumes no operating current #### 15.2.5 BOR CALIBRATION The PIC16F785/HV785 stores the BOR calibration values in fuses located in the Calibration Word (2008h). The Calibration Word is not erased when using the specified bulk erase sequence in the "PIC16F785/HV785 Memory Programming Specification" (DS41237) and thus, does not require reprogramming. Note: Address 2008h is beyond the user program memory space. It belongs to the special configuration memory space (2000h-3FFh), which can be accessed only during programming. See "PIC16F785/HV785 Memory Programming Specification" (DS41237) for more information. #### FIGURE 15-3: BROWN-OUT SITUATIONS TABLE 19-3: PRECISION INTERNAL OSCILLATOR PARAMETERS | Param<br>No. | Sym | Characteristic | Freq.<br>Tolerance | Min | Тур† | Max | Units | Conditions | |--------------|---------|---------------------------------|--------------------|------|------|------|-------|-------------------------------------------------------------------------------------------------------------| | F10 | Fosc | Internal Calibrated | ±1% | 7.92 | 8.00 | 8.08 | MHz | VDD = 3.5V, 25°C | | | | INTOSC Frequency <sup>(1)</sup> | ±2% | 7.84 | 8.00 | 8.16 | MHz | $2.5 \text{V} \le \text{VDD} \le 5.5 \text{V}$<br>$0^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ | | | | | ±5% | 7.60 | 8.00 | 8.40 | MHz | $2.0V \le VDD \le 5.5V$<br>-40°C \le TA \le +85°C (Ind.)<br>-40°C \le TA \le +125°C (Ext.) | | F14 | Tioscst | Oscillator wake-up from | _ | _ | 12 | 24 | μS | $VDD = 2.0V, -40^{\circ}C \text{ to } +85^{\circ}C$ | | | | Sleep start-up time* | _ | _ | 7 | 14 | μS | $VDD = 3.0V, -40^{\circ}C \text{ to } +85^{\circ}C$ | | | | | _ | _ | 6 | 11 | μS | $VDD = 5.0V, -40^{\circ}C \text{ to } +85^{\circ}C$ | <sup>\*</sup> These parameters are characterized but not tested. **Note 1:** To ensure these oscillator frequency tolerances, VDD and VSS must be capacitively decoupled as close to the device as possible. 0.1 uF and 0.01 uF values in parallel are recommended. FIGURE 19-5: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING <sup>†</sup> Data in 'Typ' column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. FIGURE 20-6: MAXIMUM IDD vs. VDD OVER FOSC (XT MODE) FIGURE 20-7: IDD vs. VDD (LP MODE) FIGURE 20-10: IDD vs. VDD OVER FOSC (LFINTOSC MODE, 31 kHz) FIGURE 20-11: TYPICAL IDD vs. FOSC OVER VDD (HFINTOSC MODE) FIGURE 20-14: MAXIMUM IPD vs. VDD (SLEEP MODE, ALL PERIPHERALS DISABLED) FIGURE 20-15: COMPARATOR IPD vs. VDD (BOTH COMPARATORS ENABLED) ### 20-Lead Plastic Dual In-Line (P) - 300 mil Body [PDIP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | INCHES | | | | |----------------------------|------------------|--------|----------|-------|--| | | Dimension Limits | MIN | NOM | MAX | | | Number of Pins | N | | 20 | | | | Pitch | е | | .100 BSC | | | | Top to Seating Plane | A | _ | _ | .210 | | | Molded Package Thickness | A2 | .115 | .130 | .195 | | | Base to Seating Plane | A1 | .015 | _ | _ | | | Shoulder to Shoulder Width | E | .300 | .310 | .325 | | | Molded Package Width | E1 | .240 | .250 | .280 | | | Overall Length | D | .980 | 1.030 | 1.060 | | | Tip to Seating Plane | L | .115 | .130 | .150 | | | Lead Thickness | С | .008 | .010 | .015 | | | Upper Lead Width | b1 | .045 | .060 | .070 | | | Lower Lead Width | b | .014 | .018 | .022 | | | Overall Row Spacing § | eB | _ | _ | .430 | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic. - 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side. - 4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing C04-019B ### **INDEX** | A | | RC2 and RC3 Pins | 47 | |------------------------------------------|----------|------------------------------------------------|-------| | A/D | 79 | RC4 Pin | 47 | | Acquisition Requirements | | RC5 Pin | _ | | Analog Port Pins | | Resonator Operation | 25 | | Associated Registers | | Timer1 | | | Block Diagram | | Timer2 | | | Calculating Acquisition Time | | TMR0/WDT Prescaler | 49 | | Channel Selection | | Two Phase PWM | | | Configuration and Operation | | Complementary Output Mode | | | Configuring | 85 | Simplified Diagram | | | Configuring Interrupt | | Single Phase Example | | | Conversion Clock | | VR Reference | | | Effects of Reset | 89 | Watchdog Timer (WDT) | | | Internal Sampling Switch (Rss) Impedance | 86 | Brown-out Reset (BOR) | | | Operation During Sleep | 88 | Associated Registers | | | Output Format | | Calibration | | | Reference Voltage (VREF) | 80 | Specifications | | | Source Impedance | 86 | Timing and Characteristics | 154 | | Special Event Trigger | 89 | С | | | Specifications159, | 160, 161 | C Compilers | | | Starting a Conversion | 81 | MPLAB C18 | 138 | | Using the ECCP Trigger | 89 | MPLAB C30 | | | Absolute Maximum Ratings | 141 | Capture Module. See Capture/Compare/PWM (CCP) | . 130 | | AC Characteristics | | Capture/Compare/PWM (CCP) | 57 | | Load Conditions | | Associated Registers | | | ADCON0 Register | | Associated Registers w/ Capture/Compare/Timer1 | | | ADCON1 Register | 84 | Capture Mode | | | Analog-to-Digital Converter. See A/D | | CCP1 Pin Configuration | | | ANSEL Register93 | | Compare Mode | | | ANSEL0 Register | | CCP1 Pin Configuration | | | ANSEL1 Register | 82 | Software Interrupt Mode | | | Assembler | | Special Event Trigger and A/D Conversions | | | MPASM Assembler | 138 | Timer1 Mode Selection | | | В | | Prescaler | | | | | PWM Mode | | | Block Diagrams | 50 | Duty Cycle | | | (CCP) Capture Mode Operation | | Effects of Reset | | | Angles Input Model | | Example PWM Frequencies and Resolutions | | | Analog Input Model | | Operation in Power Managed Modes | | | CCP PWM Clock Source | | Operation with Fail-Safe Clock Monitor | | | Comparator 1 | | Setup for Operation | | | • | | Setup for PWM Operation | | | Comparator 2 | | Specifications | 156 | | Compare<br>CVref | | Timer Resources | | | | | CCP. See Capture/Compare/PWM (CCP) | | | Fail-Safe Clock Monitor (FSCM) | | CCP1CON Register | 57 | | Interrupt Logic | | CCPR1H Register | | | On-Chip Reset Circuit | | CCPR1L Register | 57 | | OPA Module | | Clock Sources | 23 | | PIC16F785/HV785 | | CM1CON0 | 65 | | RA0 Pin | | CM2CON1 | 68 | | RA1 Pin | | Code Examples | | | RA2 Pin | | Assigning Prescaler to Timer0 | 50 | | RA3 Pin | | Assigning Prescaler to WDT | | | RA4 Pin | | Changing Between Capture Prescalers | 58 | | RA5 Pin | | Data EEPROM Read | | | RB4 and RB5 Pins | | Data EEPROM Write | 105 | | RB6 Pin | | EEPROM Write Verify | 105 | | RB7 Pin | | Indirect Addressing | 22 | | RC0 and RC1 Pins | | Initializing A/D | | | RC0, RC6 and RC7 Pins | | Initializing PORTA | 35 | | RC1 Pin | | Initializing PORTB | 42 | | 1.011 | 40 | Initializing PORTC | 45 | | Interrupt Context Saving | 120 | Instruction Format | 127 | |----------------------------------------------|-----|------------------------------------------|-----| | Code Protection | 124 | Instruction Set | 127 | | Comparator Module | 63 | ADDLW | 129 | | Associated Registers | 74 | ADDWF | 129 | | C1 Output State Versus Input Conditions | 63 | ANDLW | 129 | | C2 Output State Versus Input Conditions | 66 | ANDWF | 129 | | Comparator Interrupts | 69 | MOVF | 132 | | Effects of Reset | 69 | RRF | 133 | | Comparator Voltage Reference (CVREF) | | SLEEP | 133 | | Specifications | 157 | SUBLW | 134 | | Comparators | | SUBWF | | | C2OUT as T1 Gate | 52 | SWAPF | | | Specifications | - | TRIS | | | Compare Module. See Capture/Compare/PWM (CCF | | XORLW | | | CONFIG Register | | XORWF | _ | | Configuration Bits | | BCF | | | Customer Change Notification Service | | BSF | | | | | | | | Customer Notification Service | | BTFSC | | | Customer Support | 201 | BTFSS | | | D | | CALL | | | _ | | CLRF | | | Data EEPROM Memory | 400 | CLRW | | | Associated Registers | | CLRWDT | | | Code Protection | | COMF | | | Data Memory | 9 | DECF | | | DC and AC Characteristics | | DECFSZ | 131 | | Graphs and Tables | 163 | GOTO | 131 | | DC Characteristics | | INCF | 131 | | Extended and Industrial | 148 | INCFSZ | 131 | | Industrial and Extended | 143 | IORLW | 132 | | Development Support | 137 | IORWF | 132 | | Device Overview | 5 | MOVLW | 132 | | - | | MOVWF | 132 | | E | | NOP | | | EEADR Register | 103 | RETFIE | | | EECON1 Register | 104 | RETLW | | | EECON2 Register | | RETURN | | | EEDAT Register | 103 | RLF | | | EEPROM Data Memory | | Summary Table | | | Avoiding Spurious Write | 105 | INTCON Register | | | Reading | | Internal Oscillator Block | 17 | | Write Verify | | | | | Writing | | INTOSC | 451 | | Effects of Reset | | Specifications | | | A/D module | 80 | Internal Sampling Switch (Rss) Impedance | | | | | Internet Address | | | Comparator module | | Interrupts | | | OPA module | | (CCP) Compare | | | PWM mode | | A/D | | | Electrical Specifications | | Associated Registers | | | Errata | 4 | Comparator | 69 | | F | | Context Saving | 120 | | | | Data EEPROM Memory Write | 104 | | Fail-Safe Clock Monitor | | Interrupt-on-Change | 37 | | Fail-Safe Condition Clearing | | Oscillator Fail (OSF) | 31 | | Reset and Wake-up from Sleep | | PORTA Interrupt-on-change | | | Firmware Instructions | 127 | RA2/INT | | | Fuses. See Configuration Bits | | TMR0 | | | G | | TMR1 | | | G | | TMR2 to PR2 Match | _ | | General Purpose Register File | 9 | INTOSC Specifications | | | 1 | | IOCA (Interrupt-on-Change) | | | 1 | | | | | ID Locations | 124 | IOCA Register | 31 | | In-Circuit Debugger | 125 | L | | | In-Circuit Serial Programming (ICSP) | | Load Conditions | 451 | | Indirect Addressing, INDF and FSR Registers | | LUAU CUTUIUUTS | 100 | #### THE MICROCHIP WEB SITE Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information: - Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software - General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing - Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives # CUSTOMER CHANGE NOTIFICATION SERVICE Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest. To register, access the Microchip web site at www.microchip.com, click on Customer Change Notification and follow the registration instructions. #### CUSTOMER SUPPORT Users of Microchip products can receive assistance through several channels: - · Distributor or Representative - · Local Sales Office - Field Application Engineer (FAE) - · Technical Support - Development Systems Information Line Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document. Technical support is available through the web site at: http://support.microchip.com ### PRODUCT IDENTIFICATION SYSTEM To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office. | PART NO.<br>Device | X /XX XXX<br> <br>Temperature Package Pattern<br>Range | Examples: a) PIC16F785 - E/SO 301 = Extended temp., SOIC package. b) PIC16F785 - I/ML = Industrial temp., QFN package. | |-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------| | Device: | PIC16F785 <sup>(1)</sup> , PIC16HV785 <sup>(1)</sup> , PIC16F785T <sup>(2)</sup> , PIC16HV785T <sup>(2)</sup> ; VDD range 4.2V to 5.5V PIC16F785 <sup>(1)</sup> , PIC16HV785 <sup>(1)</sup> , PIC16F785T <sup>(2)</sup> , PIC16HV785T <sup>(2)</sup> ; VDD range 2.0V to 5.5V | | | Temperature<br>Range: | I = -40°C to +85°C Industrial)<br>E = -40°C to +125°C Extended) | | | Package: | ML = QFN<br>P = PDIP<br>SO = SOIC<br>SS = SSOP | Note 1: F = Standard Voltage Range LF = Wide Voltage Range | | Pattern: | QTP, SQTP, Code or Special Requirements (blank otherwise) | 2: T = in tape and reel PLCC, and TQFP packages only. |