



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 -</u> <u>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 × 8                                                                    |
| RAM Size                   | 224 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                  |
| Data Converters            | -                                                                          |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 18-SOIC (0.295", 7.50mm Width)                                             |
| Supplier Device Package    | 18-SOIC                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf628-04-so |
|                            |                                                                            |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

| 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 locatior | n uses cont | ents of FSF  | to address   | s data mem    | ory (not a pl | hysical reg- | XXXX XXXX                               | 25                 |
| 101h    | TMR0   | RBPU             | INTEDG          | TOCS        | TOSE         | PSA          | PS2           | PS1           | PS0          | 1111 1111                               | 43                 |
| 102h    | PCL    | Program 0        | Counter's (PC   | ) Least Sig | nificant Byt | e            |               |               |              | 0000 0000                               | 25                 |
| 103h    | STATUS | IRP              | RP1             | RP0         | TO           | PD           | Z             | DC            | С            | 0001 1xxx                               | 19                 |
| 104h    | FSR    | Indirect da      | ata memory a    | ddress poir | nter         | 1            | 1             |               |              | xxxx xxxx                               | 25                 |
| 105h    | _      | Unimplem         | iented          |             |              |              |               |               |              | _                                       | _                  |
| 106h    | PORTB  | RB7              | RB6             | RB5         | RB4          | RB3          | RB2           | RB1           | RB0          | xxxx xxxx                               | 34                 |
| 107h    | _      | Unimplem         | ented           |             | •            |              | •             |               |              | _                                       | _                  |
| 108h    | _      | Unimplem         | ented           |             |              |              |               |               |              |                                         | _                  |
| 109h    | _      | Unimplem         | ented           |             |              |              |               |               |              | _                                       | _                  |
| 10Ah    | PCLATH |                  | _               | _           | Write        | buffer for u | pper 5 bits o | of program of | counter      | 0 0000                                  | 25                 |
| 10Bh    | INTCON | GIE              | PEIE            | T0IE        | INTE         | RBIE         | T0IF          | INTF          | RBIF         | 0000 000x                               | 21                 |
| 10Ch    | _      | Unimplem         | ented           |             |              |              |               |               |              | _                                       | _                  |
| 10Dh    | _      | Unimplem         | ented           |             |              |              |               |               |              | _                                       | _                  |
| 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           |             |              |              |               |               |              | _                                       | _                  |

TABLE 3-3: SPECIAL FUNCTION REGISTERS SUMMARY BANK 2

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.6 PCON Register

The PCON register contains flag bits to differentiate between a Power-on Reset, an external MCLR Reset, WDT Reset or a Brown-out Detect.

Note: BOD is unknown on Power-on Reset. It must then be set by the user and checked on subsequent RESETS to see if BOD is cleared, indicating a brown-out has occurred. The BOD STATUS bit is a "don't care" and is not necessarily predictable if the brown-out circuit is disabled (by clearing the BODEN bit in the Configuration word).

### REGISTER 3-6: PCON REGISTER (ADDRESS: 0Ch)

| U-0   | U-0 | U-0 | U-0 | R/W-1 | U-0 | R/W-q | R/W-q |
|-------|-----|-----|-----|-------|-----|-------|-------|
| _     | —   | —   | —   | OSCF  | _   | POR   | BOD   |
| bit 7 |     |     |     |       |     |       | bit 0 |

- bit 7-4 Unimplemented: Read as '0'
- bit 3 OSCF: INTRC/ER oscillator frequency
  - 1 = 4 MHz typical<sup>(1)</sup>
  - 0 = 37 KHz typical
- bit 2 Unimplemented: Read as '0'
- bit 1 **POR**: Power-on Reset STATUS bit
  - 1 = No Power-on Reset occurred
    - 0 = A Power-on Reset occurred (must be set in software after a Power-on Reset occurs)

bit 0 BOD: Brown-out Detect STATUS bit

- 1 = No Brown-out Reset occurred
  - 0 = A Brown-out Reset occurred (must be set in software after a Brown-out Reset occurs)
  - **Note 1:** When in ER Oscillator mode, setting OSCF = 1 will cause the oscillator frequency to change to the frequency specified by the external resistor.

| Legend:           |                  |                      |                    |
|-------------------|------------------|----------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented    | bit, read as '0'   |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown |

### 3.3 PCL and PCLATH

The program counter (PC) is 13-bits wide. The low byte comes from the PCL register, which is a readable and writable register. The high byte (PC<12:8>) is not directly readable or writable and comes from PCLATH. On any RESET, the PC is cleared. Figure 3-3 shows the two situations for the loading of the PC. The upper example in the figure shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). The lower example in the figure shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).

#### FIGURE 3-3: LOADING OF PC IN DIFFERENT SITUATIONS



### 3.3.1 COMPUTED GOTO

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block). Refer to the application note *"Implementing a Table Read"* (AN556).

### 3.3.2 STACK

The PIC16F62X family has an 8-level deep x 13-bit wide hardware stack (Figure 3-1 and Figure 3-2). The stack space is not part of either program or data space and the stack pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation.

The stack operates as a circular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on).

Note 1: There are no STATUS bits to indicate stack overflow or stack underflow conditions.

2: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW and RETFIE instructions, or the vectoring to an interrupt address.

### 3.4 Indirect Addressing, INDF and FSR Registers

The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing.

Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses data pointed to by the file select register (FSR). Reading INDF itself indirectly will produce 00h. Writing to the INDF register indirectly results in a nooperation (although STATUS bits may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS<7>), as shown in Figure 3-4.

A simple program to clear RAM location 20h-2Fh using indirect addressing is shown in Example 3-1.

#### EXAMPLE 3-1: Indirect Addressing

| NEXT | movlw<br>movwf<br>clrf<br>incf | 0x20<br>FSR<br>INDF<br>FSR<br>FSP 4 | <pre>;initialize pointer ;to RAM ;clear INDF register ;inc pointer .all done2</pre> |
|------|--------------------------------|-------------------------------------|-------------------------------------------------------------------------------------|
|      | btfss                          | FSR,4                               | ;all done?                                                                          |
|      | goto                           | NEXT                                | ;no clear next                                                                      |
|      |                                |                                     | ;yes continue                                                                       |

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 | FOI         | 0X20                              |
|----------|-------------|-----------------------------------|
| CLRF     | FLAG REG    | 01120                             |
| CLRF     | PORTA       | ;Init PORTA                       |
| MOVE     | 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 CMCONtoend 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      |             | ;Enable peripheral interrupts     |
| BSF      | INTCON, GIE | ;Global interrupt enable          |
| 101      | INICON, GIE | , Grobar incerrupt 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).



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).

### 9.5 Comparator Outputs

The comparator outputs are read through the CMCON register. These bits are read only. The comparator outputs may also be directly output to the RA3 and RA4 I/O pins. When the CM<2:0> = 110, multiplexors in the output path of the RA3 and RA4/T0CK1 pins will switch and the output of each pin will be the unsynchronized output of the comparator. The uncertainty of each of the comparators is related to the input offset voltage and the response time given in the specifications. Figure 9-3 shows the comparator output block diagram.

The TRISA bits will still function as an output enable/ disable for the RA3 and RA4/T0CK1 pins while in this mode.

- Note 1: When reading the PORT register, all pins configured as analog inputs will read as a '0'. Pins configured as digital inputs will convert an analog input according to the Schmitt Trigger input specification.
  - 2: Analog levels on any pin that is defined as a digital input may cause the input buffer to consume more current than is specified.

#### FIGURE 9-3: COMPARATOR OUTPUT BLOCK DIAGRAM



### 11.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 PORTB data latch, the TRISB<3> 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 PORTB I/O data |
|       | latch.                                    |

Figure 11-2 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 11.3.3.

#### FIGURE 11-2: SIMPLIFIED PWM BLOCK DIAGRAM



A PWM output (Figure 11-3) has a time-base (period) and a time that the output stays high (duty cycle). The frequency of the PWM is the inverse of the period (1/period).

FIGURE 11-3: PWM OUTPUT



### 11.3.1 PWM PERIOD

The PWM period is specified by writing to the PR2register. The PWM period can be calculated using the following formula:

PWM period = [(PR2) + 1] • 4 • Tosc • (TMR2 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 8.0) is not used in the determination of the PWM frequency. The postscaler could be used to have an interrupt occur at a different frequency than the PWM output.

### 12.0 UNIVERSAL SYNCHRONOUS/ ASYNCHRONOUS RECEIVER/ TRANSMITTER (USART) MODULE

The Universal Synchronous Asynchronous Receiver Transmitter (USART) module is one of the two serial I/O modules. (USART is also known as a Serial Communications Interface or SCI). The USART can be configured as a full duplex asynchronous system that can communicate with peripheral devices such as CRT terminals and personal computers, or it can be configured as a half duplex synchronous system that can communicate with peripheral devices such as A/D or D/ A integrated circuits, Serial EEPROMs etc. The USART can be configured in the following modes:

- Asynchronous (full duplex)
- Synchronous Master (half duplex)
- Synchronous Slave (half duplex)

Bit SPEN (RCSTA<7>), and bits TRISB<2:1>, have to be set in order to configure pins RB2/TX/CK and RB1/ RX/DT as the Universal Synchronous Asynchronous Receiver Transmitter.

### REGISTER 12-1: TXSTA: TRANSMIT STATUS AND CONTROL REGISTER (ADDRESS: 98h)

|       | R/W-0                                               | R/W-0                                            | R/W-0                         | R/W-0           | U-0          | <b>R</b> /W-0 | R-1            | ,<br>R/W-0 |
|-------|-----------------------------------------------------|--------------------------------------------------|-------------------------------|-----------------|--------------|---------------|----------------|------------|
|       | CSRC                                                | TX9                                              | TXEN                          | SYNC            | —            | BRGH          | TRMT           | TX9D       |
|       | bit 7                                               |                                                  |                               |                 |              |               |                | bit 0      |
| bit 7 | CSRC: Cloc                                          | k Source Sel                                     | ect bit                       |                 |              |               |                |            |
|       | Asynchronou<br>Don't car                            |                                                  |                               |                 |              |               |                |            |
|       |                                                     | er mode (Clo                                     | ck generated<br>k from extern | internally from | m BRG)       |               |                |            |
| bit 6 | 1 = Selects 9                                       | ansmit Enabl<br>9-bit transmis<br>3-bit transmis | sion                          |                 |              |               |                |            |
| bit 5 | <b>TXEN</b> : Trans<br>1 = Transmit<br>0 = Transmit |                                                  | <sub>oit</sub> (1)            |                 |              |               |                |            |
| bit 4 | SYNC: USA<br>1 = Synchro<br>0 = Asynchro            |                                                  | ect bit                       |                 |              |               |                |            |
| bit 3 | Unimpleme                                           | nted: Read a                                     | is '0'                        |                 |              |               |                |            |
| bit 2 | BRGH: High                                          | Baud Rate S                                      | Select bit                    |                 |              |               |                |            |
|       | Asynchronou<br>1 = High s<br>0 = Low s              | speed                                            |                               |                 |              |               |                |            |
|       | <u>Synchronou</u>                                   | •                                                |                               |                 |              |               |                |            |
| bit 1 | <b>TRMT</b> : Trans<br>1 = TSR em<br>0 = TSR full   |                                                  | gister STATU                  | S bit           |              |               |                |            |
| bit 0 | <b>TX9D</b> : 9th bi                                | t of transmit                                    | data. Can be                  | PARITY bit.     |              |               |                |            |
|       | Note 1: S                                           | REN/CREN                                         | overrides TX                  | EN in SYNC      | node.        |               |                |            |
|       | Legend:                                             |                                                  |                               |                 |              |               |                |            |
|       | R = Reada                                           | ble bit                                          | VV = V                        | Vritable bit    | U = Unimp    | lemented b    | oit, read as ' | )'         |
|       | -n = Value                                          | at POR                                           | '1' = E                       | Bit is set      | '0' = Bit is | cleared       | x = Bit is ur  | nknown     |



### TABLE 12-6: REGISTERS ASSOCIATED WITH ASYNCHRONOUS 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<br>all 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 Tra | nsmit Re                     | gister |       |       |        |        |        | 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 | Baud Rate Generator Register |        |       |       |        |        |        |                 | 0000 0000                       |

Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Asynchronous Transmission. Steps to follow when setting up an Asynchronous Reception:

- 1. Initialize the SPBRG register for the appropriate baud rate. If a high speed baud rate is desired, set bit BRGH. (Section 12.1).
- 2. Enable the asynchronous serial port by clearing bit SYNC, and setting bit SPEN.
- 3. If interrupts are desired, then set enable bit RCIE.
- 4. If 9-bit reception is desired, then set bit RX9.
- 5. Enable the reception by setting bit CREN.
- 6. Flag bit RCIF will be set when reception is complete and an interrupt will be generated if enable bit RCIE was set.
- 7. Read the RCSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 8. Read the 8-bit received data by reading the RCREG register.
- 9. If any error occurred, clear the error by clearing enable bit CREN.

| Address | Name  | Bit 7     | Bit 6                       | Bit 5   | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR | Value on<br>all 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 Re  | ceive Re                    | egister |       |       |        |        |        | 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 | aud Rate Generator Register |         |       |       |        |        |        | 0000 0000       | 0000 0000                       |

Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Asynchronous Reception.

### 13.0 DATA EEPROM MEMORY

The EEPROM data memory is readable and writable during normal operation (full VDD range). This memory is not directly mapped in the register file space. Instead it is indirectly addressed through the Special Function Registers (SFRs). There are four SFRs used to read and write this memory. These registers are:

- EECON1
- EECON2 (Not a physically implemented register)
- EEDATA
- EEADR

EEDATA holds the 8-bit data for read/write, and EEADR holds the address of the EEPROM location being accessed. PIC16F62X devices have 128 bytes of data EEPROM with an address range from 0h to 7Fh.

The EEPROM data memory allows byte read and write. A byte write automatically erases the location and writes the new data (erase before write). The EEPROM data memory is rated for high erase/write cycles. The write time is controlled by an on-chip timer. The writetime will vary with voltage and temperature as well as from chip to chip. Please refer to AC specifications for exact limits.

When the device is code protected, the CPU may continue to read and write the data EEPROM memory. The device programmer can no longer access this memory.

Additional information on the Data EEPROM is available in the PICmicro<sup>™</sup> Mid-Range Reference Manual, (DS33023).

### REGISTER 13-1: EEADR REGISTER (ADDRESS: 9Bh)

| R/W      | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
|----------|-------|-------|-------|-------|-------|-------|-------|
| Reserved | EADR6 | EADR5 | EADR4 | EADR3 | EADR2 | EADR1 | EADR0 |
| bit 7    |       |       |       |       |       |       | bit 0 |

#### bit 7 Unimplemented Address: Must be set to '0'

bit 6-0 **EEADR**: Specifies one of 128 locations of EEPROM Read/Write Operation

| 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 |  |  |

### 13.1 EEADR

The EEADR register can address up to a maximum of 256 bytes of data EEPROM. Only the first 128 bytes of data EEPROM are implemented and only seven of the eight bits in the register (EEADR<6:0>) are required.

The upper bit is address decoded. This means that this bit should always be '0' to ensure that the address is in the 128 byte memory space.

### 13.2 EECON1 AND EECON2 REGISTERS

EECON1 is the control register with five low order bits physically implemented. The upper-three bits are nonexistent and read as '0's.

Control bits RD and WR initiate read and write, respectively. These bits cannot be cleared, only set, in software. They are cleared in hardware at completion of the read or write operation. The inability to clear the WR bit in software prevents the accidental, premature termination of a write operation.

The WREN bit, when set, will allow a write operation. On power-up, the WREN bit is clear. The WRER<u>R bit is</u> set when a write operation is interrupted by a MCLR Reset or a WDT Timeout Reset during normal operation. In these situations, following RESET, the user can check the WRERR bit and rewrite the location. The data and address will be unchanged in the EEDATA and EEADR registers.

Interrupt flag bit EEIF in the PIR1 register is set when write is complete. This bit must be cleared in software.

EECON2 is not a physical register. Reading EECON2 will read all '0's. The EECON2 register is used exclusively in the Data EEPROM write sequence.





FIGURE 14-9: TIMEOUT SEQUENCE ON POWER-UP (MCLR NOT TIED TO VDD): CASE 2



FIGURE 14-10: TIMEOUT SEQUENCE ON POWER-UP (MCLR TIED TO VDD)



### 14.12 In-Circuit Serial Programming

The PIC16F62X microcontrollers can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data, and three other lines for power, ground, and the programming voltage. This allows customers to manufacture boards with unprogrammed devices, and then program the microcontroller just before shipping the product. This also allows the most recent firmware, or a custom firmware to be programmed.

The device is placed into a Program/Verify mode by holding the RB6 and RB7 pins low while raising the  $\overline{\text{MCLR}}$  (VPP) pin from VIL to VIHH (see programming specification). RB6 becomes the programming clock and RB7 becomes the programming data. Both RB6 and RB7 are Schmitt Trigger inputs in this mode.

After RESET, to place the device into Programming/ Verify mode, the program counter (PC) is at location 00h. A 6-bit command is then supplied to the device. Depending on the command, 14 bits of program data are then supplied to or from the device, depending if the command was a load or a read. For complete details of serial programming, please refer to the Programming Specifications.

A typical in-circuit serial programming connection is shown in Figure 14-18.

#### FIGURE 14-18: TYPICAL IN-CIRCUIT SERIAL PROGRAMMING CONNECTION



### 14.13 Low Voltage Programming

The LVP bit of the configuration word, enables the low voltage programming. This mode allows the microcontroller to be programmed via ICSP using only a 5V source. This mode removes the requirement of VIHH to be placed on the MCLR pin. The LVP bit is normally erased to '1', which enables the low voltage programming. In this mode, the RB4/PGM pin is dedicated to the programming function and ceases to be a general purpose I/O pin. The device will enter Programming mode when a '1' is placed on the RB4/PGM pin. The HV Programming mode is still available by placing VIHH on the MCLR pin.

- Note 1: While in this mode, the RB4 pin can no longer be used as a general purpose I/O pin.
  - 2: VDD must be 5.0V <u>+</u>10% during erase/ program operations while in low voltage Programming mode.

If Low voltage Programming mode is not used, the LVP bit can be programmed to a '0', and RB4/PGM becomes a digital I/O pin. To program the device, VIHH must be placed onto MCLR during programming. The LVP bit may only be programmed when programming is entered with VIHH on MCLR. The LVP bit cannot be programmed when programming is entered with RB4/PGM.

It should be noted, that once the LVP bit is programmed to 0, High voltage Programming mode can be used to program the device.

### TABLE 15-2: PIC16F62X INSTRUCTION SET

| Mnemonic,<br>Operands |         | Description                  | Cycles           |     | 14-Bit | Status  | Natas    |          |       |
|-----------------------|---------|------------------------------|------------------|-----|--------|---------|----------|----------|-------|
|                       |         | Description                  |                  | MSb |        |         | LSb      | Affected | Notes |
| BYTE-ORIE             | NTED F  | ILE 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                | 00  | 0110   | dfff    | ffff     | Z        | 1,2   |
| BIT-ORIENT            | ED FILE | EREGISTER 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 AN            | ND 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        |       |
|                       |         |                              |                  |     | 7010   | 1010101 | 12121212 | -        |       |

Note 1: When an I/O register is modified as a function of itself (e.g., MOVF PORTB, 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'.

2: 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.

3: 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.

## 17.0 ELECTRICAL SPECIFICATIONS

### Absolute Maximum Ratings†

| Ambient temperature under bias                                                                              | 40 to +125°C              |
|-------------------------------------------------------------------------------------------------------------|---------------------------|
| Storage temperature                                                                                         |                           |
| Voltage on VDD with respect to Vss                                                                          |                           |
| Voltage on MCLR and RA4 with respect to Vss                                                                 |                           |
| Voltage on all other pins with respect to Vss                                                               | 0.3V to VDD + 0.3V        |
| Total power dissipation <sup>(1)</sup>                                                                      |                           |
| Maximum current out of Vss pin                                                                              |                           |
| Maximum current into VDD pin                                                                                |                           |
| Input clamp current, Iк (Vi < 0 or Vi > VDD)                                                                | ±20 mA                    |
| Output clamp current, Iок (Vo < 0 or Vo >VDD)                                                               | ±20 mA                    |
| Maximum output current sunk by any I/O pin                                                                  |                           |
| Maximum output current sourced by any I/O pin                                                               | 25 mA                     |
| Maximum current sunk by PORTA and PORTB                                                                     | 200 mA                    |
| Maximum current sourced by PORTA and PORTB                                                                  |                           |
| <b>Note 1:</b> Power dissipation is calculated as follows: PDIS = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD-V | он) x Iон} + ∑(Vol x IoL) |

**† NOTICE**: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

**Note:** Voltage spikes below Vss at the  $\overline{MCLR}$  pin, inducing currents greater than 80 mA, may cause latchup. Thus, a series resistor of 50-100  $\Omega$  should be used when applying a "low" level to the  $\overline{MCLR}$  pin rather than pulling this pin directly to Vss



# FIGURE 17-4: PIC16LF62X VOLTAGE-FREQUENCY GRAPH, -40°C $\leq$ TA < 0°C, +70°C < TA $\leq$ 85°C



© 2003 Microchip Technology Inc.

| Param<br>No. | Sym       | Characteristic                                                                      |                           | Min            | Тур†                                | Max | Units | Conditions |                                    |
|--------------|-----------|-------------------------------------------------------------------------------------|---------------------------|----------------|-------------------------------------|-----|-------|------------|------------------------------------|
| 40*          | Tt0H      | T0CKI High Puls                                                                     | e Width                   | No Prescaler   | 0.5Tcy + 20 —                       |     |       | ns         |                                    |
|              |           |                                                                                     |                           | With Prescaler | 10                                  | —   | _     | ns         |                                    |
| 41*          | TtOL      | T0CKI Low Pulse Width No Prescaler                                                  |                           | 0.5Tcy + 20    | —                                   | —   | ns    |            |                                    |
|              |           |                                                                                     |                           | With Prescaler | 10                                  | -   | —     | ns         |                                    |
| 42*          | Tt0P      | T0CKI Period                                                                        |                           |                | Greater of:<br><u>Tcy + 40</u><br>N | _   | —     | ns         | N = prescale value<br>(2, 4,, 256) |
| 45*          | Tt1H      | T1CKI High                                                                          | Synchronous, No Prescaler |                | 0.5Tcy + 20                         | —   | —     | ns         |                                    |
|              |           | Time                                                                                | Synchronous,              | 16F62X         | 15                                  | -   | —     | ns         |                                    |
|              |           |                                                                                     | with Prescaler            | 16LF62X        | 25                                  | —   | —     | ns         |                                    |
|              |           |                                                                                     | Asynchronous              | 16F62X         | 30                                  | _   | -     | ns         |                                    |
|              |           |                                                                                     |                           | 16LF62X        | 50                                  | —   | _     | ns         |                                    |
| 46*          | Tt1L      | T1CKI Low Time                                                                      | Synchronous, N            | lo Prescaler   | 0.5Tcy + 20                         | —   | —     | ns         |                                    |
|              |           |                                                                                     | Synchronous,              | 16F62X         | 15                                  | —   | —     | ns         |                                    |
|              |           |                                                                                     | with Prescaler            | 16LF62X        | 25                                  | —   | —     | ns         |                                    |
|              |           |                                                                                     | Asynchronous              | 16F62X         | 30                                  | -   | Ι     | ns         |                                    |
|              |           |                                                                                     |                           | 16LF62X        | 50                                  | —   | —     | ns         |                                    |
| 47*          | Tt1P      | T1CKI input<br>period                                                               | Synchronous               | 16F62X         | Greater of:<br><u>Tcy + 40</u><br>N | —   | —     | ns         | N = prescale value<br>(1, 2, 4, 8) |
|              |           |                                                                                     |                           | 16LF62X        | Greater of:<br><u>Tcy + 40</u><br>N | _   | —     | —          |                                    |
|              |           |                                                                                     | Asynchronous              | 16F62X         | 60                                  | _   | -     | ns         |                                    |
|              |           |                                                                                     |                           | 16LF62X        | 100                                 | -   | —     | ns         |                                    |
|              | Ft1       | Timer1 oscillator input frequency range (oscillator enabled by setting bit T1OSCEN) |                           | DC             | -                                   | 200 | kHz   |            |                                    |
| 48           | TCKEZtmr1 | Delay from external clock edge to timer<br>increment                                |                           |                | 2Tosc                               | -   | 7Tosc | _          |                                    |

† Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

#### FIGURE 17-11: **CAPTURE/COMPARE/PWM TIMINGS**



NOTES:

Note: The graphs and tables provided in this section are for design guidance and are not tested.



#### FIGURE 18-14: Alcomp vs VDD SLEEP MODE, COMPARATORS ENABLED





Note: The graphs and tables provided in this section are for design guidance and are not tested.



#### FIGURE 18-18: VOH VS IOH OVER TEMP (C) VDD = 5V







# WORLDWIDE SALES AND SERVICE

#### AMERICAS

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: 480-792-7627 Web Address: http://www.microchip.com

#### Rocky Mountain

2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7966 Fax: 480-792-4338

#### Atlanta

3780 Mansell Road, Suite 130 Alpharetta, GA 30022 Tel: 770-640-0034 Fax: 770-640-0307

#### Boston

2 Lan Drive, Suite 120 Westford, MA 01886 Tel: 978-692-3848 Fax: 978-692-3821

#### Chicago

333 Pierce Road, Suite 180 Itasca, IL 60143 Tel: 630-285-0071 Fax: 630-285-0075

#### Dallas

4570 Westgrove Drive, Suite 160 Addison, TX 75001 Tel: 972-818-7423 Fax: 972-818-2924

#### Detroit

Tri-Atria Office Building 32255 Northwestern Highway, Suite 190 Farmington Hills, MI 48334 Tel: 248-538-2250 Fax: 248-538-2260

#### Kokomo

2767 S. Albright Road Kokomo, Indiana 46902 Tel: 765-864-8360 Fax: 765-864-8387

#### Los Angeles

18201 Von Karman, Suite 1090 Irvine, CA 92612 Tel: 949-263-1888 Fax: 949-263-1338

#### San Jose

Microchip Technology Inc. 2107 North First Street, Suite 590 San Jose, CA 95131 Tel: 408-436-7950 Fax: 408-436-7955

#### Toronto

6285 Northam Drive, Suite 108 Mississauga, Ontario L4V 1X5, Canada Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Australia

Microchip Technology Australia Pty Ltd Suite 22, 41 Rawson Street Epping 2121, NSW Australia

Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

China - Beijing Microchip Technology Consulting (Shanghai) Co., Ltd., Beijing Liaison Office Unit 915 Bei Hai Wan Tai Bldg. No. 6 Chaoyangmen Beidajie Beijing, 100027, No. China Tel: 86-10-85282100 Fax: 86-10-85282104

#### China - Chengdu

Microchip Technology Consulting (Shanghai) Co., Ltd., Chengdu Liaison Office Rm. 2401-2402, 24th Floor, Ming Xing Financial Tower No. 88 TIDU Street Chengdu 610016, China Tel: 86-28-86766200 Fax: 86-28-86766599

#### China - Fuzhou

Microchip Technology Consulting (Shanghai) Co., Ltd., Fuzhou Liaison Office Unit 28F, World Trade Plaza No. 71 Wusi Road Fuzhou 350001, China Tel: 86-591-7503506 Fax: 86-591-7503521

#### China - Hong Kong SAR

Microchip Technology Hongkong Ltd. Unit 901-6, Tower 2, Metroplaza 223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431

China - Shanghai

Microchip Technology Consulting (Shanghai) Co., Ltd. Room 701, Bldg. B Far East International Plaza No. 317 Xian Xia Road Shanghai, 200051 Tel: 86-21-6275-5700 Fax: 86-21-6275-5060 **China - Shenzhen** Microchip Technology Consulting (Shanghai)

Microchip Technology Consulting (Shanghai) Co., Ltd., Shenzhen Liaison Office Rm. 1812, 18/F, Building A, United Plaza No. 5022 Binhe Road, Futian District Shenzhen 518033, China Tel: 86-755-82901380 Fax: 86-755-82966626 **China - Qingdao** 

Rm. B503, Fullhope Plaza, No. 12 Hong Kong Central Rd. Qingdao 266071, China Tel: 86-532-5027355 Fax: 86-532-5027205 **India** Microchip Technology Inc. India Liaison Office Divyasree Chambers 1 Floor, Wing A (A3/A4) No. 11, O'Shaugnessey Road Bangalore, 560 025, India Tel: 91-80-2290061 Fax: 91-80-2290062

#### Japan

Microchip Technology Japan K.K. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa, 222-0033, Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122 Korea Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea 135-882 Tel: 82-2-554-7200 Fax: 82-2-558-5934 Singapore Microchip Technology Singapore Pte Ltd. 200 Middle Road #07-02 Prime Centre Singapore, 188980 Tel: 65-6334-8870 Fax: 65-6334-8850 Taiwan Microchip Technology (Barbados) Inc., Taiwan Branch 11F-3, No. 207 Tung Hua North Road Taipei, 105, Taiwan Tel: 886-2-2717-7175 Fax: 886-2-2545-0139 **EUROPE** Austria Microchip Technology Austria GmbH Durisolstrasse 2

Durisolstrasse 2 A-4600 Wels Austria Tel: 43-7242-2244-399 Fax: 43-7242-2244-393

#### Denmark

Microchip Technology Nordic ApS Regus Business Centre Lautrup hoj 1-3 Ballerup DK-2750 Denmark Tel: 45 4420 9895 Fax: 45 4420 9910 France Microchip Technology SARL Parc d'Activite du Moulin de Massy 43 Rue du Saule Trapu Batiment A - ler Etage 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79 Germany Microchip Technology GmbH Steinheilstrasse 10 D-85737 Ismaning, Germany Tel: 49-89-627-144 0 Fax: 49-89-627-144-44 Italy Microchip Technology SRL Centro Direzionale Colleoni Palazzo Taurus 1 V. Le Colleoni 1 20041 Agrate Brianza Milan, Italy Tel: 39-039-65791-1 Fax: 39-039-6899883 United Kingdom Microchip Ltd.

Microchip Ltd. 505 Eskdale Road Winnersh Triangle Wokingham Berkshire, England RG41 5TU Tel: 44 118 921 5869 Fax: 44-118 921-5820

12/05/02