Welcome to **E-XFL.COM** What is "Embedded - Microcontrollers"? "Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications. Applications of "<u>Embedded - Microcontrollers</u>" | Details | | |----------------------------|---------------------------------------------------------------------------| | Product Status | Active | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 20MHz | | Connectivity | I <sup>2</sup> C, SPI | | Peripherals | Brown-out Detect/Reset, POR, PWM, WDT | | Number of I/O | 22 | | Program Memory Size | 3.5KB (2K x 14) | | Program Memory Type | OTP | | EEPROM Size | - | | RAM Size | 128 x 8 | | Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V | | Data Converters | A/D 5x8b | | Oscillator Type | External | | Operating Temperature | 0°C ~ 70°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 28-SSOP (0.209", 5.30mm Width) | | Supplier Device Package | 28-SSOP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16c72a-20-ss | # **Pin Diagrams** | Key Features PIC® Mid-Range Reference Manual (DS33023) | PIC16C62B | PIC16C72A | |--------------------------------------------------------|----------------------|----------------------| | Operating Frequency | DC - 20 MHz | DC - 20 MHz | | Resets (and Delays) | POR, BOR (PWRT, OST) | POR, BOR (PWRT, OST) | | Program Memory (14-bit words) | 2K | 2K | | Data Memory (bytes) | 128 | 128 | | Interrupts | 7 | 8 | | I/O Ports | Ports A,B,C | Ports A,B,C | | Timers | 3 | 3 | | Capture/Compare/PWM modules | 1 | 1 | | Serial Communications | SSP | SSP | | 8-bit Analog-to-Digital Module | _ | 5 input channels | ## 1.0 DEVICE OVERVIEW This document contains device-specific information. Additional information may be found in the PIC® MCU 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 rec- ommended reading for a better understanding of the device architecture and operation of the peripheral modules. There are two devices (PIC16C62B, PIC16C72A) covered by this datasheet. The PIC16C62B does not have the A/D module implemented. Figure 1-1 is the block diagram for both devices. The pinouts are listed in Table 1-1. FIGURE 1-1: PIC16C62B/PIC16C72A BLOCK DIAGRAM **NOTES:** ## 6.1 <u>Timer2 Operation</u> The Timer2 output is also used by the CCP module to generate the PWM "On-Time", and the PWM period with a match with PR2. The TMR2 register is readable and writable, and is cleared on any device reset. The input clock (Fosc/4) has a prescale option of 1:1, 1:4 or 1:16, selected by control bits T2CKPS1:T2CKPS0 (T2CON<1:0>). The match output of TMR2 goes through a 4-bit post-scaler (which gives a 1:1 to 1:16 scaling) to generate a TMR2 interrupt (latched in flag bit TMR2IF, (PIR1<1>)). The prescaler and postscaler counters are cleared when any of the following occurs: - · a write to the TMR2 register - · a write to the T2CON register - any device reset (Power-on Reset, MCLR reset, Watchdog Timer reset or Brown-out Reset) TMR2 is not cleared when T2CON is written. # 6.2 <u>Timer2 Interrupt</u> The Timer2 module has an 8-bit period register PR2. Timer2 increments from 00h until it matches PR2 and then resets to 00h on the next increment cycle. PR2 is a readable and writable register. The PR2 register is initialized to FFh upon reset. #### 6.3 Output of TMR2 The output of TMR2 (before the postscaler) is fed to the Synchronous Serial Port module, which optionally uses it to generate shift clock. TABLE 6-1 REGISTERS ASSOCIATED WITH TIMER2 AS A TIMER/COUNTER | 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 | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | 0Ch | PIR1 | _ | ADIF | - | - | SSPIF | CCP1IF | TMR2IF | TMR1IF | -00- 0000 | 0000 0000 | | 8Ch | PIE1 | _ | ADIE | _ | _ | SSPIE | CCP1IE | TMR2IE | TMR1IE | -0 0000 | 0000 0000 | | 11h | TMR2 | Timer2 mod | dule's registe | r | | | | | | 0000 0000 | 0000 0000 | | 12h | T2CON | _ | TOUTPS3 | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000 0000 | -000 0000 | | 92h | PR2 | Timer2 Peri | od Register | | | | | | | 1111 1111 | 1111 1111 | Legend: x = unknown, u = unchanged, - = unimplemented read as '0'. Shaded cells are not used by the Timer2 module. #### 7.1 Capture Mode In Capture mode, CCPR1H:CCPR1L captures the 16-bit value of the TMR1 register, when an event occurs on pin RC2/CCP1. An event is defined as: - every falling edge - · every rising edge - · every 4th rising edge - · every 16th rising edge An event is selected by control bits CCP1M3:CCP1M0 (CCP1CON<3:0>). When a capture is made, the interrupt request flag bit ,CCP1IF (PIR1<2>), is set. It must be cleared in software. If another capture occurs before the value in register CCPR1 is read, the old captured value will be lost. # FIGURE 7-1: CAPTURE MODE OPERATION BLOCK DIAGRAM #### 7.1.1 CCP PIN CONFIGURATION In Capture mode, the RC2/CCP1 pin should be configured as an input by setting the TRISC<2> bit. **Note:** If the RC2/CCP1 is configured as an output, a write to the port can cause a capture condition. #### 7.1.2 TIMER1 MODE SELECTION Timer1 must be running in timer mode or synchronized counter mode for the CCP module to use the capture feature. In asynchronous counter mode, the capture operation may not work consistently. #### 7.1.3 SOFTWARE INTERRUPT When the Capture mode is changed, a false capture interrupt may be generated. The user should clear CCP1IE (PIE1<2>) before changing the capture mode to avoid false interrupts. Clear the interrupt flag bit, CCP1IE before setting CCP1IE. #### 7.1.4 CCP PRESCALER There are four prescaler settings, specified by bits CCP1M3:CCP1M0. Whenever the CCP module is turned off, or the CCP module is not in capture mode, the prescaler counter is cleared. This means that any reset will clear the prescaler counter. Switching from one capture prescaler to another may generate an interrupt. Also, the prescaler counter will not be cleared, therefore the first capture may be from a non-zero prescaler. Example 7-1 shows the recommended method for switching between capture prescalers. This example also clears the prescaler counter and will not generate the "false" interrupt. # EXAMPLE 7-1: CHANGING BETWEEN CAPTURE PRESCALERS ``` CLRF CCP1CON ;Turn CCP module off MOVLW NEW_CAPT_PS ;Load the W reg with ; the new prescaler ; mode value and CCP ON MOVWF CCP1CON ;Load CCP1CON with this ; value ``` ## 7.2 Compare Mode In Compare mode, the 16-bit CCPR1 register value is constantly compared against the TMR1 register pair value. When a match occurs, the RC2/CCP1 pin is: - · driven High - · driven Low - · remains Unchanged The action on the pin is based on the value of control bits CCP1M3:CCP1M0 (CCP1CON<3:0>). The interrupt flag bit, CCP1IF, is set on all compare matches. # FIGURE 7-2: COMPARE MODE OPERATION BLOCK DIAGRAM #### 7.2.1 CCP PIN CONFIGURATION The user must configure the RC2/CCP1 pin as an output by clearing the TRISC<2> bit. Note: Clearing the CCP1CON register will force the RC2/CCP1 compare output latch to the default low level. This is not the data latch. #### 7.2.2 TIMER1 MODE SELECTION Timer1 must be running in Timer mode or Synchronized Counter mode if the CCP module is using the compare feature. In Asynchronous Counter mode, the compare operation may not work. #### 7.2.3 SOFTWARE INTERRUPT MODE When a generated software interrupt is chosen, the CCP1 pin is not affected. Only a CCP interrupt is generated (if enabled). #### 7.2.4 SPECIAL EVENT TRIGGER In this mode, an internal hardware trigger is generated, which may be used to initiate an action. The special event trigger output of CCP1 resets the TMR1 register pair. This allows the CCPR1 register to effectively be a 16-bit programmable period register for Timer1. The special trigger output of CCP1 resets the TMR1 register pair and starts an A/D conversion (if the A/D module is enabled). TABLE 7-3 REGISTERS ASSOCIATED WITH CAPTURE, COMPARE, AND TIMER1 | 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 | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | 0Ch | PIR1 | _ | ADIF | _ | _ | SSPIF | CCP1IF | TMR2IF | TMR1IF | -0 0000 | -0 0000 | | 8Ch | PIE1 | _ | ADIE | _ | _ | SSPIE | CCP1IE | TMR2IE | TMR1IE | -0 0000 | -0 0000 | | 87h | TRISC | PORTC Da | ata Dire | ection Regis | ter | | | | | 1111 1111 | 1111 1111 | | 0Eh | TMR1L | Holding reg | gister fo | or the Least | Significant | Byte of the | 16-bit TMF | R1 register | | xxxx xxxx | uuuu uuuu | | 0Fh | TMR1H | Holding reg | gister fo | or the Most | Significant | Byte of the 1 | 16-bit TMR | 1register | | xxxx xxxx | uuuu uuuu | | 10h | T1CON | _ | _ | T1CKPS1 | T1CKPS0 | T10SCEN | T1SYNC | TMR1CS | TMR10N | 00 0000 | uu uuuu | | 15h | CCPR1L | Capture/Co | ompare | /PWM regis | ster1 (LSB) | | | | | xxxx xxxx | uuuu uuuu | | 16h | CCPR1H | Capture/Co | ompare | PWM regis | ster1 (MSB) | ) | | | | xxxx xxxx | uuuu uuuu | | 17h | CCP1CON | _ | _ | CCP1X | CCP1Y | CCP1M3 | CCP1M2 | CCP1M1 | CCP1M0 | 00 0000 | 00 0000 | Legend: x = unknown, u = unchanged, - = unimplemented read as '0'. Shaded cells are not used by Capture and Timer1. #### 7.3 PWM Mode In Pulse Width Modulation (PWM) mode, the CCP1 pin produces up to a 10-bit resolution PWM output. Since the CCP1 pin is multiplexed with the PORTC data latch, the TRISC<2> bit must be cleared to make the CCP1 pin an output. Note: Clearing the CCP1CON register will force the CCP1 PWM output latch to the default low level. This is not the PORTC I/O data latch Figure 7-3 shows a simplified block diagram of the CCP module in PWM mode. For a step by step procedure on how to set up the CCP module for PWM operation, see Section 7.3.3. FIGURE 7-3: SIMPLIFIED PWM BLOCK DIAGRAM A PWM output (Figure 7-4) has a time base (period) and a time that the output stays high (on-time). The frequency of the PWM is the inverse of the period (1/period). FIGURE 7-4: PWM OUTPUT #### 7.3.1 PWM PERIOD The PWM period is specified by writing to the PR2 register. The PWM period can be calculated using the following formula: PWM period = $$[(PR2) + 1] \cdot 4 \cdot TOSC \cdot (TMR2 \text{ prescale value})$$ PWM frequency is defined as 1 / [PWM period]. When TMR2 is equal to PR2, the following three events occur on the next increment cycle: - · TMR2 is cleared - The CCP1 pin is set (exception: if PWM duty cycle = 0%, the CCP1 pin will not be set) - The PWM duty cycle is latched from CCPR1L into CCPR1H Note: The Timer2 postscaler (see Section 6.0) is not used in the determination of the PWM frequency. The postscaler could be used to have a servo update rate at a different frequency than the PWM output. # 7.3.2 PWM ON-TIME The PWM on-time is specified by writing to the CCPR1L register and to the CCP1CON<5:4> bits. Up to 10-bit resolution is available. CCPR1L contains eight MSbs and CCP1CON<5:4> contains two LSbs. This 10-bit value is represented by CCPR1L:CCP1CON<5:4>. The following equation is used to calculate the PWM duty cycle in time: CCPR1L and CCP1CON<5:4> can be written to at any time, but the on-time value is not latched into CCPR1H until after a match between PR2 and TMR2 occurs (i.e., the period is complete). In PWM mode, CCPR1H is a read-only register. The CCPR1H register and a 2-bit internal latch are used to double buffer the PWM on-time. This double buffering is essential for glitchless PWM operation. When the CCPR1H and 2-bit latch match TMR2 concatenated with an internal 2-bit Q clock or 2 bits of the TMR2 prescaler, the CCP1 pin is cleared. Maximum PWM resolution (bits) for a given PWM frequency: Resolution = $$\frac{\log \left( \frac{\text{Fosc}}{\text{Fpwm}} \right)}{\log(2)}$$ bits **Note:** If the PWM on-time value is larger than the PWM period, the CCP1 pin will not be cleared. For an example PWM period and on-time calculation, see the PIC<sup>®</sup> MCU Mid-Range Reference Manual, (DS33023). #### 8.3.2 MASTER OPERATION Master operation is supported in firmware using interrupt generation on the detection of the START and STOP conditions. The STOP (P) and START (S) bits are cleared by a reset or when the SSP module is disabled. The STOP (P) and START (S) bits will toggle based on the START and STOP conditions. Control of the I<sup>2</sup>C bus may be taken when the P bit is set, or the bus is idle and both the S and P bits are clear. In master operation, the SCL and SDA lines are manipulated in software by clearing the corresponding TRISC<4:3> bit(s). The output level is always low, irrespective of the value(s) in PORTC<4:3>. So when transmitting data, a '1' data bit must have the TRISC<4> bit set (input) and a '0' data bit must have the TRISC<4> bit cleared (output). The same scenario is true for the SCL line with the TRISC<3> bit. The following events will cause SSP Interrupt Flag bit, SSPIF, to be set (SSP Interrupt if enabled): - · START condition - · STOP condition - · Byte transfer completed Master operation can be done with either the slave mode idle (SSPM3:SSPM0 = 1011) or with the slave active. When both master operation and slave modes are used, the software needs to differentiate the source(s) of the interrupt. For more information on master operation, see *AN554* - *Software Implementation of I<sup>2</sup>C Bus Master.* #### 8.3.3 MULTI-MASTER OPERATION In multi-master operation, the interrupt generation on the detection of the START and STOP conditions allows the determination of when the bus is free. The STOP (P) and START (S) bits are cleared from a reset or when the SSP module is disabled. The STOP (P) and START (S) bits will toggle based on the START and STOP conditions. Control of the I<sup>2</sup>C bus may be taken when bit P (SSPSTAT<4>) is set, or the bus is idle and both the S and P bits clear. When the bus is busy, enabling the SSP Interrupt will generate the interrupt when the STOP condition occurs. In multi-master operation, the SDA line must be monitored to see if the signal level is the expected output level. This check only needs to be done when a high level is output. If a high level is expected and a low level is present, the device needs to release the SDA and SCL lines (set TRISC<4:3>). There are two stages where this arbitration can be lost, these are: - · Address Transfer - · Data Transfer When the slave logic is enabled, the slave continues to receive. If arbitration was lost during the address transfer stage, communication to the device may be in progress. If addressed, an $\overline{ACK}$ pulse will be generated. If arbitration was lost during the data transfer stage, the device will need to re-transfer the data at a later time. For more information on master operation, see *AN578* - *Use of the SSP Module in the of I<sup>2</sup>C Multi-Master Environment.* TABLE 8-3 REGISTERS ASSOCIATED WITH I<sup>2</sup>C OPERATION | 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 | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 0000 000u | | 0Ch | PIR1 | _ | ADIF | _ | _ | SSPIF | CCP1IF | TMR2IF | TMR1IF | -0 0000 | -0 0000 | | 8Ch | PIE1 | _ | ADIE | _ | _ | SSPIE | CCP1IE | TMR2IE | TMR1IE | -0 0000 | -0 0000 | | 13h | SSPBUF | Synchronou | ıs Serial F | ort Recei | ve Buffer | Transmit | Register | | | xxxx xxxx | uuuu uuuu | | 93h | SSPADD | Synchronou | ıs Serial F | Port (I <sup>2</sup> C n | node) Add | dress Reg | gister | | | 0000 0000 | 0000 0000 | | 14h | SSPCON | WCOL | SSPOV | SSPEN | CKP | SSPM3 | SSPM2 | SSPM1 | SSPM0 | 0000 0000 | 0000 0000 | | 94h | SSPSTAT | SMP <sup>(1)</sup> | CKE <sup>(1)</sup> | D/A | Р | S | R/W | UA | BF | 0000 0000 | 0000 0000 | | 87h | TRISC | PORTC Dat | ta Directio | n register | | • | | • | | 1111 1111 | 1111 1111 | Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by SSP module in SPI mode. Note 1: Maintain these bits clear in I<sup>2</sup>C mode. # REGISTER 9-2:ADCON1 REGISTER (ADDRESS 9Fh) | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |------|-----|-----|-----|-----|-------|-------|-------| | _ | _ | _ | _ | _ | PCFG2 | PCFG1 | PCFG0 | | bit7 | • | | | • | | • | bit0 | R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' - n = Value at POR reset bit 7-3: Unimplemented: Read as '0' bit 2-0: PCFG2:PCFG0: A/D Port Configuration Control bits | PCFG2:PCFG0 | RA0 | RA1 | RA2 | RA5 | RA3 | VREF | |-------------|-----|-----|-----|-----|------|------| | 000 | Α | Α | Α | Α | Α | VDD | | 001 | Α | Α | Α | Α | VREF | RA3 | | 010 | Α | Α | Α | Α | Α | VDD | | 011 | Α | Α | Α | Α | VREF | RA3 | | 100 | Α | Α | D | D | Α | VDD | | 101 | Α | Α | D | D | VREF | RA3 | | 11x | D | D | D | D | D | VDD | A = Analog input D = Digital I/O ## 10.4 Power-On Reset (POR) A Power-on Reset pulse is generated on-chip when VDD rise is detected (in the range of 1.5V - 2.1V). To take advantage of the POR, just tie the MCLR pin directly (or through a resistor) to VDD. This will eliminate external RC components usually needed to create a Power-on Reset. A maximum rise time for VDD is specified (SVDD, parameter D004). For a slow rise time, see Figure 10-6. When the device starts normal operation (exits the reset condition), device operating parameters (voltage, frequency, temperature,...) must be met to ensure operation. If these conditions are not met, the device must be held in reset until the operating conditions are met. Brown-out Reset may be used to meet the start-up conditions. FIGURE 10-6: EXTERNAL POWER-ON RESET CIRCUIT (FOR SLOW VDD POWER-UP) - Note 1: External Power-on Reset circuit is required only if VDD power-up slope is too slow. The diode D helps discharge the capacitor quickly when VDD powers down. - 2: $R < 40 \text{ k}\Omega$ is recommended to make sure that voltage drop across R does not violate the device's electrical specification. - 3: R1 = $100\Omega$ to 1 k $\Omega$ will limit any current flowing into $\overline{MCLR}$ from external capacitor C in the event of $\overline{MCLR}$ /VPP pin breakdown due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS). ## 10.5 Power-up Timer (PWRT) The Power-up Timer provides a fixed nominal time-out (TPWRT, parameter #33) from the POR. The Power-up Timer operates on an internal RC oscillator. The chip is kept in reset as long as the PWRT is active. The PWRT's time delay allows VDD to rise to an acceptable level. A configuration bit is provided to enable/disable the PWRT. The power-up time delay will vary from chip-to-chip due to VDD, temperature and process variation. See DC parameters for details. #### 10.6 Oscillator Start-up Timer (OST) The Oscillator Start-up Timer (OST) provides a delay of 1024 oscillator cycles (from OSC1 input) after the PWRT delay is over (Tost, parameter #32). This ensures that the crystal oscillator or resonator has started and stabilized. The OST time-out is invoked only for XT, LP and HS modes and only on Power-on Reset or wake-up from SLEEP. **Note:** The OST delay may not occur when the device wakes from SLEEP. #### 10.7 Brown-Out Reset (BOR) The configuration bit, BODEN, can enable or disable the Brown-Out Reset circuit. If VPP falls below Vbor (parameter #35, about $100\mu S$ ), the brown-out situation will reset the device. If VDD falls below VBOR for less than TBOR, a reset may not occur. Once the brown-out occurs, the device will remain in brown-out reset until VDD rises above VBOR. The power-up timer then keeps the device in reset for TPWRT (parameter #33, about 72mS). If VDD should fall below VBOR during TPWRT, the brown-out reset process will restart when VDD rises above VBOR with the power-up timer reset. The power-up timer is always enabled when the brown-out reset circuit is enabled, regardless of the state of the $\overline{\text{PWRT}}$ configuration bit. ## 10.12 Watchdog Timer (WDT) The Watchdog Timer is a free running on-chip RC oscillator which does not require any external components. This RC oscillator is separate from the RC oscillator of the OSC1/CLKIN pin. The WDT will run, even if the clock on the OSC1/CLKIN and OSC2/CLKOUT pins of the device has been stopped, for example, by execution of a SLEEP instruction. During normal operation, a WDT time-out generates a device RESET (Watchdog Timer Reset). If the device is in SLEEP mode, a WDT time-out causes the device to wake-up and continue with normal operation (Watchdog Timer Wake-up). The TO bit in the STATUS register will be cleared upon a Watchdog Timer time-out. The WDT can be permanently disabled by clearing configuration bit WDTE (Section 10.1). The WDT time-out period (TWDT, parameter #31) is multiplied by the prescaler ratio, when the prescaler is assigned to the WDT. The prescaler assignment (assigned to either the WDT or Timer0) and prescaler ratio are set in the OPTION\_REG register. Note: The CLRWDT and SLEEP instructions clear the WDT and the postscaler, if assigned to the WDT, and prevent it from timing out and generating a device RESET condition. When a CLRWDT instruction is executed and the prescaler is assigned to the WDT, the prescaler count will be cleared, but the prescaler assignment is not changed. FIGURE 10-8: WATCHDOG TIMER BLOCK DIAGRAM Note: # FIGURE 10-9: SUMMARY OF WATCHDOG TIMER REGISTERS | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------|--------------|-------|--------|-------|-------|-------|-------|-------|-------| | 2007h | Config. bits | | BODEN | CP1 | CP0 | PWRTE | WDTE | FOSC1 | FOSC0 | | 81h | OPTION_REG | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | Legend: Shaded cells are not used by the Watchdog Timer. ## 12.0 DEVELOPMENT SUPPORT The PIC® microcontrollers are supported with a full range of hardware and software development tools: - · Integrated Development Environment - MPLAB™ IDE Software - Assemblers/Compilers/Linkers - MPASM Assembler - MPLAB-C17 and MPLAB-C18 C Compilers - MPLINK/MPLIB Linker/Librarian - Simulators - MPLAB-SIM Software Simulator - Emulators - MPLAB-ICE Real-Time In-Circuit Emulator - PICMASTER®/PICMASTER-CE In-Circuit Emulator - ICEPIC™ - · In-Circuit Debugger - MPLAB-ICD for PIC16F877 - · Device Programmers - PRO MATE® II Universal Programmer - PICSTART® Plus Entry-Level Prototype Programmer - · Low-Cost Demonstration Boards - SIMICE - PICDEM-1 - PICDEM-2 - PICDEM-3 - PICDEM-17 - SEEVAL® - KEELOQ® ## 12.1 <u>MPLAB Integrated Development</u> Environment Software - The MPLAB IDE software brings an ease of software development previously unseen in the 8-bit microcontroller market. MPLAB is a Windows®-based application which contains: - · Multiple functionality - editor - simulator - programmer (sold separately) - emulator (sold separately) - A full featured editor - A project manager - · Customizable tool bar and key mapping - · A status bar - On-line help MPLAB allows you to: - Edit your source files (either assembly or 'C') - One touch assemble (or compile) and download to PIC MCU tools (automatically updates all project information) - · Debug using: - source files - absolute listing file - object code The ability to use MPLAB with Microchip's simulator, MPLAB-SIM, allows a consistent platform and the ability to easily switch from the cost-effective simulator to the full featured emulator with minimal retraining. ## 12.2 MPASM Assembler MPASM is a full featured universal macro assembler for all PIC MCUs. It can produce absolute code directly in the form of HEX files for device programmers, or it can generate relocatable objects for MPLINK. MPASM has a command line interface and a Windows shell and can be used as a standalone application on a Windows 3.x or greater system. MPASM generates relocatable object files, Intel standard HEX files, MAP files to detail memory usage and symbol reference, an absolute LST file which contains source lines and generated machine code, and a COD file for MPLAB debugging. MPASM features include: - MPASM and MPLINK are integrated into MPLAB projects. - MPASM allows user defined macros to be created for streamlined assembly. - MPASM allows conditional assembly for multi purpose source files. - MPASM directives allow complete control over the assembly process. # 12.3 MPLAB-C17 and MPLAB-C18 C Compilers The MPLAB-C17 and MPLAB-C18 Code Development Systems are complete ANSI 'C' compilers and integrated development environments for Microchip's PIC17CXXX and PIC18CXXX family of microcontrollers, respectively. These compilers provide powerful integration capabilities and ease of use not found with other compilers. For easier source level debugging, the compilers provide symbol information that is compatible with the MPLAB IDE memory display. #### 12.4 MPLINK/MPLIB Linker/Librarian MPLINK is a relocatable linker for MPASM and MPLAB-C17 and MPLAB-C18. It can link relocatable objects from assembly or C source files along with precompiled libraries using directives from a linker script. and test the sample code. In addition, PICDEM-17 supports down-loading of programs to and executing out of external FLASH memory on board. The PICDEM-17 is also usable with the MPLAB-ICE or PICMASTER emulator, and all of the sample programs can be run and modified using either emulator. Additionally, a generous prototype area is available for user hardware. ## 12.17 <u>SEEVAL Evaluation and Programming</u> <u>System</u> The SEEVAL SEEPROM Designer's Kit supports all Microchip 2-wire and 3-wire Serial EEPROMs. The kit includes everything necessary to read, write, erase or program special features of any Microchip SEEPROM product including Smart Serials™ and secure serials. The Total Endurance™ Disk is included to aid in trade-off analysis and reliability calculations. The total kit can significantly reduce time-to-market and result in an optimized system. # 12.18 <u>KEELog Evaluation and</u> <u>Programming Tools</u> KEELOQ evaluation and programming tools support Microchips HCS Secure Data Products. The HCS evaluation kit includes an LCD display to show changing codes, a decoder to decode transmissions, and a programming interface to program test transmitters. TABLE 12-1: DEVELOPMENT TOOLS FROM MICROCHIP | | / biciscx | | < blc1ec2 | / PIC16C6 | / PIC16CX | ✓ blC16F62 | / bic16C7 | V PIC16C7X | > PIC16C8) | √ biC16F8X | X629L2IG | < < blocks | XY27T12I4 | < bic18CXX | 59CXX\<br>59CXX\ | нсеххх | MCRFXXX | WCP2510 | |---|-----------|---|-----------|-----------|-----------|------------|-----------|------------|------------|------------|----------|------------|-----------|------------|------------------|--------|---------|---------| | 1 | | | | | | | | | | | | | | > | | | | | | | ` | > | ` | > | > | > | > | > | > | > | ` | > | > | > | > | > | | | | | ` | ` | ` | > | ` | * | > | ^ | > | > | > | ` | > | > | | | | | | | > | > | > | > | > | | > | > | > | | > | > | > | | | | | | | | ` | | > | > | > | | > | <b>,</b> | > | | > | | | | | | | | | | | | | * | | | *> | | | > | | | | | | | | | | | > | > | > | > | ^ | **^ | ^ | ^ | ^ | > | > | > | > | > | | | | | | | > | > | > | > | > | **> | > | ^ | ^ | > | > | > | > | > | > | ^ | | | | | > | | > | | | | | | | | | | | | | | | | | | | | ^ | | ^ | | <b>√</b> | | ^ | | | ` | | | | | | | | | | | | à | | | ✓† | | | | | | | > | | | | | | | | | | | | | | | | | > | | | | | | | | | | | ^ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | | | | | | | | | | | | | | | | | | | | | | | ^ | | | | | | | | | | | | | | | | | | | | ^ | | | | | | | | | | | | | | | | | | | | | > | | | | | | | | | | | | | | | | | | | | > | | | | | | | | | | | | | | | | | | | | > | | | | | | | | | | | | | | | | | | | | > | | | | | | | | | | | | | | | | | | | | | > | \*\* Contact Microchip Technology Inc. for availability date. † Development tool is available on select devices. Standard Operating Conditions (unless otherwise stated) Operating temperature $0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended Operating voltage VDD range as described in DC spec Section 13.1 and Section 13.2 | Param | Sym | Characteristic | Min | Typ† | Max | Units | Conditions | |-------|-------------------|-----------------------------------------|---------|------|-----|-------|----------------------------------------------------------------------------| | No. | | | | | | | | | | | | - | - | 0.6 | V | IOL = 7.0 mA, VDD = 4.5V,<br>-40°C to +125°C | | D083 | | OSC2/CLKOUT<br>(RC osc mode) | - | - | 0.6 | V | IOL = 1.6 mA, $VDD = 4.5V$ , $-40^{\circ}C$ to $+85^{\circ}C$ | | | | | - | - | 0.6 | V | IOL = 1.2 mA, VDD = 4.5V,<br>-40°C to +125°C | | | | Output High Voltage | | | | | | | D090 | Vон | I/O ports (Note 3) | VDD-0.7 | - | - | V | $IOH = -3.0 \text{ mA}, VDD = 4.5V, -40^{\circ}C \text{ to } +85^{\circ}C$ | | | | | VDD-0.7 | - | - | V | IOH = $-2.5$ mA, VDD = $4.5$ V, $-40$ °C to $+125$ °C | | D092 | | OSC2/CLKOUT (RC osc mode) | VDD-0.7 | - | - | V | IOH = -1.3 mA, VDD = $4.5V$ , $-40^{\circ}$ C to $+85^{\circ}$ C | | | | | VDD-0.7 | - | - | V | IOH = -1.0 mA, VDD = $4.5$ V, $-40$ °C to $+125$ °C | | D150* | Vod | Open-Drain High Voltage | - | - | 8.5 | V | RA4 pin | | | | Capacitive Loading Specs on Output Pins | | | | | | | D100 | Cosc <sub>2</sub> | OSC2 pin | - | - | 15 | pF | In XT, HS and LP modes when external clock is used to drive OSC1. | | D101 | Cio | All I/O pins and OSC2 (in RC mode) | - | - | 50 | pF | | | D102 | Cb | SCL, SDA in I <sup>2</sup> C mode | - | - | 400 | pF | | <sup>\*</sup> These parameters are characterized but not tested. **DC CHARACTERISTICS** - **Note 1:** In RC oscillator mode, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the device be driven with external clock in RC mode. - 2: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages. - 3: Negative current is defined as current sourced by the pin. <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. FIGURE 13-7: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING FIGURE 13-8: BROWN-OUT RESET TIMING TABLE 13-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER AND BROWN-OUT RESET REQUIREMENTS | Param<br>No. | Sym | Characteristic | Min | Typ† | Max | Units | Conditions | |--------------|-------|------------------------------------------------|-----|--------------|-----|-------|----------------------------------------------------| | 30 | TmcL | MCLR Pulse Width (low) | 2 | _ | _ | μS | VDD = 5V, -40°C to +125°C | | 31* | Twdt | Watchdog Timer Time-out Period (No Prescaler) | 7 | 18 | 33 | ms | VDD = 5V, -40°C to +125°C | | 32 | Tost | Oscillator Start-up Timer Period | _ | 1024<br>Tosc | _ | _ | Tosc = OSC1 period | | 33* | Tpwrt | Power-up Timer Period | 28 | 72 | 132 | ms | $VDD = 5V, -40^{\circ}C \text{ to } +125^{\circ}C$ | | 34 | Tıoz | I/O Hi-impedance from MCLR<br>Low or WDT reset | _ | _ | 2.1 | μS | | | 35 | Твоп | Brown-out Reset Pulse Width | 100 | _ | _ | μS | VDD ≤ BVDD (D005) | <sup>\*</sup> These parameters are characterized but not tested. <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. T0CKI T1OSO/T1CKI 48 TMR0 or TMR1 Note: Refer to Figure 13-4 for load conditions. FIGURE 13-9: TIMERO AND TIMER1 EXTERNAL CLOCK TIMINGS **TABLE 13-5**: TIMERO AND TIMER1 EXTERNAL CLOCK REQUIREMENTS | Param<br>No. | Sym | | Characteristic | | Min | Typ† | Max | Units | Conditions | |--------------|-----------|----------------------------------------------|--------------------|----------------|------------------------------------|------|-------|-------|------------------------------------| | 40* | Tt0H | T0CKI High Pulse W | /idth | No Prescaler | 0.5Tcy + 20 | _ | _ | ns | Must also meet | | | | | | With Prescaler | 10 | _ | _ | ns | parameter 42 | | 41* | TtOL | T0CKI Low Pulse W | idth | No Prescaler | 0.5Tcy + 20 | _ | _ | ns | Must also meet | | | | | | With Prescaler | 10 | _ | _ | ns | parameter 42 | | 42* | Tt0P | T0CKI Period | | No Prescaler | Tcy + 40 | _ | _ | ns | | | | | | | With Prescaler | Greater of:<br>20 or TCY + 40<br>N | _ | _ | ns | N = prescale value<br>(2, 4,, 256) | | 45* | Tt1H | T1CKI High Time | Synchronous, Pr | rescaler = 1 | 0.5Tcy + 20 | _ | _ | ns | Must also meet | | | | | Synchronous, | PIC16CXX | 15 | _ | _ | ns | parameter 47 | | | | Prescaler = 2,4,8 | | PIC16LCXX | 25 | - | _ | ns | | | | | | Asynchronous | PIC16CXX | 30 | _ | _ | ns | | | | | | | PIC16LCXX | 50 | _ | _ | ns | | | 46* | Tt1L | T1CKI Low Time | Synchronous, Pr | rescaler = 1 | 0.5Tcy + 20 | _ | _ | ns | Must also meet | | | | | Synchronous, | PIC16CXX | 15 | _ | _ | ns | parameter 47 | | | | Prescaler = 2,4,8 | | PIC16LCXX | 25 | _ | _ | ns | | | | | | Asynchronous | PIC16CXX | 30 | _ | _ | ns | | | | | | | PIC16LCXX | 50 | _ | _ | ns | | | 47* | Tt1P | T1CKI input period | Synchronous | PIC16CXX | GREATER OF:<br>30 OR TCY + 40<br>N | - | _ | ns | N = prescale value (1, 2, 4, 8) | | | | | | PIC16LCXX | GREATER OF:<br>50 OR TCY + 40<br>N | | | | N = prescale value (1, 2, 4, 8) | | | | | Asynchronous | PIC16CXX | 60 | _ | _ | ns | | | | | | | PIC16LCXX | 100 | _ | _ | ns | | | | Ft1 | Timer1 oscillator inp (oscillator enabled by | | | DC | _ | 200 | kHz | | | 48 | TCKEZtmr1 | Delay from external | clock edge to time | r increment | 2Tosc | _ | 7Tosc | _ | | <sup>\*</sup> These parameters are characterized but not tested. † Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. **NOTES:** | Instruction Set | 67 | RB0/INT Enable (INTE Bit) | 13 | |----------------------------------------|--------|---------------------------------------------------|--------| | ADDLW | 69 | SSP Enable (SSPIE Bit) | | | ADDWF | 69 | TMR0 Overflow Enable (T0IE Bit) | 13 | | ANDLW | 69 | TMR1 Overflow Enable (TMR1IE Bit) | | | ANDWF | | TMR2 to PR2 Match Enable (TMR2IE Bit) | 14 | | BCF | 69 | Interrupts, Flag Bits | | | BSF | 69 | A/D Converter Flag (ADIF Bit)1 | 15, 51 | | BTFSC | 70 | CCP1 Flag (CCP1IF Bit)15, 3 | 34, 35 | | BTFSS | 70 | Interrupt on Change (RB7:RB4) | | | CALL | 70 | Flag (RBIF Bit)13, 2 | 21, 63 | | CLRF | 70 | RB0/INT Flag (INTF Bit) | 13 | | CLRW | 70 | SSP Flag (SSPIF Bit) | | | CLRWDT | 70 | TMR0 Overflow Flag (T0IF Bit)1 | | | COMF | 71 | TMR1 Overflow Flag (TMR1IF Bit) | | | DECF | 71 | TMR2 to PR2 Match Flag (TMR2IF Bit) | | | DECFSZ | | | | | GOTO | | K | | | INCF | | KeeLog® Evaluation and Programming Tools | 78 | | INCFSZ | | | | | IORLW | | M | | | IORWF | ····· | Master Clear (MCLR) | 6 | | MOVF | | MCLR Reset, Normal Operation57, 6 | | | MOVLW | | MCLR Reset, SLEEP57, 6 | | | MOVWF | | Memory Organization | , . | | NOP | | Data Memory | 8 | | RETFIE | | Program Memory | | | RETLW | _ | MPLAB Integrated Development Environment Software | | | RETURN | | | | | RLF | _ | 0 | | | RRF | | OPCODE Field Descriptions | 67 | | SLEEP | | OPTION_REG Register1 | 10, 12 | | SUBLW | | INTEDG Bit | | | SUBWF | | PS2:PS0 Bits1 | | | SWAPF | | PSA Bit1 | | | XORLW | | RBPU Bit | 12 | | XORWF | | T0CS Bit1 | | | | | T0SE Bit1 | , | | Summary TableINTCON Register | | OSC1/CLKIN Pin | é | | GIE Bit | , | OSC2/CLKOUT Pin | 6 | | INTE Bit | | Oscillator Configuration5 | | | INTF Bit | _ | HS5 | | | PEIE Bit | | LP5 | | | RBIE Bit | | RC6, 5 | | | RBIF Bit | | Selection (FOSC1:FOSC0 Bits) | | | TOIE Bit | | XT5 | | | | | Oscillator, Timer12 | 27, 29 | | TOIF Bit | | Oscillator, WDT | | | Interrupt Sources | | | | | A/D Conversion Complete | | Р | | | Block Diagram | | Packaging | 105 | | Capture Complete (CCP) | | Paging, Program Memory | | | Compare Complete (CCP) | | PCON Register1 | | | Interrupt on Change (RB7:RB4) | | BOR Bit | | | RB0/INT Pin, External | | POR Bit | | | SSP Receive/Transmit Complete | | PICDEM-1 Low-Cost PIC MCU Demo Board | 77 | | TMR0 Overflow | , | PICDEM-2 Low-Cost PIC16CXX Demo Board | | | TMR1 Overflow | , | PICDEM-3 Low-Cost PIC16CXXX Demo Board | | | TMR2 to PR2 Match | - | PICSTART® Plus Entry Level Development System | | | TMR2 to PR2 Match (PWM) | | PIE1 Register1 | | | Interrupts, Context Saving During | 63 | ADIE Bit | | | Interrupts, Enable Bits | | CCP1IE Bit | | | A/D Converter Enable (ADIE Bit) | | SSPIE Bit | | | CCP1 Enable (CCP1IE Bit) | | TMR1IE Bit | | | Global Interrupt Enable (GIE Bit) | 13, 62 | TMR2IE Bit | | | Interrupt on Change (RB7:RB4) | | Pinout Descriptions | 14 | | Enable (RBIE Bit) | | PIC16C62B/PIC16C72A | G | | Peripheral Interrupt Enable (PEIE Bit) | 13 | 1 10 1000LD/1 10 100/L/1 | | | Enable (SSPIE Bit) | SSP | .39 Tin | ner1 | 27 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--------------|---------------------------------------|------| | Flag (SSPIF Bit) | | | | | | RAŠ/SS/AN4 Pin | , | | · · · · · · · · · · · · · · · · · · · | | | RG/SS/KSCL Pin 6 | | | | | | RC4/SDISDA Pin 6 | | | | | | RCS/SDO Pin 6 Oscillator 27, 28 SSPADA Register 10 Oscillator 10 SSPEON Register 9 Overflow Enable (TMOSCEN Bit) 27 27 28 28 27 29 29 29 29 29 29 29 | | | | | | SSPADD Register 10 | | | | | | SSPBUF Register 9 | SSPADD Register | . 10 | | _ | | SSPCON Register 9, 47 Overflow Interrupt 9, 27 SSPSTAT Register 10, 46 Overflow Interrupt 27, 25 Mrite Collision Detect (WCOL Bit) 47 RCI/T1OSL 6 SSPCON Register 47 RCI/T1OSL 6 CKP Bit 47 TRON Register 29, 38 CKP Bit 47 Timing Diagram 99, 27 SSPMS:SSPM0 Bits 47 Timing Diagram 99, 27 SSPOV Bit 47 Timing Diagram 98 SSPSTAT Register 46 Block Diagram 32 SSPSTAT Register 46 SSP Clock Shift 33 DIA Bit 46 SSP Clock Shift 32 DIA Bit 46 SSP Clock Shift 33 SBI 45, 46 TIME2 Register 9, 31 RW Bit 45, 46 TIME2 Register 9, 31 SIACK 17 Time2 Diagrams 32 STATUS Register 9, 11, 63 Time2 Diagram 32 STATUS Register 9, 11, 63< | | | | | | SSPSTAT Register TMR2 Output for Clock Shift 32 RCVT 1502/TICKI Pin RCVT 110SI SPCON Register 47 SPCON Register 47 CVP Bit 47 SSPEN Bit 47 TICON Register 9, 27 SSPEN Bit 47 TIME Register 9, 27 SSPSN Bit 47 TIME Register 9, 27 SSPSN Bit 47 TIME Register 9, 27 SSPSN Bit 47 TIME Register 9, 27 SSPSN Bit 47 TIME Register 9, 27 SSPSN Bit 47 TIME Register 9, 27 SSPSN Bit 47 TIME Register 9, 27 SSPSTAT Register 46 BF Bit 46 CKE Bit 46 SF Bit 46 CKE Bit 46 SF Bit 46 SF Bit 46 SF Bit 46 SF Bit 46 SF Bit 47 TIME Register 9, 31 SF SSP Clock Shift 32 DIÁ Bit 45 SB BI 45 SB BI 45 SB BI 45 SB BI 46 SB BIT AB BI | | | | | | TMR2 Output for Clock Shift | · · · · · · · · · · · · · · · · · · · | | | | | Write Collision Detect (WCOL Bit) 47 School Event Trigger (CCP) 2.9, 35 2.9, 35 35 35 35 35 35 35 35 | | | | | | SSPCON Register 47 Special Event Trigger (CCP) 29, 32 CKP Bit 47 T1CON Register 9, 27 SSPEN Bit 47 Timing Diagram 93 SSPOV Bit 47 Timing Diagram 93 SSPSTAT Register 46 BICK Diagram 32 SSPSTAT Register 46 BICK Diagram 32 SSPSTAT Register 46 BICK Diagram 32 CKE Bit 46 SSP Clock Shift 32 DIA Bit 46 SSP Clock Shift 32 DIA Bit 46 SSP Clock Shift 32 S Bit 45, 46 TIMP2 Register 9, 31 NW Bit 42, 43, 44, 46 TIMP2 to PR2 Match Interrupt 46 S SMAD Shit 46 TIMP2 to PR2 Match Interrupt 46 S STATUS Register 9, 11, 63 Timing Diagrams 31, 32, 32 Vale Wake-up from SLEEP via Interrupt 66 Timing Diagrams 43 STATUS Register 9, 11, 63 Timing Diagrams and Specifications | | | RC1/T10SI | 6 | | CKP Bit | · · · · · · · · · · · · · · · · · · · | | Special Event Trigger (CCP)29 | , 35 | | SSPEN Bit 47 Timing Diagram 93 SSPM3:SSPM0 Bits 47 TMR1H Register 9.8 SSPOYD Bit 47 TMR1H Register 9.8 WCOL Bit 47 Timer? WCOL Bit 9.8 SSPSTAT Register 46 BF Bit 46 PR2 Register 10,31,36 36 CKE Bit 46 SSP Clock Shift 32 32 32 72CON Register 9,31 32 72CON Register 9,31 32 72CON Register 9,31 32 72CON Register 9,31 32 72CON Register 9,31 32 72CON Register 9,31 32 32 72CON Register 9,31 33 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 | | | | | | SPOV Bit 47 | SSPEN Bit | . 47 | | - | | SPOV Bit 47 | SSPM3:SSPM0 Bits | . 47 | TMR1H Register | 9 | | WCOL Bit 47 Timer2 SPSTAT Register 46 BF Bit 46 CKE Bit 46 SSP Clock Shift 32 D/A Bit 46 SSP Clock Shift 32 P bit 45, 46 TSCNO Register 9, 31 R/W Bit 42, 43, 44, 46 TMR2 to PR2 Match Enable (TMR2IE Bit) 14 S Bit 45, 46 TMR2 to PR2 Match Enable (TMR2IE Bit) 15 S Bit 46 TMR2 to PR2 Match Enable (TMR2IE Bit) 15 S Bit 46 TMR2 to PR2 Match Enable (TMR2IE Bit) 16 S Bit 46 TMR2 to PR2 Match Enable (TMR2IE Bit) 16 S Bit 46 TMR2 to PR2 Match Enable (TMR2IE Bit) 11 TMR2 to PR2 Match Enable (TMR2IE Bit) 14 <td>SSPOV Bit</td> <td>. 47</td> <td></td> <td></td> | SSPOV Bit | . 47 | | | | BF Bit | WCOL Bit | . 47 Tin | <u> </u> | | | BF Bit | SSPSTAT Register | . 46 | Block Diagram | 32 | | CKE Bit | · · · · · · · · · · · · · · · · · · · | | | | | D/Ā Bit | CKE Bit | .46 | | | | P bit | D/A Bit | .46 | | | | R/W Bit | | | | | | S Bit | , | | · · · · · · · · · · · · · · · · · · · | , | | SMP Bit | | | | | | UA Bit | • | | | | | Stack | | | . , | , | | STATUS Register 9, 11, 63 Wake-up from SLEEP via Interrupt 66 C Bit 11 Timing Diagrams and Specifications 90 JC Bit 11 A/D Conversion 102 IRP Bit 11 Brown-out Reset (BOR) 92 PD Bit 11, 57 Capture/Compare/PWM (CCP) 94 RP1:RP0 Bits 11 CLKOUT and I/O 91 TO Bit 11, 57 External Clock 90 Z Bit 11 External Clock 90 T CLON Register 9, 27 External Clock 90 T1CON Register 9, 27 Power-up Timer (OST) 92 T1CKPS1:T1CKPS0 Bits 27 Timer (PWRT) 92 T1SYNC Bit 27 Timer (PWRT) 92 T2CON Register 9, 31 Watchdog Timer (WDT) 92 T2CON Register 9, 31 Wake-up from SLEEP 55 66 TMRIOS Bit 27 Timer on Miler (WDT) 92 92 92 92 92 93 93 93 <td></td> <td></td> <td></td> <td> 43</td> | | | | 43 | | C Bit 11 Timing Diagrams and Specifications 90 DC Bit 11 A/D Conversion 102 IRP Bit 11 Brown-out Reset (BOR) 92 PD Bit 11, 57 Capture/Compare/PWM (CCP) 94 RP1:RP0 Bits 11 CLKOUT and I/O 91 TO Bit 11, 57 External Clock 90 Z Bit 11 I²C Bus Data 100 I²C Bus Start/Stop Bits 99 Oscillator Start-up Timer (OST) 92 T1CON Register 9, 27 Power-up Timer (PWRT) 92 T1CKPS1:T1CKPS0 Bits 27 Reset 22 T1GSCEN Bit 27 Timer0 and Timer1 93 T2CKPS1:T2CKPS0 Bits 27 Watchdog Timer (WDT) 92 T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP 55, 65 TMR2ON Bit 31 Macke-up from SLEEP 55, 65 TImer0 25 Timing Diagram 66 Block Diagram 25 WDT Reset 61 Clock Sou | | | | | | DC Bit | , , | | · | | | IRP Bit | | | | | | PD Bit | | | | | | RP1:RP0 Bits | | | | | | TO Bit | , | | , | | | T1CON Register 9, 27 T1CKPS1:T1CKPS0 Bits 27 T1SYNC Bit 27 TMR1CS Bit 27 T2CON Register 9, 31 T2CON Register 9, 31 T1SYNC Bit 27 TMR1CS Bit 27 TMR1CS Bit 27 TMR1CS Bit 27 TOCKPS1:T2CKPS0 Bits 31 TOUTPS3:TOUTPS0 Bits 31 TIMEO Diagram 25 Block Diagram 25 Clock Source Edge Select (TOCS Bit) 12, 25 Clock Source Edge Select (TOCS Bit) 13, 63 Overflow Enable (T0IE Bit) 13, 63 Overflow Interrupt 26, 63 RA4/TOCKI Pin, External Clock 6 Timing Diagram 93 TMR0 Register 93 TMR0 Register 94 TRIC Bus Start/Stop Bits 99 Oscillator Start-up Timer (OST) 92 Text Dewer-up Timer (OST) 92 Text Dewer-up Timer (PWRT) 92 Timer0 and Timer1 93 Watchdog Timer (WDT) 92 W W W **Country Start-up Timer (WDT) 92 **Country Start Diagram 66 **Country Start Diagram 66 **Country Start Diagram 66 **Country Start Diagram 64 Overflow Enable (TOIE Bit) 13, 63 Overflow Flag (TOIF Bit) 13, 63 Overflow Interrupt 26, 63 RA4/TOCKI Pin, External Clock 6 Timing Diagram 93 TMDT Reset, Normal Operation 57, 60, 61 TMR0 Register 99 WDT Reset, SLEEP 57, 60, 61 | | | | | | T I²C Bus Start/Stop Bits 99 T1CON Register 9, 27 Power-up Timer (OST) 92 T1CKPS1:T1CKPS0 Bits 27 Power-up Timer (PWRT) 92 T1OSCEN Bit 27 Reset 22 T1SYNC Bit 27 Timer0 and Timer1 93 TMR1CS Bit 27 Watchdog Timer (WDT) 92 TMR1ON Bit 27 W T2COR Register 9, 31 W Register 63 T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP 55, 65 TMR2ON Bit 31 Interrupts 60, 61 TOUTPS3:TOUTPS0 Bits 31 MCLR Reset 61 Timer0 25 Timing Diagram 66 Block Diagram 25 WDT Reset 61 Clock Source Edge Select (TOSE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Overflow Enable (TOIE Bit) 13, 63 Programming Considerations 64 Overflow Flag (TOIF Bit) 13, 63 Programming Considerations 64 Overflow Interrupt< | , | | | | | Oscillator Start-up Timer (OST) 92 | _ | | | | | T1CON Register 9, 27 Power-up Timer (PWRT) 92 T1CKPS1:T1CKPS0 Bits 27 Reset 2 T1SYNC Bit 27 Timer0 and Timer1 93 T2CNR1:SBit 27 Watchdog Timer (WDT) 92 T2CON Register 9, 31 W W T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP 55, 65 TMR2ON Bit 31 Interrupts 60, 61 TOUTPS3:TOUTPS0 Bits 31 MCLR Reset 61 Timer0 25 WDT Reset 61 Glock Diagram 25 WDT Reset 61 Clock Source Edge Select (TOSE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Overflow Enable (T0IE Bit) 13, 63 Programming Considerations 64 Overflow Interrupt 26, 63 RC Oscillator 64 Overflow Interrupt 26, 63 RC Oscillator 64 RA4/TOCKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation | Т | | | | | T1CKPS1:T1CKPS0 Bits 27 Reset 22 T1OSCEN Bit 27 Timer0 and Timer1 93 T1SYNC Bit 27 Watchdog Timer (WDT) 92 TMR1ON Bit 27 W T2CON Register 9, 31 W W T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP 55, 65 TMR2ON Bit 31 Interrupts 60, 61 TOUTPS3:TOUTPS0 Bits 31 MCLR Reset 61 Timer0 25 Timing Diagram 66 Block Diagram 25 WDT Reset 61 Clock Source Edge Select (TOSE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Clock Source Select (TOCS Bit) 12, 25 WDT Reset 61 Overflow Enable (TOIE Bit) 13 Enable (WDTE Bit) 55, 64 Overflow Interrupt 26, 63 RC Oscillator 64 RA4/TOCKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 | T1CON Register9, | 27 | | | | T1OSCEN Bit 27 Timer0 and Timer1 93 T1SYNC Bit 27 Watchdog Timer (WDT) 92 TMR1CS Bit 27 W T2CON Register 9, 31 W Register 63 T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP 55, 65 TMR2ON Bit 31 Interrupts 60, 61 TOUTPS3:TOUTPS0 Bits 31 MCLR Reset 61 Timer0 25 Timing Diagram 66 Block Diagram 25 WDT Reset 61 Clock Source Edge Select (T0SE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Clock Source Select (T0CS Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Overflow Enable (T0IE Bit) 13 Enable (WDTE Bit) 55, 64 Overflow Interrupt 26, 63 RC Oscillator 64 Querilow Interrupt 26, 63 RC Oscillator 64 RA4/T0CKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, | | | . , , | | | T1SYNC Bit 27 Watchdog Timer (WDT) 92 TMR1CS Bit 27 W TMR1ON Bit 27 W T2CON Register 9, 31 W Register 63 T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP 55, 65 TMR2ON Bit 31 Interrupts 60, 61 TOUTPS3:TOUTPS0 Bits 31 MCLR Reset 61 Timer0 25 WDT Reset 61 Clock Diagram 25 WDT Reset 61 Clock Source Edge Select (TOSE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Clock Source Select (TOCS Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Clock Source Select (TOCS Bit) 12, 25 Block Diagram 64 Overflow Enable (TOIE Bit) 13 Enable (WDTE Bit) 55, 64 Overflow Flag (TOIF Bit) 13, 63 Programming Considerations 64 Overflow Interrupt 26, 63 RC Oscillator 64 RA4/TOCKI Pin, External Clock 6 Timing Diagram 92 <t< td=""><td>T1OSCEN Bit</td><td>. 27</td><td></td><td></td></t<> | T1OSCEN Bit | . 27 | | | | TMR1CS Bit 27 TMR1ON Bit 27 T2CON Register 9, 31 W Register 63 T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP 55, 65 TMR2ON Bit 31 Interrupts 60, 61 TOUTPS3:TOUTPS0 Bits 31 MCLR Reset 61 Timer0 25 Timing Diagram 66 Block Diagram 25 WDT Reset 61 Clock Source Edge Select (T0SE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Overflow Enable (T0IE Bit) 13 Enable (WDTE Bit) 55, 64 Overflow Flag (T0IF Bit) 13, 63 Programming Considerations 64 Overflow Interrupt 26, 63 RC Oscillator 64 RA4/T0CKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP 57, 60, 61 | T1SYNC Bit | .27 | Watchdog Timer (WDT) | 92 | | T2CON Register 9, 31 W Register 63 T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP 55, 65 TMR2ON Bit 31 Interrupts 60, 61 TOUTPS3:TOUTPS0 Bits 31 MCLR Reset 61 Timer0 25 Timing Diagram 66 Block Diagram 25 WDT Reset 61 Clock Source Edge Select (T0SE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Clock Source Select (T0CS Bit) 12, 25 Block Diagram 64 Overflow Enable (T0IE Bit) 13 Enable (WDTE Bit) 55, 64 Overflow Flag (T0IF Bit) 13, 63 Programming Considerations 64 Overflow Interrupt 26, 63 RC Oscillator 64 RA4/T0CKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP 57, 60, 61 | TMR1CS Bit | .27 | 3 ( ) | | | T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP .55, 65 TMR2ON Bit 31 Interrupts .60, 61 TOUTPS3:TOUTPS0 Bits 31 MCLR Reset .61 Timer0 25 Timing Diagram .66 Block Diagram 25 WDT Reset .61 Clock Source Edge Select (T0SE Bit) 12, 25 Watchdog Timer (WDT) .55, 64 Clock Source Select (T0CS Bit) 12, 25 Block Diagram .64 Overflow Enable (T0IE Bit) 13 Enable (WDTE Bit) .55, 64 Overflow Flag (T0IF Bit) 13, 63 Programming Considerations .64 Overflow Interrupt 26, 63 RC Oscillator .64 RA4/T0CKI Pin, External Clock 6 Timing Diagram .92 Timing Diagram .93 WDT Reset, Normal Operation .57, 60, 61 TMR0 Register .9 WDT Reset, SLEEP .57, 60, 61 | TMR1ON Bit | .27 <b>W</b> | | | | T2CKPS1:T2CKPS0 Bits 31 Wake-up from SLEEP .55, 65 TMR2ON Bit 31 Interrupts .60, 61 TOUTPS3:TOUTPS0 Bits 31 MCLR Reset .61 Timer0 25 Timing Diagram .66 Block Diagram 25 WDT Reset .61 Clock Source Edge Select (T0SE Bit) 12, 25 Watchdog Timer (WDT) .55, 64 Clock Source Select (T0CS Bit) 12, 25 Block Diagram .64 Overflow Enable (T0IE Bit) 13 Enable (WDTE Bit) .55, 64 Overflow Flag (T0IF Bit) 13, 63 Programming Considerations .64 Overflow Interrupt 26, 63 RC Oscillator .64 RA4/T0CKI Pin, External Clock 6 Timing Diagram .92 Timing Diagram .93 WDT Reset, Normal Operation .57, 60, 61 TMR0 Register .9 WDT Reset, SLEEP .57, 60, 61 | T2CON Register9, | 31 W | Register | 63 | | TOUTPS3:TOUTPS0 Bits 31 MCLR Reset 61 Timer0 25 Timing Diagram 66 Block Diagram 25 WDT Reset 61 Clock Source Edge Select (TOSE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Clock Source Select (TOCS Bit) 12, 25 Block Diagram 64 Overflow Enable (TOIE Bit) 13 Enable (WDTE Bit) 55, 64 Overflow Flag (TOIF Bit) 13, 63 Programming Considerations 64 Overflow Interrupt 26, 63 RC Oscillator 64 RA4/TOCKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP 57, 60, 61 | T2CKPS1:T2CKPS0 Bits | | | | | TOUTPS3:TOUTPS0 Bits 31 MCLR Reset 61 Timer0 25 Timing Diagram 66 Block Diagram 25 WDT Reset 61 Clock Source Edge Select (TOSE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Clock Source Select (TOCS Bit) 12, 25 Block Diagram 64 Overflow Enable (TOIE Bit) 13 Enable (WDTE Bit) 55, 64 Overflow Flag (TOIF Bit) 13, 63 Programming Considerations 64 Overflow Interrupt 26, 63 RC Oscillator 64 RA4/TOCKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP 57, 60, 61 | TMR2ON Bit | .31 | Interrupts60 | , 61 | | Block Diagram 25 WDT Reset 61 Clock Source Edge Select (T0SE Bit) 12, 25 Watchdog Timer (WDT) 55, 64 Clock Source Select (T0CS Bit) 12, 25 Block Diagram 64 Overflow Enable (T0IE Bit) 13 Enable (WDTE Bit) 55, 64 Overflow Flag (T0IF Bit) 13, 63 Programming Considerations 64 Overflow Interrupt 26, 63 RC Oscillator 64 RA4/T0CKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP 57, 60, 61 | TOUTPS3:TOUTPS0 Bits | .31 | | | | Clock Source Edge Select (T0SE Bit) 12, 25 Watchdog Timer (WDT) .55, 64 Clock Source Select (T0CS Bit) 12, 25 Block Diagram .64 Overflow Enable (T0IE Bit) 13 Enable (WDTE Bit) .55, 64 Overflow Flag (T0IF Bit) 13, 63 Programming Considerations .64 Overflow Interrupt 26, 63 RC Oscillator .64 RA4/T0CKI Pin, External Clock 6 Timing Diagram .92 Timing Diagram .93 WDT Reset, Normal Operation .57, 60, 61 TMR0 Register .9 WDT Reset, SLEEP .57, 60, 61 | Timer0 | . 25 | Timing Diagram | 66 | | Clock Source Edge Select (T0SE Bit) 12, 25 Watchdog Timer (WDT) .55, 64 Clock Source Select (T0CS Bit) 12, 25 Block Diagram .64 Overflow Enable (T0IE Bit) 13 Enable (WDTE Bit) .55, 64 Overflow Flag (T0IF Bit) 13, 63 Programming Considerations .64 Overflow Interrupt 26, 63 RC Oscillator .64 RA4/T0CKI Pin, External Clock 6 Timing Diagram .92 Timing Diagram .93 WDT Reset, Normal Operation .57, 60, 61 TMR0 Register .9 WDT Reset, SLEEP .57, 60, 61 | Block Diagram | . 25 | WDT Reset | 61 | | Clock Source Select (TOCS Bit) 12, 25 Block Diagram 64 Overflow Enable (TOIE Bit) 13 Enable (WDTE Bit) .55, 64 Overflow Flag (TOIF Bit) 13, 63 Programming Considerations .64 Overflow Interrupt 26, 63 RC Oscillator .64 RA4/TOCKI Pin, External Clock 6 Timing Diagram .92 Timing Diagram 93 WDT Reset, Normal Operation .57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP .57, 60, 61 | | | | | | Overflow Enable (T0IE Bit) 13 Enable (WDTE Bit) .55, 64 Overflow Flag (T0IF Bit) 13, 63 Programming Considerations .64 Overflow Interrupt 26, 63 RC Oscillator .64 RA4/T0CKI Pin, External Clock 6 Timing Diagram .92 Timing Diagram .93 WDT Reset, Normal Operation .57, 60, 61 TMR0 Register .9 WDT Reset, SLEEP .57, 60, 61 | • , , , | | | | | Overflow Flag (T0IF Bit) 13, 63 Programming Considerations 64 Overflow Interrupt 26, 63 RC Oscillator 64 RA4/T0CKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP 57, 60, 61 | | | | | | Overflow Interrupt 26, 63 RC Oscillator 64 RA4/T0CKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP 57, 60, 61 | | | | | | RA4/T0CKI Pin, External Clock 6 Timing Diagram 92 Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP 57, 60, 61 | <u> </u> | | | | | Timing Diagram 93 WDT Reset, Normal Operation 57, 60, 61 TMR0 Register 9 WDT Reset, SLEEP 57, 60, 61 | | | | | | TMR0 Register | | | | | | · · · · · · · · · · · · · · · · · · · | | | | | | | -<br>- | | | , |