



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                      | 32MHz                                                                    |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                |
| Peripherals                | Brown-out Detect/Reset, LCD, POR, PWM, WDT                               |
| Number of I/O              | 36                                                                       |
| Program Memory Size        | 28KB (16K x 14)                                                          |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | 256 x 8                                                                  |
| RAM Size                   | 1K x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 5.5V                                                              |
| Data Converters            | A/D 14x10b                                                               |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                       |
| Mounting Type              | Through Hole                                                             |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                                 |
| Supplier Device Package    | 40-PDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f1939-e-p |
|                            |                                                                          |

Email: info@E-XFL.COM

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

## TABLE 3-4: PIC16(L)F1938/9 MEMORY MAP, BANKS 8-15

|      | BANK 8               | -    | BANK 9               |      | BANK 10              |      | BANK 11              |      | BANK 12              |      | BANK 13       |      | BANK 14       |      | BANK 15          |
|------|----------------------|------|----------------------|------|----------------------|------|----------------------|------|----------------------|------|---------------|------|---------------|------|------------------|
| 400h | INDF0                | 480h | INDF0                | 500h | INDF0                | 580h | INDF0                | 600h | INDF0                | 680h | INDF0         | 700h | INDF0         | 780h | INDF0            |
| 401h | INDF1                | 481h | INDF1                | 501h | INDF1                | 581h | INDF1                | 601h | INDF1                | 681h | INDF1         | 701h | INDF1         | 781h | INDF1            |
| 402h | PCL                  | 482h | PCL                  | 502h | PCL                  | 582h | PCL                  | 602h | PCL                  | 682h | PCL           | 702h | PCL           | 782h | PCL              |
| 403h | STATUS               | 483h | STATUS               | 503h | STATUS               | 583h | STATUS               | 603h | STATUS               | 683h | STATUS        | 703h | STATUS        | 783h | STATUS           |
| 404h | FSR0L                | 484h | FSR0L                | 504h | FSR0L                | 584h | FSR0L                | 604h | FSR0L                | 684h | FSR0L         | 704h | FSR0L         | 784h | FSR0L            |
| 405h | FSR0H                | 485h | FSR0H                | 505h | FSR0H                | 585h | FSR0H                | 605h | FSR0H                | 685h | FSR0H         | 705h | FSR0H         | 785h | FSR0H            |
| 406h | FSR1L                | 486h | FSR1L                | 506h | FSR1L                | 586h | FSR1L                | 606h | FSR1L                | 686h | FSR1L         | 706h | FSR1L         | 786h | FSR1L            |
| 407h | FSR1H                | 487h | FSR1H                | 507h | FSR1H                | 587h | FSR1H                | 607h | FSR1H                | 687h | FSR1H         | 707h | FSR1H         | 787h | FSR1H            |
| 408h | BSR                  | 488h | BSR                  | 508h | BSR                  | 588h | BSR                  | 608h | BSR                  | 688h | BSR           | 708h | BSR           | 788h | BSR              |
| 409h | WREG                 | 489h | WREG                 | 509h | WREG                 | 589h | WREG                 | 609h | WREG                 | 689h | WREG          | 709h | WREG          | 789h | WREG             |
| 40Ah | PCLATH               | 48Ah | PCLATH               | 50Ah | PCLATH               | 58Ah | PCLATH               | 60Ah | PCLATH               | 68Ah | PCLATH        | 70Ah | PCLATH        | 78Ah | PCLATH           |
| 40Bh | INTCON               | 48Bh | INTCON               | 50Bh | INTCON               | 58Bh | INTCON               | 60Bh | INTCON               | 68Bh | INTCON        | 70Bh | INTCON        | 78Bh | INTCON           |
| 40Ch | _                    | 48Ch | _                    | 50Ch |                      | 58Ch |                      | 60Ch |                      | 68Ch | —             | 70Ch | _             | 78Ch | —                |
| 40Dh | —                    | 48Dh | _                    | 50Dh | _                    | 58Dh | —                    | 60Dh |                      | 68Dh | —             | 70Dh |               | 78Dh | —                |
| 40Eh | —                    | 48Eh | _                    | 50Eh | _                    | 58Eh |                      | 60Eh |                      | 68Eh | —             | 70Eh | _             | 78Eh | —                |
| 40Fh | —                    | 48Fh | —                    | 50Fh | —                    | 58Fh | —                    | 60Fh | _                    | 68Fh | —             | 70Fh | —             | 78Fh | —                |
| 410h | —                    | 490h | —                    | 510h | —                    | 590h | —                    | 610h | —                    | 690h | —             | 710h | —             | 790h | —                |
| 411h | —                    | 491h | —                    | 511h | —                    | 591h | —                    | 611h | _                    | 691h | —             | 711h | —             | 791h |                  |
| 412h | —                    | 492h | —                    | 512h | —                    | 592h | —                    | 612h | —                    | 692h | —             | 712h | —             | 792h |                  |
| 413h | —                    | 493h | —                    | 513h | —                    | 593h | —                    | 613h | —                    | 693h | —             | 713h |               | 793h |                  |
| 414h | —                    | 494h | _                    | 514h | _                    | 594h | _                    | 614h | _                    | 694h | _             | 714h |               | 794h |                  |
| 415h | TMR4                 | 495h | —                    | 515h | —                    | 595h | —                    | 615h | _                    | 695h | —             | 715h | _             | 795h |                  |
| 416h | PR4                  | 496h | —                    | 516h | _                    | 596h | _                    | 616h | _                    | 696h |               | 716h |               | 796h |                  |
| 417h | T4CON                | 497h | _                    | 517h | _                    | 597h | _                    | 617h | _                    | 697h | _             | 717h | _             | 797h |                  |
| 418h | _                    | 498h | _                    | 518h | _                    | 598h | _                    | 618h | _                    | 698h | _             | 718h | _             | 798h |                  |
| 419h | _                    | 499h | _                    | 519h | _                    | 599h | _                    | 619h | _                    | 699h | _             | 719h | _             | 799h |                  |
| 41Ah | —                    | 49Ah | —                    | 51Ah | _                    | 59Ah |                      | 61Ah |                      | 69Ah | _             | 71Ah |               | 79Ah | See Table 3-7 or |
| 41Bh |                      | 49Bh | _                    | 51Bh | _                    | 59Bh |                      | 61Bh |                      | 69Bh | _             | 71Bh |               | 79Bh | Table 3-8        |
| 41Ch | TMR6                 | 49Ch |                      | 51Ch |                      | 59Ch |                      | 61Ch |                      | 69Ch | _             | 71Ch |               | 79Ch |                  |
| 41Dh | PR6                  | 49Dh | _                    | 51Dh |                      | 59Dh |                      | 61Dh |                      | 69Dh | _             | 71Dh | _             | 79Dh |                  |
| 41Eh | T6CON                | 49Eh | _                    | 51Eh | —                    | 59Eh | —                    | 61Eh |                      | 69Eh |               | 71Eh |               | 79Eh |                  |
| 41Fh | —                    | 49Fh | —                    | 51Fh | —                    | 59Fh | —                    | 61Fh | —                    | 69Fh | —             | 71Fh | _             | 79Fh |                  |
| 420h |                      | 4A0h |                      | 520h |                      | 5A0h |                      | 620h | General Purpose      | 6A0h |               | 720h |               | 7A0h |                  |
|      | General              |      | General              |      | General              |      | General              |      | Register<br>48 Bytes |      |               |      |               |      |                  |
|      | Purpose              |      | Purpose              |      | Purpose              |      | Purpose              |      | 40 Byles             |      | Unimplemented |      | Unimplemented |      |                  |
|      | Register<br>80 Bytes |      | Register<br>80 Bytes |      | Register<br>80 Bytes |      | Register<br>80 Bytes |      | Unimplemented        |      | Read as '0'   |      | Read as '0'   |      |                  |
|      | of Bytes             |      | 00 Dytes             |      | 00 Dytes             |      | 00 Dytes             |      | Read as '0'          |      |               |      |               |      |                  |
| 46Fh |                      | 4EFh |                      | 56Fh |                      | 5EFh |                      | 66Fh |                      | 6EFh |               | 76Fh |               | 7EFh |                  |
| 470h |                      | 4F0h |                      | 570h |                      | 5F0h |                      | 670h |                      | 6F0h |               | 770h |               | 7F0h |                  |
|      | Accesses             |      | Accesses      |      | Accesses      |      | Accesses         |
|      | 70h – 7Fh            |      | 70h – 7Fh     |      | 70h – 7Fh     |      | 70h – 7Fh        |
| 47Fh |                      | 4FFh |                      | 57Fh |                      | 5FFh |                      | 67Fh |                      | 6FFh |               | 77Fh |               | 7FFh |                  |

Legend: = Unimplemented data memory locations, read as '0'.

| TABLE 3-10: | SPECIAL | FUNCTION REGISTER SUMMARY |
|-------------|---------|---------------------------|
|             |         |                           |

| Address                | Name                                                                                                            | Bit 7                                               | Bit 6                                                    | Bit 5          | Bit 4           | Bit 3                        | Bit 2              | Bit 1              | Bit 0              | Value on<br>POR, BOR | Value on all<br>other<br>Resets |  |  |
|------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|----------------------------------------------------------|----------------|-----------------|------------------------------|--------------------|--------------------|--------------------|----------------------|---------------------------------|--|--|
| Bank 0                 |                                                                                                                 |                                                     |                                                          |                |                 |                              |                    |                    |                    |                      |                                 |  |  |
| 000h <sup>(2)</sup>    | INDF0 Addressing this location uses contents of FSR0H/FSR0L to address data memory<br>(not a physical register) |                                                     |                                                          |                |                 |                              |                    |                    |                    |                      | ****                            |  |  |
| 001h <sup>(2)</sup>    | INDF1                                                                                                           | Addressing<br>(not a physi                          |                                                          | XXXX XXXX      | XXXX XXXX       |                              |                    |                    |                    |                      |                                 |  |  |
| 002h <sup>(2)</sup>    | PCL                                                                                                             | Program Co                                          | ounter (PC) L                                            | east Significa | nt Byte         |                              |                    |                    |                    | 0000 0000            | 0000 0000                       |  |  |
| 003h <sup>(2)</sup>    | STATUS                                                                                                          |                                                     |                                                          | —              | TO              | PD                           | Z                  | DC                 | С                  | 1 1000               | q quuu                          |  |  |
| 004h <sup>(2)</sup>    | FSR0L                                                                                                           | Indirect Dat                                        | a Memory Ac                                              | Idress 0 Low   | Pointer         |                              |                    |                    |                    | 0000 0000            | uuuu uuuu                       |  |  |
| 005h <sup>(2)</sup>    | FSR0H                                                                                                           | Indirect Dat                                        | a Memory Ac                                              | ldress 0 High  | Pointer         |                              |                    |                    |                    | 0000 0000            | 0000 0000                       |  |  |
| 006h <sup>(2)</sup>    | FSR1L                                                                                                           | Indirect Dat                                        | a Memory Ac                                              | ldress 1 Low   | Pointer         |                              |                    |                    |                    | 0000 0000            | uuuu uuuu                       |  |  |
| 007h <sup>(2)</sup>    | FSR1H                                                                                                           | Indirect Dat                                        | a Memory Ac                                              | ldress 1 High  | Pointer         |                              |                    |                    |                    | 0000 0000            | 0000 0000                       |  |  |
| 008h <sup>(2)</sup>    | BSR                                                                                                             | _                                                   | _                                                        | _              |                 |                              | BSR<4:0>           |                    |                    | 0 0000               | 0 0000                          |  |  |
| 009h <sup>(2)</sup>    | WREG                                                                                                            | Working Re                                          | gister                                                   |                |                 |                              |                    |                    |                    | 0000 0000            | uuuu uuuu                       |  |  |
| 00Ah <sup>(1, 2)</sup> | PCLATH                                                                                                          |                                                     | Write Buffer for the upper 7 bits of the Program Counter |                |                 |                              |                    |                    |                    |                      | -000 0000                       |  |  |
| 00Bh <sup>(2)</sup>    | INTCON                                                                                                          | GIE                                                 | PEIE                                                     | TMR0IE         | INTE            | IOCIE                        | TMR0IF             | INTF               | IOCIF              | 0000 0000            | 0000 0000                       |  |  |
| 00Ch                   | PORTA                                                                                                           | PORTA Dat                                           | PORTA Data Latch when written: PORTA pins when read      |                |                 |                              |                    |                    |                    |                      |                                 |  |  |
| 00Dh                   | PORTB                                                                                                           | PORTB Data Latch when written: PORTB pins when read |                                                          |                |                 |                              |                    |                    |                    | XXXX XXXX            | uuuu uuuu                       |  |  |
| 00Eh                   | PORTC                                                                                                           | PORTC Da                                            | PORTC Data Latch when written: PORTC pins when read      |                |                 |                              |                    |                    |                    |                      |                                 |  |  |
| 00Fh <sup>(3)</sup>    | PORTD                                                                                                           | PORTD Da                                            | ta Latch whe                                             | n written: POF | RTD pins whe    | en read                      |                    |                    |                    | XXXX XXXX            | uuuu uuuu                       |  |  |
| 010h                   | PORTE                                                                                                           |                                                     |                                                          | —              | _               | RE3                          | RE2 <sup>(3)</sup> | RE1 <sup>(3)</sup> | RE0 <sup>(3)</sup> | xxxx                 | uuuu                            |  |  |
| 011h                   | PIR1                                                                                                            | TMR1GIF                                             | ADIF                                                     | RCIF           | TXIF            | SSPIF                        | CCP1IF             | TMR2IF             | TMR1IF             | 0000 0000            | 0000 0000                       |  |  |
| 012h                   | PIR2                                                                                                            | OSFIF                                               | C2IF                                                     | C1IF           | EEIF            | BCLIF                        | LCDIF              | _                  | CCP2IF             | 0000 00-0            | 0000 00-0                       |  |  |
| 013h                   | PIR3                                                                                                            | _                                                   | CCP5IF                                                   | CCP4IF         | CCP3IF          | TMR6IF                       | _                  | TMR4IF             |                    | -000 0-0-            | -000 0-0-                       |  |  |
| 014h                   | —                                                                                                               | Unimpleme                                           | nted                                                     |                |                 |                              |                    |                    |                    | _                    | —                               |  |  |
| 015h                   | TMR0                                                                                                            | Timer0 Mod                                          | lule Register                                            |                |                 |                              |                    |                    |                    | XXXX XXXX            | uuuu uuuu                       |  |  |
| 016h                   | TMR1L                                                                                                           | Holding Re                                          | gister for the                                           | Least Signific | ant Byte of th  | e 16-bit TMR                 | 1 Register         |                    |                    | XXXX XXXX            | uuuu uuuu                       |  |  |
| 017h                   | TMR1H                                                                                                           | Holding Re                                          | gister for the                                           | Most Significa | ant Byte of the | e 16-bit TMR1                | Register           |                    |                    | XXXX XXXX            | uuuu uuuu                       |  |  |
| 018h                   | T1CON                                                                                                           | TMR10                                               | CS<1:0>                                                  | T1CKP          | 'S<1:0>         | T1OSCEN                      | T1SYNC             | _                  | TMR10N             | 0000 00-0            | uuuu uu-u                       |  |  |
| 019h                   | T1GCON                                                                                                          | TMR1GE                                              | T1GPOL T1GTM T1GSPM T <u>1GGO</u> / T1GVAL T1GSS<1:0>    |                |                 |                              |                    |                    |                    | 0000 0x00            | uuuu uxuu                       |  |  |
| 01Ah                   | TMR2                                                                                                            | Timer 2 Mo                                          | dule Register                                            |                |                 |                              |                    | •                  |                    | 0000 0000            | 0000 0000                       |  |  |
| 01Bh                   | PR2                                                                                                             | Timer 2 Per                                         | Timer 2 Period Register                                  |                |                 |                              |                    |                    |                    |                      | 1111 1111                       |  |  |
| 01Ch                   | T2CON                                                                                                           | —                                                   | - T2OUTPS<3:0> TMR2ON T2CKPS<1:0>                        |                |                 |                              |                    |                    |                    |                      | -000 0000                       |  |  |
| 01Dh                   | —                                                                                                               | Unimpleme                                           | Unimplemented                                            |                |                 |                              |                    |                    |                    |                      |                                 |  |  |
| 01Eh                   | CPSCON0                                                                                                         | CPSON                                               | CPSRM                                                    | _              | _               | CPSRNG<1:0>     CPSOUT T0XCS |                    |                    |                    | 00 0000              | 00 0000                         |  |  |
| 01Fh                   | CPSCON1 CPSCH<3:0>                                                                                              |                                                     |                                                          |                |                 |                              |                    |                    |                    | 0000                 | 0000                            |  |  |

x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved. Shaded locations are unimplemented, read as '0'. Legend:

The upper byte of the program counter is not directly accessible. PCLATH is a holding register for the PC<14:8>, whose contents are Note 1: transferred to the upper byte of the program counter.

2: These registers can be addressed from any bank.

3: These registers/bits are not implemented on PIC16(L)F1938 devices, read as '0'.

4: Unimplemented, read as '1'.

| Name       | Bit 7   | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2   | Bit 1  | Bit 0  | Register<br>on Page |
|------------|---------|--------|--------|--------|--------|---------|--------|--------|---------------------|
| INTCON     | GIE     | PEIE   | TMR0IE | INTE   | IOCIE  | TMR0IF  | INTF   | IOCIF  | 90                  |
| OPTION_REG | WPUEN   | INTEDG | TMROCS | TMROSE | PSA    | PS<2:0> |        |        | 187                 |
| PIE1       | TMR1GIE | ADIE   | RCIE   | TXIE   | SSPIE  | CCP1IE  | TMR2IE | TMR1IE | 91                  |
| PIE2       | OSFIE   | C2IE   | C1IE   | EEIE   | BCLIE  | LCDIE   | _      | CCP2IE | 92                  |
| PIE3       | _       | CCP5IE | CCP4IE | CCP3IE | TMR6IE | _       | TMR4IE | _      | 93                  |
| PIR1       | TMR1GIF | ADIF   | RCIF   | TXIF   | SSPIF  | CCP1IF  | TMR2IF | TMR1IF | 94                  |
| PIR2       | OSFIF   | C2IF   | C1IF   | EEIF   | BCLIF  | LCDIF   |        | CCP2IF | 95                  |
| PIR3       | —       | CCP5IF | CCP4IF | CCP3IF | TMR6IF | _       | TMR4IF |        | 96                  |

 TABLE 7-1:
 SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPTS

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used by Interrupts.

## 15.2 ADC Operation

#### 15.2.1 STARTING A CONVERSION

To enable the ADC module, the ADON bit of the ADCON0 register must be set to a '1'. Setting the GO/ DONE bit of the ADCON0 register to a '1' will start the Analog-to-Digital conversion.

| Note: | The GO/DONE bit should not be set in the |  |  |  |  |  |  |  |
|-------|------------------------------------------|--|--|--|--|--|--|--|
|       | same instruction that turns on the ADC.  |  |  |  |  |  |  |  |
|       | Refer to Section 15.2.6 "A/D Conver-     |  |  |  |  |  |  |  |
|       | sion Procedure".                         |  |  |  |  |  |  |  |

#### 15.2.2 COMPLETION OF A CONVERSION

When the conversion is complete, the ADC module will:

- Clear the GO/DONE bit
- Set the ADIF Interrupt Flag bit
- Update the ADRESH and ADRESL registers with new conversion result

#### 15.2.3 TERMINATING A CONVERSION

If a conversion must be terminated before completion, the GO/DONE bit can be cleared in software. The ADRESH and ADRESL registers will be updated with the partially complete Analog-to-Digital conversion sample. Incomplete bits will match the last bit converted.

Note: A device Reset forces all registers to their Reset state. Thus, the ADC module is turned off and any pending conversion is terminated.

#### 15.2.4 ADC OPERATION DURING SLEEP

The ADC module can operate during Sleep. This requires the ADC clock source to be set to the FRC option. When the FRC clock source is selected, the ADC waits one additional instruction before starting the conversion. This allows the SLEEP instruction to be executed, which can reduce system noise during the conversion. If the ADC interrupt is enabled, the device will wake-up from Sleep when the conversion completes. If the ADC interrupt is disabled, the ADC module is turned off after the conversion completes, although the ADON bit remains set.

When the ADC clock source is something other than FRC, a SLEEP instruction causes the present conversion to be aborted and the ADC module is turned off, although the ADON bit remains set.

#### 15.2.5 SPECIAL EVENT TRIGGER

The Special Event Trigger of the CCPx/ECCPX module allows periodic ADC measurements without software intervention. When this trigger occurs, the GO/DONE bit is set by hardware and the Timer1 counter resets to zero.

#### TABLE 15-2: SPECIAL EVENT TRIGGER

| Device        | CCPx/ECCPx |
|---------------|------------|
| PIC16(L)F193X | CCP5       |

Using the Special Event Trigger does not assure proper ADC timing. It is the user's responsibility to ensure that the ADC timing requirements are met.

Refer to Section 23.0 "Capture/Compare/PWM Modules" for more information.

# PIC16(L)F1938/9

#### 15.2.6 A/D CONVERSION PROCEDURE

This is an example procedure for using the ADC to perform an Analog-to-Digital conversion:

- 1. Configure Port:
  - Disable pin output driver (Refer to the TRIS register)
  - Configure pin as analog (Refer to the ANSEL register)
- 2. Configure the ADC module:
  - Select ADC conversion clock
  - Configure voltage reference
  - Select ADC input channel
  - Turn on ADC module
- 3. Configure ADC interrupt (optional):
  - Clear ADC interrupt flag
  - Enable ADC interrupt
  - Enable peripheral interrupt
  - Enable global interrupt<sup>(1)</sup>
- 4. Wait the required acquisition time<sup>(2)</sup>.
- 5. Start conversion by setting the  $GO/\overline{DONE}$  bit.
- 6. Wait for ADC conversion to complete by one of the following:
  - Polling the GO/DONE bit
  - Waiting for the ADC interrupt (interrupts enabled)
- 7. Read ADC Result.
- 8. Clear the ADC interrupt flag (required if interrupt is enabled).

**Note 1:** The global interrupt can be disabled if the user is attempting to wake-up from Sleep and resume in-line code execution.

2: Refer to Section 15.4 "A/D Acquisition Requirements".

#### EXAMPLE 15-1: A/D CONVERSION

```
; This code block configures the ADC
; for polling, Vdd and Vss references, Frc
; clock and ANO input.
;Conversion start & polling for completion
; are included.
BANKSEL ADCON1
MOVLW B'11110000' ;Right justify, Frc
                   ;clock
MOVWF
       ADCON1
                  ;Vdd and Vss Vref
BANKSEL TRISA
                  ;
BSF
       TRISA,0 ;Set RAO to input
BANKSEL ANSEL
                  ;
        ANSEL,0 ;Set RAO to analog
BSF
BANKSEL ADCONO
                   ;
        B'00000001' ;Select channel ANO
MOVLW
MOVWF
        ADCON0
                   ;Turn ADC On
CALL
        SampleTime ;Acquisiton delay
       ADCON0, ADGO ; Start conversion
BSF
BTFSC ADCON0, ADGO ; Is conversion done?
GOTO
       $-1
                ;No, test again
BANKSEL ADRESH
                  ;
MOVF
        ADRESH,W ;Read upper 2 bits
MOVWF
        RESULTHI ;store in GPR space
BANKSEL
        ADRESL
                   ;
        ADRESL,W
MOVF
                   ;Read lower 8 bits
        RESULTLO ;Store in GPR space
MOVWE
```

| R/W-x/u          | R/W-x/u | R/W-x/u           | R/W-x/u | R/W-x/u        | R/W-x/u          | R/W-x/u        | R/W-x/u      |
|------------------|---------|-------------------|---------|----------------|------------------|----------------|--------------|
|                  |         |                   | ADRE    | S<9:2>         |                  |                |              |
| bit 7            |         |                   |         |                |                  |                | bit 0        |
|                  |         |                   |         |                |                  |                |              |
| Legend:          |         |                   |         |                |                  |                |              |
| R = Readable     | bit     | W = Writable b    | oit     | U = Unimpler   | nented bit, read | d as '0'       |              |
| u = Bit is unch  | anged   | x = Bit is unkno  | own     | -n/n = Value a | at POR and BC    | R/Value at all | other Resets |
| '1' = Bit is set |         | '0' = Bit is clea | red     |                |                  |                |              |

## **REGISTER 15-3:** ADRESH: ADC RESULT REGISTER HIGH (ADRESH) ADFM = 0

bit 7-0 **ADRES<9:2>:** ADC Result Register bits Upper eight bits of 10-bit conversion result

#### **REGISTER 15-4:** ADRESL: ADC RESULT REGISTER LOW (ADRESL) ADFM = 0

| R/W-x/u |
|---------|---------|---------|---------|---------|---------|---------|---------|
| ADRES   | S<1:0>  | —       | —       | —       | —       | —       | —       |
| bit 7   |         |         |         |         |         |         | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

bit 7-6 ADRES<1:0>: ADC Result Register bits Lower two bits of 10-bit conversion result

bit 5-0 **Reserved**: Do not use.

## 21.3 Timer1 Prescaler

Timer1 has four prescaler options allowing 1, 2, 4 or 8 divisions of the clock input. The T1CKPS bits of the T1CON register control the prescale counter. The prescale counter is not directly readable or writable; however, the prescaler counter is cleared upon a write to TMR1H or TMR1L.

## 21.4 Timer1 Oscillator

A dedicated low-power 32.768 kHz oscillator circuit is built-in between pins T1OSI (input) and T1OSO (amplifier output). This internal circuit is to be used in conjunction with an external 32.768 kHz crystal.

The oscillator circuit is enabled by setting the T1OSCEN bit of the T1CON register. The oscillator will continue to run during Sleep.

Note: The oscillator requires a start-up and stabilization time before use. Thus, T1OSCEN should be set and a suitable delay observed prior to using Timer1. A suitable delay similar to the OST delay can be implemented in software by clearing the TMR1IF bit then presetting the TMR1H:TMR1L register pair to FC00h. The TMR1IF flag will be set when 1024 clock cycles have elapsed, thereby indicating that the oscillator is running and reasonably stable.

## 21.5 Timer1 Operation in Asynchronous Counter Mode

If control bit T1SYNC of the T1CON register is set, the external clock input is not synchronized. The timer increments asynchronously to the internal phase clocks. If the external clock source is selected then the timer will continue to run during Sleep and can generate an interrupt on overflow, which will wake-up the processor. However, special precautions in software are needed to read/write the timer (see Section 21.5.1 "Reading and Writing Timer1 in Asynchronous Counter Mode").

| Note: | When switching from synchronous to        |
|-------|-------------------------------------------|
|       | asynchronous operation, it is possible to |
|       | skip an increment. When switching from    |
|       | asynchronous to synchronous operation,    |
|       | it is possible to produce an additional   |
|       | increment.                                |

#### 21.5.1 READING AND WRITING TIMER1 IN ASYNCHRONOUS COUNTER MODE

Reading TMR1H or TMR1L while the timer is running from an external asynchronous clock will ensure a valid read (taken care of in hardware). However, the user should keep in mind that reading the 16-bit timer in two 8-bit values itself, poses certain problems, since the timer may overflow between the reads.

For writes, it is recommended that the user simply stop the timer and write the desired values. A write contention may occur by writing to the timer registers, while the register is incrementing. This may produce an unpredictable value in the TMR1H:TMR1L register pair.

## 21.6 Timer1 Gate

Timer1 can be configured to count freely or the count can be enabled and disabled using Timer1 gate circuitry. This is also referred to as Timer1 Gate Enable.

Timer1 gate can also be driven by multiple selectable sources.

#### 21.6.1 TIMER1 GATE ENABLE

The Timer1 Gate Enable mode is enabled by setting the TMR1GE bit of the T1GCON register. The polarity of the Timer1 Gate Enable mode is configured using the T1GPOL bit of the T1GCON register.

When Timer1 Gate Enable mode is enabled, Timer1 will increment on the rising edge of the Timer1 clock source. When Timer1 Gate Enable mode is disabled, no incrementing will occur and Timer1 will hold the current count. See Figure 21-3 for timing details.

TABLE 21-3: TIMER1 GATE ENABLE SELECTIONS

| T1CLK      | T1GPOL | T1G | Timer1 Operation |
|------------|--------|-----|------------------|
| $\uparrow$ | 0      | 0   | Counts           |
| $\uparrow$ | 0      | 1   | Holds Count      |
| $\uparrow$ | 1      | 0   | Holds Count      |
| 1          | 1      | 1   | Counts           |

### 23.3.2 SETUP FOR PWM OPERATION

The following steps should be taken when configuring the CCP module for standard PWM operation:

- 1. Disable the CCPx pin output driver by setting the associated TRIS bit.
- 2. Timer2/4/6 resource selection:
  - Select the Timer2/4/6 resource to be used for PWM generation by setting the CxTSEL<1:0> bits in the CCPTMERSx register.
- 3. Load the PRx register with the PWM period value.
- Configure the CCP module for the PWM mode by loading the CCPxCON register with the appropriate values.
- Load the CCPRxL register and the DCxBx bits of the CCPxCON register, with the PWM duty cycle value.
- 6. Configure and start Timer2/4/6:
  - Clear the TMRxIF interrupt flag bit of the PIRx register. See Note below.
  - Configure the TxCKPS bits of the TxCON register with the Timer prescale value.
  - Enable the Timer by setting the TMRxON bit of the TxCON register.
- 7. Enable PWM output pin:
  - Wait until the Timer overflows and the TMRxIF bit of the PIRx register is set. See Note below.
  - Enable the CCPx pin output driver by clearing the associated TRIS bit.
- **Note:** In order to send a complete duty cycle and period on the first PWM output, the above steps must be included in the setup sequence. If it is not critical to start with a complete PWM signal on the first output, then step 6 may be ignored.

## 23.3.3 TIMER2/4/6 TIMER RESOURCE

The PWM standard mode makes use of one of the 8-bit Timer2/4/6 timer resources to specify the PWM period.

Configuring the CxTSEL<1:0> bits in the CCPTMRSx register selects which Timer2/4/6 timer is used.

#### 23.3.4 PWM PERIOD

The PWM period is specified by the PRx register of Timer2/4/6. The PWM period can be calculated using the formula of Equation 23-1.

#### EQUATION 23-1: PWM PERIOD

 $PWM Period = [(PRx) + 1] \bullet 4 \bullet TOSC \bullet$ (TMRx Prescale Value)

Note 1: Tosc = 1/Fosc

When TMRx is equal to PRx, the following three events occur on the next increment cycle:

- TMRx is cleared
- The CCPx pin is set. (Exception: If the PWM duty cycle = 0%, the pin will not be set.)
- The PWM duty cycle is latched from CCPRxL into CCPRxH.

Note: The Timer postscaler (see Section 22.1 "Timer2/4/6 Operation") is not used in the determination of the PWM frequency.

#### 23.3.5 PWM DUTY CYCLE

The PWM duty cycle is specified by writing a 10-bit value to multiple registers: CCPRxL register and DCxB<1:0> bits of the CCPxCON register. The CCPRxL contains the eight MSbs and the DCxB<1:0> bits of the CCPxCON register contain the two LSbs. CCPRxL and DCxB<1:0> bits of the CCPxCON register can be written to at any time. The duty cycle value is not latched into CCPRxH until after the period completes (i.e., a match between PRx and TMRx registers occurs). While using the PWM, the CCPRxH register is read-only.

Equation 23-2 is used to calculate the PWM pulse width.

Equation 23-3 is used to calculate the PWM duty cycle ratio.

## EQUATION 23-2: PULSE WIDTH

 $Pulse Width = (CCPRxL:CCPxCON < 5:4>) \bullet$ 

TOSC • (TMRx Prescale Value)

## EQUATION 23-3: DUTY CYCLE RATIO

 $Duty Cycle Ratio = \frac{(CCPRxL:CCPxCON < 5:4>)}{4(PRx + 1)}$ 

The CCPRxH register and a 2-bit internal latch are used to double buffer the PWM duty cycle. This double buffering is essential for glitchless PWM operation.

The 8-bit timer TMRx register is concatenated with either the 2-bit internal system clock (FOSC), or two bits of the prescaler, to create the 10-bit time base. The system clock is used if the Timer2/4/6 prescaler is set to 1:1.

When the 10-bit time base matches the CCPRxH and 2-bit latch, then the CCPx pin is cleared (see Figure 23-4).

## 23.4 PWM (Enhanced Mode)

The enhanced PWM function described in this section is available for CCP modules ECCP1, ECCP2 and ECCP3, with any differences between modules noted.

The enhanced PWM mode generates a Pulse-Width Modulation (PWM) signal on up to four different output pins with up to 10 bits of resolution. The period, duty cycle, and resolution are controlled by the following registers:

- PRx registers
- TxCON registers
- · CCPRxL registers
- CCPxCON registers

The ECCP modules have the following additional PWM registers which control Auto-shutdown, Auto-restart, Dead-band Delay and PWM Steering modes:

- · CCPxAS registers
- PSTRxCON registers
- PWMxCON registers

The enhanced PWM module can generate the following five PWM Output modes:

- Single PWM
- Half-Bridge PWM
- Full-Bridge PWM, Forward mode
- Full-Bridge PWM, Reverse mode
- Single PWM with PWM Steering mode

To select an Enhanced PWM Output mode, the PxM bits of the CCPxCON register must be configured appropriately.

The PWM outputs are multiplexed with I/O pins and are designated PxA, PxB, PxC and PxD. The polarity of the PWM pins is configurable and is selected by setting the CCPxM bits in the CCPxCON register appropriately.

Figure 23-5 shows an example of a simplified block diagram of the Enhanced PWM module.

Table 23-9 shows the pin assignments for various Enhanced PWM modes.

- Note 1: The corresponding TRIS bit must be cleared to enable the PWM output on the CCPx pin.
  - 2: Clearing the CCPxCON register will relinquish control of the CCPx pin.
  - **3:** Any pin not used in the enhanced PWM mode is available for alternate pin functions, if applicable.
  - 4: To prevent the generation of an incomplete waveform when the PWM is first enabled, the ECCP module waits until the start of a new PWM period before generating a PWM signal.



#### FIGURE 23-5: EXAMPLE SIMPLIFIED BLOCK DIAGRAM OF THE ENHANCED PWM MODE

Note 1: The 8-bit timer TMRx register is concatenated with the 2-bit internal Q clock, or two bits of the prescaler to create the 10-bit time base.

### 23.4.2 FULL-BRIDGE MODE

In Full-Bridge mode, all four pins are used as outputs. An example of Full-Bridge application is shown in Figure 23-10.

In the Forward mode, pin CCPx/PxA is driven to its active state, pin PxD is modulated, while PxB and PxC will be driven to their inactive state as shown in Figure 23-11.

In the Reverse mode, PxC is driven to its active state, pin PxB is modulated, while PxA and PxD will be driven to their inactive state as shown Figure 23-11.

PxA, PxB, PxC and PxD outputs are multiplexed with the PORT data latches. The associated TRIS bits must be cleared to configure the PxA, PxB, PxC and PxD pins as outputs.

#### FIGURE 23-10: EXAMPLE OF FULL-BRIDGE APPLICATION



## 24.2 SPI Mode Overview

The Serial Peripheral Interface (SPI) bus is a synchronous serial data communication bus that operates in Full-Duplex mode. Devices communicate in a master/slave environment where the master device initiates the communication. A slave device is controlled through a Chip Select known as Slave Select.

The SPI bus specifies four signal connections:

- Serial Clock (SCK)
- Serial Data Out (SDO)
- Serial Data In (SDI)
- Slave Select (SS)

Figure 24-1 shows the block diagram of the MSSP module when operating in SPI mode.

The SPI bus operates with a single master device and one or more slave devices. When multiple slave devices are used, an independent Slave Select connection is required from the master device to each slave device.

Figure 24-4 shows a typical connection between a master device and multiple slave devices.

The master selects only one slave at a time. Most slave devices have tri-state outputs so their output signal appears disconnected from the bus when they are not selected.

Transmissions involve two shift registers, eight bits in size, one in the master and one in the slave. With either the master or the slave device, data is always shifted out one bit at a time, with the Most Significant bit (MSb) shifted out first. At the same time, a new Least Significant bit (LSb) is shifted into the same register.

Figure 24-5 shows a typical connection between two processors configured as master and slave devices.

Data is shifted out of both shift registers on the programmed clock edge and latched on the opposite edge of the clock.

The master device transmits information out on its SDO output pin which is connected to, and received by, the slave's SDI input pin. The slave device transmits information out on its SDO output pin, which is connected to, and received by, the master's SDI input pin.

To begin communication, the master device first sends out the clock signal. Both the master and the slave devices should be configured for the same clock polarity.

The master device starts a transmission by sending out the MSb from its shift register. The slave device reads this bit from that same line and saves it into the LSb position of its shift register.

During each SPI clock cycle, a full-duplex data transmission occurs. This means that while the master device is sending out the MSb from its shift register (on

its SDO pin) and the slave device is reading this bit and saving it as the LSb of its shift register, that the slave device is also sending out the MSb from its shift register (on its SDO pin) and the master device is reading this bit and saving it as the LSb of its shift register.

After eight bits have been shifted out, the master and slave have exchanged register values.

If there is more data to exchange, the shift registers are loaded with new data and the process repeats itself.

Whether the data is meaningful or not (dummy data), depends on the application software. This leads to three scenarios for data transmission:

- Master sends useful data and slave sends dummy data.
- Master sends useful data and slave sends useful data.
- Master sends dummy data and slave sends useful data.

Transmissions may involve any number of clock cycles. When there is no more data to be transmitted, the master stops sending the clock signal and it deselects the slave.

Every slave device connected to the bus that has not been selected through its slave select line must disregard the clock and transmission signals and must not transmit out any data of its own.

### 24.4.9 ACKNOWLEDGE SEQUENCE

The ninth SCL pulse for any transferred byte in  $I^2C$  is dedicated as an Acknowledge. It allows receiving devices to respond back to the transmitter by pulling the SDA line low. The transmitter must release control of the line during this time to shift in the response. The Acknowledge (ACK) is an active-low signal, pulling the SDA line low indicated to the transmitter that the device has received the transmitted data and is ready to receive more.

The result of an  $\overline{ACK}$  is placed in the ACKSTAT bit of the SSPCON2 register.

Slave software, when the AHEN and DHEN bits are set, allow the user to set the  $\overline{ACK}$  value sent back to the transmitter. The ACKDT bit of the SSPCON2 register is set/cleared to determine the response.

Slave hardware will generate an ACK response if the AHEN and DHEN bits of the SSPCON3 register are clear.

There are certain conditions where an  $\overline{ACK}$  will not be sent by the slave. If the BF bit of the SSPSTAT register or the SSPOV bit of the SSPCON1 register are set when a byte is received.

When the module is addressed, after the eighth falling edge of SCL on the bus, the ACKTIM bit of the SSPCON3 register is set. The ACKTIM bit indicates the acknowledge time of the active bus. The ACKTIM Status bit is only active when the AHEN bit or DHEN bit is enabled.

## 24.5 I<sup>2</sup>C Slave Mode Operation

The MSSP Slave mode operates in one of four modes selected in the SSPM bits of SSPCON1 register. The modes can be divided into 7-bit and 10-bit Addressing mode. 10-bit Addressing modes operate the same as 7-bit with some additional overhead for handling the larger addresses.

Modes with Start and Stop bit interrupts operated the same as the other modes with SSPIF additionally getting set upon detection of a Start, Restart, or Stop condition.

#### 24.5.1 SLAVE MODE ADDRESSES

The SSPADD register (Register 24-6) contains the Slave mode address. The first byte received after a Start or Restart condition is compared against the value stored in this register. If the byte matches, the value is loaded into the SSPBUF register and an interrupt is generated. If the value does not match, the module goes idle and no indication is given to the software that anything happened.

The SSP Mask register (Register 24-5) affects the address matching process. See Section 24.5.9 "SSP Mask Register" for more information.

#### 24.5.1.1 I<sup>2</sup>C Slave 7-bit Addressing Mode

In 7-bit Addressing mode, the LSb of the received data byte is ignored when determining if there is an address match.

#### 24.5.1.2 I<sup>2</sup>C Slave 10-bit Addressing Mode

In 10-bit Addressing mode, the first received byte is compared to the binary value of '1 1 1 1 0 A9 A8 0'. A9 and A8 are the two MSb of the 10-bit address and stored in bits 2 and 1 of the SSPADD register.

After the acknowledge of the high byte the UA bit is set and SCL is held low until the user updates SSPADD with the low address. The low address byte is clocked in and all eight bits are compared to the low address value in SSPADD. Even if there is not an address match; SSPIF and UA are set, and SCL is held low until SSPADD is updated to receive a high byte again. When SSPADD is updated the UA bit is cleared. This ensures the module is ready to receive the high address byte on the next communication.

A high and low address match as a write request is required at the start of all 10-bit addressing communication. A transmission can be initiated by issuing a Restart once the slave is addressed, and clocking in the high address with the R/W bit set. The slave hardware will then acknowledge the read request and prepare to clock out data. This is only valid for a slave after it has received a complete high and low address byte match.

#### 25.1.1.5 TSR Status

The TRMT bit of the TXSTA register indicates the status of the TSR register. This is a read-only bit. The TRMT bit is set when the TSR register is empty and is cleared when a character is transferred to the TSR register from the TXREG. The TRMT bit remains clear until all bits have been shifted out of the TSR register. No interrupt logic is tied to this bit, so the user has to poll this bit to determine the TSR status.

| Note: | The TSR register is not mapped in data      |
|-------|---------------------------------------------|
|       | memory, so it is not available to the user. |

#### 25.1.1.6 Transmitting 9-Bit Characters

The EUSART supports 9-bit character transmissions. When the TX9 bit of the TXSTA register is set, the EUSART will shift nine bits out for each character transmitted. The TX9D bit of the TXSTA register is the ninth, and Most Significant, data bit. When transmitting 9-bit data, the TX9D data bit must be written before writing the eight Least Significant bits into the TXREG. All nine bits of data will be transferred to the TSR shift register immediately after the TXREG is written.

A special 9-bit Address mode is available for use with multiple receivers. See **Section 25.1.2.7** "Address **Detection**" for more information on the address mode.

#### 25.1.1.7 Asynchronous Transmission Set-up:

- Initialize the SPBRGH, SPBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 25.4 "EUSART Baud Rate Generator (BRG)").
- 2. Enable the asynchronous serial port by clearing the SYNC bit and setting the SPEN bit.
- 3. If 9-bit transmission is desired, set the TX9 control bit. A set ninth data bit will indicate that the eight Least Significant data bits are an address when the receiver is set for address detection.
- 4. Set SCKP bit if inverted transmit is desired.
- Enable the transmission by setting the TXEN control bit. This will cause the TXIF interrupt bit to be set.
- If interrupts are desired, set the TXIE interrupt enable bit of the PIE1 register. An interrupt will occur immediately provided that the GIE and PEIE bits of the INTCON register are also set.
- 7. If 9-bit transmission is selected, the ninth bit should be loaded into the TX9D data bit.
- 8. Load 8-bit data into the TXREG register. This will start the transmission.



#### FIGURE 25-3: ASYNCHRONOUS TRANSMISSION





#### 25.1.2.4 Receive Framing Error

Each character in the receive FIFO buffer has a corresponding framing error Status bit. A framing error indicates that a Stop bit was not seen at the expected time. The framing error status is accessed via the FERR bit of the RCSTA register. The FERR bit represents the status of the top unread character in the receive FIFO. Therefore, the FERR bit must be read before reading the RCREG.

The FERR bit is read-only and only applies to the top unread character in the receive FIFO. A framing error (FERR = 1) does not preclude reception of additional characters. It is not necessary to clear the FERR bit. Reading the next character from the FIFO buffer will advance the FIFO to the next character and the next corresponding framing error.

The FERR bit can be forced clear by clearing the SPEN bit of the RCSTA register which resets the EUSART. Clearing the CREN bit of the RCSTA register does not affect the FERR bit. A framing error by itself does not generate an interrupt.

| Note: | If all receive characters in the receive  |
|-------|-------------------------------------------|
|       | FIFO have framing errors, repeated reads  |
|       | of the RCREG will not clear the FERR bit. |

#### 25.1.2.5 Receive Overrun Error

The receive FIFO buffer can hold two characters. An overrun error will be generated if a third character, in its entirety, is received before the FIFO is accessed. When this happens the OERR bit of the RCSTA register is set. The characters already in the FIFO buffer can be read but no additional characters will be received until the error is cleared. The error must be cleared by either clearing the CREN bit of the RCSTA register or by resetting the EUSART by clearing the SPEN bit of the RCSTA register.

#### 25.1.2.6 Receiving 9-bit Characters

The EUSART supports 9-bit character reception. When the RX9 bit of the RCSTA register is set the EUSART will shift nine bits into the RSR for each character received. The RX9D bit of the RCSTA register is the ninth and Most Significant data bit of the top unread character in the receive FIFO. When reading 9-bit data from the receive FIFO buffer, the RX9D data bit must be read before reading the eight Least Significant bits from the RCREG.

#### 25.1.2.7 Address Detection

A special Address Detection mode is available for use when multiple receivers share the same transmission line, such as in RS-485 systems. Address detection is enabled by setting the ADDEN bit of the RCSTA register.

Address detection requires 9-bit character reception. When address detection is enabled, only characters with the ninth data bit set will be transferred to the receive FIFO buffer, thereby setting the RCIF interrupt bit. All other characters will be ignored.

Upon receiving an address character, user software determines if the address matches its own. Upon address match, user software must disable address detection by clearing the ADDEN bit before the next Stop bit occurs. When user software detects the end of the message, determined by the message protocol used, software places the receiver back into the Address Detection mode by setting the ADDEN bit.

# PIC16(L)F1938/9





## 29.2 Instruction Descriptions

| ADDFSR           | Add Literal to FSRn                                                                           |
|------------------|-----------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] ADDFSR FSRn, k                                                                      |
| Operands:        | $-32 \le k \le 31$<br>n $\in$ [ 0, 1]                                                         |
| Operation:       | $FSR(n) + k \rightarrow FSR(n)$                                                               |
| Status Affected: | None                                                                                          |
| Description:     | The signed 6-bit literal 'k' is added to<br>the contents of the FSRnH:FSRnL<br>register pair. |
|                  | ECDs is limited to the server 0000h                                                           |

FSRn is limited to the range 0000h -FFFFh. Moving beyond these bounds will cause the FSR to wrap-around.

| ANDLW            | AND literal with W                                                                                              |
|------------------|-----------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] ANDLW k                                                                                        |
| Operands:        | $0 \leq k \leq 255$                                                                                             |
| Operation:       | (W) .AND. (k) $\rightarrow$ (W)                                                                                 |
| Status Affected: | Z                                                                                                               |
| Description:     | The contents of W register are<br>AND'ed with the 8-bit literal 'k'. The<br>result is placed in the W register. |

| ADDLW            | Add literal and W                                                                                                   |
|------------------|---------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] ADDLW k                                                                                            |
| Operands:        | $0 \leq k \leq 255$                                                                                                 |
| Operation:       | $(W) + k \to (W)$                                                                                                   |
| Status Affected: | C, DC, Z                                                                                                            |
| Description:     | The contents of the W register are<br>added to the 8-bit literal 'k' and the<br>result is placed in the W register. |

| ADDWF            | Add W and f                                                                                                                                                                     |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] ADDWF f,d                                                                                                                                                      |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                              |
| Operation:       | (W) + (f) $\rightarrow$ (destination)                                                                                                                                           |
| Status Affected: | C, DC, Z                                                                                                                                                                        |
| Description:     | Add the contents of the W register<br>with register 'f'. If 'd' is '0', the result is<br>stored in the W register. If 'd' is '1', the<br>result is stored back in register 'f'. |

| Status Affected:<br>Description: | Z<br>AND the W register with register 'f'. If<br>'d' is '0', the result is stored in the W<br>register. If 'd' is '1', the result is stored |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| ASRF                             | back in register 'f'.<br>Arithmetic Right Shift                                                                                             |
| Syntax:                          | [ label ] ASRF f {,d}                                                                                                                       |
| Operands:                        | $0 \le f \le 127$                                                                                                                           |

AND W with f

[label] ANDWF

(W) .AND. (f)  $\rightarrow$  (destination)

 $0 \leq f \leq 127$ 

 $\mathsf{d} \in [0,1]$ 

f,d

ANDWF

Syntax:

Operands:

Operation:

| Operands:        | 0 ≤ f ≤ 127<br>d ∈ [0,1]                                                                                                  |
|------------------|---------------------------------------------------------------------------------------------------------------------------|
| Operation:       | (f<7>)→ dest<7><br>(f<7:1>) → dest<6:0>,<br>(f<0>) → C,                                                                   |
| Status Affected: | C, Z                                                                                                                      |
| Description:     | The contents of register 'f' are shifted<br>one bit to the right through the Carry<br>flag. The MSb remains unchanged. If |

flag. The MSb remains unchanged. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is stored back in register 'f'.



| ADDWFC    | ADD W and CAR                      | RY bit to f |
|-----------|------------------------------------|-------------|
| Syntax:   | [ label ] ADDWFC                   | f {,d}      |
| Operands: | $0 \le f \le 127$<br>d $\in [0,1]$ |             |

| Operation:       | $(W) + (f) + (C) \rightarrow dest$                                                                                                                                        |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status Affected: | C, DC, Z                                                                                                                                                                  |
| Description:     | Add W, the Carry flag and data mem-<br>ory location 'f'. If 'd' is '0', the result is<br>placed in W. If 'd' is '1', the result is<br>placed in data memory location 'f'. |

# PIC16(L)F1938/9

| DECFSZ           | Decrement f, Skip if 0                                                                                                                                                                                                                                                                                                               |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] DECFSZ f,d                                                                                                                                                                                                                                                                                                          |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                                                                                                                                                                      |
| Operation:       | (f) - 1 $\rightarrow$ (destination);<br>skip if result = 0                                                                                                                                                                                                                                                                           |
| Status Affected: | None                                                                                                                                                                                                                                                                                                                                 |
| Description:     | The contents of register 'f' are decre-<br>mented. If 'd' is '0', the result is placed<br>in the W register. If 'd' is '1', the result<br>is placed back in register 'f'.<br>If the result is '1', the next instruction is<br>executed. If the result is '0', then a<br>NOP is executed instead, making it a<br>2-cycle instruction. |

| GOTO             | Unconditional Branch                                                                                                                                                                        |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] GOTO k                                                                                                                                                                     |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                        |
| Operation:       | $k \rightarrow PC<10:0>$<br>PCLATH<6:3> $\rightarrow$ PC<14:11>                                                                                                                             |
| Status Affected: | None                                                                                                                                                                                        |
| Description:     | GOTO is an unconditional branch. The<br>eleven-bit immediate value is loaded<br>into PC bits <10:0>. The upper bits of<br>PC are loaded from PCLATH<4:3>.<br>GOTO is a 2-cycle instruction. |

| INCFSZ           | Increment f, Skip if 0                                                                                                                                                                                                                                                                                                          |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:          | [ <i>label</i> ] INCFSZ f,d                                                                                                                                                                                                                                                                                                     |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                                                                                                                                                                                               |  |  |  |
| Operation:       | (f) + 1 $\rightarrow$ (destination),<br>skip if result = 0                                                                                                                                                                                                                                                                      |  |  |  |
| Status Affected: | None                                                                                                                                                                                                                                                                                                                            |  |  |  |
| Description:     | The contents of register 'f' are incre-<br>mented. If 'd' is '0', the result is placed<br>in the W register. If 'd' is '1', the result<br>is placed back in register 'f'.<br>If the result is '1', the next instruction is<br>executed. If the result is '0', a NOP is<br>executed instead, making it a 2-cycle<br>instruction. |  |  |  |

| IORLW            | Inclusive OR literal with W                                                                                        |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:          | [ <i>label</i> ] IORLW k                                                                                           |  |  |  |
| Operands:        | $0 \leq k \leq 255$                                                                                                |  |  |  |
| Operation:       | (W) .OR. $k \rightarrow$ (W)                                                                                       |  |  |  |
| Status Affected: | Z                                                                                                                  |  |  |  |
| Description:     | The contents of the W register are<br>OR'ed with the 8-bit literal 'k'. The<br>result is placed in the W register. |  |  |  |

| NCF Increment f  |                                                                                                                                                                           | IORWF                                                | Inclusive OR W with f                                                                                                                                                      |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [label] INCF f,d                                                                                                                                                          | Syntax:                                              | [ <i>label</i> ] IORWF f,d                                                                                                                                                 |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                        | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |                                                                                                                                                                            |  |  |
| Operation:       | (f) + 1 $\rightarrow$ (destination)                                                                                                                                       | Operation:                                           | (W) .OR. (f) $\rightarrow$ (destination)                                                                                                                                   |  |  |
| Status Affected: | Z                                                                                                                                                                         | Status Affected:                                     | Z                                                                                                                                                                          |  |  |
| Description:     | The contents of register 'f' are incre-<br>mented. If 'd' is '0', the result is placed<br>in the W register. If 'd' is '1', the result<br>is placed back in register 'f'. | Description:                                         | Inclusive OR the W register with regis-<br>ter 'f'. If 'd' is '0', the result is placed in<br>the W register. If 'd' is '1', the result is<br>placed back in register 'f'. |  |  |

# PIC16(L)F1938/9



FIGURE 31-50: IPD, COMPARATOR, NORMAL-POWER MODE, (CxSP = 1), PIC16F1938/9 ONLY



## 40-Lead Plastic Ultra Thin Quad Flat, No Lead Package (MV) - 5x5 mm Body [UQFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                            | MILLIMETERS |          |      |      |
|----------------------------|-------------|----------|------|------|
| Dimension Limits           |             | MIN      | NOM  | MAX  |
| Contact Pitch              | E           | 0.40 BSC |      |      |
| Optional Center Pad Width  | W2          |          |      | 3.80 |
| Optional Center Pad Length | T2          |          |      | 3.80 |
| Contact Pad Spacing        | C1          |          | 5.00 |      |
| Contact Pad Spacing        | C2          |          | 5.00 |      |
| Contact Pad Width (X40)    | X1          |          |      | 0.20 |
| Contact Pad Length (X40)   | Y1          |          |      | 0.75 |
| Distance Between Pads      | G           | 0.20     |      |      |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-2156B

## THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information:

- Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

## CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip web site at www.microchip.com. Under "Support", click on "Customer Change Notification" and follow the registration instructions.

## **CUSTOMER SUPPORT**

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- · Local Sales Office
- Field Application Engineer (FAE)
- Technical Support

Customers should contact their distributor, representative or Field Application Engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the web site at: http://microchip.com/support