Welcome to **E-XFL.COM** What is "Embedded - Microcontrollers"? "Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications. Applications of "<u>Embedded - Microcontrollers</u>" | Details | | |----------------------------|----------------------------------------------------------------------------| | Product Status | Active | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 4MHz | | Connectivity | UART/USART | | Peripherals | Brown-out Detect/Reset, POR, PWM, WDT | | Number of I/O | 16 | | Program Memory Size | 3.5KB (2K x 14) | | Program Memory Type | FLASH | | EEPROM Size | 128 x 8 | | RAM Size | 224 x 8 | | Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V | | Data Converters | - | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 125°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 20-SSOP (0.209", 5.30mm Width) | | Supplier Device Package | 20-SSOP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16f628-04e-ss | #### Note the following details of the code protection feature on Microchip devices: - Microchip products meet the specification contained in their particular Microchip Data Sheet. - Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions. - There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property. - Microchip is willing to work with the customer who is concerned about the integrity of their code. - Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable." Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Information contained in this publication regarding device applications and the like is intended through suggestion only and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. 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. #### **Trademarks** The Microchip name and logo, the Microchip logo, KEELOQ, MPLAB, PIC, PICmicro, PICSTART and PRO MATE are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. FilterLab, microID, MXDEV, MXLAB, PICMASTER, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A. dsPIC, dsPICDEM.net, ECONOMONITOR, FanSense, FlexROM, fuzzyLAB, In-Circuit Serial Programming, ICSP, ICEPIC, microPort, Migratable Memory, MPASM, MPLIB, MPLINK, MPSIM, PICC, PICDEM, PICDEM.net, rfPIC, Select Mode and Total Endurance are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. Serialized Quick Turn 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. © 2003, 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 and Mountain View, California in March 2002. The Company's quality system processes and procedures are QS-9000 compliant for its PICmicro® 8-bit MCUs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, non-volatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001 certified. TABLE 2-1: PIC16F62X PINOUT DESCRIPTION | Name | Function | Input Type | Output Type | Description | |-----------------|----------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RA0/AN0 | RA0 | ST | CMOS | Bi-directional I/O port | | | AN0 | AN | _ | Analog comparator input | | RA1/AN1 | RA1 | ST | CMOS | Bi-directional I/O port | | | AN1 | AN | _ | Analog comparator input | | RA2/AN2/VREF | RA2 | ST | CMOS | Bi-directional I/O port | | | AN2 | AN | _ | Analog comparator input | | | VREF | _ | AN | VREF output | | RA3/AN3/CMP1 | RA3 | ST | CMOS | Bi-directional I/O port | | | AN3 | AN | _ | Analog comparator input | | | CMP1 | _ | CMOS | Comparator 1 output | | RA4/T0CKI/CMP2 | RA4 | ST | OD | Bi-directional I/O port | | | T0CKI | ST | | Timer0 clock input | | | CMP2 | _ | OD | Comparator 2 output | | RA5/MCLR/VPP | RA5 | ST | _ | Input port | | | MCLR | ST | _ | Master clear | | | VPP | _ | _ | Programming voltage input. When configured as MCLR, this pin is an active low RESET to the device. Voltage on MCLR/VPP must not exceed VDD during normal device operation. | | RA6/OSC2/CLKOUT | RA6 | ST | CMOS | Bi-directional I/O port | | | OSC2 | XTAL | _ | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. | | | CLKOUT | _ | CMOS | In ER/INTRC mode, OSC2 pin can output CLKOUT, which has 1/4 the frequency of OSC1 | | RA7/OSC1/CLKIN | RA7 | ST | CMOS | Bi-directional I/O port | | | OSC1 | XTAL | _ | Oscillator crystal input | | | CLKIN | ST | _ | External clock source input. ER biasing pin. | | RB0/INT | RB0 | TTL | CMOS | Bi-directional I/O port. Can be software programmed for internal weak pull-up. | | | INT | ST | _ | External interrupt. | | RB1/RX/DT | RB1 | TTL | CMOS | Bi-directional I/O port. Can be software programmed for internal weak pull-up. | | | RX | ST | _ | USART receive pin | | | DT | ST | CMOS | Synchronous data I/O. | | RB2/TX/CK | RB2 | TTL | CMOS | Bi-directional I/O port. | | | TX | _ | CMOS | USART transmit pin | | | CK | ST | CMOS | Synchronous clock I/O. Can be software programmed for internal weak pull-up. | | RB3/CCP1 | RB3 | TTL | CMOS | Bi-directional I/O port. Can be software programmed for internal weak pull-up. | | | CCP1 | ST | CMOS | Capture/Compare/PWM I/O | Legend: O = Output CMOS = CMOS Output P = Power — = Not used I = Input ST = Schmitt Trigger Input TTL = TTL Input OD = Open Drain Output AN = Analog #### 3.0 MEMORY ORGANIZATION #### 3.1 Program Memory Organization The PIC16F62X has a 13-bit program counter capable of addressing an 8K x 14 program memory space. Only the first 1K x 14 (0000h - 03FFh) for the PIC16F627 and 2K x 14 (0000h - 07FFh) for the PIC16F628 are physically implemented. Accessing a location above these boundaries will cause a wrap-around within the first 1K x 14 space (PIC16F627) or 2K x 14 space (PIC16F628). The RESET vector is at 0000h and the interrupt vector is at 0004h (Figure 3-1). FIGURE 3-1: PROGRAM MEMORY MAP AND STACK #### 3.2 Data Memory Organization The data memory (Figure 3-2) is partitioned into four banks, which contain the general purpose registers and the Special Function Registers (SFR). The SFR's are located in the first 32 locations of each Bank. Register locations 20-7Fh, A0h-FFh, 120h-14Fh, 170h-17Fh and 1F0h-1FFh are general purpose registers implemented as static RAM. The Table below lists how to access the four banks of registers: | | RP1 | RP0 | |-------|-----|-----| | Bank0 | 0 | 0 | | Bank1 | 0 | 1 | | Bank2 | 1 | 0 | | Bank3 | 1 | 1 | Addresses F0h-FFh, 170h-17Fh and 1F0h-1FFh are implemented as common RAM and mapped back to addresses 70h-7Fh. ### 3.2.1 GENERAL PURPOSE REGISTER FILE The register file is organized as 224 x 8 in the PIC16F62X. Each is accessed either directly or indirectly through the File Select Register FSR (See Section 3.4). © 2003 Microchip Technology Inc. Preliminary DS40300C-page 13 TABLE 3-3: SPECIAL FUNCTION REGISTERS SUMMARY BANK 2 | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR<br>Reset <sup>(1)</sup> | Details on<br>Page | |---------|--------|------------------|------------------------------------------------------|-----------|-------------|------------|-----------|---------------|--------------|-----------------------------------------|--------------------| | Bank 2 | | | | | | | | | | | | | 100h | INDF | Addressin ister) | g this location | uses cont | ents of FSF | to address | data memo | ory (not a pł | nysical reg- | xxxx xxxx | 25 | | 101h | TMR0 | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 43 | | 102h | PCL | Program 0 | ogram Counter's (PC) Least Significant Byte | | | | | | | | 25 | | 103h | STATUS | IRP | RP1 | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 19 | | 104h | FSR | | ata memory a | | | | | | | xxxx xxxx | 25 | | 105h | _ | Unimplem | | | | | | | | _ | _ | | 106h | PORTB | RB7 | RB6 | RB5 | RB4 | RB3 | RB2 | RB1 | RB0 | xxxx xxxx | 34 | | 107h | _ | Unimplem | ented | | L | <u>I</u> | l. | l | l | _ | _ | | 108h | _ | Unimplem | ented | | | | | | | _ | _ | | 109h | _ | Unimplem | ented | | | | | | | _ | _ | | 10Ah | PCLATH | | — — Write buffer for upper 5 bits of program counter | | | | | | | 0 0000 | 25 | | 10Bh | INTCON | GIE | PEIE | T0IE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 21 | | 10Ch | _ | Unimplem | ented | | _ | _ | | | | | | | 10Dh | _ | Unimplem | Jnimplemented | | | | | | | | _ | | 10Eh | _ | Unimplem | ented | | | | | | | _ | _ | | 10Fh | _ | Unimplem | ented | | | | | | | _ | _ | | 110h | _ | Unimplem | ented | | | | | | | _ | _ | | 111h | _ | Unimplem | ented | | | | | | | _ | _ | | 112h | _ | Unimplem | ented | | | | | | | _ | _ | | 113h | | Unimplem | ented | | | | | | | _ | _ | | 114h | _ | Unimplem | ented | | | | | | | _ | _ | | 115h | _ | Unimplem | ented | | | | | | | _ | _ | | 116h | _ | Unimplem | ented | | | | | | | _ | _ | | 117h | _ | Unimplem | ented | | | | | | | _ | _ | | 118h | _ | Unimplem | ented | | | | | | | _ | _ | | 119h | _ | Unimplem | ented | | | | | | | _ | _ | | 11Ah | _ | Unimplem | ented | | | | | | | _ | _ | | 11Bh | _ | Unimplem | ented | | | | | | | _ | _ | | 11Ch | _ | Unimplem | ented | | | | | | | _ | _ | | 11Dh | _ | Unimplem | ented | | | | | | | _ | _ | | 11Eh | _ | Unimplem | ented | | | | | | | _ | _ | | 11Fh | _ | Unimplem | ented | | | | | | | _ | _ | Legend: — = Unimplemented locations read as '0', u = unchanged, x = unknown, q = value depends on condition, shaded = unimplemented. Note 1: For the Initialization Condition for Registers Tables, refer to Table 14-7 and Table 14-8 on page 98. © 2003 Microchip Technology Inc. Preliminary DS40300C-page 17 TABLE 3-4: SPECIAL FUNCTION REGISTERS SUMMARY BANK 3 | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR<br>Reset <sup>(1)</sup> | Details on<br>Page | |---------|--------|------------------|------------------------------------------------------|-------------|-------------|--------------|------------|---------------|--------------|-----------------------------------------|--------------------| | Bank 3 | | | | | | | | | | | | | 180h | INDF | Addressin ister) | g this location | n uses cont | ents of FSF | R to address | s data mem | ory (not a pl | hysical reg- | xxxx xxxx | 25 | | 181h | OPTION | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 20 | | 182h | PCL | Program ( | gram Counter's (PC) Least Significant Byte | | | | | | | | 25 | | 183h | STATUS | IRP | RP1 | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 19 | | 184h | FSR | _ | ata memory a | | nter | | . – | | | xxxx xxxx | 25 | | 185h | _ | Unimplem | | | | | | | | _ | _ | | 186h | TRISB | TRISB7 | TRISB6 | TRISB5 | TRISB4 | TRISB3 | TRISB2 | TRISB1 | TRISB0 | 1111 1111 | 34 | | 187h | _ | Unimplem | ented | | | | | L | | _ | _ | | 188h | _ | Unimplem | ented | | | | | | | _ | _ | | 189h | _ | Unimplem | ented | | | | | | | _ | _ | | 18Ah | PCLATH | | — — Write buffer for upper 5 bits of program counter | | | | | | 0 0000 | 25 | | | 18Bh | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | RBIF | 0000 000x | 21 | | 18Ch | _ | Unimplem | ented | | _ | _ | | | | | | | 18Dh | _ | Unimplem | Inimplemented | | | | | | | | _ | | 18Eh | _ | Unimplem | Inimplemented | | | | | | | | _ | | 18Fh | _ | Unimplem | ented | | | | | | | _ | _ | | 190h | _ | Unimplem | ented | | | | | | | _ | _ | | 191h | _ | Unimplem | ented | | | | | | | _ | _ | | 192h | _ | Unimplem | ented | | | | | | | _ | _ | | 193h | _ | Unimplem | ented | | | | | | | _ | _ | | 194h | _ | Unimplem | ented | | | | | | | _ | _ | | 195h | _ | Unimplem | ented | | | | | | | _ | _ | | 196h | _ | Unimplem | ented | | | | | | | _ | _ | | 197h | _ | Unimplem | ented | | | | | | | _ | _ | | 198h | _ | Unimplem | nented | | | | | | | _ | _ | | 199h | _ | Unimplem | nented | | | | | | | _ | _ | | 19Ah | _ | Unimplem | ented | | | | | | | _ | _ | | 19Bh | _ | Unimplem | ented | | | | | | | _ | _ | | 19Ch | _ | Unimplem | ented | | | | | | | _ | _ | | 19Dh | _ | Unimplem | ented | | | | | | | _ | _ | | 19Eh | _ | Unimplem | ented | | | | | | | _ | _ | | 19Fh | _ | Unimplem | ented | | | | | | | _ | _ | Legend: — = Unimplemented locations read as '0', u = unchanged, x = unknown, q = value depends on condition, shaded = unimplemented Note 1: For the Initialization Condition for Registers Tables, refer to Table 14-7 and Table 14-8 on page 98. #### 3.2.2.2 OPTION Register The OPTION register is a readable and writable register which contains various control bits to configure the TMR0/WDT prescaler, the external RB0/INT interrupt, TMR0, and the weak pull-ups on PORTB. Note: To achieve a 1:1 prescaler assignment for TMR0, assign the prescaler to the WDT (PSA = 1). See Section 6.3.1 #### REGISTER 3-2: OPTION REGISTER (ADDRESS: 81h, 181h) | R/W-1 | | | |-------|--------|-------|-------|-------|-------|-------|-------|--|--|--| | RBPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | | | | | 177 | | | | | | | | | | | bit 7 bit 0 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 $\ensuremath{\mathtt{1}}$ = Increment on high-to-low transition on RA4/T0CKI pin 0 = Increment on low-to-high transition on RA4/T0CKI pin bit 3 **PSA**: Prescaler Assignment bit 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 | | | | 111 | 1:256 | 1 : 128 | | | | Legend: | | | | | |------------|---------|------------------|----------------------|--------------------| | R = Readal | ole 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 | DS40300C-page 23 #### 3.2.2.5 PIR1 Register This register contains interrupt flag bits. Note: Interrupt flag bits get 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 3-5: PIR1 REGISTER (ADDRESS: 0Ch) | R/W-0 | R/W-0 | R-0 | R-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-------|------|------|----------|--------|--------|--------| | EEIF | CMIF | RCIF | TXIF | _ | CCP1IF | TMR2IF | TMR1IF | | | • | | | <u> </u> | | | | bit 7 bit 0 bit 7 **EEIF:** EEPROM Write Operation Interrupt Flag bit 1 = The write operation completed (must be cleared in software)0 = The write operation has not completed or has not been started bit 6 **CMIF**: Comparator Interrupt Flag bit 1 = Comparator output has changed 0 = Comparator output has not changed bit 5 RCIF: USART Receive Interrupt Flag bit 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 **Unimplemented**: Read as '0' bit 2 CCP1IF: CCP1 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 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 bit 0 TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflowed (must be cleared in software) 0 = TMR1 register did not overflow 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 #### 5.3 I/O Programming Considerations #### 5.3.1 BI-DIRECTIONAL I/O PORTS Any instruction which writes, operates internally as a read followed by a write operation. The BCF and BSF instructions, for example, read the register into the CPU, execute the bit operation and write the result back to the register. Caution must be used when these instructions are applied to a port with both inputs and outputs defined. For example, a BSF operation on Bit 5 of PORTB will cause all eight bits of PORTB to be read into the CPU. Then the BSF operation takes place on Bit 5 and PORTB is written to the output latches. If another bit of PORTB is used as a bi-directional I/O pin (e.g., Bit 0) and it is defined as an input at this time, the input signal present on the pin itself would be read into the CPU and rewritten to the data latch of this particular pin, overwriting the previous content. As long as the pin stays in the Input mode, no problem occurs. However, if Bit 0 is switched into Output mode later on, the content of the data latch may now be unknown. Reading a port register, reads the values of the port pins. Writing to the port register writes the value to the port latch. When using read-modify-write instructions (ex. BCF, BSF, etc.) on a port, the value of the port pins is read, the desired operation is done to this value, and this value is then written to the port latch. Example 5-2 shows the effect of two sequential read-modify-write instructions (ex., BCF, BSF, etc.) on an I/O port A pin actively outputting a Low or High should not be driven from external devices at the same time in order to change the level on this pin ("wired-or", "wired-and"). The resulting high output currents may damage the chip. # EXAMPLE 5-2: READ-MODIFY-WRITE INSTRUCTIONS ON AN I/O PORT ``` ;Initial PORT settings:PORTB<7:4> Inputs ; PORTB<3:0> Outputs ;PORTB<7:6> have external pull-up and are not ; connected to other circuitry PORT latchPORT Pins BCF STATUS, RP0 BCF PORTB, 7 ;01pp pppp 11pp pppp BSF STATUS, RPO BCF TRISB, 7 ;10pp pppp 11pp pppp BCF TRISB, 6 ;10pp pppp 10pp pppp ; Note that the user may have expected the pin ; values to be 00pp pppp. The 2nd BCF caused ;RB7 to be latched as the pin value (High). ``` ### 5.3.2 SUCCESSIVE OPERATIONS ON I/O PORTS The actual write to an I/O port happens at the end of an instruction cycle, whereas for reading, the data must be valid at the beginning of the instruction cycle (Figure 5-16). Therefore, care must be exercised if a write followed by a read operation is carried out on the same I/O port. The sequence of instructions should be such to allow the pin voltage to stabilize (load dependent) before the next instruction which causes that file to be read into the CPU is executed. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. When in doubt, it is better to separate these instructions with a NOP or another instruction not accessing this I/O port. #### FIGURE 5-16: SUCCESSIVE I/O OPERATION Note - 1: This example shows write to PORTB followed by a read from PORTB. - 2: Data setup time = (0.25 Tcy TPD) where Tcy = instruction cycle and TPD = propagation delay of Q1 cycle to output valid. Therefore, at higher clock frequencies, a write followed by a read may be problematic. The code example in Example 9-1 depicts the steps required to configure the Comparator module. RA3 and RA4 are configured as digital output. RA0 and RA1 are configured as the V- inputs and RA2 as the V+ input to both comparators. ### EXAMPLE 9-1: INITIALIZING COMPARATOR MODULE | FLAG_REG | EQU | 0X20 | |----------|--------------|--------------------------------------| | CLRF | FLAG_REG | ;Init flag register | | CLRF | PORTA | ;Init PORTA | | MOVF | CMCON, W | ;Load comparator bits | | ANDLW | 0xC0 | ;Mask comparator bits | | IORWF | FLAG_REG,F | ;Store bits in flag register | | MOVLW | 0x03 | ;Init comparator mode | | MOVWF | CMCON | ;CM<2:0> = 011 | | BSF | STATUS, RPO | ;Select Bank1 | | MOVLW | 0x07 | ;Initialize data direction | | MOVWF | TRISA | ;Set RA<2:0> as inputs | | | | ;RA<4:3> as outputs | | | | ;TRISA<7:5> always read '0' | | BCF | STATUS, RPO | ;Select Bank 0 | | CALL | DELAY10 | ;10µs delay | | MOVF | CMCON, F | ; Read CMCON to end change condition | | BCF | PIR1,CMIF | ;Clear pending interrupts | | BSF | STATUS, RPO | ;Select Bank 1 | | BSF | PIE1,CMIE | ;Enable comparator interrupts | | BCF | STATUS, RPO | ;Select Bank 0 | | BSF | INTCON, PEIE | ;Enable peripheral interrupts | | BSF | INTCON, GIE | ;Global interrupt enable | #### 9.2 Comparator Operation A single comparator is shown in Figure 9-2 along with the relationship between the analog input levels and the digital output. When the analog input at VIN+ is less than the analog input VIN-, the output of the comparator is a digital low level. When the analog input at VIN+ is greater than the analog input VIN-, the output of the comparator is a digital high level. The shaded areas of the output of the comparator in Figure 9-2 represent the uncertainty due to input offsets and response time. #### 9.3 Comparator Reference An external or internal reference signal may be used depending on the Comparator Operating mode. The analog signal that is present at VIN- is compared to the signal at VIN+, and the digital output of the comparator is adjusted accordingly (Figure 9-2). #### FIGURE 9-2: SINGLE COMPARATOR #### 9.3.1 EXTERNAL REFERENCE SIGNAL When external voltage references are used, the comparator module can be configured to have the comparators operate from the same or different reference sources. However, threshold detector applications may require the same reference. The reference signal must be between Vss and VDD, and can be applied to either pin of the comparator(s). #### 9.3.2 INTERNAL REFERENCE SIGNAL The Comparator module also allows the selection of an internally generated voltage reference for the comparators. Section 10.0, Voltage Reference Manual, contains a detailed description of the Voltage Reference module that provides this signal. The internal reference signal is used when the comparators are in mode CM<2:0>=010 (Figure 9-1). In this mode, the internal voltage reference is applied to the VIN+ pin of both comparators. #### 9.4 Comparator Response Time Response time is the minimum time, after selecting a new reference voltage or input source, before the comparator output is ensured to have a valid level. If the internal reference is changed, the maximum delay of the internal voltage reference must be considered when using the comparator outputs. Otherwise the maximum delay of the comparators should be used (Table 17-1). ### 12.4 USART Synchronous Master Mode In Synchronous Master mode, the data is transmitted in a half-duplex manner (i.e., transmission and reception do not occur at the same time). When transmitting data, the reception is inhibited and vice versa. Synchronous mode is entered by setting bit SYNC (TXSTA<4>). In addition, enable bit SPEN (RCSTA<7>) is set in order to configure the RB2/TX/CK and RB1/RX/DT I/O pins to CK (clock) and DT (data) lines respectively. The Master mode indicates that the processor transmits the master clock on the CK line. The Master mode is entered by setting bit CSRC (TXSTA<7>). ### 12.4.1 USART SYNCHRONOUS MASTER TRANSMISSION The USART Transmitter Block Diagram is shown in Figure 12-5. The heart of the transmitter is the Transmit (serial) Shift register (TSR). The Shift register obtains its data from the read/write transmit buffer register TXREG. The TXREG register is loaded with data in software. The TSR register is not loaded until the last bit has been transmitted from the previous load. As soon as the last bit is transmitted, the TSR is loaded with new data from the TXREG (if available). Once the TXREG register transfers the data to the TSR register (occurs in one Tcycle), the TXREG is empty and interrupt bit, TXIF (PIR1<4>) is set. The interrupt can be enabled/disabled by setting/clearing enable bit TXIE (PIE1<4>). Flag bit TXIF will be set regardless of the state of enable bit TXIE and cannot be cleared in software. It will RESET only when new data is loaded into the TXREG register. While flag bit TXIF indicates the status of the TXREG register, another bit TRMT (TXSTA<1>) shows the status of the TSR register. TRMT is a read only bit which is set when the TSR is empty. No interrupt logic is tied to this bit, so the user has to poll this bit in order to determine if the TSR register is empty. The TSR is not mapped in data memory so it is not available to the user. Transmission is enabled by setting enable bit TXEN (TXSTA<5>). The actual transmission will not occur until the TXREG register has been loaded with data. The first data bit will be shifted out on the next available rising edge of the clock on the CK line. Data out is stable around the falling edge of the synchronous clock (Figure 12-12). The transmission can also be started by first loading the TXREG register and then setting bit TXEN (Figure 12-13). This is advantageous when slow baud rates are selected, since the BRG is kept in RESET when bits TXEN, CREN, and SREN are clear. Setting enable bit TXEN will start the BRG, creating a shift clock immediately. Normally when transmission is first started, the TSR register is empty, so a transfer to the TXREG register will result in an immediate transfer to TSR resulting in an empty TXREG. Back-to-back transfers are possible. Clearing enable bit TXEN, during a transmission, will cause the transmission to be aborted and will RESET the transmitter. The DT and CK pins will revert to hiimpedance. If either bit CREN or bit SREN is set, during a transmission, the transmission is aborted and the DT pin reverts to a hi-impedance state (for a reception). The CK pin will remain an output if bit CSRC is set (internal clock). The transmitter logic however is not RESET although it is disconnected from the pins. In order to RESET the transmitter, the user has to clear bit TXEN. If bit SREN is set (to interrupt an on-going transmission and receive a single word), then after the single word is received, bit SREN will be cleared and the serial port will revert back to transmitting since bit TXEN is still set. The DT line will immediately switch from Hi-impedance Receive mode to transmit and start driving. To avoid this, bit TXEN should be cleared. In order to select 9-bit transmission, the TX9 (TXSTA<6>) bit should be set and the ninth bit should be written to bit TX9D (TXSTA<0>). The ninth bit must be written before writing the 8-bit data to the TXREG register. This is because a data write to the TXREG can result in an immediate transfer of the data to the TSR register (if the TSR is empty). If the TSR was empty and the TXREG was written before writing the "new" TX9D, the "present" value of bit TX9D is loaded. Steps to follow when setting up a Synchronous Master Transmission: - 1. Initialize the SPBRG register for the appropriate baud rate (Section 12.1). - Enable the synchronous master serial port by setting bits SYNC, SPEN, and CSRC. - If interrupts are desired, then set enable bit TXIE. - 4. If 9-bit transmission is desired, then set bit TX9. - Enable the transmission by setting bit TXEN. - If 9-bit transmission is selected, the ninth bit should be loaded in bit TX9D. - Start transmission by loading data to the TXREG register. ### 12.5.2 USART SYNCHRONOUS SLAVE RECEPTION The operation of the Synchronous Master and Slave modes is identical except in the case of the SLEEP mode. Also, bit SREN is a don't care in Slave mode. If receive is enabled, by setting bit CREN, prior to the SLEEP instruction, then a word may be received during SLEEP. On completely receiving the word, the RSR register will transfer the data to the RCREG register and if enable bit RCIE bit is set, the interrupt generated will wake the chip from SLEEP. If the global interrupt is enabled, the program will branch to the interrupt vector (0004h). Steps to follow when setting up a Synchronous Slave Reception: 1. Enable the synchronous master serial port by - setting bits SYNC and SPEN and clearing bit CSRC. - If interrupts are desired, then set enable bit RCIE. - 3. If 9-bit reception is desired, then set bit RX9. - 4. To enable reception, set enable bit CREN. - 5. Flag bit RCIF will be set when reception is complete and an interrupt will be generated, if enable bit RCIE was set. - Read the RCSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception. - 7. Read the 8-bit received data by reading the RCREG register. - If any error occurred, clear the error by clearing bit CREN. TABLE 12-11: REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE TRANSMISSION | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR | Value on all<br>other<br>RESETS | |---------|------------------------------------|----------|-----------|----------|-------|-------|--------|--------|--------|-----------------|---------------------------------| | 0Ch | PIR1 | EEIF | CMIF | RCIF | TXIF | | CCP1IF | TMR2IF | TMR1IF | 0000 -000 | 0000 -000 | | 18h | RCSTA | SPEN | RX9 | SREN | CREN | ADEN | FERR | OERR | RX9D | 0000 -00x | 0000 -00x | | 19h | TXREG | USART Ti | ransmit F | Register | | | | | | 0000 0000 | 0000 0000 | | 8Ch | PIE1 | EEIE | CMIE | RCIE | TXIE | _ | CCP1IE | TMR2IE | TMR1IE | 0000 -000 | 0000 -000 | | 98h | TXSTA | CSRC | TX9 | TXEN | SYNC | _ | BRGH | TRMT | TX9D | 0000 -010 | 0000 -010 | | 99h | SPBRG Baud Rate Generator Register | | | | | | | | | 0000 0000 | 0000 0000 | Legend: x = unknown, - = unimplemented read as '0'. Shaded cells are not used for Synchronous Slave Transmission. #### TABLE 12-12: REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE RECEPTION | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR | Value on all<br>other<br>RESETS | |---------|-------|---------------------------------|----------|----------|-------|-------|--------|--------|--------|-----------------|---------------------------------| | 0Ch | PIR1 | EEIF | CMIF | RCIF | TXIF | | CCP1IF | TMR2IF | TMR1IF | 0000 -000 | 0000 -000 | | 18h | RCSTA | SPEN | RX9 | SREN | CREN | ADEN | FERR | OERR | RX9D | 0000 -00x | 0000 -00x | | 1Ah | RCREG | USART R | eceive F | Register | | | • | • | • | 0000 0000 | 0000 0000 | | 8Ch | PIE1 | EEIE | CMIE | RCIE | TXIE | 1 | CCP1IE | TMR2IE | TMR1IE | 0000 -000 | 0000 -000 | | 98h | TXSTA | CSRC | TX9 | TXEN | SYNC | _ | BRGH | TRMT | TX9D | 0000 -010 | 0000 -010 | | 99h | SPBRG | RG Baud Rate Generator Register | | | | | | | | | 0000 0000 | Legend: x = unknown, - = unimplemented read as '0'. Shaded cells are not used for Synchronous Slave Reception. © 2003 Microchip Technology Inc. Preliminary DS40300C-page 85 FIGURE 14-2: EXTERNAL PARALLEL RESONANT CRYSTAL Figure 14-3 shows a series resonant oscillator circuit. This circuit is also designed to use the fundamental frequency of the crystal. The inverter performs a 180° phase shift in a series resonant oscillator circuit. The 330 k $\Omega$ resistors provide the negative feedback to bias the inverters in their linear region. FIGURE 14-3: EXTERNAL SERIES RESONANT CRYSTAL OSCILLATOR CIRCUIT #### 14.2.4 EXTERNAL CLOCK IN For applications, where a clock is already available elsewhere, users may directly drive the PIC16F62X provided that this external clock source meets the AC/DC timing requirements listed in Section 17.4. Figure 14-4 shows how an external clock circuit should be configured. FIGURE 14-4: EXTERNAL CLOCK INPUT OPERATION (EC, HS, XT OR LP OSC CONFIGURATION) #### 14.2.5 ER OSCILLATOR For timing insensitive applications, the ER (External Resistor) Clock mode offers additional cost savings. Only one external component, a resistor to Vss, is needed to set the operating frequency of the internal oscillator. The resistor draws a DC bias current which controls the oscillation frequency. In addition to the resistance value, the oscillator frequency will vary from unit to unit, and as a function of supply voltage and temperature. Since the controlling parameter is a DC current and not a capacitance, the particular package type and lead frame will not have a significant effect on the resultant frequency. Figure 14-5 shows how the controlling resistor is connected to the PIC16F62X. For REXT values below 10k, the oscillator operation becomes sensitive to temperature. For very high REXT values (e.g., 1M), the oscillator becomes sensitive to leakage and may stop completely. Thus, we recommend keeping REXT between 10k and 1M. FIGURE 14-5: EXTERNAL RESISTOR Table 14-3 shows the relationship between the resistance value and the operating frequency. TABLE 14-3: RESISTANCE AND FREQUENCY RELATIONSHIP | Resistance | Frequency | |------------|-----------| | 0 | 10.4 MHz | | 1K | 10 MHz | | 10K | 7.4 MHz | | 20K | 5.3 MHz | | 47K | 3 MHz | | 100K | 1.6 MHz | | 220K | 800 kHz | | 470K | 300 kHz | | 1M | 200 kHz | The ER Oscillator mode has two options that control the unused OSC2 pin. The first allows it to be used as a general purpose I/O port. The other configures the pin as an output providing the Fosc signal (internal clock divided by 4) for test or external synchronization purposes. #### 14.5.5 TIMEOUT SEQUENCE On power-up the timeout sequence is as follows: First PWRT timeout is invoked after POR has expired. Then OST is activated. The total timeout will vary based on oscillator configuration and PWRTE bit status. For example, in ER mode with PWRTE bit erased (PWRT disabled), there will be no timeout at all. Figure 14-8, Figure 14-9 and Figure 14-10 depict timeout sequences. Since the timeouts occur from the POR pulse, if MCLR is kept low long enough, the timeouts will expire. Then bringing MCLR high will begin execution immediately (see Figure 14-9). This is useful for testing purposes or to synchronize more than one PIC16F62X device operating in parallel. Table 14-7 shows the RESET conditions for some special registers, while Table 14-8 shows the RESET conditions for all the registers. ### 14.5.6 POWER CONTROL (PCON) STATUS REGISTER The Power Control/STATUS register, PCON (address 8Eh) has two bits. Bit0 is $\overline{BOD}$ (Brown-out). $\overline{BOD}$ is unknown on Power-on Reset. It must then be set by the user and checked on subsequent RESETS to see if $\overline{BOD}$ = 0 indicating that a brown-out has occurred. The $\overline{BOD}$ STATUS bit is a don't care and is not necessarily predictable if the brown-out circuit is disabled (by setting BODEN bit = 0 in the Configuration word). Bit1 is $\overline{\mathsf{POR}}$ (Power-on Reset). It is a '0' on Power-on Reset and unaffected otherwise. The user must write a '1' to this bit following a Power-on Reset. On a subsequent RESET if $\overline{\mathsf{POR}}$ is '0', it will indicate that a Power-on Reset must have occurred (VDD may have gone too low). **TABLE 14-4: TIMEOUT IN VARIOUS SITUATIONS** | Oscillator Configuration | Powe | er-up | Brown-out Detect | Wake-up | |--------------------------|-------------------|-----------|-------------------|------------| | | PWRTE = 0 | PWRTE = 1 | Reset | from SLEEP | | XT, HS, LP | 72 ms + 1024 Tosc | 1024 Tosc | 72 ms + 1024 Tosc | 1024 Tosc | | ER, INTRC, EC | 72 ms | _ | 72 ms | _ | TABLE 14-5: STATUS/PCON BITS AND THEIR SIGNIFICANCE | POR | BOD | TO | PD | | | | | |-----|-----|----|----|------------------------------------|--|--|--| | 0 | Х | 1 | 1 | Power-on Reset | | | | | 0 | Х | 0 | Х | Illegal, TO is set on POR | | | | | 0 | Х | Х | 0 | Illegal, PD is set on POR | | | | | 1 | 0 | X | Х | Brown-out Detect Reset | | | | | 1 | 1 | 0 | u | WDT Reset | | | | | 1 | 1 | 0 | 0 | WDT Wake-up | | | | | 1 | 1 | u | u | MCLR Reset during normal operation | | | | | 1 | 1 | 1 | 0 | MCLR Reset during SLEEP | | | | Legend: u = unchanged, x = unknown. TABLE 14-6: SUMMARY OF REGISTERS ASSOCIATED WITH BROWN-OUT | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR Reset | Value on all<br>other<br>RESETS <sup>(1)</sup> | |---------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------|------------------------------------------------| | 03h | STATUS | IRP | RP1 | RPO | TO | PD | Z | DC | С | 0001 1xxx | 000q quuu | | 8Eh | PCON | | | | 1 | OSCF | Reset | POR | BOD | 1-0x | u-uq | Note 1: Other (non Power-up) Resets include MCLR Reset, Brown-out Detect Reset and Watchdog Timer Reset during normal operation. ### PIC16F62X TABLE 15-2: PIC16F62X INSTRUCTION SET | Mnem | onic, | Description | Cycles | 14-Bit Opcode | | | | Status | Notes | |-----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------|------|------|------|--------------|-------| | Opera | ands | 2 Societa de la constante l | | MSb | | | LSb | Affected | Hotes | | BYTE-ORI | ENTED FI | LE REGISTER OPERATIONS | | | | | | | | | ADDWF | f, d | Add W and f | 1 | 00 | 0111 | dfff | ffff | C,DC,Z | 1,2 | | ANDWF | f, d | AND W with f | 1 | 00 | 0101 | dfff | ffff | Z | 1,2 | | CLRF | f | Clear f | 1 | 00 | 0001 | lfff | ffff | Z | 2 | | CLRW | _ | Clear W | 1 | 00 | 0001 | 0000 | 0011 | Z | | | COMF | f, d | Complement f | 1 | 00 | 1001 | dfff | ffff | Z | 1,2 | | DECF | f, d | Decrement f | 1 | 00 | 0011 | dfff | ffff | Z | 1,2 | | DECFSZ | f, d | Decrement f, Skip if 0 | 1 <sup>(2)</sup> | 00 | 1011 | dfff | ffff | | 1,2,3 | | INCF | f, d | Increment f | 1 | 00 | 1010 | dfff | ffff | Z | 1,2 | | INCFSZ | f, d | Increment f, Skip if 0 | 1 <sup>(2)</sup> | 00 | 1111 | dfff | ffff | | 1,2,3 | | IORWF | f, d | Inclusive OR W with f | 1 | 00 | 0100 | dfff | ffff | Z | 1,2 | | MOVF | f, d | Move f | 1 | 00 | 1000 | dfff | ffff | Z | 1,2 | | MOVWF | f | Move W to f | 1 | 00 | 0000 | lfff | ffff | | | | NOP | _ | No Operation | 1 | 00 | 0000 | 0xx0 | 0000 | | | | RLF | f, d | Rotate Left f through Carry | 1 | 00 | 1101 | dfff | ffff | С | 1,2 | | RRF | f, d | Rotate Right f through Carry | 1 | 00 | 1100 | dfff | ffff | С | 1,2 | | SUBWF | f, d | Subtract W from f | 1 | 00 | 0010 | dfff | ffff | C,DC,Z | 1,2 | | SWAPF | f, d | Swap nibbles in f | 1 | 00 | 1110 | dfff | ffff | | 1,2 | | XORWF | f, d | Exclusive OR W with f | 1 | 0.0 | 0110 | dfff | ffff | Z | 1,2 | | BIT-ORIEN | NTED FILE | REGISTER OPERATIONS | | | | | | | | | BCF | f, b | Bit Clear f | 1 | 01 | 00bb | bfff | ffff | | 1,2 | | BSF | f, b | Bit Set f | 1 | 01 | 01bb | bfff | ffff | | 1,2 | | BTFSC | f, b | Bit Test f, Skip if Clear | 1 <sup>(2)</sup> | 01 | 10bb | bfff | ffff | | 3 | | BTFSS | f, b | Bit Test f, Skip if Set | 1 <sup>(2)</sup> | 01 | 11bb | bfff | ffff | | 3 | | LITERAL A | AND CON | TROL OPERATIONS | | | | | | | | | ADDLW | k | Add literal and W | 1 | 11 | 111x | kkkk | kkkk | C,DC,Z | | | ANDLW | k | AND literal with W | 1 | 11 | 1001 | kkkk | kkkk | Z | | | CALL | k | Call subroutine | 2 | 10 | 0kkk | kkkk | kkkk | | | | CLRWDT | _ | Clear Watchdog Timer | 1 | 00 | 0000 | 0110 | 0100 | TO,PD | | | GOTO | k | Go to address | 2 | 10 | 1kkk | kkkk | kkkk | | | | IORLW | k | Inclusive OR literal with W | 1 | 11 | 1000 | kkkk | kkkk | Z | | | MOVLW | k | Move literal to W | 1 | 11 | 00xx | kkkk | kkkk | | | | RETFIE | _ | Return from interrupt | 2 | 00 | 0000 | 0000 | 1001 | | | | RETLW | k | Return with literal in W | 2 | 11 | 01xx | kkkk | kkkk | | | | RETURN | _ | Return from Subroutine | 2 | 00 | 0000 | 0000 | 1000 | | | | SLEEP | _ | Go into Standby mode | 1 | 00 | 0000 | 0110 | 0011 | TO,PD | | | SUBLW | k | Subtract W from literal | 1 | 11 | 110x | kkkk | kkkk | C,DC,Z | | | XORLW | k | Exclusive OR literal with W | 1 | 11 | 1010 | kkkk | kkkk | Z | | | Note 1. | | I/O register is modified as a function of itself ( a.g. 200) | | | | | | tualua propo | | Note 1: When an I/O register is modified as a function of itself (e.g., MOVF PORTE, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'. <sup>2:</sup> If this instruction is executed on the TMR0 register (and, where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 Module. <sup>3:</sup> If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP. | BTFSS | Bit Test f, Skip if Set | CALL | Call Subroutine | |------------------|-------------------------------------------------------------------|---------------------|----------------------------------------------------------------| | Syntax: | [ label ] BTFSS f,b | Syntax: | [label] CALL k | | Operands: | $0 \leq f \leq 127$ | Operands: | $0 \leq k \leq 2047$ | | | 0 ≤ b < 7 | Operation: | (PC)+ $1 \rightarrow TOS$ , | | Operation: | skip if (f <b>) = 1</b> | | $k \rightarrow PC<10:0>$ , | | Status Affected: | None | Chatura Affarata di | (PCLATH<4:3>) → PC<12:11> | | Encoding: | 01 11bb bfff ffff | Status Affected: | None | | Description: | If bit 'b' in register 'f' is '1' then the | Encoding: | 10 0kkk kkkk kkkk | | | next instruction is skipped. If bit 'b' is '1', then the next | Description: | Call Subroutine. First, return address (PC+1) is pushed onto | | | instruction fetched during the | | the stack. The eleven bit | | | current instruction execution, is discarded and a NOP is executed | | immediate address is loaded into PC bits <10:0>. The upper | | | instead, making this a two-cycle | | bits of the PC are loaded from | | | instruction. | | PCLATH. CALL is a two-cycle | | Words: | 1 | Words: | instruction. | | Cycles: | 1 <sup>(2)</sup> | Words: | 1 | | Example | HERE BTFSS REG1 FALSE GOTO PROCESS CODE | Cycles: | 2 | | | FALSE GOTO PROCESS_CODE TRUE • | Example | HERE CALL THERE | | | • | | Before Instruction PC = Address HERE | | | Before Instruction | | After Instruction | | | PC = address HERE | | PC = Address THERE<br>TOS = Address HERE+1 | | | After Instruction | | 100 - Address HEREFT | | | if FLAG<1> = 0,<br>PC = address FALSE | | | | | if FLAG<1> = 1, | CLRF | Clear f | | | PC = address TRUE | Syntax: | [label] CLRF f | | | | Operands: | $0 \leq f \leq 127$ | | | | Operation: | $00h \to (f)$ $1 \to Z$ | | | | Status Affected: | Z | | | | Encoding: | 00 0001 1fff ffff | | | | Description: | The contents of register 'f' are cleared and the Z bit is set. | | | | Words: | 1 | | | | Cycles: | 1 | | | | Example | CLRF REG1 | | | | | Before Instruction | | | | | REG1 = 0x5A<br>After Instruction | | | | | REG1 = 0x00 | TABLE 17-7: TIMERO AND TIMER1 EXTERNAL CLOCK REQUIREMENTS | Param<br>No. | Sym | | Characteristic | | Min | Тур† | Max | Units | Conditions | |--------------|-----------|------------------------|------------------------------------------|---------------------------|------------------------------|----------|-------|-------|------------------------------------| | 40* | Tt0H | T0CKI High Pu | lse Width | No Prescaler | 0.5Tcy + 20 | _ | _ | ns | | | | | | | With Prescaler | 10 | _ | _ | ns | | | 41* | Tt0L | T0CKI Low Pul | se Width | No Prescaler | 0.5Tcy + 20 | _ | _ | ns | | | | | | | With Prescaler | 10 | _ | _ | ns | | | 42* | Tt0P | T0CKI Period | | | Greater of:<br>TCY + 40<br>N | _ | _ | ns | N = prescale value<br>(2, 4,, 256) | | 45* | Tt1H | T1CKI High | Synchronous, N | lo Prescaler | 0.5Tcy + 20 | _ | _ | ns | | | | | Time | Synchronous, | 16F62X | 15 | <u> </u> | _ | ns | | | | | | with Prescaler | 16LF62X | 25 | _ | _ | ns | | | | | | Asynchronous | 16F62X | 30 | _ | _ | ns | | | | | | | 16LF62X | 50 | _ | _ | ns | | | 46* | Tt1L | T1CKI Low Tim | e Synchronous, N | Synchronous, No Prescaler | | _ | _ | ns | | | | | | Synchronous, | 16F62X | 15 | _ | _ | ns | | | | | | with Prescaler | 16LF62X | 25 | _ | _ | ns | | | | | | Asynchronous | 16F62X | 30 | _ | _ | ns | | | | | | | 16LF62X | 50 | _ | _ | ns | | | 47* | Tt1P | T1CKI input period | Synchronous | 16F62X | Greater of: Tcy + 40 N | _ | _ | ns | N = prescale value<br>(1, 2, 4, 8) | | | | | | 16LF62X | Greater of:<br>TCY + 40<br>N | _ | _ | _ | | | | | | Asynchronous | 16F62X | 60 | _ | _ | ns | | | | | | | 16LF62X | 100 | _ | _ | ns | | | | Ft1 | | or input frequency<br>led by setting bit | DC | _ | 200 | kHz | | | | 48 | TCKEZtmr1 | Delay from externation | ernal clock edge to | o timer | 2Tosc | _ | 7Tosc | | | These parameters are characterized but not tested. FIGURE 17-11: CAPTURE/COMPARE/PWM TIMINGS <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. ## PIC16F62X NOTES: The graphs and tables provided in this section are for design guidance and are not tested. Note: FIGURE 18-12: $\triangle$ ITMR10SC VS VDD OVER TEMP (0C to +70°C) SLEEP MODE, TIMER1 OSCILLATOR, 32 kHz XTAL FIGURE 18-13: ∆IWDT VS VDD SLEEP MODE, WATCH DOG TIMER ENABLED #### 19.0 PACKAGING INFORMATION #### 19.1 Package Marking Information #### **18-LEAD PDIP** #### 18-LEAD SOIC (.300") #### 20-LEAD SSOP #### **EXAMPLE** #### **EXAMPLE** #### **EXAMPLE** Legend: MM...M Microchip part number information XX...X Customer specific information(1) YY Year code (last 2 digits of calendar year) YY Year code (last 2 digits of calendar year) WW Week code (week of January 1 is week '01') NNN Alphanumeric traceability code Note: In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line thus limiting the number of available characters for customer specific information. \* Standard OTP marking consists of Microchip part number, year code, week code, facility code, mask rev#, and assembly code. For OTP marking beyond this, certain price adders apply. Please check with your Microchip Sales Office. For QTP devices, any special marking adders are included in QTP price. ### K04-051 18-Lead Plastic Small Outline (SO) - Wide, 300 mil | | Units | | | | MILLIMETERS | | | |--------------------------|-------|------|------|------|-------------|-------|-------| | Dimension | MIN | NOM | MAX | MIN | NOM | MAX | | | Number of Pins | n | | 18 | | | 18 | | | Pitch | р | | .050 | | | 1.27 | | | Overall Height | Α | .093 | .099 | .104 | 2.36 | 2.50 | 2.64 | | Molded Package Thickness | A2 | .088 | .091 | .094 | 2.24 | 2.31 | 2.39 | | Standoff § | A1 | .004 | .008 | .012 | 0.10 | 0.20 | 0.30 | | Overall Width | Е | .394 | .407 | .420 | 10.01 | 10.34 | 10.67 | | Molded Package Width | E1 | .291 | .295 | .299 | 7.39 | 7.49 | 7.59 | | Overall Length | D | .446 | .454 | .462 | 11.33 | 11.53 | 11.73 | | Chamfer Distance | h | .010 | .020 | .029 | 0.25 | 0.50 | 0.74 | | Foot Length | L | .016 | .033 | .050 | 0.41 | 0.84 | 1.27 | | Foot Angle | ф | 0 | 4 | 8 | 0 | 4 | 8 | | Lead Thickness | С | .009 | .011 | .012 | 0.23 | 0.27 | 0.30 | | Lead Width | В | .014 | .017 | .020 | 0.36 | 0.42 | 0.51 | | Mold Draft Angle Top | α | 0 | 12 | 15 | 0 | 12 | 15 | | Mold Draft Angle Bottom | β | 0 | 12 | 15 | 0 | 12 | 15 | Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" (0.254mm) per side. JEDEC Equivalent: MS-013 Drawing No. C04-051 <sup>\*</sup> Controlling Parameter § Significant Characteristic