### Through-Hole or Surface Mount #### **Features** - Surface and through-hole mounting types. - 1 Form C contact arrangement. - · Latching or non-latching versions available. - · Switches loads from dry circuit to 1 amp. - Washable meets IEC protection class IP67 - · Low coil power requirement for IC compatibility. - Terminals arranged on 0.1" grid. - Designed for compact, high density mounting, 106.6mm<sup>2</sup> surface area. - · Getter protected contact area. - · Ideal for data and communication systems. #### Contact Data @ 25°C Arrangements: 1 Form C (SPDT). Material & Style: Palladium-Nickel with Gold-Rhodium overlay, bifurcated. Expected Mechanical Life: 1 billion operations. Expected Electrical Life:50 million ops. at 100mA, 6VDC, res., 10 ops./sec.; 3 million ops. at 1A, 24VDC, res., 6 ops./min.; 500,000 ops. at 500mA, 100VDC, res., 6 ops./min.; 250,000 ops. at 400mA, 125VAC, res., 6 ops./min. Contact Ratings: Maximum Switched Voltage: 150VDC, 125VAC. Maximum Switched Current: 1A. Maximum Carrying Current: 1A. Maximum Switched Power: 30W (DC), 60VA (AC). Note: Max. switched power is voltage dependent. See Figure 1. Minimum Switched Capability: 100μV. Initial Contact Resistance: 50 milliohms max. @ 10mA, 6VDC. #### Figure 1 - Limiting Curve for Contact Loads = Recommended Field of Application #### Initial Dielectric Strength Between Open Contacts: 500V rms. Note: FCC version meets 1,500V surge per FCC Part 68. Consult factory regarding availability (10/160µs). Between Contacts and Coil: 1,500V rms. #### **Initial Insulation Resistance** **Between Mutually Insulated Conductors:** 10<sup>9</sup> ohms @ 500VDC. #### Coil Data @ 20°C Voltage: 1.5 to 24VDC. Thermal Resistance at Continuous Thermal Load: 130°K per Watt. Maximum Coil Temperature: 85°C Duty Cycle: Continuous. ## V23026 series # Miniature, Sealed PC Board Relay **FII** File E48393 **®** File LR45064-5 **■** CECC approved in accordance with CECC 16501-002/VDE400.74/04.90 (Through-hole version) #### Coil Data @ 20°C | Nominal<br>Voltage<br>(VDC) | Maximum<br>Operating<br>Voltage (VDC) | Operating Power | | Coil Number<br>Order Designation<br>(Step 4 in Ordering<br>Information chart) | | | | | | | |-------------------------------------------|---------------------------------------|-----------------|--------------------------------------|-------------------------------------------------------------------------------|--|--|--|--|--|--| | Ion-Latching — Through-Hole versions (A1) | | | | | | | | | | | | 1.5 | 4.5 | 63 | 36 | 7 | | | | | | | | 3 | 8.8 | 66 | 137 | 6 | | | | | | | | 5 | 14.5 | 67 | 370 | 1 | | | | | | | | 9 | 25.5 | 69 | 1,165 | 5 | | | | | | | | 12 | 35 | 64 | 2,250 | 2 | | | | | | | | 15 | 42 | 72 | 3,100 | 3 | | | | | | | | 24 | 50 | 128 | 4,500 | 4 | | | | | | | | Non-Latchin | ıg — Surface-Mou | ınt versions ( | (D1) | | | | | | | | | 1.5 | 4 | 80 | 28 | 7 | | | | | | | | 3 | 8 | 80 | 113 | 6 | | | | | | | | 5 | 13.3 | 80 | 313 | 1 | | | | | | | | 9 | 24 | 80 | 1,013 | 5 | | | | | | | | 12 | 32 | 80 | 1,800 | 2 | | | | | | | | 15 | 40 | 80 | 2,813 | 3 | | | | | | | | 24 | 50 | 128 | 4,500 | 4 | | | | | | | | Bistable, Du | al Coils — Throug | | Surface-Mount vene for each coil)(1) | | | | | | | | | | | | | | | | | | | | | 1.5 | 4.25 | 70 | 32 | 7 | | | | | | | | 3 | 8.55 | 69 | 130 | 6 | | | | | | | | 5 | 14.75 | 64 | 390 | 1 | | | | | | | | 9 | 14.75 | 68 | 1,200 | 5 | | | | | | | | 12 | 29 | 96 | 1,500 | 2 | | | | | | | | 15 | 29 | 150 | 1,500 | 3 | | | | | | | | Bistable, Sir | ngle Coil — Throu | gh-Hole and | Surface-Mount v | ersions (C1,F1) | | | | | | | | 1.5 | 6 | 37 | 61 | 5 | | | | | | | | 3 | 13 | 30 | 300 | 6 | | | | | | | | 5 | 20 | 34 | 740 | 1 | | | | | | | | 9 | 35 | 38 | 2,160 | 7 | | | | | | | | 12 | 50 | 32 | 4,500 | 2 | | | | | | | | 15 | 50 | 50 | 4,500 | 3 | | | | | | | | 24 | 50 | 128 | 4,500 | 4 | | | | | | | <sup>(1)</sup> The specified voltages apply with only one coil energized. #### Operate Data @ 20°C Must Operate Voltage: 75% of nominal voltage or less. Must Release Voltage: 10% of nominal voltage or less. Max. Continuous Thermal Load: 500mW. Operate Time (Excluding Bounce)†: 1 ms, typ. Operate Bounce Time†: 1 ms, typ. Release Time (Excluding Bounce)†: 0.4 ms, typ. Set Time (Latching)†: 1 ms, typ. Reset Time (Latching) 1: 0.9 ms, typ. Maximum Switching Rate: 200 operations/second † At or from Nominal Coil Voltage #### **Environmental Data** Temperature Range: -40°C to +70°C. Vibration, Operational: 40g, 10-200 Hz. **Shock, Operational:** 50g at 11 ms 1/2 sinusoidal impulse. Surface Mount Version Only: Vapor Phase: 215°C, 40 sec. Infrared: 215°C, 40 sec. Double Wave: 260°C, 10 sec. #### Mechanical Data **Termination:** Through-hole or surface mount printed circuit terminals. **Enclosure Type:** Immersion cleanable, plastic sealed case. Weight: 0.063 oz. (1.8g) approximately. #### Ordering Information Typical Part Number ▶ V23026 **A1** 00 2 **B201** #### 1. Basic Series: V23026 = Miniature, printed circuit board relay #### Termination: | | | Non-Latching | Dual Coil Latching | Single Coil Latching | | | | | |---|-----------------------------------------------------------------------------------------------|--------------|--------------------|----------------------|--|--|--|--| | | Through-Hole | A1 | B1 | C1 | | | | | | | Surface Mount D1 E1 F1 | | | | | | | | | C | Consult factory regarding availability of models meeting FCC Part 68/1500V surge requirement. | | | | | | | | 3. Function Type: 00 = Single Coil Non-Latching, Through-Hole terminals 05 = Single Coil Latching 02 = Single Coil Non-Latching, Surface-Mount terminals 10 = Dual Coil Latching 4. Coil Voltage: $7 = 1.5 \text{VDC}^{(1)}$ 6 = 3VDC1 = 5VDC $5 = 9VDC^{(1)}$ 2 = 12VDC 3 = 15VDC4 = 24VDC(2)(1) For single coil latching versions only (C1, F1), 5 = 1.5VDC and 7 = 9VDC (2) 24V coil not available on dual coil version 5. Contact Type: B201 = Bifurcated, 1 Form C (SPDT). #### Stock Items - Recommended part numbers are for new designs. V23026D1021B201 V23026A1001B201 V23026A1002B201 V23026D1022B201 V23026A1004B201 V23026D1024B201 #### **Outline Dimensions** #### Through-Hole #### **Surface Mount** #### Wiring Diagrams (Bottom Views) Single Coil Non-Latching & Single Coil Latching For non-latching versions, coil polarity must be observed. For single coil latching versions, polarity shown results in "set" condition. Reverse polarity results in "reset" condition. Diagram indicates de-energized position for non-latching and "reset" position for single coil latching. #### **Dual Coil Latching** Diagram indicates relay in the "reset" position, with "reset" coil most recently energized as shown. Energizing "set" coil as shown will transfer the contacts. #### PC Board Layouts (Bottom Views) #### Through-Hole Tyco Electronics Corporation - P&B, Winston-Salem, NC 27102 Technical Support Center: 1-800-522-6752, www.pandbrelays.com ### **Surface Mount** <sup>\*</sup>Consult factory for tape and reel packaging ### 2N7000 / 2N7002 / NDS7002A N-Channel Enhancement Mode Field Effect Transistor ### **General Description** These N-Channel enhancement mode field effect transistors are produced using Fairchild's proprietary, high cell density, DMOS technology. These products have been designed to minimize on-state resistance while provide rugged, reliable, and fast switching performance. They can be used in most applications requiring up to 400mA DC and can deliver pulsed currents up to 2A. These products are particularly suited for low voltage, low current applications such as small servo motor control, power MOSFET gate drivers, and other switching applications. #### **Features** - High density cell design for low R<sub>DS(ON)</sub>. - Voltage controlled small signal switch. - Rugged and reliable. - High saturation current capability. 2N7002/NDS7002A Absolute Maximum Ratings T = 25°C unless otherwise noted | Symbol | Parameter | 2N7000 | 2N7002 | NDS7002A | Units | |------------------|------------------------------------------------------------------------------------|-----------------------|--------|----------|-------| | V <sub>DSS</sub> | Drain-Source Voltage | | 60 | • | V | | $V_{DGR}$ | Drain-Gate Voltage ( $R_{GS} \le 1 M\Omega$ ) | | 60 | | V | | $V_{GSS}$ | Gate-Source Voltage - Continuous | | ±20 | | V | | | - Non Repetitive (tp < 50μs) | | ±40 | | | | I <sub>D</sub> | Maximum Drain Current - Continuous | 200 | 115 | 280 | mA | | | - Pulsed | 500 | 800 | 1500 | | | P <sub>D</sub> | Maximum Power Dissipation | 400 | 200 | 300 | mW | | | Derated above 25°C | 3.2 | 1.6 | 2.4 | mW/°C | | $T_J,T_STG$ | Operating and Storage Temperature Range | -55 to 150 -65 to 150 | | | °C | | T <sub>L</sub> | Maximum Lead Temperature for Soldering<br>Purposes, 1/16" from Case for 10 Seconds | 300 | | | °C | | THERMA | L CHARACTERISTICS | | | | | | R <sub>θJA</sub> | Thermal Resistance, Junction-to-Ambient | 312.5 | 625 | 417 | °C/W | | Symbol | Parameter | Conditions | Type | Min | Тур | Max | Units | | |---------------------|-----------------------------------|-------------------------------------------------|-----------------------|--------------------|------|------|-------|----| | OFF CHA | RACTERISTICS | | | | | | | | | BV <sub>DSS</sub> | Drain-Source Breakdown Voltage | $V_{GS} = 0 \text{ V}, I_{D} = 10 \mu\text{A}$ | | All | 60 | | | V | | I <sub>DSS</sub> | Zero Gate Voltage Drain Current | $V_{DS} = 48 \text{ V}, V_{GS} = 0 \text{ V}$ | | 2N7000 | | | 1 | μΑ | | | | | T <sub>J</sub> =125°C | | | | 1 | mA | | | | $V_{DS} = 60 \text{ V}, V_{GS} = 0 \text{ V}$ | | 2N7002 | | | 1 | μΑ | | | | | T <sub>J</sub> =125°C | NDS7002A | | | 0.5 | mA | | GSSF | Gate - Body Leakage, Forward | $V_{GS} = 15 \text{ V}, V_{DS} = 0 \text{ V}$ | | 2N7000 | | | 10 | nA | | | | $V_{GS} = 20 \text{ V}, V_{DS} = 0 \text{ V}$ | | 2N7002<br>NDS7002A | | | 100 | nA | | GSSR | Gate - Body Leakage, Reverse | $V_{GS} = -15 \text{ V}, V_{DS} = 0 \text{ V}$ | | 2N7000 | | | -10 | nA | | | | $V_{GS} = -20 \text{ V}, V_{DS} = 0 \text{ V}$ | | 2N7002<br>NDS7002A | | | -100 | nA | | ON CHAF | RACTERISTICS (Note 1) | | | | | | | | | $I_{\rm GS(th)}$ | Gate Threshold Voltage | $V_{DS} = V_{GS}$ , $I_D = 1 \text{ mA}$ | | 2N7000 | 0.8 | 2.1 | 3 | V | | | | $V_{DS} = V_{GS}, I_{D} = 250 \mu A$ | | 2N7002<br>NDS7002A | 1 | 2.1 | 2.5 | | | R <sub>DS(ON)</sub> | Static Drain-Source On-Resistance | $V_{GS} = 10 \text{ V}, I_{D} = 500 \text{ mA}$ | | 2N7000 | | 1.2 | 5 | Ω | | | | | T <sub>J</sub> =125°C | | | 1.9 | 9 | | | | | $V_{GS} = 4.5 \text{ V}, I_{D} = 75 \text{ mA}$ | | | | 1.8 | 5.3 | | | | | $V_{GS} = 10 \text{ V}, I_{D} = 500 \text{ mA}$ | | 2N7002 | | 1.2 | 7.5 | | | | | | T <sub>J</sub> =100°C | | | 1.7 | 13.5 | | | | | $V_{GS} = 5.0 \text{ V}, I_{D} = 50 \text{ mA}$ | | | | 1.7 | 7.5 | | | | | | T <sub>J</sub> =100C | | | 2.4 | 13.5 | | | | | $V_{GS} = 10 \text{ V}, I_{D} = 500 \text{ mA}$ | | NDS7002A | | 1.2 | 2 | | | | | | T <sub>J</sub> =125°C | | | 2 | 3.5 | | | | | $V_{GS} = 5.0 \text{ V}, I_{D} = 50 \text{ mA}$ | | | | 1.7 | 3 | | | | | | T <sub>J</sub> =125°C | | | 2.8 | 5 | | | / <sub>DS(ON)</sub> | Drain-Source On-Voltage | $V_{GS} = 10 \text{ V}, I_{D} = 500 \text{ mA}$ | | 2N7000 | | 0.6 | 2.5 | V | | | | $V_{GS} = 4.5 \text{ V}, I_{D} = 75 \text{ mA}$ | | | 0.14 | 0.4 | | | | | | $V_{GS} = 10 \text{ V}, I_{D} = 500 \text{mA}$ | 2N7002 | | 0.6 | 3.75 | | | | | | $V_{GS} = 5.0 \text{ V}, I_{D} = 50 \text{ mA}$ | | | 0.09 | 1.5 | | | | | | $V_{GS} = 10 \text{ V}, I_{D} = 500 \text{mA}$ | | NDS7002A | | 0.6 | 1 | | | | | $V_{GS} = 5.0 \text{ V}, I_{D} = 50 \text{ mA}$ | | | | 0.09 | 0.15 | 1 | | Symbol | Parameter | Conditions | Туре | Min | Тур | Max | Units | |--------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----|------|-----|-------| | ON CHAP | RACTERISTICS Continued (Note 1) | • | | | | | | | I <sub>D(ON)</sub> | On-State Drain Current | $V_{GS} = 4.5 \text{ V}, \ V_{DS} = 10 \text{ V}$ | 2N7000 | 75 | 600 | | mA | | | | $V_{GS} = 10 \text{ V}, V_{DS} \ge 2 V_{DS(on)}$ | 2N7002 | 500 | 2700 | | | | | | $V_{GS} = 10 \text{ V}, V_{DS} \ge 2 V_{DS(on)}$ | NDS7002A | 500 | 2700 | | | | g <sub>FS</sub> | Forward Transconductance | V <sub>DS</sub> = 10 V, I <sub>D</sub> = 200 mA | 2N7000 | 100 | 320 | | mS | | | | $V_{DS} \ge 2 V_{DS(on)}, I_D = 200 \text{ mA}$ | 2N7002 | 80 | 320 | | | | | | $V_{DS} \ge 2 V_{DS(on)}$ , $I_D = 200 \text{ mA}$ | NDS7002A | 80 | 320 | | | | DYNAMIC | CHARACTERISTICS | | | | | | | | C <sub>iss</sub> | Input Capacitance | $V_{DS} = 25 \text{ V}, \ V_{GS} = 0 \text{ V}, $ f = 1.0 MHz | All | | 20 | 50 | pF | | C <sub>oss</sub> | Output Capacitance | f = 1.0 MHz | All | | 11 | 25 | pF | | C <sub>rss</sub> | Reverse Transfer Capacitance | | All | | 4 | 5 | pF | | t <sub>on</sub> | Turn-On Time | $V_{DD} = 15 \text{ V}, R_{L} = 25 \Omega,$<br>$I_{D} = 500 \text{ mA}, V_{GS} = 10 \text{ V},$<br>$R_{GEN} = 25$ | 2N7000 | | | 10 | ns | | | | $\begin{split} &V_{DD} = 30 \; V, \; R_{L} = 150 \; \Omega, \\ &I_{D} = 200 \; mA, \; V_{GS} = 10 \; V, \\ &R_{GEN} = 25 \; \Omega \end{split}$ | 2N700<br>NDS7002A | | | 20 | | | t <sub>off</sub> | Turn-Off Time | $V_{DD} = 15 \text{ V}, R_{L} = 25 \Omega,$<br>$I_{D} = 500 \text{ mA}, V_{GS} = 10 \text{ V},$<br>$R_{GEN} = 25$ | 2N7000 | | | 10 | ns | | | | $\begin{split} &V_{\text{DD}} = 30 \text{ V}, \text{ R}_{\text{L}} = 150 \Omega, \\ &I_{\text{D}} = 200 \text{ mA}, V_{\text{GS}} = 10 \text{ V}, \\ &R_{\text{GEN}} = 25 \Omega \end{split}$ | 2N700<br>NDS7002A | | | 20 | | | DRAIN-S | OURCE DIODE CHARACTERISTICS | S AND MAXIMUM RATINGS | | | | | | | I <sub>s</sub> | Maximum Continuous Drain-Sour | ce Diode Forward Current | 2N7002 | | | 115 | mA | | | | | NDS7002A | | | 280 | | | I <sub>SM</sub> | Maximum Pulsed Drain-Source D | iode Forward Current | 2N7002 | | | 0.8 | Α | | | | | NDS7002A | | | 1.5 | | | V <sub>SD</sub> | Drain-Source Diode Forward | V <sub>GS</sub> = 0 V, I <sub>S</sub> = 115 mA (Note 1) | 2N7002 | | 0.88 | 1.5 | V | | | Voltage | V <sub>GS</sub> = 0 V, I <sub>S</sub> = 400 mA (Note 1) | NDS7002A | | 0.88 | 1.2 | ] | Note: 1. Pulse Test: Pulse Width ≤ 300µs, Duty Cycle ≤ 2.0%. #### **Typical Electrical Characteristics** #### 2N7000 / 2N7002 / NDS7002A Figure 1. On-Region Characteristics Figure 2. On-Resistance Variation with Gate Voltage and Drain Current Figure 3. On-Resistance Variation with Temperature Figure 4. On-Resistance Variation with Drain Current and Temperature Figure 5. Transfer Characteristics Figure 6. Gate Threshold Variation with Temperature #### **Typical Electrical Characteristics (continued)** #### 2N7000 / 2N7002 /NDS7002A Figure 7. Breakdown Voltage Variation with Temperature Figure 8. Body Diode Forward Voltage Variation with Figure 9. Capacitance Characteristics Figure 10. Gate Charge Characteristics Figure 11. Figure 12. Switching Waveforms #### **TRADEMARKS** The following are registered and unregistered trademarks Fairchild Semiconductor owns or is authorized to use and is not intended to be an exhaustive list of all such trademarks. $ACEx^{TM}$ FASTr™ PowerTrench® SyncFET™ Bottomless™ QFET™ TinyLogic™ GlobalOptoisolator™ QSTM UHC™ CoolFET™ GTO™ **VCX**<sup>TM</sup> $CROSSVOLT^{TM}$ QT Optoelectronics™ HiSeC™ DOME™ ISOPLANAR™ Quiet Series™ #### **DISCLAIMER** FAIRCHILD SEMICONDUCTOR RESERVES THE RIGHT TO MAKE CHANGES WITHOUT FURTHER NOTICE TO ANY PRODUCTS HEREIN TO IMPROVE RELIABILITY, FUNCTION OR DESIGN. FAIRCHILD DOES NOT ASSUME ANY LIABILITY ARISING OUT OF THE APPLICATION OR USE OF ANY PRODUCT OR CIRCUIT DESCRIBED HEREIN; NEITHER DOES IT CONVEY ANY LICENSE UNDER ITS PATENT RIGHTS, NOR THE RIGHTS OF OTHERS. #### LIFE SUPPORT POLICY FAIRCHILD'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF FAIRCHILD SEMICONDUCTOR CORPORATION. As used herein: - 1. Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, or (c) whose failure to perform when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in significant injury to the user. - 2. A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness. #### PRODUCT STATUS DEFINITIONS #### **Definition of Terms** | Datasheet Identification | Product Status | Definition | |--------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Advance Information | Formative or<br>In Design | This datasheet contains the design specifications for product development. Specifications may change in any manner without notice. | | Preliminary | First Production | This datasheet contains preliminary data, and supplementary data will be published at a later date. Fairchild Semiconductor reserves the right to make changes at any time without notice in order to improve design. | | No Identification Needed | Full Production | This datasheet contains final specifications. Fairchild Semiconductor reserves the right to make changes at any time without notice in order to improve design. | | Obsolete | Not In Production | This datasheet contains specifications on a product that has been discontinued by Fairchild semiconductor. The datasheet is printed for reference information only. | ### 4301H1/5 Series Solid State LED Lamps-High Brite Bi-Color T-1 3/4 (5mm) ### DESCRIPTION AND FEATURES #### T-1 3/4 Dual Color LED - •Provides red and green in the same two lead packages. - •Chips are brightness matched-green and red light is uniform. #### ELECTRO-OPTICAL CHARACTERISTICS AND RATINGS | PART NUMBER | 4301H1/5 | |----------------------------------------|-----------| | Output Color | Red/Green | | Diffusion | Diffused | | Package Color | Clear | | Rated Current (mA) | 10 | | Forward Voltage Typ. (V) | 2.2 | | Forward Voltage Max. (V) | 2.8 | | Luminous Intensity Min. (mcd) | 3 | | Luminous Intensity Typ. (mcd) | 6 | | Luminous Intensity Max. (mcd) | - | | Peak Wavelength (nm) | 650/568 | | Viewing Angle 20 1/2 (degrees) | 50 | | Power Dissipation (mW) | 115 | | Continuous Forward Current Max. (mA) | 25 | | Peak Forward Current @ 1ms-300 PPS (A) | .06 | | Reverse Breakdown Voltage Min. (V) | - | # PIC16F87X Data Sheet 28/40-Pin 8-Bit CMOS FLASH Microcontrollers "All rights reserved. Copyright © 2001, Microchip Technology Incorporated, USA. Information contained in this publication regarding device applications and the like is intended through suggestion only and may be superseded by updates. No representation or warranty is given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infringement of patents or other intellectual property rights arising from such use or otherwise. Use of Microchip's products as critical components in life support systems is not authorized except with express written approval by Microchip. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights. The Microchip logo and name are registered trademarks of Microchip Technology Inc. in the U.S.A. and other countries. All rights reserved. All other trademarks mentioned herein are the property of their respective companies. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights." #### **Trademarks** The Microchip name, logo, PIC, PICmicro, PICMASTER, PIC-START, PRO MATE, KEELOQ, SEEVAL, MPLAB and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. Total Endurance, ICSP, In-Circuit Serial Programming, Filter-Lab, MXDEV, microID, FlexROM, fuzzyLAB, MPASM, MPLINK, MPLIB, PICDEM, ICEPIC, Migratable Memory, FanSense, ECONOMONITOR and SelectMode are trademarks of Microchip Technology Incorporated in the U.S.A. Serialized Quick Term Programming (SQTP) is a service mark of Microchip Technology Incorporated in the U.S.A. All other trademarks mentioned herein are property of their respective companies. © 2001, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved. Microchip received QS-9000 quality system certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona in July 1999. The Company's quality system processes and procedures are QS-9000 compliant for its PICmicro® 8-bit MCUs, KEELO© code hopping devices, Serial EEPROMs and microperipheral products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001 certified. ### 28/40-Pin 8-Bit CMOS FLASH Microcontrollers #### Devices Included in this Data Sheet: - PIC16F873 - PIC16F876 - PIC16F874 - PIC16F877 #### Microcontroller Core Features: - · High performance RISC CPU - Only 35 single word instructions to learn - All single cycle instructions except for program branches which are two cycle - Operating speed: DC 20 MHz clock input DC - 200 ns instruction cycle - Up to 8K x 14 words of FLASH Program Memory, Up to 368 x 8 bytes of Data Memory (RAM) Up to 256 x 8 bytes of EEPROM Data Memory - Pinout compatible to the PIC16C73B/74B/76/77 - · Interrupt capability (up to 14 sources) - · Eight level deep hardware stack - · Direct, indirect and relative addressing modes - Power-on Reset (POR) - Power-up Timer (PWRT) and Oscillator Start-up Timer (OST) - Watchdog Timer (WDT) with its own on-chip RC oscillator for reliable operation - Programmable code protection - · Power saving SLEEP mode - · Selectable oscillator options - Low power, high speed CMOS FLASH/EEPROM technology - Fully static design - In-Circuit Serial Programming™ (ICSP) via two pins - Single 5V In-Circuit Serial Programming capability - In-Circuit Debugging via two pins - Processor read/write access to program memory - Wide operating voltage range: 2.0V to 5.5V - · High Sink/Source Current: 25 mA - Commercial, Industrial and Extended temperature ranges - Low-power consumption: - < 0.6 mA typical @ 3V, 4 MHz</li> - 20 μA typical @ 3V, 32 kHz - < 1 μA typical standby current ### Pin Diagram #### **Peripheral Features:** - Timer0: 8-bit timer/counter with 8-bit prescaler - Timer1: 16-bit timer/counter with prescaler, can be incremented during SLEEP via external crystal/clock - Timer2: 8-bit timer/counter with 8-bit period register, prescaler and postscaler - · Two Capture, Compare, PWM modules - Capture is 16-bit, max. resolution is 12.5 ns - Compare is 16-bit, max. resolution is 200 ns - PWM max. resolution is 10-bit - 10-bit multi-channel Analog-to-Digital converter - Synchronous Serial Port (SSP) with SPI<sup>™</sup> (Master mode) and I<sup>2</sup>C<sup>™</sup> (Master/Slave) - Universal Synchronous Asynchronous Receiver Transmitter (USART/SCI) with 9-bit address detection - Parallel Slave Port (PSP) 8-bits wide, with external RD, WR and CS controls (40/44-pin only) - Brown-out detection circuitry for Brown-out Reset (BOR) #### **Pin Diagrams** | Key Features<br>PICmicro™ Mid-Range Reference<br>Manual (DS33023) | PIC16F873 | PIC16F874 | PIC16F876 | PIC16F877 | |-------------------------------------------------------------------|-------------------------|-------------------------|-------------------------|-------------------------| | Operating Frequency | DC - 20 MHz | DC - 20 MHz | DC - 20 MHz | DC - 20 MHz | | RESETS (and Delays) | POR, BOR<br>(PWRT, OST) | POR, BOR<br>(PWRT, OST) | POR, BOR<br>(PWRT, OST) | POR, BOR<br>(PWRT, OST) | | FLASH Program Memory<br>(14-bit words) | 4K | 4K | 8K | 8K | | Data Memory (bytes) | 192 | 192 | 368 | 368 | | EEPROM Data Memory | 128 | 128 | 256 | 256 | | Interrupts | 13 | 14 | 13 | 14 | | I/O Ports | Ports A,B,C | Ports A,B,C,D,E | Ports A,B,C | Ports A,B,C,D,E | | Timers | 3 | 3 | 3 | 3 | | Capture/Compare/PWM Modules | 2 | 2 | 2 | 2 | | Serial Communications | MSSP, USART | MSSP, USART | MSSP, USART | MSSP, USART | | Parallel Communications | _ | PSP | _ | PSP | | 10-bit Analog-to-Digital Module | 5 input channels | 8 input channels | 5 input channels | 8 input channels | | Instruction Set | 35 instructions | 35 instructions | 35 instructions | 35 instructions | #### **Table of Contents** | 1.0 | Device Overview | 5 | |-------|-----------------------------------------------------------------------------|-----| | 2.0 | Memory Organization | 11 | | 3.0 | I/O Ports | | | 4.0 | Data EEPROM and FLASH Program Memory | 41 | | 5.0 | Timer0 Module | | | 6.0 | Timer1 Module | 51 | | 7.0 | Timer2 Module | 55 | | 8.0 | Capture/Compare/PWM Modules | 57 | | 9.0 | Master Synchronous Serial Port (MSSP) Module | | | 10.0 | Addressable Universal Synchronous Asynchronous Receiver Transmitter (USART) | 95 | | 11.0 | Analog-to-Digital Converter (A/D) Module | 111 | | 12.0 | Special Features of the CPU | 119 | | 13.0 | Instruction Set Summary | 135 | | | Development Support | | | | Electrical Characteristics | | | | DC and AC Characteristics Graphs and Tables | | | 17.0 | Packaging Information | 189 | | Appe | endix A: Revision History | 197 | | Appe | endix B: Device Differences | 197 | | Appe | endix C: Conversion Considerations | 198 | | Index | Х | 199 | | On-L | Line Support | 207 | | Read | der Response | 208 | | PIC1 | 16F87X Product Identification System | 200 | #### TO OUR VALUED CUSTOMERS It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced. If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@mail.microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback. #### **Most Current Data Sheet** To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at: http://www.microchip.com You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000). #### **Errata** An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies. To determine if an errata sheet exists for a particular device, please check with one of the following: - Microchip's Worldwide Web site; http://www.microchip.com - · Your local Microchip sales office (see last page) - The Microchip Corporate Literature Center; U.S. FAX: (480) 792-7277 When contacting a sales office or the literature center, please specify which device, revision of silicon and data sheet (include literature number) you are using. #### **Customer Notification System** Register on our web site at www.microchip.com/cn to receive the most current information on all of our products. #### 1.0 DEVICE OVERVIEW This document contains device specific information. Additional information may be found in the PICmicro™ Mid-Range Reference Manual (DS33023), which may be obtained from your local Microchip Sales Representative or downloaded from the Microchip website. The Reference Manual should be considered a complementary document to this data sheet, and is highly recommended reading for a better understanding of the device architecture and operation of the peripheral modules. There are four devices (PIC16F873, PIC16F874, PIC16F876 and PIC16F877) covered by this data sheet. The PIC16F876/873 devices come in 28-pin packages and the PIC16F877/874 devices come in 40-pin packages. The Parallel Slave Port is not implemented on the 28-pin devices. The following device block diagrams are sorted by pin number; 28-pin for Figure 1-1 and 40-pin for Figure 1-2. The 28-pin and 40-pin pinouts are listed in Table 1-1 and Table 1-2, respectively. FIGURE 1-1: PIC16F873 AND PIC16F876 BLOCK DIAGRAM FIGURE 1-2: PIC16F874 AND PIC16F877 BLOCK DIAGRAM TABLE 1-1: PIC16F873 AND PIC16F876 PINOUT DESCRIPTION | Pin Name | DIP<br>Pin# | SOIC<br>Pin# | I/O/P<br>Type | Buffer<br>Type | Description | |-----------------|-------------|--------------|---------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OSC1/CLKIN | 9 | 9 | I | ST/CMOS <sup>(3)</sup> | Oscillator crystal input/external clock source input. | | OSC2/CLKOUT | 10 | 10 | 0 | _ | Oscillator crystal output. Connects to crystal or resonator in crystal oscillator mode. In RC mode, the OSC2 pin outputs CLKOUT which has 1/4 the frequency of OSC1, and denotes the instruction cycle rate. | | MCLR/VPP | 1 | 1 | 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 | 2 | 2 | I/O | TTL | RA0 can also be analog input0. | | RA1/AN1 | 3 | 3 | I/O | TTL | RA1 can also be analog input1. | | RA2/AN2/VREF- | 4 | 4 | I/O | TTL | RA2 can also be analog input2 or negative analog reference voltage. | | RA3/AN3/VREF+ | 5 | 5 | I/O | TTL | RA3 can also be analog input3 or positive analog reference voltage. | | RA4/T0CKI | 6 | 6 | I/O | ST | RA4 can also be the clock input to the Timer0 module. Output is open drain type. | | RA5/SS/AN4 | 7 | 7 | I/O | TTL | RA5 can also be analog input4 or the slave select for the synchronous serial port. | | | | | | | PORTB is a bi-directional I/O port. PORTB can be software | | | | | | (4) | programmed for internal weak pull-up on all inputs. | | RB0/INT | 21 | 21 | I/O | TTL/ST <sup>(1)</sup> | RB0 can also be the external interrupt pin. | | RB1 | 22 | 22 | I/O | TTL | | | RB2 | 23 | 23 | I/O | TTL | | | RB3/PGM | 24 | 24 | I/O | TTL | RB3 can also be the low voltage programming input. | | RB4 | 25 | 25 | I/O | TTL | Interrupt-on-change pin. | | RB5 | 26 | 26 | I/O | TTL | Interrupt-on-change pin. | | RB6/PGC | 27 | 27 | I/O | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin or In-Circuit Debugger pin. Serial programming clock. | | RB7/PGD | 28 | 28 | I/O | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin or In-Circuit Debugger pin. Serial programming data. | | | | | | | PORTC is a bi-directional I/O port. | | RC0/T1OSO/T1CKI | 11 | 11 | I/O | ST | RC0 can also be the Timer1 oscillator output or Timer1 clock input. | | RC1/T1OSI/CCP2 | 12 | 12 | I/O | ST | RC1 can also be the Timer1 oscillator input or Capture2 input/Compare2 output/PWM2 output. | | RC2/CCP1 | 13 | 13 | I/O | ST | RC2 can also be the Capture1 input/Compare1 output/<br>PWM1 output. | | RC3/SCK/SCL | 14 | 14 | I/O | ST | RC3 can also be the synchronous serial clock input/output for both SPI and I <sup>2</sup> C modes. | | RC4/SDI/SDA | 15 | 15 | I/O | ST | RC4 can also be the SPI Data In (SPI mode) or data I/O (I <sup>2</sup> C mode). | | RC5/SDO | 16 | 16 | I/O | ST | RC5 can also be the SPI Data Out (SPI mode). | | RC6/TX/CK | 17 | 17 | I/O | ST | RC6 can also be the USART Asynchronous Transmit or Synchronous Clock. | | RC7/RX/DT | 18 | 18 | I/O | ST | RC7 can also be the USART Asynchronous Receive or Synchronous Data. | | Vss | 8, 19 | 8, 19 | Р | _ | Ground reference for logic and I/O pins. | | VDD | 20 | 20 | Р | _ | Positive supply for logic and I/O pins. | $Legend: \quad I = input$ O = output I/O = input/output P = power — = Not used TTL = TTL input 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. - 3: This buffer is a Schmitt Trigger input when configured in RC oscillator mode and a CMOS input otherwise. PIC16F874 AND PIC16F877 PINOUT DESCRIPTION **TABLE 1-2:** | Pin Name | DIP<br>Pin# | PLCC<br>Pin# | QFP<br>Pin# | I/O/P<br>Type | Buffer<br>Type | Description | |---------------|-------------|--------------|-------------|---------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OSC1/CLKIN | 13 | 14 | 30 | I | ST/CMOS <sup>(4)</sup> | Oscillator crystal input/external clock source input. | | OSC2/CLKOUT | 14 | 15 | 31 | 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 | 1 | 2 | 18 | 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 | 2 | 3 | 19 | I/O | TTL | RA0 can also be analog input0. | | RA1/AN1 | 3 | 4 | 20 | I/O | TTL | RA1 can also be analog input1. | | RA2/AN2/VREF- | 4 | 5 | 21 | I/O | TTL | RA2 can also be analog input2 or negative analog reference voltage. | | RA3/AN3/VREF+ | 5 | 6 | 22 | I/O | TTL | RA3 can also be analog input3 or positive analog reference voltage. | | RA4/T0CKI | 6 | 7 | 23 | I/O | ST | RA4 can also be the clock input to the Timer0 timer/ counter. Output is open drain type. | | RA5/SS/AN4 | 7 | 8 | 24 | I/O | TTL | RA5 can also be analog input4 or the slave select for the synchronous serial port. | | | | | | | | PORTB is a bi-directional I/O port. PORTB can be software programmed for internal weak pull-up on all inputs. | | RB0/INT | 33 | 36 | 8 | I/O | TTL/ST <sup>(1)</sup> | RB0 can also be the external interrupt pin. | | RB1 | 34 | 37 | 9 | I/O | TTL | | | RB2 | 35 | 38 | 10 | I/O | TTL | | | RB3/PGM | 36 | 39 | 11 | I/O | TTL | RB3 can also be the low voltage programming input. | | RB4 | 37 | 41 | 14 | I/O | TTL | Interrupt-on-change pin. | | RB5 | 38 | 42 | 15 | I/O | TTL | Interrupt-on-change pin. | | RB6/PGC | 39 | 43 | 16 | I/O | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin or In-Circuit Debugger pin.<br>Serial programming clock. | | RB7/PGD | 40 | 44 | 17 | I/O | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin or In-Circuit Debugger pin.<br>Serial programming data. | Legend: I = input O = output - = Not used I/O = input/output P = power TTL = TTL input ST = Schmitt Trigger input Note 1: This buffer is a Schmitt Trigger input when configured as an external interrupt. - 2: This buffer is a Schmitt Trigger input when used in Serial Programming mode. - 3: This buffer is a Schmitt Trigger input when configured as general purpose I/O and a TTL input when used in the Parallel Slave Port mode (for interfacing to a microprocessor bus). - 4: This buffer is a Schmitt Trigger input when configured in RC oscillator mode and a CMOS input otherwise. PIC16F874 AND PIC16F877 PINOUT DESCRIPTION (CONTINUED) **TABLE 1-2:** | RC0/T10S0/T1CK 15 | Pin Name | DIP<br>Pin# | PLCC<br>Pin# | QFP<br>Pin# | I/O/P<br>Type | Buffer<br>Type | Description | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|--------------|-------------|---------------|-----------------------|---------------------------------------------------------------------------------| | RC1/T10SI/CCP2 | | | | | | | PORTC is a bi-directional I/O port. | | RC2/CCP1 | RC0/T1OSO/T1CKI | 15 | 16 | 32 | I/O | ST | · | | RC3/SCK/SCL | RC1/T1OSI/CCP2 | 16 | 18 | 35 | I/O | ST | · | | RC4/SDI/SDA 23 25 42 I/O ST RC4 can also be the SPI Data In (SPI mode) or data I/O (I <sup>2</sup> C mode). RC5/SDO 24 26 43 I/O ST RC5 can also be the SPI Data Out (SPI mode). RC6/TX/CK 25 27 44 I/O ST RC6 can also be the SPI Data Out (SPI mode). RC6/TX/CK 25 27 44 I/O ST RC6 can also be the USART Asynchronous Transmit or Synchronous Clock. RC7/RX/DT 26 29 1 I/O ST RC7 can also be the USART Asynchronous Receive or Synchronous Data. PORTD is a bi-directional I/O port or parallel slave port when interfacing to a microprocessor bus. PORTD is a bi-directional I/O port or parallel slave port when interfacing to a microprocessor bus. RD3/PSP2 21 23 40 I/O ST/TTL(3) RD3/PSP3 22 24 41 I/O ST/TTL(3) RD4/PSP4 27 30 2 I/O ST/TTL(3) RD5/PSP5 28 31 3 I/O ST/TTL(3) RD5/PSP6 29 32 4 I/O ST/TTL(3) RD6/PSP6 29 32 4 I/O ST/TTL(3) RE0/RD/AN5 8 9 25 I/O ST/TTL(3) RE0 can also be read control for the parallel slave port, or analog input5. RE1 can also be write control for the parallel slave port, or analog input6. RE2/RD/AN7 10 11 27 I/O ST/TTL(3) RE2 can also be select control for the parallel slave port, or analog input7. RE2 can also be select control for the parallel slave port, or analog input7. RE2/RD/AN7 10 11 27 I/O ST/TTL(3) RE2 can also be select control for the parallel slave port, or analog input7. RE2/RD/AN7 RE2/R | RC2/CCP1 | 17 | 19 | 36 | I/O | ST | 1 ' ' ' | | RC5/SDO | RC3/SCK/SCL | 18 | 20 | 37 | I/O | ST | | | RC6/TX/CK 25 27 | RC4/SDI/SDA | 23 | 25 | 42 | I/O | ST | RC4 can also be the SPI Data In (SPI mode) or data I/O (I <sup>2</sup> C mode). | | RC7/RX/DT 26 29 | RC5/SDO | 24 | 26 | 43 | I/O | ST | RC5 can also be the SPI Data Out (SPI mode). | | RD0/PSP0 | RC6/TX/CK | 25 | 27 | 44 | I/O | ST | · · · · · · · · · · · · · · · · · · · | | RD0/PSP0 | RC7/RX/DT | 26 | 29 | 1 | I/O | ST | • | | RD1/PSP1 20 22 39 I/O ST/TTL(3) RD2/PSP2 21 23 40 I/O ST/TTL(3) RD3/PSP3 22 24 41 I/O ST/TTL(3) RD4/PSP4 27 30 2 I/O ST/TTL(3) RD5/PSP5 28 31 3 I/O ST/TTL(3) RD6/PSP6 29 32 4 I/O ST/TTL(3) RD7/PSP7 30 33 5 I/O ST/TTL(3) RE0/RD/AN5 8 9 25 I/O ST/TTL(3) RE0 can also be read control for the parallel slave port, or analog input5. RE1/WR/AN6 9 10 26 I/O ST/TTL(3) RE1 can also be write control for the parallel slave port, or analog input6. RE2/CS/AN7 10 11 27 I/O ST/TTL(3) RE2 can also be select control for the parallel slave port, or analog input7. Vss 12,31 13,34 6,29 P — Ground reference for logic and I/O pins. NC | | | | | | | | | RD2/PSP2 | RD0/PSP0 | 19 | 21 | 38 | I/O | ST/TTL <sup>(3)</sup> | | | RD3/PSP3 22 24 41 I/O ST/TTL(3) RD4/PSP4 27 30 2 I/O ST/TTL(3) RD5/PSP5 28 31 3 I/O ST/TTL(3) RD6/PSP6 29 32 4 I/O ST/TTL(3) RD7/PSP7 30 33 5 I/O ST/TTL(3) PORTE is a bi-directional I/O port. RE0 can also be read control for the parallel slave port, or analog input5. RE1/WR/AN6 9 10 26 I/O ST/TTL(3) RE1 can also be write control for the parallel slave port, or analog input5. RE2/CS/AN7 10 11 27 I/O ST/TTL(3) RE2 can also be select control for the parallel slave port, or analog input6. VSS 12,31 13,34 6,29 P — Ground reference for logic and I/O pins. VDD 11,32 12,35 7,28 P — Positive supply for logic and I/O pins. NC — 1,17,28, 12,13, — These pins are not internally connected. These pins | RD1/PSP1 | 20 | 22 | 39 | I/O | ST/TTL <sup>(3)</sup> | | | RD4/PSP4 27 30 2 I/O ST/TTL(3) RD5/PSP5 28 31 3 I/O ST/TTL(3) RD6/PSP6 29 32 4 I/O ST/TTL(3) RD7/PSP7 30 33 5 I/O ST/TTL(3) PORTE is a bi-directional I/O port. RE0/RD/AN5 8 9 25 I/O ST/TTL(3) RE0 can also be read control for the parallel slave port, or analog input5. RE1/WR/AN6 9 10 26 I/O ST/TTL(3) RE1 can also be write control for the parallel slave port, or analog input6. RE2/CS/AN7 10 11 27 I/O ST/TTL(3) RE2 can also be select control for the parallel slave port, or analog input7. Vss 12,31 13,34 6,29 P — Ground reference for logic and I/O pins. VDD 11,32 12,35 7,28 P — Positive supply for logic and I/O pins. NC — 1,17,28, 12,13, — These pins are not internally connected. These pins | RD2/PSP2 | 21 | 23 | 40 | I/O | ST/TTL <sup>(3)</sup> | | | RD5/PSP5 28 31 3 I/O ST/TTL(3) RD6/PSP6 29 32 4 I/O ST/TTL(3) PORTE is a bi-directional I/O port. RD7/PSP7 30 33 5 I/O ST/TTL(3) PORTE is a bi-directional I/O port. RE0/RD/AN5 8 9 25 I/O ST/TTL(3) RE0 can also be read control for the parallel slave port, or analog input5. RE1/WR/AN6 9 10 26 I/O ST/TTL(3) RE1 can also be write control for the parallel slave port, or analog input6. RE2/CS/AN7 10 11 27 I/O ST/TTL(3) RE2 can also be select control for the parallel slave port, or analog input7. Vss 12,31 13,34 6,29 P — Ground reference for logic and I/O pins. VDD 11,32 12,35 7,28 P — Positive supply for logic and I/O pins. NC — 1,17,28 12,13 — These pins are not internally connected. These pins | RD3/PSP3 | 22 | 24 | 41 | I/O | ST/TTL <sup>(3)</sup> | | | RD6/PSP6 29 32 4 I/O ST/TTL(3) RD7/PSP7 30 33 5 I/O ST/TTL(3) PORTE is a bi-directional I/O port. RE0/RD/AN5 8 9 25 I/O ST/TTL(3) RE0 can also be read control for the parallel slave port, or analog input5. RE1/WR/AN6 9 10 26 I/O ST/TTL(3) RE1 can also be write control for the parallel slave port, or analog input6. RE2/CS/AN7 10 11 27 I/O ST/TTL(3) RE2 can also be select control for the parallel slave port, or analog input7. Vss 12,31 13,34 6,29 P — Ground reference for logic and I/O pins. VDD 11,32 12,35 7,28 P — Positive supply for logic and I/O pins. NC — 1,17,28, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,13, 12,14 | RD4/PSP4 | 27 | 30 | 2 | I/O | ST/TTL <sup>(3)</sup> | | | RD7/PSP7 30 33 5 I/O ST/TTL <sup>(3)</sup> PORTE is a bi-directional I/O port. RE0/RD/AN5 8 9 25 I/O ST/TTL <sup>(3)</sup> RE0 can also be read control for the parallel slave port, or analog input5. RE1/WR/AN6 9 10 26 I/O ST/TTL <sup>(3)</sup> RE1 can also be write control for the parallel slave port, or analog input6. RE2/CS/AN7 10 11 27 I/O ST/TTL <sup>(3)</sup> RE2 can also be select control for the parallel slave port, or analog input6. RE2 can also be select control for the parallel slave port, or analog input7. VSS 12,31 13,34 6,29 P Ground reference for logic and I/O pins. NC - 1,17,28, 12,13, - These pins are not internally connected. These pins | RD5/PSP5 | 28 | 31 | 3 | I/O | | | | RE0/RD/AN5 8 9 10 25 1/O ST/TTL(3) RE0 can also be read control for the parallel slave port, or analog input5. RE1/WR/AN6 9 10 26 1/O ST/TTL(3) RE1 can also be write control for the parallel slave port, or analog input6. RE2/CS/AN7 10 11 27 1/O ST/TTL(3) RE1 can also be write control for the parallel slave port, or analog input6. RE2 can also be select control for the parallel slave port, or analog input7. Vss 12,31 13,34 6,29 P Ground reference for logic and I/O pins. VDD 11,32 12,35 7,28 P Positive supply for logic and I/O pins. These pins are not internally connected. These pins | RD6/PSP6 | 29 | 32 | 4 | I/O | | | | RE0/RD/AN5 8 9 25 I/O ST/TTL(3) RE0 can also be read control for the parallel slave port, or analog input5. RE1/WR/AN6 9 10 26 I/O ST/TTL(3) RE1 can also be write control for the parallel slave port, or analog input6. RE2/CS/AN7 10 11 27 I/O ST/TTL(3) RE2 can also be select control for the parallel slave port, or analog input7. Vss 12,31 13,34 6,29 P — Ground reference for logic and I/O pins. VDD 11,32 12,35 7,28 P — Positive supply for logic and I/O pins. NC — 1,17,28, 12,13, 12,13, 12,13, 12,13 — These pins are not internally connected. These pins | RD7/PSP7 | 30 | 33 | 5 | I/O | ST/TTL <sup>(3)</sup> | | | RE1/WR/AN6 9 10 26 I/O ST/TTL <sup>(3)</sup> RE1 can also be write control for the parallel slave port, or analog input5. RE2/CS/AN7 10 11 27 I/O ST/TTL <sup>(3)</sup> RE2 can also be select control for the parallel slave port, or analog input7. Vss 12,31 13,34 6,29 P — Ground reference for logic and I/O pins. VDD 11,32 12,35 7,28 P — Positive supply for logic and I/O pins. NC — 1,17,28, 12,13, — These pins are not internally connected. These pins | | | | | | | PORTE is a bi-directional I/O port. | | RE2/CS/AN7 10 11 27 I/O ST/TTL <sup>(3)</sup> RE2 can also be select control for the parallel slave port, or analog input7. Vss 12,31 13,34 6,29 P Ground reference for logic and I/O pins. VDD 11,32 12,35 7,28 P Positive supply for logic and I/O pins. NC - 1,17,28, 12,13, These pins are not internally connected. These pins | RE0/RD/AN5 | 8 | 9 | 25 | I/O | ST/TTL <sup>(3)</sup> | · | | VSS 12,31 13,34 6,29 P — Ground reference for logic and I/O pins. VDD 11,32 12,35 7,28 P — Positive supply for logic and I/O pins. NC — 1,17,28, 12,13, 12,13, 12,13, 12,13 — These pins are not internally connected. These pins | RE1/WR/AN6 | 9 | 10 | 26 | I/O | ST/TTL <sup>(3)</sup> | · · | | VDD 11,32 12,35 7,28 P — Positive supply for logic and I/O pins. NC — 1,17,28, 12,13, 12,13, 12,13, 12,13, 12,13 — These pins are not internally connected. These pins | RE2/CS/AN7 | 10 | 11 | 27 | I/O | ST/TTL <sup>(3)</sup> | · | | NC — 1,17,28, 12,13, — These pins are not internally connected. These pins | Vss | 12,31 | 13,34 | 6,29 | Р | _ | Ground reference for logic and I/O pins. | | | VDD | 11,32 | 12,35 | 7,28 | Р | _ | Positive supply for logic and I/O pins. | | | NC | _ | | | | _ | · · · · · · · · · · · · · · · · · · · | 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 an external interrupt. - 2: This buffer is a Schmitt Trigger input when used in Serial Programming mode. - 3: This buffer is a Schmitt Trigger input when configured as general purpose I/O and a TTL input when used in the Parallel Slave Port mode (for interfacing to a microprocessor bus). - 4: This buffer is a Schmitt Trigger input when configured in RC oscillator mode and a CMOS input otherwise. NOTES: #### 2.0 MEMORY ORGANIZATION There are three memory blocks in each of the PIC16F87X MCUs. The Program Memory and Data Memory have separate buses so that concurrent access can occur and is detailed in this section. The EEPROM data memory block is detailed in Section 4.0. Additional information on device memory may be found in the PICmicro™ Mid-Range Reference Manual, (DS33023). FIGURE 2-1: PIC16F877/876 PROGRAM MEMORY MAP AND STACK #### 2.1 Program Memory Organization The PIC16F87X devices have a 13-bit program counter capable of addressing an 8K x 14 program memory space. The PIC16F877/876 devices have 8K x 14 words of FLASH program memory, and the PIC16F873/874 devices have 4K x 14. Accessing a location above the physically implemented address will cause a wraparound. The RESET vector is at 0000h and the interrupt vector is at 0004h. FIGURE 2-2: PIC16F874/873 PROGRAM MEMORY MAP AND STACK #### 2.2 Data Memory Organization The data memory is partitioned into multiple banks which contain the General Purpose Registers and the Special Function Registers. Bits RP1 (STATUS<6>) and RP0 (STATUS<5>) are the bank select bits. | RP1:RP0 | Bank | |---------|------| | 00 | 0 | | 01 | 1 | | 10 | 2 | | 11 | 3 | Each bank extends up to 7Fh (128 bytes). The lower locations of each bank are reserved for the Special Function Registers. Above the Special Function Registers are General Purpose Registers, implemented as static RAM. All implemented banks contain Special Function Registers. Some frequently used Special Function Registers from one bank may be mirrored in another bank for code reduction and quicker access. | Note: | EEPROM Data Memory description can be | |-------|------------------------------------------| | | found in Section 4.0 of this data sheet. | # 2.2.1 GENERAL PURPOSE REGISTER FILE The register file can be accessed either directly, or indirectly through the File Select Register (FSR). FIGURE 2-3: PIC16F877/876 REGISTER FILE MAP | , | File<br>Address | | File<br>Address | | File<br>Address | | File<br>Addre | |--------------------------------------------|-----------------|--------------------------------------------|-----------------|--------------------------------------------|-----------------|--------------------------------------------|---------------| | Indirect addr.(*) | 00h | Indirect addr.(*) | 80h | Indirect addr.(*) | 100h | Indirect addr.(*) | 180 | | TMR0 | 01h | OPTION_REG | 81h | TMR0 | 101h | OPTION_REG | 18 | | PCL | 02h | PCL | 82h | PCL | 102h | PCL | 182 | | STATUS | 03h | STATUS | 83h | STATUS | 103h | STATUS | 183 | | FSR | 04h | FSR | 84h | FSR | 104h | FSR | 184 | | PORTA | 05h | TRISA | 85h | | 105h | | 18 | | PORTB | 06h | TRISB | 86h | PORTB | 106h | TRISB | 180 | | PORTC | 07h | TRISC | 87h | | 107h | | 18 | | PORTD <sup>(1)</sup> | 08h | TRISD <sup>(1)</sup> | 88h | | 108h | | 188 | | PORTE <sup>(1)</sup> | 09h | TRISE <sup>(1)</sup> | 89h | | 109h | | 189 | | PCLATH | 0Ah | PCLATH | 8Ah | PCLATH | 10Ah | PCLATH | 18 | | INTCON | 0Bh | INTCON | 8Bh | INTCON | 10Bh | INTCON | 18 | | PIR1 | 0Ch | PIE1 | 8Ch | EEDATA | 10Ch | EECON1 | 18 | | PIR2 | 0Dh | PIE2 | 8Dh | EEADR | 10Dh | EECON2 | 18 | | TMR1L | 0Eh | PCON | 8Eh | EEDATH | 10Eh | Reserved <sup>(2)</sup> | 18 | | TMR1H | 0Fh | | 8Fh | EEADRH | 10Fh | Reserved <sup>(2)</sup> | 18 | | T1CON | 10h | | 90h | | 110h | | 19 | | TMR2 | 11h | SSPCON2 | 91h | | 111h | | 19 | | T2CON | 12h | PR2 | 92h | | 112h | | 19 | | SSPBUF | 13h | SSPADD | 93h | | 113h | | 19 | | SSPCON | 14h | SSPSTAT | 94h | | 114h | | 19 | | CCPR1L | 15h | | 95h | | 115h | | 19 | | CCPR1H | 16h | | 96h | | 116h | | 19 | | CCP1CON | 17h | | 97h | General | 117h | General | 19 | | RCSTA | 18h | TXSTA | 98h | Purpose<br>Register | 118h | Purpose<br>Register | 19 | | TXREG | 19h | SPBRG | 99h | 16 Bytes | 119h | 16 Bytes | 19 | | RCREG | 1Ah | 0. 20 | 9Ah | 10 27100 | 11Ah | . 5 2 7 1 5 5 | 19. | | CCPR2L | 1Bh | | 9Bh | | 11Bh | | 19 | | CCPR2H | 1Ch | | 9Ch | | 11Ch | | 19 | | CCP2CON | 1Dh | | 9Dh | | 11Dh | | 19 | | ADRESH | 1Eh | ADRESL | 9Eh | | 11Eh | | 19 | | ADCON0 | 1Fh | ADCON1 | 9Fh | | 11Fh | | 19 | | ABOONO | 20h | 7,000141 | A0h | | 120h | | 1A | | General<br>Purpose<br>Register<br>96 Bytes | | General<br>Purpose<br>Register<br>80 Bytes | EFh | General<br>Purpose<br>Register<br>80 Bytes | . 16Fh | General<br>Purpose<br>Register<br>80 Bytes | 1E | | · | 7Fh | accesses<br>70h-7Fh | F0h<br>FFh | accesses<br>70h-7Fh | 170h<br>17Fh | accesses<br>70h - 7Fh | 1F | | Bank 0 | | Bank 1 | | Bank 2 | | Bank 3 | •• | Note 1: These registers are not implemented on the PIC16F876. 2: These registers are reserved, maintain these registers clear. FIGURE 2-4: PIC16F874/873 REGISTER FILE MAP | | File<br>Address | A | File<br>Address | , | File<br>Address | A | File<br>Address | |----------------------|-----------------------------|----------------------------------------------------------------------|-----------------|-------------------|-----------------|-------------------------|-----------------| | Indirect addr.(*) | 00h | Indirect addr.(*) | 80h | Indirect addr.(*) | 100h | Indirect addr.(*) | 180h | | TMR0 | 01h | OPTION_REG | 81h | TMR0 | 101h | OPTION_REG | 181h | | PCL | 02h | PCL | 82h | PCL | 102h | PCL | 182h | | STATUS | 03h | STATUS | 83h | STATUS | 103h | STATUS | 183h | | FSR | 04h | FSR | 84h | FSR | 104h | FSR | 184h | | PORTA | 05h | TRISA | 85h | | 105h | | 185h | | PORTB | 06h | TRISB | 86h | PORTB | 106h | TRISB | 186h | | PORTC | 07h | TRISC | 87h | | 107h | | 187h | | PORTD <sup>(1)</sup> | 08h | TRISD <sup>(1)</sup> | 88h | | 108h | | 188h | | PORTE <sup>(1)</sup> | 09h | TRISE <sup>(1)</sup> | 89h | | 109h | | 189h | | PCLATH | 0Ah | PCLATH | 8Ah | PCLATH | 10Ah | PCLATH | 18Ah | | INTCON | 0Bh | INTCON | 8Bh | INTCON | 10Bh | INTCON | 18Bh | | PIR1 | 0Ch | PIE1 | 8Ch | EEDATA | 10Ch | EECON1 | 18Ch | | PIR2 | 0Dh | PIE2 | 8Dh | EEADR | 10Dh | EECON2 | 18Dh | | TMR1L | 0Eh | PCON | 8Eh | EEDATH | 10Eh | Reserved <sup>(2)</sup> | 18Eh | | TMR1H | 0Fh | | 8Fh | EEADRH | 10Fh | Reserved <sup>(2)</sup> | 18Fh | | T1CON | 10h | | 90h | | 110h | | 190h | | TMR2 | 11h | SSPCON2 | 91h | | | | | | T2CON | 12h | PR2 | 92h | | | | | | SSPBUF | 13h | SSPADD | 93h | | | | | | SSPCON | 14h | SSPSTAT | 94h | | | | | | CCPR1L | 15h | | 95h | | | | | | CCPR1H | 16h | | 96h | | | | | | CCP1CON | 17h | | 97h | | | | | | RCSTA | 18h | TXSTA | 98h | | | | | | TXREG | 19h | SPBRG | 99h | | | | | | RCREG | 1Ah | | 9Ah | | | | | | CCPR2L | 1Bh | | 9Bh | | | | | | CCPR2H | 1Ch | | 9Ch | | | | | | CCP2CON | 1Dh | | 9Dh | | | | | | ADRESH | 1Eh | ADRESL | 9Eh | | | | | | ADCON0 | 1Fh | ADCON1 | 9Fh | | 4005 | | 4 A OI- | | | 20h | | A0h | | 120h | | 1A0h | | General<br>Purpose | | General<br>Purpose | | accesses | | accesses | | | Register | | Register | | 20h-7Fh | | A0h - FFh | | | 96 Bytes | | 96 Bytes | | | 16Fh<br>170h | | 1EFh<br>1F0h | | | J 7Fh | | FFh | | 17Fh | | 1FFh | | Bank 0 | | Bank 1 | <b>··</b> | Bank 2 | | Bank 3 | | | * Not a Note 1: Thes | physical reg<br>e registers | data memory loca<br>gister.<br>are not implemen<br>are reserved, mai | ted on the | e PIC16F873. | | | | #### 2.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. A list of these registers is given in Table 2-1. The Special Function Registers can be classified into two sets: core (CPU) and peripheral. Those registers associated with the core functions are described in detail in this section. Those related to the operation of the peripheral features are described in detail in the peripheral features section. TABLE 2-1: 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 | Details<br>on<br>page: | |----------------------|---------|----------------------|------------------------------------|---------------|---------------|----------------|-------------------|----------------|-----------|--------------------------|------------------------| | Bank 0 | | | | | | | | | | | | | 00h <sup>(3)</sup> | INDF | Addressing | g this locatio | n uses conte | nts of FSR to | address data | a memory (no | t a physical r | egister) | 0000 0000 | 27 | | 01h | TMR0 | Timer0 Mo | dule Registe | er | | | | | | xxxx xxxx | 47 | | 02h <sup>(3)</sup> | PCL | Program C | ounter (PC) | Least Signif | icant Byte | _ | | | | 0000 0000 | 26 | | 03h <sup>(3)</sup> | STATUS | IRP | RP1 | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 18 | | 04h <sup>(3)</sup> | FSR | Indirect Da | ta Memory | Address Poir | iter | | | | | xxxx xxxx | 27 | | 05h | PORTA | _ | ı | PORTA Dat | ta Latch whe | n written: POI | RTA pins whe | n read | | 0x 0000 | 29 | | 06h | PORTB | PORTB Da | ata Latch wh | en written: P | ORTB pins v | hen read | | | | xxxx xxxx | 31 | | 07h | PORTC | PORTC Da | ata Latch wh | en written: P | ORTC pins v | vhen read | | | | xxxx xxxx | 33 | | 08h <sup>(4)</sup> | PORTD | PORTD D | ata Latch wh | en written: P | ORTD pins v | vhen read | | | | xxxx xxxx | 35 | | 09h <sup>(4)</sup> | PORTE | | I | _ | _ | _ | RE2 | RE1 | RE0 | xxx | 36 | | 0Ah <sup>(1,3)</sup> | PCLATH | _ | 1 | _ | Write Buffer | for the upper | r 5 bits of the I | Program Cou | unter | 0 0000 | 26 | | 0Bh <sup>(3)</sup> | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 20 | | 0Ch | PIR1 | PSPIF <sup>(3)</sup> | ADIF | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF | 0000 0000 | 22 | | 0Dh | PIR2 | _ | (5) | _ | EEIF | BCLIF | _ | _ | CCP2IF | -r-0 00 | 24 | | 0Eh | TMR1L | Holding re | gister for the | Least Signif | icant Byte of | the 16-bit TM | IR1 Register | | | xxxx xxxx | 52 | | 0Fh | TMR1H | Holding re | gister for the | Most Signifi | cant Byte of | the 16-bit TM | R1 Register | | | xxxx xxxx | 52 | | 10h | T1CON | _ | 1 | T1CKPS1 | T1CKPS0 | T10SCEN | T1SYNC | TMR1CS | TMR10N | 00 0000 | 51 | | 11h | TMR2 | Timer2 Mo | dule Registe | er | | | | | | 0000 0000 | 55 | | 12h | T2CON | - | TOUTPS3 | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000 0000 | 55 | | 13h | SSPBUF | Synchrono | us Serial Po | rt Receive B | uffer/Transm | it Register | | | | xxxx xxxx | 70, 73 | | 14h | SSPCON | WCOL | SSPOV | SSPEN | CKP | SSPM3 | SSPM2 | SSPM1 | SSPM0 | 0000 0000 | 67 | | 15h | CCPR1L | Capture/C | ompare/PWI | M Register1 | (LSB) | | | | | xxxx xxxx | 57 | | 16h | CCPR1H | Capture/C | ompare/PWI | M Register1 | (MSB) | | | | | xxxx xxxx | 57 | | 17h | CCP1CON | _ | - | CCP1X | CCP1Y | CCP1M3 | CCP1M2 | CCP1M1 | CCP1M0 | 00 0000 | 58 | | 18h | RCSTA | SPEN | RX9 | SREN | CREN | ADDEN | FERR | OERR | RX9D | 0000 000x | 96 | | 19h | TXREG | USART Tra | ansmit Data | Register | | | | | | 0000 0000 | 99 | | 1Ah | RCREG | USART Re | eceive Data | Register | | | | | | 0000 0000 | 101 | | 1Bh | CCPR2L | Capture/C | apture/Compare/PWM Register2 (LSB) | | | | | | xxxx xxxx | 57 | | | 1Ch | CCPR2H | Capture/C | apture/Compare/PWM Register2 (MSB) | | | | | | xxxx xxxx | 57 | | | 1Dh | CCP2CON | | _ | CCP2X | CCP2Y | CCP2M3 | CCP2M2 | CCP2M1 | CCP2M0 | 00 0000 | 58 | | 1Eh | ADRESH | A/D Result | Register Hi | gh Byte | | | | | | xxxx xxxx | 116 | | 1Fh | ADCON0 | ADCS1 | ADCS0 | CHS2 | CHS1 | CHS0 | GO/DONE | _ | ADON | 0000 00-0 | 111 | Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved. Shaded locations are unimplemented, read as '0'. Note 1: 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. - 2: Bits PSPIE and PSPIF are reserved on PIC16F873/876 devices; always maintain these bits clear. - 3: These registers can be addressed from any bank. - 4: PORTD, PORTE, TRISD, and TRISE are not physically implemented on PIC16F873/876 devices; read as '0'. - 5: PIR2<6> and PIE2<6> are reserved on these devices; always maintain these bits clear. #### **TABLE 2-1:** SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED) | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Details<br>on<br>page: | |----------------------|------------|--------------------------------------------------------------|-----------------|---------------------------|----------------|-------------|--------------|----------------|----------|--------------------------|------------------------| | Bank 1 | | | | | | | | | | | | | 80h <sup>(3)</sup> | INDF | Addressing | g this location | n uses conte | ents of FSR to | address dat | a memory (no | t a physical r | egister) | 0000 0000 | 27 | | 81h | OPTION_REG | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 19 | | 82h <sup>(3)</sup> | PCL | Program C | Counter (PC) | Least Signif | icant Byte | | | | | 0000 0000 | 26 | | 83h <sup>(3)</sup> | STATUS | IRP | RP1 | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 18 | | 84h <sup>(3)</sup> | FSR | Indirect Da | ata Memory A | Address Poir | nter | | | | | xxxx xxxx | 27 | | 85h | TRISA | _ | _ | PORTA Da | ta Direction R | Register | | | | 11 1111 | 29 | | 86h | TRISB | PORTB Da | ata Direction | Register | | | | | | 1111 1111 | 31 | | 87h | TRISC | PORTC Da | ata Direction | Register | | | | | | 1111 1111 | 33 | | 88h <sup>(4)</sup> | TRISD | PORTD Data Direction Register | | | | | 1111 1111 | 35 | | | | | 89h <sup>(4)</sup> | TRISE | IBF | OBF | IBOV | PSPMODE | _ | PORTE Data | Direction B | its | 0000 -111 | 37 | | 8Ah <sup>(1,3)</sup> | PCLATH | — — Write Buffer for the upper 5 bits of the Program Counter | | | | | 0 0000 | 26 | | | | | 8Bh <sup>(3)</sup> | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 20 | | 8Ch | PIE1 | PSPIE <sup>(2)</sup> | ADIE | RCIE | TXIE | SSPIE | CCP1IE | TMR2IE | TMR1IE | 0000 0000 | 21 | | 8Dh | PIE2 | _ | (5) | _ | EEIE | BCLIE | _ | _ | CCP2IE | -r-0 00 | 23 | | 8Eh | PCON | _ | _ | _ | _ | _ | _ | POR | BOR | qq | 25 | | 8Fh | _ | Unimpleme | ented | | | | | | | _ | _ | | 90h | _ | Unimpleme | ented | | | | | | | | _ | | 91h | SSPCON2 | GCEN | ACKSTAT | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | 0000 0000 | 68 | | 92h | PR2 | Timer2 Pe | riod Register | | | | | | | 1111 1111 | 55 | | 93h | SSPADD | Synchrono | ous Serial Po | rt (I <sup>2</sup> C mode | ) Address Re | gister | | | | 0000 0000 | 73, 74 | | 94h | SSPSTAT | SMP | CKE | D/A | Р | S | R/W | UA | BF | 0000 0000 | 66 | | 95h | _ | Unimpleme | ented | | | | | | | _ | _ | | 96h | _ | Unimpleme | ented | | | | | | | _ | _ | | 97h | _ | Unimpleme | ented | | | | | | | _ | _ | | 98h | TXSTA | CSRC | TX9 | TXEN | SYNC | _ | BRGH | TRMT | TX9D | 0000 -010 | 95 | | 99h | SPBRG | Baud Rate | Generator F | Register | | | | | | 0000 0000 | 97 | | 9Ah | _ | Unimpleme | ented | | | | | | | _ | _ | | 9Bh | _ | Unimpleme | ented | | | | | | | _ | _ | | 9Ch | _ | Unimpleme | ented | | | | | | | _ | _ | | 9Dh | _ | Unimpleme | ented | | | | | | | _ | _ | | 9Eh | ADRESL | A/D Result | t Register Lo | w Byte | | | | | | xxxx xxxx | 116 | | 9Fh | ADCON1 | ADFM | _ | | _ | PCFG3 | PCFG2 | PCFG1 | PCFG0 | 0 0000 | 112 | - These registers can be addressed from any bank. PORTD, PORTE, TRISD, and TRISE are not physically implemented on PIC16F873/876 devices; read as '0'. PIR2<6> and PIE2<6> are reserved on these devices; always maintain these bits clear. Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved. Shaded locations are unimplemented, read as '0'. Note 1: 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. 2: Bits PSPIE and PSPIF are reserved on PIC16F873/876 devices; always maintain these bits clear. **TABLE 2-1:** SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED) | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Details<br>on<br>page: | |-----------------------|------------|-------------|----------------------------------------------------------|------------------|---------------|--------------|-----------------|----------------|----------|--------------------------|------------------------| | Bank 2 | | | | | | | | | | | | | 100h <sup>(3)</sup> | INDF | Addressing | g this location | n uses conte | nts of FSR to | address dat | a memory (no | t a physical r | egister) | 0000 0000 | 27 | | 101h | TMR0 | Timer0 Mo | dule Registe | r | | | | | | xxxx xxxx | 47 | | 102h <sup>(3)</sup> | PCL | Program C | Counter's (PC | ) Least Sign | ificant Byte | | | | | 0000 0000 | 26 | | 103h <sup>(3)</sup> | STATUS | IRP | RP1 | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 18 | | 104h <sup>(3)</sup> | FSR | Indirect Da | ata Memory A | Address Poir | iter | | | | | xxxx xxxx | 27 | | 105h | _ | Unimpleme | ented | | | | | | | _ | _ | | 106h | PORTB | PORTB Da | ata Latch wh | en written: P | ORTB pins w | hen read | | | | xxxx xxxx | 31 | | 107h | _ | Unimpleme | ented | | | | | | | _ | _ | | 108h | _ | Unimpleme | implemented | | | | | | | _ | _ | | 109h | _ | Unimpleme | emented | | | | | | | _ | _ | | 10Ah <sup>(1,3)</sup> | PCLATH | _ | Write Buffer for the upper 5 bits of the Program Counter | | | | | | 0 0000 | 26 | | | 10Bh <sup>(3)</sup> | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 20 | | 10Ch | EEDATA | EEPROM | Data Registe | er Low Byte | | | | | | xxxx xxxx | 41 | | 10Dh | EEADR | EEPROM | EPROM Address Register Low Byte | | | | | | | xxxx xxxx | 41 | | 10Eh | EEDATH | _ | EEPROM Data Register High Byte | | | | | | | xxxx xxxx | 41 | | 10Fh | EEADRH | _ | _ | _ | EEPROM A | ddress Regis | ter High Byte | | | xxxx xxxx | 41 | | Bank 3 | | | | | | | | | | | | | 180h <sup>(3)</sup> | INDF | Addressing | this location | n uses conte | nts of FSR to | address dat | a memory (no | t a physical r | egister) | 0000 0000 | 27 | | 181h | OPTION_REG | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 19 | | 182h <sup>(3)</sup> | PCL | Program C | counter (PC) | Least Signi | ficant Byte | | | | | 0000 0000 | 26 | | 183h <sup>(3)</sup> | STATUS | IRP | RP1 | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 18 | | 184h <sup>(3)</sup> | FSR | Indirect Da | ta Memory A | Address Poir | iter | | | | | xxxx xxxx | 27 | | 185h | _ | Unimpleme | ented | | | | | | | _ | _ | | 186h | TRISB | PORTB Da | ata Direction | Register | | | | | | 1111 1111 | 31 | | 187h | _ | Unimpleme | ented | | | | | | | _ | _ | | 188h | _ | Unimpleme | ented | | | | | | | _ | _ | | 189h | _ | Unimpleme | ented | | | | | | | _ | _ | | 18Ah <sup>(1,3)</sup> | PCLATH | | _ | _ | Write Buffer | for the uppe | 5 bits of the I | Program Cou | ınter | 0 0000 | 26 | | 18Bh <sup>(3)</sup> | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 20 | | 18Ch | EECON1 | EEPGD | _ | WRERR WREN WR RD | | | | | | x x000 | 41, 42 | | 18Dh | EECON2 | EEPROM | PROM Control Register2 (not a physical register) | | | | | | | | 41 | | 18Eh | _ | Reserved | maintain clea | | 0000 0000 | _ | | | | | | | 18Fh | _ | Reserved | maintain clea | ar | | | | | | 0000 0000 | _ | x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved. Shaded locations are unimplemented, read as '0'. Legend: Note 1: 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. Bits PSPIE and PSPIF are reserved on PIC16F873/876 devices; always maintain these bits clear. - 3: These registers can be addressed from any bank. 4: PORTD, PORTE, TRISD, and TRISE are not physically implemented on PIC16F873/876 devices; read as '0'. - **5:** PIR2<6> and PIE2<6> are reserved on these devices; always maintain these bits clear. #### 2.2.2.1 STATUS Register The STATUS register 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: The <u>C</u> and <u>DC</u> bits operate as a borrow and digit borrow bit, respectively, in subtraction. See the <u>SUBLW</u> and <u>SUBWF</u> instructions for examples. #### REGISTER 2-1: STATUS REGISTER (ADDRESS 03h, 83h, 103h, 183h) | R/W-0 | R/W-0 | R/W-0 | R-1 | R-1 | R/W-x | R/W-x | R/W-x | |-------|-------|-------|-----|-----|-------|-------|-------| | IRP | RP1 | RP0 | TO | PD | Z | DC | С | | bit 7 | | | | | | | bit 0 | bit 7 IRP: Register Bank Select bit (used for indirect addressing) 1 = Bank 2, 3 (100h - 1FFh) 0 = Bank 0, 1 (00h - FFh) bit 6-5 RP1:RP0: Register Bank Select bits (used for direct addressing) 11 = Bank 3 (180h - 1FFh) 10 = Bank 2 (100h - 17Fh) 01 = Bank 1 (80h - FFh) 00 = Bank 0 (00h - 7Fh) Each bank is 128 bytes bit 4 **TO**: Time-out bit 1 = After power-up, CLRWDT instruction, or SLEEP instruction 0 = A WDT time-out occurred bit 3 **PD**: Power-down bit 1 = After power-up or by the CLRWDT instruction 0 = By execution of the SLEEP instruction bit 2 Z: Zero bit 1 = The result of an arithmetic or logic operation is zero 0 = The result of an arithmetic or logic operation is not zero bit 1 DC: Digit carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions) (for borrow, the polarity is reversed) 1 = A carry-out from the 4th low order bit of the result occurred 0 = No carry-out from the 4th low order bit of the result bit 0 C: Carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions) 1 = A carry-out from the Most Significant bit of the result occurred 0 = No carry-out from the Most Significant bit of the result occurred Note: For borrow, the polarity is reversed. A subtraction is executed by adding the two's complement of the second operand. For rotate (RRF, RLF) instructions, this bit is loaded with either the high, or low order bit of the source register. #### 2.2.2.2 OPTION\_REG Register The OPTION\_REG Register is a readable and writable register, which contains various control bits to configure the TMR0 prescaler/WDT postscaler (single assignable register known also as the prescaler), the External INT Interrupt, TMR0 and the weak pull-ups on PORTB. To achieve a 1:1 prescaler assignment for the TMR0 register, assign the prescaler to the Watchdog Timer. #### REGISTER 2-2: OPTION\_REG REGISTER (ADDRESS 81h, 181h) | R/W-1 |-------|--------|-------|-------|-------|-------|-------|-------| | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | | bit 7 | | | | | | | bit 0 | Note: bit 7 RBPU: PORTB Pull-up Enable bit 1 = PORTB pull-ups are disabled 0 = PORTB pull-ups are enabled by individual port latch values bit 6 INTEDG: Interrupt Edge Select bit 1 = Interrupt on rising edge of RB0/INT pin 0 = Interrupt on falling edge of RB0/INT pin bit 5 TOCS: TMR0 Clock Source Select bit 1 = Transition on RA4/T0CKI pin 0 = Internal instruction cycle clock (CLKOUT) bit 4 **T0SE**: TMR0 Source Edge Select bit 1 = Increment on high-to-low transition on RA4/T0CKI pin 1:128 0 = Increment on low-to-high transition on RA4/T0CKI pin bit 3 **PSA**: Prescaler Assignment bit 111 1 = Prescaler is assigned to the WDT 0 = Prescaler is assigned to the Timer0 module bit 2-0 **PS2:PS0**: Prescaler Rate Select bits | Bit Value | TMR0 Rate | WDT Rate | |-----------|-----------|----------| | 000 | 1:2 | 1:1 | | 001 | 1:4 | 1:2 | | 010 | 1:8 | 1:4 | | 011 | 1:16 | 1:8 | | 100 | 1:32 | 1 : 16 | | 101 | 1:64 | 1:32 | | 110 | 1 · 128 | 1:64 | 1:256 | Legend: | | | | |--------------------|------------------|----------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented I | bit, read as '0' | | - n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | When using low voltage ICSP programming (LVP) and the pull-ups on PORTB are enabled, bit 3 in the TRISB register must be cleared to disable the pull-up on RB3 and ensure the proper operation of the device Note: #### 2.2.2.3 INTCON Register The INTCON Register is a readable and writable register, which contains various enable and flag bits for the TMR0 register overflow, RB Port change and External RB0/INT pin interrupts. Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt. #### REGISTER 2-3: INTCON REGISTER (ADDRESS 0Bh, 8Bh, 10Bh, 18Bh) | R/W-0 R/W-x | |-------|-------|-------|-------|-------|-------|-------|-------| | GIE | PEIE | T0IE | INTE | RBIE | T0IF | INTF | RBIF | | bit 7 | | | | | | | bit 0 | Note: bit 7 GIE: Global Interrupt Enable bit 1 = Enables all unmasked interrupts 0 = Disables all interrupts bit 6 PEIE: Peripheral Interrupt Enable bit 1 = Enables all unmasked peripheral interrupts 0 = Disables all peripheral interrupts bit 5 **T0IE**: TMR0 Overflow Interrupt Enable bit 1 = Enables the TMR0 interrupt 0 = Disables the TMR0 interrupt bit 4 INTE: RB0/INT External Interrupt Enable bit 1 = Enables the RB0/INT external interrupt 0 = Disables the RB0/INT external interrupt bit 3 RBIE: RB Port Change Interrupt Enable bit 1 = Enables the RB port change interrupt 0 = Disables the RB port change interrupt bit 2 T0IF: TMR0 Overflow Interrupt Flag bit 1 = TMR0 register has overflowed (must be cleared in software) 0 = TMR0 register did not overflow bit 1 INTF: RB0/INT External Interrupt Flag bit 1 = The RB0/INT external interrupt occurred (must be cleared in software) 0 = The RB0/INT external interrupt did not occur bit 0 RBIF: RB Port Change Interrupt Flag bit 1 = At least one of the RB7:RB4 pins changed state; a mismatch condition will continue to set the bit. Reading PORTB will end the mismatch condition and allow the bit to be cleared (must be cleared in software). 0 = None of the RB7:RB4 pins have changed state 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 #### 2.2.2.4 PIE1 Register The PIE1 register contains the individual enable bits for the peripheral interrupts. **Note:** Bit PEIE (INTCON<6>) must be set to enable any peripheral interrupt. #### REGISTER 2-4: PIE1 REGISTER (ADDRESS 8Ch) | | R/W-0 |-------|----------------------|-------|-------|-------|-------|--------|--------|--------| | | PSPIE <sup>(1)</sup> | ADIE | RCIE | TXIE | SSPIE | CCP1IE | TMR2IE | TMR1IE | | bit 7 | | | | | | | | bit 0 | bit 7 **PSPIE**(1): Parallel Slave Port Read/Write Interrupt Enable bit 1 = Enables the PSP read/write interrupt 0 = Disables the PSP read/write interrupt bit 6 ADIE: A/D Converter Interrupt Enable bit 1 = Enables the A/D converter interrupt0 = Disables the A/D converter interrupt bit 5 RCIE: USART Receive Interrupt Enable bit 1 = Enables the USART receive interrupt0 = Disables the USART receive interrupt bit 4 TXIE: USART Transmit Interrupt Enable bit 1 = Enables the USART transmit interrupt 0 = Disables the USART transmit interrupt bit 3 SSPIE: Synchronous Serial Port Interrupt Enable bit 1 = Enables the SSP interrupt 0 = Disables the SSP interrupt bit 2 **CCP1IE**: CCP1 Interrupt Enable bit 1 = Enables the CCP1 interrupt 0 = Disables the CCP1 interrupt bit 1 TMR2IE: TMR2 to PR2 Match Interrupt Enable bit 1 = Enables the TMR2 to PR2 match interrupt 0 = Disables the TMR2 to PR2 match interrupt bit 0 TMR1IE: TMR1 Overflow Interrupt Enable bit 1 = Enables the TMR1 overflow interrupt 0 = Disables the TMR1 overflow interrupt Note 1: PSPIE is reserved on PIC16F873/876 devices; always maintain this bit clear. 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 #### 2.2.2.5 PIR1 Register The PIR1 register contains the individual flag bits for the peripheral interrupts. Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt bits are clear prior to enabling an interrupt. #### REGISTER 2-5: PIR1 REGISTER (ADDRESS 0Ch) | R/W-0 | R/W-0 | R-0 | R-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |----------------------|-------|------|------|-------|--------|--------|--------| | PSPIF <sup>(1)</sup> | ADIF | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF | | bit 7 | | | | | | | bit 0 | Note: - PSPIF<sup>(1)</sup>: Parallel Slave Port Read/Write Interrupt Flag bit bit 7 - 1 = A read or a write operation has taken place (must be cleared in software) - 0 = No read or write has occurred - bit 6 ADIF: A/D Converter Interrupt Flag bit - 1 = An A/D conversion completed - 0 = The A/D conversion is not complete - RCIF: USART Receive Interrupt Flag bit bit 5 - 1 = The USART receive buffer is full 0 = The USART receive buffer is empty - bit 4 TXIF: USART Transmit Interrupt Flag bit - 1 = The USART transmit buffer is empty - 0 = The USART transmit buffer is full - bit 3 SSPIF: Synchronous Serial Port (SSP) Interrupt Flag - 1 = The SSP interrupt condition has occurred, and must be cleared in software before returning from the Interrupt Service Routine. The conditions that will set this bit are: - SPI - A transmission/reception has taken place. - I<sup>2</sup>C Slave - A transmission/reception has taken place. - I<sup>2</sup>C Master - A transmission/reception has taken place. - The initiated START condition was completed by the SSP module. - The initiated STOP condition was completed by the SSP module. - The initiated Restart condition was completed by the SSP module. - The initiated Acknowledge condition was completed by the SSP module. - A START condition occurred while the SSP module was idle (Multi-Master system). - A STOP condition occurred while the SSP module was idle (Multi-Master system). - 0 = No SSP interrupt condition has occurred. #### CCP1IF: CCP1 Interrupt Flag bit bit 2 #### Capture mode: - 1 = A TMR1 register capture occurred (must be cleared in software) - 0 = No TMR1 register capture occurred #### Compare mode: - 1 = A TMR1 register compare match occurred (must be cleared in software) - 0 = No TMR1 register compare match occurred #### PWM mode: Unused in this mode - bit 1 TMR2IF: TMR2 to PR2 Match Interrupt Flag bit - 1 = TMR2 to PR2 match occurred (must be cleared in software) - 0 = No TMR2 to PR2 match occurred - TMR1IF: TMR1 Overflow Interrupt Flag bit bit 0 - 1 = TMR1 register overflowed (must be cleared in software) - 0 = TMR1 register did not overflow Note 1: PSPIF is reserved on PIC16F873/876 devices; always maintain this bit clear. | | $\sim$ | Δ | n | ٦ | |---|--------|---|-----|---| | L | EU | ᆮ | 110 | | 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 #### 2.2.2.6 PIE2 Register The PIE2 register contains the individual enable bits for the CCP2 peripheral interrupt, the SSP bus collision interrupt, and the EEPROM write operation interrupt. #### REGISTER 2-6: PIE2 REGISTER (ADDRESS 8Dh) | U-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | |-------|----------|-----|-------|-------|-----|-----|--------| | _ | Reserved | _ | EEIE | BCLIE | _ | _ | CCP2IE | | bit 7 | | | | | | | bit 0 | bit 7 Unimplemented: Read as '0' bit 6 Reserved: Always maintain this bit clear bit 5 Unimplemented: Read as '0' bit 4 **EEIE**: EEPROM Write Operation Interrupt Enable 1 = Enable EE Write Interrupt0 = Disable EE Write Interrupt bit 3 BCLIE: Bus Collision Interrupt Enable 1 = Enable Bus Collision Interrupt 0 = Disable Bus Collision Interrupt bit 2-1 Unimplemented: Read as '0' bit 0 CCP2IE: CCP2 Interrupt Enable bit 1 = Enables the CCP2 interrupt 0 = Disables the CCP2 interrupt 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 #### 2.2.2.7 PIR2 Register The PIR2 register contains the flag bits for the CCP2 interrupt, the SSP bus collision interrupt and the EEPROM write operation interrupt. Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt. #### REGISTER 2-7: PIR2 REGISTER (ADDRESS 0Dh) | L | J-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | |-------|-----|----------|-----|-------|-------|-----|-----|--------| | - | _ | Reserved | _ | EEIF | BCLIF | _ | _ | CCP2IF | | bit 7 | | | | | | | | bit 0 | Note: bit 7 Unimplemented: Read as '0' bit 6 Reserved: Always maintain this bit clear bit 5 Unimplemented: Read as '0' bit 4 **EEIF**: EEPROM Write Operation Interrupt Flag bit 1 = The write operation completed (must be cleared in software) 0 = The write operation is not complete or has not been started bit 3 BCLIF: Bus Collision Interrupt Flag bit 1 = A bus collision has occurred in the SSP, when configured for I2C Master mode 0 = No bus collision has occurred bit 2-1 **Unimplemented:** Read as '0' bit 0 CCP2IF: CCP2 Interrupt Flag bit Capture mode: 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register capture occurred Compare mode: 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM mode: Unused 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 ### 2.2.2.8 PCON Register The Power Control (PCON) Register contains flag bits to allow differentiation between a Power-on Reset (POR), a Brown-out Reset (BOR), a Watchdog Reset (WDT), and an external $\overline{\text{MCLR}}$ Reset. BOR is unknown on POR. It must be set by the user and checked on subsequent RESETS to see if BOR is clear, indicating a brown-out has occurred. The BOR status bit is a "don't care" and is not predictable if the brown-out circuit is disabled (by clearing the BODEN bit in the configuration word). ### REGISTER 2-8: PCON REGISTER (ADDRESS 8Eh) | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-1 | |-------|-----|-----|-----|-----|-----|-------|-------| | _ | _ | _ | _ | _ | _ | POR | BOR | | bit 7 | | | | | | | bit 0 | Note: bit 7-2 **Unimplemented:** Read as '0' bit 1 **POR**: Power-on Reset Status bit 1 = No Power-on Reset occurred 0 = A Power-on Reset occurred (must be set in software after a Power-on Reset occurs) bit 0 BOR: Brown-out Reset Status bit 1 = No Brown-out Reset occurred 0 = A Brown-out Reset occurred (must be set in software after a Brown-out Reset occurs) 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 #### 2.3 PCL and PCLATH The program counter (PC) is 13-bits wide. The low byte comes from the PCL register, which is a readable and writable register. The upper bits (PC<12:8>) are not readable, but are indirectly writable through the PCLATH register. On any RESET, the upper bits of the PC will be cleared. Figure 2-5 shows the two situations for the loading of the PC. The upper example in the figure shows how the PC is loaded on a write to PCL (PCLATH<4:0> $\rightarrow$ PCH). The lower example in the figure shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3> $\rightarrow$ PCH). FIGURE 2-5: LOADING OF PC IN DIFFERENT SITUATIONS #### 2.3.1 COMPUTED GOTO A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block). Refer to the application note, "Implementing a Table Read" (AN556). #### 2.3.2 STACK The PIC16F87X family has an 8-level deep x 13-bit wide hardware stack. The stack space is not part of either program or data space and the stack pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed, or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation. The stack operates as a circular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on). - Note 1: There are no status bits to indicate stack overflow or stack underflow conditions. - 2: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW and RETFIE instructions, or the vectoring to an interrupt address. ### 2.4 Program Memory Paging All PIC16F87X devices are capable of addressing a continuous 8K word block of program memory. The CALL and GOTO instructions provide only 11 bits of address to allow branching within any 2K program memory page. When doing a CALL or GOTO instruction, the upper 2 bits of the address are provided by PCLATH<4:3>. When doing a CALL or GOTO instruction, the user must ensure that the page select bits are programmed so that the desired program memory page is addressed. If a return from a CALL instruction (or interrupt) is executed, the entire 13-bit PC is popped off the stack. Therefore, manipulation of the PCLATH<4:3> bits is not required for the return instructions (which POPs the address from the stack). Note: The contents of the PCLATH register are unchanged after a RETURN or RETFIE instruction is executed. The user must rewrite the contents of the PCLATH register for any subsequent subroutine calls or GOTO instructions. Example 2-1 shows the calling of a subroutine in page 1 of the program memory. This example assumes that PCLATH is saved and restored by the Interrupt Service Routine (if interrupts are used). ### EXAMPLE 2-1: CALL OF A SUBROUTINE IN PAGE 1 FROM PAGE 0 ``` ORG 0x500 BCF PCLATH, 4 BSF PCLATH, 3 ;Select page 1 ; (800h-FFFh) CALL SUB1 P1 ;Call subroutine in ;page 1 (800h-FFFh) ;page 1 (800h-FFFh) ORG 0x900 SUB1 P1 ; called subroutine ;page 1 (800h-FFFh) RETURN ;return to ;Call subroutine ;in page 0 ; (000h-7FFh) ``` # 2.5 Indirect Addressing, INDF and FSR Registers The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing. Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses the register pointed to by the File Select Register, FSR. Reading the INDF register itself, indirectly (FSR = '0') will read 00h. Writing to the INDF register indirectly results in a no operation (although status bits may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS<7>), as shown in Figure 2-6. A simple program to clear RAM locations 20h-2Fh using indirect addressing is shown in Example 2-2. #### **EXAMPLE 2-2: INDIRECT ADDRESSING** | | MOVLW | 0x20 | ;initialize pointer | |----------|-------|-------|----------------------| | | MOVWF | FSR | ;to RAM | | NEXT | CLRF | INDF | clear INDF register; | | | INCF | FSR,F | ;inc pointer | | | BTFSS | FSR,4 | ;all done? | | | GOTO | NEXT | ;no clear next | | CONTINUE | | | | | | : | | ;yes continue | | | | | _ | FIGURE 2-6: DIRECT/INDIRECT ADDRESSING # PIC16F87X NOTES: #### 3.0 I/O PORTS Some pins for these I/O ports are multiplexed with an alternate function for the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin. Additional information on I/O ports may be found in the PICmicro™ Mid-Range Reference Manual, (DS33023). ### 3.1 PORTA and the TRISA Register PORTA is a 6-bit wide, bi-directional port. The corresponding data direction register is TRISA. Setting a TRISA bit (= 1) will make the corresponding PORTA pin an input (i.e., put the corresponding output driver in a Hi-Impedance mode). Clearing a TRISA bit (= 0) will make the corresponding PORTA pin an output (i.e., put the contents of the output latch on the selected pin). Reading the PORTA register reads the status of the pins, whereas writing to it will write to the port latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, the value is modified and then written to the port data latch. Pin RA4 is multiplexed with the Timer0 module clock input to become the RA4/T0CKI pin. The RA4/T0CKI pin is a Schmitt Trigger input and an open drain output. All other PORTA pins have TTL input levels and full CMOS output drivers. Other PORTA pins are multiplexed with analog inputs and analog VREF input. The operation of each pin is selected by clearing/setting the control bits in the ADCON1 register (A/D Control Register1). **Note:** On a Power-on Reset, these pins are configured as analog inputs and read as '0'. The TRISA register controls the direction of the RA pins, even when they are being used as analog inputs. The user must ensure the bits in the TRISA register are maintained set when using them as analog inputs. ### **EXAMPLE 3-1: INITIALIZING PORTA** | | | | • • • | ALIZINO I OKTA | |-------|---------|-----|-------|-----------------------| | BCF | STATUS, | RP0 | ; | | | BCF | STATUS, | RP1 | ; | Bank0 | | CLRF | PORTA | | ; | Initialize PORTA by | | | | | ; | clearing output | | | | | ; | data latches | | BSF | STATUS, | RP0 | ; | Select Bank 1 | | MOVLW | 0x06 | | ; | Configure all pins | | MOVWF | ADCON1 | | ; | as digital inputs | | MOVLW | 0xCF | | ; | Value used to | | | | | ; | initialize data | | | | | ; | direction | | MOVWF | TRISA | | ; | Set RA<3:0> as inputs | | | | | ; | RA<5:4> as outputs | | | | | ; | TRISA<7:6>are always | | | | | ; | read as '0'. | | | | | | | ### FIGURE 3-1: BLOCK DIAGRAM OF RA3:RA0 AND RA5 PINS ### FIGURE 3-2: BLOCK DIAGRAM OF RA4/T0CKI PIN ### PIC16F87X TABLE 3-1: PORTA FUNCTIONS | Name | Bit# | Buffer | Function | |--------------|------|--------|---------------------------------------------------------------------------------| | RA0/AN0 | bit0 | TTL | Input/output or analog input. | | RA1/AN1 | bit1 | TTL | Input/output or analog input. | | RA2/AN2 | bit2 | TTL | Input/output or analog input. | | RA3/AN3/VREF | bit3 | TTL | Input/output or analog input or VREF. | | RA4/T0CKI | bit4 | ST | Input/output or external clock input for Timer0. Output is open drain type. | | RA5/SS/AN4 | bit5 | TTL | Input/output or slave select input for synchronous serial port or analog input. | Legend: TTL = TTL input, ST = Schmitt Trigger input TABLE 3-2: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA | 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 | |---------|--------|-------|-------|-------|-------------------------------|-------|-------|-------|-------|--------------------------|---------------------------| | 05h | PORTA | _ | _ | RA5 | RA4 | RA3 | RA2 | RA1 | RA0 | 0x 0000 | 0u 0000 | | 85h | TRISA | _ | _ | PORTA | PORTA Data Direction Register | | | | | | 11 1111 | | 9Fh | ADCON1 | ADFM | _ | _ | _ | PCFG3 | PCFG2 | PCFG1 | PCFG0 | 0- 0000 | 0- 0000 | Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by PORTA. Note: When using the SSP module in SPI Slave mode and $\overline{SS}$ enabled, the A/D converter must be set to one of the following modes, where PCFG3:PCFG0 = 0100, 0101, 011x, 1101, 1111. ### 3.2 PORTB and the TRISB Register PORTB is an 8-bit wide, bi-directional port. The corresponding data direction register is TRISB. Setting a TRISB bit (= 1) will make the corresponding PORTB pin an input (i.e., put the corresponding output driver in a Hi-Impedance mode). Clearing a TRISB bit (= 0) will make the corresponding PORTB pin an output (i.e., put the contents of the output latch on the selected pin). Three pins of PORTB are multiplexed with the Low Voltage Programming function: RB3/PGM, RB6/PGC and RB7/PGD. The alternate functions of these pins are described in the Special Features Section. Each of the PORTB pins has a weak internal pull-up. A single control bit can turn on all the pull-ups. This is performed by clearing bit RBPU (OPTION\_REG<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 3-3: BLOCK DIAGRAM OF RB3:RB0 PINS Four of the PORTB pins, RB7:RB4, have an interrupton-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 interrupton-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: - 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. 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. This interrupt-on-mismatch feature, together with soft-ware configureable 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 Strokes" (AN552). RB0/INT is an external interrupt input pin and is configured using the INTEDG bit (OPTION\_REG<6>). RB0/INT is discussed in detail in Section 12.10.1. FIGURE 3-4: BLOCK DIAGRAM OF RB7:RB4 PINS ### PIC16F87X TABLE 3-3: PORTB FUNCTIONS | Name | Bit# | Buffer | Function | |------------------------|------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------| | RB0/INT | bit0 | TTL/ST <sup>(1)</sup> | Input/output pin or external interrupt input. Internal software programmable weak pull-up. | | RB1 | bit1 | TTL | Input/output pin. Internal software programmable weak pull-up. | | RB2 | bit2 | TTL | Input/output pin. Internal software programmable weak pull-up. | | RB3/PGM <sup>(3)</sup> | bit3 | TTL | Input/output pin or programming pin in LVP mode. Internal software programmable weak pull-up. | | RB4 | bit4 | TTL | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up. | | RB5 | bit5 | TTL | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up. | | RB6/PGC | bit6 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change) or In-Circuit Debugger pin. Internal software programmable weak pull-up. Serial programming clock. | | RB7/PGD | bit7 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change) or In-Circuit Debugger pin. Internal software programmable weak pull-up. Serial programming data. | Legend: TTL = TTL input, 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. - **3:** Low Voltage ICSP Programming (LVP) is enabled by default, which disables the RB3 I/O function. LVP must be disabled to enable RB3 as an I/O pin and allow maximum compatibility to the other 28-pin and 40-pin mid-range devices. TABLE 3-4: SUMMARY OF REGISTERS ASSOCIATED WITH PORTB | 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 | |-----------|------------|-------|----------------------------|-------|-------|-------|-------|-------|-------|--------------------------|---------------------------| | 06h, 106h | PORTB | RB7 | RB6 | RB5 | RB4 | RB3 | RB2 | RB1 | RB0 | xxxx xxxx | uuuu uuuu | | 86h, 186h | TRISB | PORTB | PORTB Data Direction Regis | | | | | | | 1111 1111 | 1111 1111 | | 81h, 181h | OPTION_REG | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 1111 1111 | Legend: x = unknown, u = unchanged. Shaded cells are not used by PORTB. ### 3.3 PORTC and the TRISC Register PORTC is an 8-bit wide, bi-directional port. The corresponding data direction register is TRISC. Setting a TRISC bit (= 1) will make the corresponding PORTC pin an input (i.e., put the corresponding output driver in a Hi-Impedance mode). Clearing a TRISC bit (= 0) will make the corresponding PORTC pin an output (i.e., put the contents of the output latch on the selected pin). PORTC is multiplexed with several peripheral functions (Table 3-5). PORTC pins have Schmitt Trigger input buffers. When the I<sup>2</sup>C module is enabled, the PORTC<4:3> pins can be configured with normal I<sup>2</sup>C levels, or with SMBus levels by using the CKE bit (SSPSTAT<6>). When enabling peripheral functions, care should be taken in defining TRIS bits for each PORTC pin. Some peripherals override the TRIS bit to make a pin an output, while other peripherals override the TRIS bit to make a pin an input. Since the TRIS bit override is in effect while the peripheral is enabled, read-modify-write instructions (BSF, BCF, XORWF) with TRISC as destination, should be avoided. The user should refer to the corresponding peripheral section for the correct TRIS bit settings. FIGURE 3-5: PORTC BLOCK DIAGRAM (PERIPHERAL OUTPUT OVERRIDE) RC<2:0>, FIGURE 3-6: PORTC E PORTC BLOCK DIAGRAM (PERIPHERAL OUTPUT OVERRIDE) RC<4:3> - Note 1: I/O pins have diode protection to VDD and Vss. - 2: Port/Peripheral select signal selects between port data and peripheral output. - **3:** Peripheral OE (output enable) is only activated if peripheral select is active. data and peripheral output. peripheral select is active. 3: Peripheral OE (output enable) is only activated if ### PIC16F87X TABLE 3-5: PORTC FUNCTIONS | Name | Bit# | Buffer Type | Function | |-----------------|------|-------------|-------------------------------------------------------------------------------------------------| | RC0/T1OSO/T1CKI | bit0 | ST | Input/output port pin or Timer1 oscillator output/Timer1 clock input. | | RC1/T1OSI/CCP2 | bit1 | ST | Input/output port pin or Timer1 oscillator input or Capture2 input/Compare2 output/PWM2 output. | | RC2/CCP1 | bit2 | ST | Input/output port pin or Capture1 input/Compare1 output/PWM1 output. | | RC3/SCK/SCL | bit3 | ST | RC3 can also be the synchronous serial clock for both SPI and I <sup>2</sup> C modes. | | RC4/SDI/SDA | bit4 | ST | RC4 can also be the SPI Data In (SPI mode) or data I/O (I <sup>2</sup> C mode). | | RC5/SDO | bit5 | ST | Input/output port pin or Synchronous Serial Port data output. | | RC6/TX/CK | bit6 | ST | Input/output port pin or USART Asynchronous Transmit or Synchronous Clock. | | RC7/RX/DT | bit7 | ST | Input/output port pin or USART Asynchronous Receive or Synchronous Data. | Legend: ST = Schmitt Trigger input TABLE 3-6: SUMMARY OF REGISTERS ASSOCIATED WITH PORTC | 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 | |---------|-------|-------|--------------------------------------------------|-------|-------|-------|-------|-------|-------|--------------------------|---------------------------| | 07h | PORTC | RC7 | RC6 | RC5 | RC4 | RC3 | RC2 | RC1 | RC0 | xxxx xxxx | uuuu uuuu | | 87h | TRISC | PORTC | ORTC Data Direction Register 1111 1111 1111 1111 | | | | | | | | | Legend: x = unknown, u = unchanged ### 3.4 PORTD and TRISD Registers PORTD and TRISD are not implemented on the PIC16F873 or PIC16F876. PORTD is an 8-bit port with Schmitt Trigger input buffers. Each pin is individually configureable as an input or output. PORTD can be configured as an 8-bit wide microprocessor port (parallel slave port) by setting control bit PSPMODE (TRISE<4>). In this mode, the input buffers are TTL. ### FIGURE 3-7: PORTD BLOCK DIAGRAM (IN I/O PORT MODE) TABLE 3-7: PORTD FUNCTIONS | Name | Bit# | Buffer Type | Function | |----------|------|-----------------------|----------------------------------------------------| | RD0/PSP0 | bit0 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit0. | | RD1/PSP1 | bit1 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit1. | | RD2/PSP2 | bit2 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit2. | | RD3/PSP3 | bit3 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit3. | | RD4/PSP4 | bit4 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit4. | | RD5/PSP5 | bit5 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit5. | | RD6/PSP6 | bit6 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit6. | | RD7/PSP7 | bit7 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit7. | Legend: ST = Schmitt Trigger input, TTL = TTL input Note 1: Input buffers are Schmitt Triggers when in I/O mode and TTL buffers when in Parallel Slave Port mode. TABLE 3-8: SUMMARY OF REGISTERS ASSOCIATED WITH PORTD | 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 | |---------|-------|-------|-------------------------------|-------|---------|---------------------------------------|-------|-------|-------|--------------------------|---------------------------| | 08h | PORTD | RD7 | RD6 | RD5 | RD4 | RD3 | RD2 | RD1 | RD0 | xxxx xxxx | uuuu uuuu | | 88h | TRISD | PORT | PORTD Data Direction Register | | | | | | | | 1111 1111 | | 89h | TRISE | IBF | OBF | IBOV | PSPMODE | PSPMODE — PORTE Data Direction Bits 0 | | | | | 0000 -111 | Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by PORTD. ### 3.5 PORTE and TRISE Register PORTE and TRISE are not implemented on the PIC16F873 or PIC16F876. PORTE has three pins (RE0/RD/AN5, RE1/WR/AN6, and RE2/CS/AN7) which are individually configureable as inputs or outputs. These pins have Schmitt Trigger input buffers. The PORTE pins become the I/O control inputs for the microprocessor port when bit PSPMODE (TRISE<4>) is set. In this mode, the user must make certain that the TRISE<2:0> bits are set, and that the pins are configured as digital inputs. Also ensure that ADCON1 is configured for digital I/O. In this mode, the input buffers are TTL. Register 3-1 shows the TRISE register, which also controls the parallel slave port operation. PORTE pins are multiplexed with analog inputs. When selected for analog input, these pins will read as '0's. TRISE controls the direction of the RE pins, even when they are being used as analog inputs. The user must make sure to keep the pins configured as inputs when using them as analog inputs. **Note:** On a Power-on Reset, these pins are configured as analog inputs, and read as '0'. ### FIGURE 3-8: PORTE BLOCK DIAGRAM (IN I/O PORT MODE) TABLE 3-9: PORTE FUNCTIONS | Name | Bit# | Buffer Type | Function | |------------|------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RE0/RD/AN5 | bit0 | ST/TTL <sup>(1)</sup> | I/O port pin or read control input in Parallel Slave Port mode or analog input: RD 1 = Idle 0 = Read operation. Contents of PORTD register are output to PORTD I/O pins (if chip selected) | | RE1/WR/AN6 | bit1 | ST/TTL <sup>(1)</sup> | I/O port pin or write control input in Parallel Slave Port mode or analog input: WR 1 = Idle 0 = Write operation. Value of PORTD I/O pins is latched into PORTD register (if chip selected) | | RE2/CS/AN7 | bit2 | ST/TTL <sup>(1)</sup> | I/O port pin or chip select control input in Parallel Slave Port mode or analog input: CS 1 = Device is not selected 0 = Device is selected | $\label{eq:loger} \textbf{Legend: ST} = \textbf{Schmitt Trigger input}, \ \ \textbf{TTL} = \textbf{TTL input}$ Note 1: Input buffers are Schmitt Triggers when in I/O mode and TTL buffers when in Parallel Slave Port mode. TABLE 3-10: SUMMARY OF REGISTERS ASSOCIATED WITH PORTE | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR, BOR | Value on<br>all other<br>RESETS | |---------|--------|-------|-------|-------|---------|-------|---------|------------|-----------|-----------------------|---------------------------------| | 09h | PORTE | _ | _ | _ | _ | _ | RE2 | RE1 | RE0 | xxx | uuu | | 89h | TRISE | IBF | OBF | IBOV | PSPMODE | _ | PORTE I | Data Direc | tion Bits | 0000 -111 | 0000 -111 | | 9Fh | ADCON1 | ADFM | _ | _ | _ | PCFG3 | PCFG2 | PCFG1 | PCFG0 | 0- 0000 | 0- 0000 | Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by PORTE. #### REGISTER 3-1: TRISE REGISTER (ADDRESS 89h) | R-0 | R-0 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | |-------|-----|-------|---------|-----|-------|-------|-------| | IBF | OBF | IBOV | PSPMODE | _ | Bit2 | Bit1 | Bit0 | | bit 7 | | | | | | | bit 0 | Parallel Slave Port Status/Control Bits: bit 7 IBF: Input Buffer Full Status bit 1 = A word has been received and is waiting to be read by the CPU 0 = No word has been received bit 6 **OBF**: Output Buffer Full Status bit 1 = The output buffer still holds a previously written word 0 = The output buffer has been read bit 5 **IBOV**: Input Buffer Overflow Detect bit (in Microprocessor mode) 1 = A write occurred when a previously input word has not been read (must be cleared in software) 0 = No overflow occurred bit 4 **PSPMODE**: Parallel Slave Port Mode Select bit 1 = PORTD functions in Parallel Slave Port mode 0 = PORTD functions in general purpose I/O mode bit 3 Unimplemented: Read as '0' **PORTE Data Direction Bits:** bit 2 Bit2: Direction Control bit for pin RE2/CS/AN7 1 = Input 0 = Output bit 1 **Bit1**: Direction Control bit for pin RE1/WR/AN6 1 = Input 0 = Output bit 0 **Bit0**: Direction Control bit for pin RE0/RD/AN5 1 = Input 0 = Output 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 #### 3.6 Parallel Slave Port The Parallel Slave Port (PSP) is not implemented on the PIC16F873 or PIC16F876. PORTD operates as an 8-bit wide Parallel Slave Port or microprocessor port, when control bit PSPMODE (TRISE<4>) is set. In Slave mode, it is asynchronously readable and writable by the external world through $\overline{RD}$ control input pin $\overline{RE0/RD}$ and $\overline{WR}$ control input pin $\overline{RE1/WR}$ . The PSP can directly interface to an 8-bit microprocessor data bus. The external microprocessor can read or write the PORTD latch as an 8-bit latch. Setting bit PSPMODE enables port pin RE0/RD to be the RD input, RE1/WR to be the WR input and RE2/CS to be the $\overline{\text{CS}}$ (chip select) input. For this functionality, the corresponding data direction bits of the TRISE register (TRISE<2:0>) must be configured as inputs (set). The A/D port configuration bits PCFG3:PCFG0 (ADCON1<3:0>) must be set to configure pins RE2:RE0 as digital I/O. There are actually two 8-bit latches: one for data output, and one for data input. The user writes 8-bit data to the PORTD data latch and reads data from the port pin latch (note that they have the same address). In this mode, the TRISD register is ignored, since the external device is controlling the direction of data flow. A write to the PSP occurs when both the $\overline{\text{CS}}$ and $\overline{\text{WR}}$ lines are first detected low. When either the $\overline{\text{CS}}$ or $\overline{\text{WR}}$ lines become high (level triggered), the Input Buffer Full (IBF) status flag bit (TRISE<7>) is set on the Q4 clock cycle, following the next Q2 cycle, to signal the write is complete (Figure 3-10). The interrupt flag bit PSPIF (PIR1<7>) is also set on the same Q4 clock cycle. IBF can only be cleared by reading the PORTD input latch. The Input Buffer Overflow (IBOV) status flag bit (TRISE<5>) is set if a second write to the PSP is attempted when the previous byte has not been read out of the buffer. A read from the PSP occurs when both the $\overline{CS}$ and $\overline{RD}$ lines are first detected low. The Output Buffer Full (OBF) status flag bit (TRISE<6>) is cleared immediately (Figure 3-11), indicating that the PORTD latch is waiting to be read by the external bus. When either the $\overline{CS}$ or $\overline{RD}$ pin becomes high (level triggered), the interrupt flag bit PSPIF is set on the Q4 clock cycle, following the next Q2 cycle, indicating that the read is complete. OBF remains low until data is written to PORTD by the user firmware. When not in PSP mode, the IBF and OBF bits are held clear. However, if flag bit IBOV was previously set, it must be cleared in firmware. An interrupt is generated and latched into flag bit PSPIF when a read or write operation is completed. PSPIF must be cleared by the user in firmware and the interrupt can be disabled by clearing the interrupt enable bit PSPIE (PIE1<7>). FIGURE 3-9: PORTD AND PORTE BLOCK DIAGRAM (PARALLEL SLAVE PORT) FIGURE 3-11: PARALLEL SLAVE PORT READ WAVEFORMS TABLE 3-11: REGISTERS ASSOCIATED WITH PARALLEL SLAVE PORT | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR, BOR | Value on<br>all other<br>RESETS | |---------|--------|----------------------|---------------------------------------------------|-------|---------|-------|---------|-------------|-----------|-----------------------|---------------------------------| | 08h | PORTD | Port Data | Port Data Latch when written: Port pins when read | | | | | | xxxx xxxx | uuuu uuuu | | | 09h | PORTE | _ | _ | _ | _ | _ | RE2 | RE1 | RE0 | xxx | uuu | | 89h | TRISE | IBF | OBF | IBOV | PSPMODE | _ | PORTE D | ata Directi | ion Bits | 0000 -111 | 0000 -111 | | 0Ch | PIR1 | PSPIF <sup>(1)</sup> | ADIF | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF | 0000 0000 | 0000 0000 | | 8Ch | PIE1 | PSPIE <sup>(1)</sup> | ADIE | RCIE | TXIE | SSPIE | CCP1IE | TMR2IE | TMR1IE | 0000 0000 | 0000 0000 | | 9Fh | ADCON1 | ADFM | _ | _ | _ | PCFG3 | PCFG2 | PCFG1 | PCFG0 | 0- 0000 | 0- 0000 | Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the Parallel Slave Port. **Note 1:** Bits PSPIE and PSPIF are reserved on the PIC16F873/876; always maintain these bits clear. # PIC16F87X NOTES: # 4.0 DATA EEPROM AND FLASH PROGRAM MEMORY The Data EEPROM and FLASH Program Memory are readable and writable during normal operation over the entire VDD range. These operations take place on a single byte for Data EEPROM memory and a single word for Program memory. A write operation causes an erase-then-write operation to take place on the specified byte or word. A bulk erase operation may not be issued from user code (which includes removing code protection). Access to program memory allows for checksum calculation. The values written to program memory do not need to be valid instructions. Therefore, up to 14-bit numbers can be stored in memory for use as calibration parameters, serial numbers, packed 7-bit ASCII, etc. Executing a program memory location containing data that form an invalid instruction, results in the execution of a NOP instruction. The EEPROM Data memory is rated for high erase/write cycles (specification D120). The FLASH program memory is rated much lower (specification D130), because EEPROM data memory can be used to store frequently updated values. An on-chip timer controls the write time and it will vary with voltage and temperature, as well as from chip to chip. Please refer to the specifications for exact limits (specifications D122 and D133). A byte or word write automatically erases the location and writes the new value (erase before write). Writing to EEPROM data memory does not impact the operation of the device. Writing to program memory will cease the execution of instructions until the write is complete. The program memory cannot be accessed during the write. During the write operation, the oscillator continues to run, the peripherals continue to function and interrupt events will be detected and essentially "queued" until the write is complete. When the write completes, the next instruction in the pipeline is executed and the branch to the interrupt vector will take place, if the interrupt is enabled and occurred during the write. Read and write access to both memories take place indirectly through a set of Special Function Registers (SFR). The six SFRs used are: - EEDATA - EEDATH - EEADR - EEADRH - EECON1 - EECON2 The EEPROM data memory allows byte read and write operations without interfering with the normal operation of the microcontroller. When interfacing to EEPROM data memory, the EEADR register holds the address to be accessed. Depending on the operation, the EEDATA register holds the data to be written, or the data read, at the address in EEADR. The PIC16F873/874 devices have 128 bytes of EEPROM data memory and therefore, require that the MSb of EEADR remain clear. The EEPROM data memory on these devices do not wrap around to 0, i.e., 0x80 in the EEADR does not map to 0x00. The PIC16F876/877 devices have 256 bytes of EEPROM data memory and therefore, uses all 8-bits of the EEADR. The FLASH program memory allows non-intrusive read access, but write operations cause the device to stop executing instructions, until the write completes. When interfacing to the program memory, the EEADRH:EEADR registers form a two-byte word, which holds the 13-bit address of the memory location being accessed. The register combination of EEDATH:EEDATA holds the 14-bit data for writes, or reflects the value of program memory after a read operation. Just as in EEPROM data memory accesses, the value of the EEADRH:EEADR registers must be within the valid range of program memory, depending on the device: 0000h to 1FFFh for the PIC16F873/874, or 0000h to 3FFFh for the PIC16F876/877. Addresses outside of this range do not wrap around to 0000h (i.e., 4000h does not map to 0000h on the PIC16F877). #### 4.1 **EECON1** and **EECON2** Registers The EECON1 register is the control register for configuring and initiating the access. The EECON2 register is not a physically implemented register, but is used exclusively in the memory write sequence to prevent inadvertent writes. There are many bits used to control the read and write operations to EEPROM data and FLASH program memory. The EEPGD bit determines if the access will be a program or data memory access. When clear, any subsequent operations will work on the EEPROM data memory. When set, all subsequent operations will operate in the program memory. Read operations only use one additional bit, RD, which initiates the read operation from the desired memory location. Once this bit is set, the value of the desired memory location will be available in the data registers. This bit cannot be cleared by firmware. It is automatically cleared at the end of the read operation. For EEPROM data memory reads, the data will be available in the EEDATA register in the very next instruction cycle after the RD bit is set. For program memory reads, the data will be loaded into the EEDATH:EEDATA registers, following the second instruction after the RD bit is set. Write operations have two control bits, WR and WREN, and two status bits, WRERR and EEIF. The WREN bit is used to enable or disable the write operation. When WREN is clear, the write operation will be disabled. Therefore, the WREN bit must be set before executing a write operation. The WR bit is used to initiate the write operation. It also is automatically cleared at the end of the write operation. The interrupt flag EEIF is used to determine when the memory write completes. This flag must be cleared in software before setting the WR bit. For EEPROM data memory, once the WREN bit and the WR bit have been set, the desired memory address in EEADR will be erased, followed by a write of the data in EEDATA. This operation takes place in parallel with the microcontroller continuing to execute normally. When the write is complete, the EEIF flag bit will be set. For program memory, once the WREN bit and the WR bit have been set, the microcontroller will cease to execute instructions. The desired memory location pointed to by EEADRH:EEADR will be erased. Then, the data value in EEDATH:EEDATA will be programmed. When complete, the EEIF flag bit will be set and the microcontroller will continue to execute code. The WRERR bit is used to indicate when the PIC16F87X device has been reset during a write operation. WRERR should be cleared after Power-on Reset. Thereafter, it should be checked on any other RESET. The WRERR bit is set when a write operation is interrupted by a $\overline{MCLR}$ Reset, or a WDT Time-out Reset, during normal operation. In these situations, following a RESET, the user should check the WRERR bit and rewrite the memory location, if set. The contents of the data registers, address registers and EEPGD bit are not affected by either $\overline{MCLR}$ Reset, or WDT Time-out Reset, during normal operation. ### REGISTER 4-1: EECON1 REGISTER (ADDRESS 18Ch) | R/W-x | U-0 | U-0 | U-0 | R/W-x | R/W-0 | R/S-0 | R/S-0 | |-------|-----|-----|-----|-------|-------|-------|-------| | EEPGD | _ | _ | _ | WRERR | WREN | WR | RD | | bit 7 | | | | | | | bit 0 | bit 7 **EEPGD**: Program/Data EEPROM Select bit 1 = Accesses program memory 0 = Accesses data memory (This bit cannot be changed while a read or write operation is in progress) bit 6-4 **Unimplemented:** Read as '0' bit 3 **WRERR:** EEPROM Error Flag bit 1 = A write operation is prematurely terminated (any MCLR Reset or any WDT Reset during normal operation) 0 = The write operation completed bit 2 WREN: EEPROM Write Enable bit 1 = Allows write cycles 0 = Inhibits write to the EEPROM bit 1 WR: Write Control bit 1 = Initiates a write cycle. (The bit is cleared by hardware once write is complete. The WR bit can only be set (not cleared) in software.) 0 = Write cycle to the EEPROM is complete bit 0 RD: Read Control bit 1 = Initiates an EEPROM read. (RD is cleared in hardware. The RD bit can only be set (not cleared) in software.) 0 = Does not initiate an EEPROM read | 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 | # 4.2 Reading the EEPROM Data Memory Reading EEPROM data memory only requires that the desired address to access be written to the EEADR register and clear the EEPGD bit. After the RD bit is set, data will be available in the EEDATA register on the very next instruction cycle. EEDATA will hold this value until another read operation is initiated or until it is written by firmware. The steps to reading the EEPROM data memory are: - Write the address to EEDATA. Make sure that the address is not larger than the memory size of the PIC16F87X device. - Clear the EEPGD bit to point to EEPROM data memory. - 3. Set the RD bit to start the read operation. - Read the data from the EEDATA register. #### EXAMPLE 4-1: EEPROM DATA READ | BSF | STATUS, | RP1 | ; | |-------|---------|-------|-----------------------| | BCF | STATUS, | RP0 | ;Bank 2 | | MOVF | ADDR, W | | ;Write address | | MOVWF | EEADR | | ;to read from | | BSF | STATUS, | RP0 | ;Bank 3 | | BCF | EECON1, | EEPGD | ;Point to Data memory | | BSF | EECON1, | RD | ;Start read operation | | BCF | STATUS, | RP0 | ;Bank 2 | | MOVF | EEDATA, | W | ;W = EEDATA | # 4.3 Writing to the EEPROM Data Memory There are many steps in writing to the EEPROM data memory. Both address and data values must be written to the SFRs. The EEPGD bit must be cleared, and the WREN bit must be set, to enable writes. The WREN bit should be kept clear at all times, except when writing to the EEPROM data. The WR bit can only be set if the WREN bit was set in a previous operation, i.e., they both cannot be set in the same operation. The WREN bit should then be cleared by firmware after the write. Clearing the WREN bit before the write actually completes will not terminate the write in progress. Writes to EEPROM data memory must also be prefaced with a special sequence of instructions, that prevent inadvertent write operations. This is a sequence of five instructions that must be executed without interruptions. The firmware should verify that a write is not in progress, before starting another cycle. The steps to write to EEPROM data memory are: - 1. If step 10 is not implemented, check the WR bit to see if a write is in progress. - Write the address to EEADR. Make sure that the address is not larger than the memory size of the PIC16F87X device. - Write the 8-bit data value to be programmed in the EEDATA register. - Clear the EEPGD bit to point to EEPROM data memory. - 5. Set the WREN bit to enable program operations. - 6. Disable interrupts (if enabled). - 7. Execute the special five instruction sequence: - Write 55h to EECON2 in two steps (first to W, then to EECON2) - Write AAh to EECON2 in two steps (first to W, then to EECON2) - · Set the WR bit - 8. Enable interrupts (if using interrupts). - Clear the WREN bit to disable program operations. - 10. At the completion of the write cycle, the WR bit is cleared and the EEIF interrupt flag bit is set. (EEIF must be cleared by firmware.) If step 1 is not implemented, then firmware should check for EEIF to be set, or WR to clear, to indicate the end of the program cycle. #### **EXAMPLE 4-2: EEPROM DATA WRITE** | BSF | STATUS, RP1 | ; | |-------|---------------|--------------------------| | BSF | STATUS, RPO | ;Bank 3 | | BTFSC | EECON1, WR | ;Wait for | | GOTO | \$-1 | ;write to finish | | BCF | STATUS, RPO | ;Bank 2 | | MOVF | ADDR, W | ;Address to | | MOVWF | EEADR | ;write to | | MOVF | VALUE, W | ;Data to | | MOVWF | EEDATA | ;write | | BSF | STATUS, RPO | ;Bank 3 | | BCF | EECON1, EEPGD | ;Point to Data memory | | BSF | EECON1, WREN | ;Enable writes | | | | ;Only disable interrupts | | BCF | INTCON, GIE | ;if already enabled, | | | | ;otherwise discard | | MOVLW | 0x55 | ;Write 55h to | | MOVWF | EECON2 | ; EECON2 | | MOVLW | 0xAA | ;Write AAh to | | MOVWF | EECON2 | ; EECON2 | | BSF | EECON1, WR | ;Start write operation | | | | ;Only enable interrupts | | BSF | INTCON, GIE | ;if using interrupts, | | | | ;otherwise discard | | BCF | EECON1, WREN | ;Disable writes | | 1 | | | ### 4.4 Reading the FLASH Program Memory Reading FLASH program memory is much like that of EEPROM data memory, only two NOP instructions must be inserted after the RD bit is set. These two instruction cycles that the NOP instructions execute, will be used by the microcontroller to read the data out of program memory and insert the value into the EEDATH:EEDATA registers. Data will be available following the second NOP instruction. EEDATH and EEDATA will hold their value until another read operation is initiated, or until they are written by firmware. The steps to reading the FLASH program memory are: - Write the address to EEADRH:EEADR. Make sure that the address is not larger than the memory size of the PIC16F87X device. - Set the EEPGD bit to point to FLASH program memory. - 3. Set the RD bit to start the read operation. - Execute two NOP instructions to allow the microcontroller to read out of program memory. - Read the data from the EEDATH:EEDATA registers. #### **EXAMPLE 4-3: FLASH PROGRAM READ** | BSF | STATUS, RP1 | ; | |-------|---------------|--------------------------| | BCF | STATUS, RP0 | ;Bank 2 | | MOVF | ADDRL, W | ;Write the | | MOVWF | EEADR | ;address bytes | | MOVF | ADDRH,W | ;for the desired | | MOVWF | EEADRH | ;address to read | | BSF | STATUS, RP0 | ;Bank 3 | | BSF | EECON1, EEPGD | ;Point to Program memory | | BSF | EECON1, RD | ;Start read operation | | NOP | | ;Required two NOPs | | NOP | | ; | | BCF | STATUS, RP0 | ;Bank 2 | | MOVF | EEDATA, W | ;DATAL = EEDATA | | MOVWF | DATAL | ; | | MOVF | EEDATH,W | ;DATAH = EEDATH | | MOVWF | DATAH | ; | | | | | # 4.5 Writing to the FLASH Program Memory Writing to FLASH program memory is unique, in that the microcontroller does not execute instructions while programming is taking place. The oscillator continues to run and all peripherals continue to operate and queue interrupts, if enabled. Once the write operation completes (specification D133), the processor begins executing code from where it left off. The other important difference when writing to FLASH program memory, is that the WRT configuration bit, when clear, prevents any writes to program memory (see Table 4-1). Just like EEPROM data memory, there are many steps in writing to the FLASH program memory. Both address and data values must be written to the SFRs. The EEPGD bit must be set, and the WREN bit must be set to enable writes. The WREN bit should be kept clear at all times, except when writing to the FLASH Program memory. The WR bit can only be set if the WREN bit was set in a previous operation, i.e., they both cannot be set in the same operation. The WREN bit should then be cleared by firmware after the write. Clearing the WREN bit before the write actually completes will not terminate the write in progress. Writes to program memory must also be prefaced with a special sequence of instructions that prevent inadvertent write operations. This is a sequence of five instructions that must be executed without interruption for each byte written. These instructions must then be followed by two NOP instructions to allow the microcontroller to setup for the write operation. Once the write is complete, the execution of instructions starts with the instruction after the second NOP. The steps to write to program memory are: - Write the address to EEADRH:EEADR. Make sure that the address is not larger than the memory size of the PIC16F87X device. - Write the 14-bit data value to be programmed in the EEDATH:EEDATA registers. - Set the EEPGD bit to point to FLASH program memory. - 4. Set the WREN bit to enable program operations. - 5. Disable interrupts (if enabled). - Execute the special five instruction sequence: - Write 55h to EECON2 in two steps (first to W, then to EECON2) - Write AAh to EECON2 in two steps (first to W, then to EECON2) - · Set the WR bit - Execute two NOP instructions to allow the microcontroller to setup for write operation. - 8. Enable interrupts (if using interrupts). - Clear the WREN bit to disable program operations. At the completion of the write cycle, the WR bit is cleared and the EEIF interrupt flag bit is set. (EEIF must be cleared by firmware.) Since the microcontroller does not execute instructions during the write cycle, the firmware does not necessarily have to check either EEIF, or WR, to determine if the write had finished. #### EXAMPLE 4-4: FLASH PROGRAM WRITE ``` BSF STATUS, RP1 BCF STATUS, RPO ;Bank 2 ;Write address MOVF ADDRL, W MOVWF EEADR ; of desired ADDRH, W MOVF ;program memory MOVWE EEADRH ;location MOVF VALUEL, W ;Write value to MOVWF EEDATA ;program at MOVF VALUEH, W ;desired memory MOVWF EEDATH ;location STATUS, RPO BSF ;Bank 3 BSF EECON1, EEPGD ; Point to Program memory BSF EECON1, WREN ; Enable writes ;Only disable interrupts INTCON, GIE ;if already enabled, BCF ;otherwise discard MOVLW 0x55 ;Write 55h to EECON2 ; EECON2 MOVWF MOVLW 0xAA ;Write AAh to MOVWF EECON2 ; EECON2 BSF EECON1, WR :Start write operation NOP ; Two NOPs to allow micro NOP ;to setup for write ;Only enable interrupts BSF INTCON, GIE ; if using interrupts, ;otherwise discard BCF EECON1, WREN ;Disable writes ``` ### 4.6 Write Verify The PIC16F87X devices do not automatically verify the value written during a write operation. Depending on the application, good programming practice may dictate that the value written to memory be verified against the original value. This should be used in applications where excessive writes can stress bits near the specified endurance limits. ### 4.7 Protection Against Spurious Writes There are conditions when the device may not want to write to the EEPROM data memory or FLASH program memory. To protect against these spurious write conditions, various mechanisms have been built into the PIC16F87X devices. On power-up, the WREN bit is cleared and the Power-up Timer (if enabled) prevents writes. The write initiate sequence, and the WREN bit together, help prevent any accidental writes during brown-out, power glitches, or firmware malfunction. ### 4.8 Operation While Code Protected The PIC16F87X devices have two code protect mechanisms, one bit for EEPROM data memory and two bits for FLASH program memory. Data can be read and written to the EEPROM data memory, regardless of the state of the code protection bit, CPD. When code protection is enabled and CPD cleared, external access via ICSP is disabled, regardless of the state of the program memory code protect bits. This prevents the contents of EEPROM data memory from being read out of the device. The state of the program memory code protect bits, CP0 and CP1, do not affect the execution of instructions out of program memory. The PIC16F87X devices can always read the values in program memory, regardless of the state of the code protect bits. However, the state of the code protect bits and the WRT bit will have different effects on writing to program memory. Table 4-1 shows the effect of the code protect bits and the WRT bit on program memory. Once code protection has been enabled for either EEPROM data memory or FLASH program memory, only a full erase of the entire device will disable code protection. ### 4.9 FLASH Program Memory Write Protection The configuration word contains a bit that write protects the FLASH program memory, called WRT. This bit can only be accessed when programming the PIC16F87X device via ICSP. Once write protection is enabled, only an erase of the entire device will disable it. When enabled, write protection prevents any writes to FLASH program memory. Write protection does not affect program memory reads. TABLE 4-1: READ/WRITE STATE OF INTERNAL FLASH PROGRAM MEMORY | Coi | Configuration Bits | | Managed and the | Internal | Internal | ICCD Deed | ICCD Weite | | |-----|--------------------|-----|--------------------|----------|----------|-----------|------------|--| | CP1 | CP0 | WRT | Memory Location | Read | Write | ICSP Read | ICSP Write | | | 0 | 0 | х | All program memory | Yes | No | No | No | | | 0 | 1 | 0 | Unprotected areas | Yes | No | Yes | No | | | 0 | 1 | 0 | Protected areas | Yes | No | No | No | | | 0 | 1 | 1 | Unprotected areas | Yes | Yes | Yes | No | | | 0 | 1 | 1 | Protected areas | Yes | No | No | No | | | 1 | 0 | 0 | Unprotected areas | Yes | No | Yes | No | | | 1 | 0 | 0 | Protected areas | Yes | No | No | No | | | 1 | 0 | 1 | Unprotected areas | Yes | Yes | Yes | No | | | 1 | 0 | 1 | Protected areas | Yes | No | No | No | | | 1 | 1 | 0 | All program memory | Yes | No | Yes | Yes | | | 1 | 1 | 1 | All program memory | Yes | Yes | Yes | Yes | | TABLE 4-2: REGISTERS ASSOCIATED WITH DATA EEPROM/PROGRAM FLASH | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS | |-------------------------|--------|--------|---------------------------------------------|-------------|---------------------------|--------------|--------|-------|--------|--------------------------|---------------------------------| | 0Bh, 8Bh,<br>10Bh, 18Bh | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | 10Dh | EEADR | EEPROM | l Address | Register | , Low Byte | е | | | | xxxx xxxx | uuuu uuuu | | 10Fh | EEADRH | _ | | _ | EEPROM Address, High Byte | | | | | xxxx xxxx | uuuu uuuu | | 10Ch | EEDATA | EEPROM | 1 Data Re | egister, Lo | w Byte | | | | | xxxx xxxx | uuuu uuuu | | 10Eh | EEDATH | _ | _ | EEPROI | M Data Re | egister, Hig | h Byte | | | xxxx xxxx | uuuu uuuu | | 18Ch | EECON1 | EEPGD | _ | _ | _ | WRERR | WREN | WR | RD | x x000 | x u000 | | 18Dh | EECON2 | EEPROM | Control Register2 (not a physical register) | | | | | | _ | _ | | | 8Dh | PIE2 | _ | (1) | _ | EEIE | BCLIE | _ | _ | CCP2IE | -r-0 00 | -r-0 00 | | 0Dh | PIR2 | _ | (1) | _ | EEIF | BCLIF | _ | _ | CCP2IF | -r-0 00 | -r-0 00 | Legend: x = unknown, u = unchanged, r = reserved, - = unimplemented, read as '0'. Shaded cells are not used during FLASH/EEPROM access. Note 1: These bits are reserved; always maintain these bits clear. ### 5.0 TIMERO MODULE The Timer0 module timer/counter has the following features: - 8-bit timer/counter - · Readable and writable - 8-bit software programmable prescaler - · Internal or external clock select - · Interrupt on overflow from FFh to 00h - · Edge select for external clock Figure 5-1 is a block diagram of the Timer0 module and the prescaler shared with the WDT. Additional information on the Timer0 module is available in the PICmicro™ Mid-Range MCU Family Reference Manual (DS33023). Timer mode is selected by clearing bit T0CS (OPTION\_REG<5>). In Timer mode, the Timer0 module will increment every instruction cycle (without prescaler). If the TMR0 register is written, the increment is inhibited for the following two instruction cycles. The user can work around this by writing an adjusted value to the TMR0 register. Counter mode is selected by setting bit T0CS (OPTION\_REG<5>). In Counter mode, Timer0 will increment either on every rising, or falling edge of pin RA4/T0CKI. The incrementing edge is determined by the Timer0 Source Edge Select bit, T0SE (OPTION\_REG<4>). Clearing bit T0SE selects the rising edge. Restrictions on the external clock input are discussed in detail in Section 5.2. The prescaler is mutually exclusively shared between the Timer0 module and the Watchdog Timer. The prescaler is not readable or writable. Section 5.3 details the operation of the prescaler. ### 5.1 Timer0 Interrupt The TMR0 interrupt is generated when the TMR0 register overflows from FFh to 00h. This overflow sets bit T0IF (INTCON<2>). The interrupt can be masked by clearing bit T0IE (INTCON<5>). Bit T0IF must be cleared in software by the Timer0 module Interrupt Service Routine before re-enabling this interrupt. The TMR0 interrupt cannot awaken the processor from SLEEP, since the timer is shut-off during SLEEP. FIGURE 5-1: BLOCK DIAGRAM OF THE TIMERO/WDT PRESCALER ### **Features** - Conductive plastic - Linear and audio tapers - PC board and bushing mount - Plastic bushing and plastic shaft - Withstands typical industrial washing processes ■ Compact package saves board and panel ### 3310 - 9mm Square Sealed Panel Control | Electrical Characteristics | | |------------------------------------------------------------|--------------------------------------------------------------------------------------------| | Standard Resistance Range - Linear | 1K ohms to 1 megohr | | Independent Linearity | ±209<br>±59 | | | | | | | | | | | | 900 VAC minimur | | 70,000 Feet | | | | 1,000 megohms minimur | | Power Rating @ 70°C (Derate to 0 at 125°C - Voltage Limite | ed By Power Dissipation or 200 VAC, Whichever is Less) | | Environmental Characteristics | | | | +1°C to +125° | | | -55°C to +125° | | TCR (Over Storage Temperature Range) | ±1,000ppm/° | | | | | | ±1% maximur | | | ±1% maximur | | | | | | ±1% maximur | | | ±1% maximur | | | ±10% TRS maximur | | Rotational Life-No Load (50,000 Cycles) | ±5% TRS maximur | | CRV | ±3% or 3 ohms (whichever is greate | | Moisture Resistance | ±10% TR | | Mechanical Characteristics | | | Stop Strength | | | | | | Torque - Running | | | | | | | | | Terminals | Solderable pin | | MarkingManufactu | irer's symbol and model number, product code, terminal style, date code and resistance cod | #### **Standard Resistance Table** | Resistance | Resistance | |------------|------------| | (Ohms) | Code | | 1,000 | 102 | | 2,000 | 202 | | 5,000 | 502 | | 10,000 | 103 | | 20,000 | 203 | | 50,000 | 503 | | 100,000 | 104 | | 200,000 | 204 | | 500,000 | 504 | | 1,000,000 | 105 | Popular values listed in boldface. Consult factory for special resistances. #### Part Numbering System 3310 Y - 0 0 1 - 103 Model Number Designator 3310 = 9mm Panel Control Terminal Style Designator Single Cup: R = In-line Straight Terminals Side Exit 2.54 mm centers R = In-line Terminals Rear Exit 2.54 mm centers P = 5.08mm x 2.54mm Triangular Pattern Rear Exit Y = 5.08mm x 5.08mmTriangular Pattern Rear Exit Dual Cup (Pot/Pot or Pot/Switch): H = Dual In-line Straight Terminals Rear Exit 2.54 mm centers Shaft End Designator 0 = Shaft End Slotted 1 = Shaft End Flatted Shaft Length Designator 0 = 12.7mm FMS Long Plastic Shaft (Available w/bushing only) 1 = 19.05mm FMS Long Plastic Shaft (Available w/bushing only) 2 = 5.59mm FMS Long Plastic Shaft (Bushingless version only) Bushing Designator Pot (or Pot/Pot): - 1 = 6.35mm x 6.35mm Plastic 2 = 6.35mm x 6.35mm Ni Plated Brass - 5 = Bushingless (Board Level Control) Pot/Switch Bushing Designator (use with "H" terminal style only.) 3 = 6.35mm x 6.35mm Plastic 4 = 6.35mm x 6.35mm Ni Plated Brass - 6 = Bushingless (Board Level) Resistance Code (1st 2 digits are significant, 3rd digit is number of 0s to follow) ### 3310 - Dimensions and Tolerances # **BOURNS** ### COMMON DIMENSIONS 3310-001 ### 3310C-001 ### 3310P-001 ### 3310R-001 MM DIMENSIONS ARE: -(INCHES) #### 3310Y-001 $9.53 \pm .25$ $\overline{(.375 \pm .010)}$ 2 9.53 ± .25 $\overline{(.375 \pm .010)}$ $2.54\pm.25$ $2.54 \pm .25$ $\overline{(.100 \pm .010)}$ $\overline{(.100 \pm .010)}$ $5.97\pm.89$ $\overline{(.235 \pm .035)}$ $5.08 \pm .25$ $\overline{(.200 \pm .010)}$ $2.54\pm.38$ $(.100 \pm .015)$ ### **COMMON DIMENSIONS** 3310<u>C</u>-101 Plastic Flatted Shaft ### 3310 - Dimensions and Tolerances # **BOURNS** ### COMMON DIMENSIONS 3310-002 Metal Bushing ### 3310C-002 | DIMENSIONS ARE: | MM | |-------------------|----------| | DINIENGIONO AITE. | (INCHES) | ### 3310 - Dimensions and Tolerances ### BOURNS COMMON DIMENSIONS 3310<u>H</u>-003 Pot/Switch Dual Cup Plastic Bushing MOUNTING DIA 3310<u>H</u>-0<u>25</u>\* Pot/Pot Dual Cup Bushingless 3310<u>H</u>-00<u>2</u> Pot/Pot Dual Cup Metal Bushing Pot/Pot Dual Cup Pot/Switch Dual Cup Pot Single Cup NOTE: \* Only recommended shaft length for bushingless version DIMENSIONS ARE: MM (INCHES) RFV 11/01