



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, POR, PWM, WDT                                     |
| Number of I/O              | 15                                                                        |
| Program Memory Size        | 14KB (8K 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 12x10b                                                                |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 125°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/pic16f1847-e-so |

Email: info@E-XFL.COM

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

# TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at docerrors@microchip.com. We welcome your feedback.

#### Most Current Data Sheet

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:

#### http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000000A is version A of document DS30000000).

#### Errata

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

- Microchip's Worldwide Web site; <a href="http://www.microchip.com">http://www.microchip.com</a>
- Your local Microchip sales office (see last page)

When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using.

#### **Customer Notification System**

Register on our web site at www.microchip.com to receive the most current information on all of our products.

# 3.3.1 SPECIAL FUNCTION REGISTER

The Special Function Registers are registers used by the application to control the desired operation of peripheral functions in the device. The registers associated with the operation of the peripherals are described in the appropriate peripheral chapter of this data sheet.

# 3.3.2 GENERAL PURPOSE RAM

There are up to 80 bytes of GPR in each data memory bank.

## 3.3.2.1 Linear Access to GPR

The general purpose RAM can be accessed in a non-banked method via the FSRs. This can simplify access to large memory structures. See **Section 3.6.2** "Linear Data Memory" for more information.

## 3.3.3 COMMON RAM

There are 16 bytes of common RAM accessible from all banks.

# FIGURE 3-2: BANKED MEMORY PARTITIONING



# 3.3.4 DEVICE MEMORY MAPS

The memory maps for the device family are as shown in Table 3-2.

# TABLE 3-2: MEMORY MAP TABLES

| Device        | Banks | Table No. |
|---------------|-------|-----------|
| PIC16(L)F1847 | 0-7   | Table 3-3 |
|               | 8-15  | Table 3-4 |
|               | 16-23 | Table 3-5 |
|               | 24-31 | Table 3-6 |
|               | 31    | Table 3-7 |

| R-1/q                                                                                                                                                                          | R-0/q                                                                                                                                                                       | R-q/q                                                    | R-0/q                                               | R-0/q                                | R-q/q                    | R-0/0            | R-0/q        |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------|--------------------------------------|--------------------------|------------------|--------------|--|
| T10SCR                                                                                                                                                                         | PLLR                                                                                                                                                                        | OSTS                                                     | HFIOFR                                              | HFIOFL                               | MFIOFR                   | LFIOFR           | HFIOFS       |  |
| bit 7                                                                                                                                                                          |                                                                                                                                                                             |                                                          |                                                     |                                      |                          |                  | bit 0        |  |
|                                                                                                                                                                                |                                                                                                                                                                             |                                                          |                                                     |                                      |                          |                  |              |  |
| Legend:                                                                                                                                                                        |                                                                                                                                                                             |                                                          |                                                     |                                      |                          |                  |              |  |
| R = Readable                                                                                                                                                                   | bit                                                                                                                                                                         | W = Writable                                             | bit                                                 | U = Unimpler                         | mented bit, read         | 1 as '0'         |              |  |
| u = Bit is unch                                                                                                                                                                | anged                                                                                                                                                                       | x = Bit is unkr                                          | nown                                                | -n/n = Value a                       | at POR and BO            | R/Value at all o | other Resets |  |
| '1' = Bit is set                                                                                                                                                               |                                                                                                                                                                             | '0' = Bit is cle                                         | ared                                                | q = Condition                        | al                       |                  |              |  |
| bit 7 <b>T1OSCR:</b> Timer1 Oscillator Ready bit<br><u>If T1OSCEN = 1</u> :<br>1 = Timer1 oscillator is ready<br>0 = Timer1 oscillator is not ready<br><u>If T1OSCEN = 0</u> : |                                                                                                                                                                             |                                                          |                                                     |                                      |                          |                  |              |  |
| bit 6                                                                                                                                                                          | PLLR 4x PLL<br>1 = 4x PLL i<br>0 = 4x PLL i                                                                                                                                 | . Ready bit<br>s ready<br>s not ready                    | aiwayo roady                                        |                                      |                          |                  |              |  |
| bit 5                                                                                                                                                                          | <b>OSTS:</b> Oscilla<br>1 = Running<br>0 = Running                                                                                                                          | ator Start-up Ti<br>I from the clock<br>I from an intern | me-out Status<br>defined by the<br>al oscillator (F | bit<br>e FOSC<2:0> k<br>OSC<2:0> = 1 | oits of the Confi<br>00) | iguration Word   | S            |  |
| bit 4                                                                                                                                                                          | <b>HFIOFR:</b> Hig<br>1 = HFINTOS<br>0 = HFINTOS                                                                                                                            | h Frequency Ir<br>SC is ready<br>SC is not ready         | iternal Oscillato                                   | or Ready bit                         |                          |                  |              |  |
| bit 3                                                                                                                                                                          | <b>HFIOFL:</b> High<br>1 = HFINTOS<br>0 = HFINTOS                                                                                                                           | h Frequency In<br>SC is at least 2<br>SC is not 2% a     | ternal Oscillato<br>% accurate<br>ccurate           | or Locked bit                        |                          |                  |              |  |
| bit 2                                                                                                                                                                          | MFIOFR: Me<br>1 = MFINTO<br>0 = MFINTO                                                                                                                                      | dium Frequenc<br>SC is ready<br>SC is not ready          | cy Internal Osc<br>∕                                | illator Ready bi                     | it                       |                  |              |  |
| bit 1                                                                                                                                                                          | LFIOFR: Low<br>1 = LFINTOS<br>0 = LFINTOS                                                                                                                                   | / Frequency Inf<br>SC is ready<br>SC is not ready        | ernal Oscillato                                     | r Ready bit                          |                          |                  |              |  |
| bit 0                                                                                                                                                                          | <ul> <li><b>HFIOFS:</b> High Frequency Internal Oscillator Stable bit</li> <li>1 = HFINTOSC is at least 0.5% accurate</li> <li>0 = HFINTOSC is not 0.5% accurate</li> </ul> |                                                          |                                                     |                                      |                          |                  |              |  |

# REGISTER 5-2: OSCSTAT: OSCILLATOR STATUS REGISTER

# TABLE 6-1: SUMMARY OF REGISTERS ASSOCIATED WITH REFERENCE CLOCK SOURCES

| Name        | Bit 7  | Bit 6  | Bit 5   | Bit 4       | Bit 3 | Bit 2 | Bit 1       | Bit 0 | Register<br>on Page |  |
|-------------|--------|--------|---------|-------------|-------|-------|-------------|-------|---------------------|--|
| CLKRCON     | CLKREN | CLKROE | CLKRSLR | CLKRDC<1:0> |       | С     | LKRDIV<2:0> | >     | 70                  |  |
| I a secondo |        |        |         |             |       |       |             |       |                     |  |

Legend: — = unimplemented locations read as '0'. Shaded cells are not used by reference clock sources.

#### TABLE 6-2: SUMMARY OF CONFIGURATION WORD WITH REFERENCE CLOCK SOURCES

| Name           | Bits | Bit -/7 | Bit -/6 | Bit 13/5   | Bit 12/4 | Bit 11/3 | Bit 10/2   | Bit 9/1 | Bit 8/0 | Register<br>on Page |
|----------------|------|---------|---------|------------|----------|----------|------------|---------|---------|---------------------|
|                | 13:8 | _       | _       | FCMEN      | IESO     | CLKOUTEN | BOREN<1:0> |         | CPD     | 40                  |
| CONFIG1 7:0 CP |      | MCLRE   | PWRTE   | PWRTE WDTE |          |          | FOSC<2:0>  |         | 40      |                     |

**Legend:** — = unimplemented locations read as '0'. Shaded cells are not used by reference clock sources.

| R/W-1/1                           | R/W-1/1 | R/W-1/1                                                               | R/W-1/1                            | R/W-1/1 | R/W-1/1 | R/W-1/1     | R/W-1/1 |  |  |
|-----------------------------------|---------|-----------------------------------------------------------------------|------------------------------------|---------|---------|-------------|---------|--|--|
| WPUB7                             | WPUB6   | WPUB5                                                                 | WPUB4                              | WPUB3   | WPUB2   | WPUB1       | WPUB0   |  |  |
| bit 7 bit 0                       |         |                                                                       |                                    |         |         |             |         |  |  |
|                                   |         |                                                                       |                                    |         |         |             |         |  |  |
| Legend:                           |         |                                                                       |                                    |         |         |             |         |  |  |
| R = Readable bit W = Writable bit |         |                                                                       | U = Unimplemented bit, read as '0' |         |         |             |         |  |  |
| u = Bit is uncha                  | anged   | nged x = Bit is unknown -n/n = Value at POR and BOR/Value at all othe |                                    |         |         | ther Resets |         |  |  |

## REGISTER 12-11: WPUB: WEAK PULL-UP PORTB REGISTER

bit 7-0 **WPUB<7:0>**: Weak Pull-up Register bits

1 = Pull-up enabled

'1' = Bit is set

- 0 = Pull-up disabled
- Note 1: Global WPUEN bit of the OPTION\_REG register must be cleared for individual pull-ups to be enabled.
  - **2**: The weak pull-up device is automatically disabled if the pin is in configured as an output.

# REGISTER 12-12: ANSELB: PORTB ANALOG SELECT REGISTER

'0' = Bit is cleared

| R/W-1/1 | U-0   |
|---------|---------|---------|---------|---------|---------|---------|-------|
| ANSB7   | ANSB6   | ANSB5   | ANSB4   | ANSB3   | ANSB2   | ANSB1   | —     |
| 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-1 **ANSB<7:1>**: Analog Select between Analog or Digital Function on Pins RB<7:1>, respectively

- 0 = Digital I/O. Pin is assigned to port or digital special function.
- 1 = Analog input. Pin is assigned as analog input<sup>(1)</sup>. Digital input buffer disabled.
- bit 0 Unimplemented: Read as '0'
- **Note 1:** When setting a pin to an analog input, the corresponding TRIS bit must be set to Input mode in order to allow external control of the voltage on the pin.

# 16.0 ANALOG-TO-DIGITAL CONVERTER (ADC) MODULE

The Analog-to-Digital Converter (ADC) allows conversion of an analog input signal to a 10-bit binary representation of that signal. This device uses analog inputs, which are multiplexed into a single sample and hold circuit. The output of the sample and hold is connected to the input of the converter. The converter generates a 10-bit binary result via successive approximation and stores the conversion result into the ADC result registers (ADRESH:ADRESL register pair). Figure 16-1 shows the block diagram of the ADC. The ADC voltage reference is software selectable to be either internally generated or externally supplied.

The ADC can generate an interrupt upon completion of a conversion. This interrupt can be used to wake-up the device from Sleep.

## FIGURE 16-1: ADC BLOCK DIAGRAM



# PIC16(L)F1847

# 16.2.6 ADC 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 16.3 "ADC Acquisition Requirements".

# EXAMPLE 16-1: ADC 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 ADCON0 ; B'00000001' ;Select channel ANO MOVLW MOVWF ADCON0 ;Turn ADC On SampleTime ;Acquisiton delay CALL 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

# PIC16(L)F1847

| R/W-0/0                                                                                                                                                                                                 | R-0/0                                                  | R/W-0/0                                                                    | R/W-0/0                                            | U-0                                                   | R/W-1/1                          | R/W-0/0         | R/W-0/0         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------|-------------------------------------------------------|----------------------------------|-----------------|-----------------|
| CxON                                                                                                                                                                                                    | CxOUT                                                  | CxOE                                                                       | CxPOL                                              | —                                                     | CxSP                             | CxHYS           | CxSYNC          |
| bit 7                                                                                                                                                                                                   |                                                        |                                                                            | I                                                  |                                                       |                                  | I               | bit 0           |
|                                                                                                                                                                                                         |                                                        |                                                                            |                                                    |                                                       |                                  |                 |                 |
| Legend:                                                                                                                                                                                                 |                                                        |                                                                            |                                                    |                                                       |                                  |                 |                 |
| R = Readable                                                                                                                                                                                            | bit                                                    | W = Writable                                                               | bit                                                | U = Unimpler                                          | nented bit, read                 | d as '0'        |                 |
| u = Bit is unch                                                                                                                                                                                         | anged                                                  | x = Bit is unkr                                                            | nown                                               | -n/n = Value a                                        | at POR and BO                    | R/Value at all  | other Resets    |
| '1' = Bit is set                                                                                                                                                                                        |                                                        | '0' = Bit is cle                                                           | ared                                               |                                                       |                                  |                 |                 |
| bit 7                                                                                                                                                                                                   | <b>CxON:</b> Comp<br>1 = Compara<br>0 = Compara        | parator Enable<br>tor is enabled<br>tor is disabled                        | bit<br>and consumes                                | s no active pow                                       | er                               |                 |                 |
| bit 6 <b>CxOUT:</b> Comparator Output bit<br>If $CxPOL = 1$ (inverted polarity):<br>1 = CxVP < CxVN<br>0 = CxVP > CxVN<br>If $CxPOL = 0$ (non-inverted polarity):<br>1 = CxVP > CxVN<br>0 = CxVP > CxVN |                                                        |                                                                            |                                                    |                                                       |                                  |                 |                 |
| bit 5                                                                                                                                                                                                   | CxOE: Comp<br>1 = CxOUT is<br>drive the<br>0 = CxOUT i | arator Output I<br>s present on the<br>pin. Not affecte<br>s internal only | Enable bit<br>e CxOUT pin. I<br>ed by CxON.        | Requires that th                                      | e associated T                   | RIS bit be clea | red to actually |
| bit 4                                                                                                                                                                                                   | <b>CxPOL:</b> Com<br>1 = Comparat<br>0 = Comparat      | parator Output<br>tor output is inv<br>tor output is no                    | Polarity Select<br>verted<br>t inverted            | ct bit                                                |                                  |                 |                 |
| bit 3                                                                                                                                                                                                   | Unimplemen                                             | ted: Read as '                                                             | 0'                                                 |                                                       |                                  |                 |                 |
| bit 2                                                                                                                                                                                                   | CxSP: Comp                                             | arator Speed/F                                                             | ower Select b                                      | it                                                    |                                  |                 |                 |
|                                                                                                                                                                                                         | 1 = Comparat<br>0 = Comparat                           | tor operates in<br>tor operates in                                         | normal power,<br>low-power, low                    | , higher speed<br>v-speed mode                        | mode                             |                 |                 |
| bit 1                                                                                                                                                                                                   | CxHYS: Com                                             | parator Hyster                                                             | esis Enable bi                                     | t                                                     |                                  |                 |                 |
|                                                                                                                                                                                                         | 1 = Compara<br>0 = Compara                             | ator hysteresis<br>ator hysteresis                                         | enabled<br>disabled                                |                                                       |                                  |                 |                 |
| bit 0                                                                                                                                                                                                   | CxSYNC: Co                                             | mparator Outp                                                              | ut Synchronou                                      | is Mode bit                                           |                                  |                 |                 |
|                                                                                                                                                                                                         | 1 = Compara<br>Output up<br>0 = Compara                | ator output to 7<br>pdated on the f<br>ator output to T                    | Timer1 and I/C<br>falling edge of<br>imer1 and I/O | ) pin is synchro<br>Timer1 clock s<br>pin is asynchro | onous to chang<br>ource.<br>nous | ges on Timer1   | clock source.   |

# REGISTER 19-1: CMxCON0: COMPARATOR Cx CONTROL REGISTER 0

# 23.0 DATA SIGNAL MODULATOR

The Data Signal Modulator (DSM) is a peripheral which allows the user to mix a data stream, also known as a modulator signal, with a carrier signal to produce a modulated output.

Both the carrier and the modulator signals are supplied to the DSM module either internally, from the output of a peripheral, or externally through an input pin.

The modulated output signal is generated by performing a logical "AND" operation of both the carrier and modulator signals and then provided to the MDOUT pin.

The carrier signal is comprised of two distinct and separate signals. A carrier high (CARH) signal and a carrier low (CARL) signal. During the time in which the modulator (MOD) signal is in a logic high state, the DSM mixes the carrier high signal with the modulator signal. When the modulator signal is in a logic low state, the DSM mixes the carrier low signal with the modulator signal. Using this method, the DSM can generate the following types of Key Modulation schemes:

- Frequency-Shift Keying (FSK)
- Phase-Shift Keying (PSK)
- On-Off Keying (OOK)

Additionally, the following features are provided within the DSM module:

- Carrier Synchronization
- · Carrier Source Polarity Select
- Carrier Source Pin Disable
- Programmable Modulator Data
- Modulator Source Pin Disable
- Modulated Output Polarity Select
- Slew Rate Control

Figure 23-1 shows a Simplified Block Diagram of the Data Signal Modulator peripheral.





# 24.3.6 PWM RESOLUTION

The resolution determines the number of available duty cycles for a given period. For example, a 10-bit resolution will result in 1024 discrete duty cycles, whereas an 8-bit resolution will result in 256 discrete duty cycles.

The maximum PWM resolution is ten bits when PRx is 255. The resolution is a function of the PRx register value as shown by Equation 24-4.

## EQUATION 24-4: PWM RESOLUTION

Resolution = 
$$\frac{\log[4(PRx+1)]}{\log(2)}$$
 bits

Note: If the pulse width value is greater than the period the assigned PWM pin(s) will remain unchanged.

# TABLE 24-5:EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 32 MHz)

| PWM Frequency             | 1.95 kHz | 7.81 kHz | 31.25 kHz | 125 kHz | 250 kHz | 333.3 kHz |
|---------------------------|----------|----------|-----------|---------|---------|-----------|
| Timer Prescale (1, 4, 16) | 16       | 4        | 1         | 1       | 1       | 1         |
| PRx Value                 | 0xFF     | 0xFF     | 0xFF      | 0x3F    | 0x1F    | 0x17      |
| Maximum Resolution (bits) | 10       | 10       | 10        | 8       | 7       | 6.6       |

## TABLE 24-6: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 20 MHz)

| PWM Frequency             | 1.22 kHz | 4.88 kHz | 19.53 kHz | 78.12 kHz | 156.3 kHz | 208.3 kHz |
|---------------------------|----------|----------|-----------|-----------|-----------|-----------|
| Timer Prescale (1, 4, 16) | 16       | 4        | 1         | 1         | 1         | 1         |
| PRx Value                 | 0xFF     | 0xFF     | 0xFF      | 0x3F      | 0x1F      | 0x17      |
| Maximum Resolution (bits) | 10       | 10       | 10        | 8         | 7         | 6.6       |

# TABLE 24-7: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 8 MHz)

| PWM Frequency             | 1.22 kHz | 4.90 kHz | 19.61 kHz | 76.92 kHz | 153.85 kHz | 200.0 kHz |
|---------------------------|----------|----------|-----------|-----------|------------|-----------|
| Timer Prescale (1, 4, 16) | 16       | 4        | 1         | 1         | 1          | 1         |
| PRx Value                 | 0x65     | 0x65     | 0x65      | 0x19      | 0x0C       | 0x09      |
| Maximum Resolution (bits) | 8        | 8        | 8         | 6         | 5          | 5         |

| ECCP Mode            | PxM<1:0> | CCPx/PxA           | PxB                | PxC                | PxD                |  |
|----------------------|----------|--------------------|--------------------|--------------------|--------------------|--|
| Single               | 00       | Yes <sup>(1)</sup> | Yes <sup>(1)</sup> | Yes <sup>(1)</sup> | Yes <sup>(1)</sup> |  |
| Half-Bridge          | 10       | Yes                | Yes                | No                 | No                 |  |
| Full-Bridge, Forward | 01       | Yes                | Yes                | Yes                | Yes                |  |
| Full-Bridge, Reverse | 11       | Yes                | Yes                | Yes                | Yes                |  |

#### **EXAMPLE PIN ASSIGNMENTS FOR VARIOUS PWM ENHANCED MODES** TABLE 24-9

**Note 1:** PWM Steering enables outputs in Single mode.

#### EXAMPLE PWM (ENHANCED MODE) OUTPUT RELATIONSHIPS (ACTIVE-HIGH FIGURE 24-6: STATE)

| PxM<1:0>       |              | Signal        | ⁰ ⊶ | Pulse      | ▶           | PRX+1       |
|----------------|--------------|---------------|-----|------------|-------------|-------------|
|                |              |               | -   |            | Period      |             |
| 00 <b>(Sin</b> | gle Output)  | PxA Modulated |     |            |             | Į           |
|                |              | PxA Modulated |     | /          |             | İ           |
| 10 <b>(H</b> a | alf-Bridge)  | PxB Modulated |     |            |             |             |
|                |              | PxA Active    |     |            |             | <br>        |
| (Fi            | ull-Bridge,  | PxB Inactive  |     |            | 1<br>1<br>1 | 1<br>1<br>1 |
| • Forward)     | PxC Inactive |               |     | 1<br>1<br> |             |             |
|                |              | PxD Modulated |     |            | -<br>       | 1<br>1<br>1 |
|                |              | PxA Inactive  |     |            | 1<br>1<br>1 | 1<br>1<br>1 |
| 11 (Fi         | ull-Bridge,  | PxB Modulated |     |            | _ <u></u>   | 1<br>1      |
| Reverse)       | PxC Active - |               |     |            |             |             |
|                |              | PxD Inactive  |     |            | <br> <br>   |             |

Period = 4 \* Tosc \* (PRx + 1) \* (TMRx Prescale Value)
Pulse Width = Tosc \* (CCPRxL<7:0>:CCPxCON<5:4>) \* (TMRx Prescale Value)
Delay = 4 \* Tosc \* (PWMxCON<6:0>)



FIGURE 24-11: **EXAMPLE OF FULL-BRIDGE PWM OUTPUT** 

| R/W-0/0          | R/W-0/0                | R/W-0/0                              | R/W-0/0                  | R/W-0/0            | R/W-0/0           | R/W-0/0        | R/W-0/0        |
|------------------|------------------------|--------------------------------------|--------------------------|--------------------|-------------------|----------------|----------------|
| PxRSEN           |                        |                                      |                          | PxDC<6:0>          |                   |                |                |
| bit 7            |                        |                                      |                          |                    |                   |                | bit 0          |
|                  |                        |                                      |                          |                    |                   |                |                |
| Legend:          |                        |                                      |                          |                    |                   |                |                |
| R = Readable     | e bit                  | W = Writable                         | bit                      | U = Unimplen       | nented bit, read  | d as '0'       |                |
| u = Bit is unch  | nanged                 | x = Bit is unkr                      | nown                     | -n/n = Value a     | at POR and BC     | R/Value at all | other Resets   |
| '1' = Bit is set |                        | '0' = Bit is cle                     | ared                     |                    |                   |                |                |
|                  |                        |                                      |                          |                    |                   |                |                |
| bit 7            | PxRSEN: P\             | NM Restart Ena                       | able bit                 |                    |                   |                |                |
|                  | 1 = Upon au<br>the PWI | ito-shutdown, th<br>V restarts auton | e CCPxASE b<br>natically | pit clears automa  | atically once the | e shutdown eve | ent goes away; |
|                  | 0 = Upon au            | uto-shutdown, C                      | CPxASE mus               | st be cleared in s | software to res   | tart the PWM   |                |
| bit 6-0          | PxDC<6:0>:             | PWM Delay Co                         | ount bits                |                    |                   |                |                |
|                  | PxDCx = Nu             | mber of Fosc/                        | 4 (4 * Tosc) (           | cycles between     | the schedule      | d time when a  | a PWM signal   |

# REGISTER 24-4: PWMxCON: ENHANCED PWM CONTROL REGISTER

**Note 1:** Bit resets to '0' with Two-Speed Start-up and LP, XT or HS selected as the Oscillator mode or Fail-Safe mode is enabled.

should transition active and the actual time it transitions active

### 25.5.3.3 7-Bit Transmission with Address Hold Enabled

Setting the AHEN bit of the SSPxCON3 register enables additional clock stretching and interrupt generation after the 8th falling edge of a received matching address. Once a matching address has been clocked in, CKP is cleared and the SSPxIF interrupt is set.

Figure 25-19 displays a standard waveform of a 7-bit Address Slave Transmission with AHEN enabled.

- 1. Bus starts Idle.
- Master sends Start condition; the S bit of SSPxSTAT is set; SSPxIF is set if interrupt on Start detect is enabled.
- Master sends matching address with R/W bit set. After the 8th falling edge of the SCLx line the CKP bit is cleared and SSPxIF interrupt is generated.
- 4. Slave software clears SSPxIF.
- Slave software reads ACKTIM bit of SSPxCON3 register, and R/W and D/A of the SSPxSTAT register to determine the source of the interrupt.
- 6. Slave reads the address value from the SSPxBUF register clearing the BF bit.
- 7. Slave software decides from this information if it wishes to ACK or not ACK and sets the ACKDT bit of the SSPxCON2 register accordingly.
- 8. Slave sets the CKP bit releasing SCLx.
- 9. Master clocks in the  $\overline{ACK}$  value from the slave.
- 10. Slave hardware automatically clears the CKP bit and sets SSPxIF after the ACK if the R/W bit is set.
- 11. Slave software clears SSPxIF.
- 12. Slave loads value to transmit to the master into SSPxBUF setting the BF bit.

Note: <u>SSPxBUF</u> cannot be loaded until after the ACK.

13. Slave sets CKP bit releasing the clock.

- 14. Master clocks out the data from the slave and sends an ACK value on the 9th SCLx pulse.
- 15. Slave hardware copies the ACK value into the ACKSTAT bit of the SSPxCON2 register.
- 16. Steps 10-15 are repeated for each byte transmitted to the master from the slave.
- 17. If the master sends a not  $\overline{ACK}$  the slave releases the bus allowing the master to send a Stop and end the communication.

**Note:** Master must send a not ACK on the last byte to ensure that the slave releases the SCLx line to receive a Stop.



#### 26.3.4 BREAK CHARACTER SEQUENCE

The EUSART module has the capability of sending the special Break character sequences that are required by the LIN bus standard. A Break character consists of a Start bit, followed by 12 '0' bits and a Stop bit.

To send a Break character, set the SENDB and TXEN bits of the TXSTA register. The Break character transmission is then initiated by a write to the TXREG. The value of data written to TXREG will be ignored and all '0's will be transmitted.

The SENDB bit is automatically reset by hardware after the corresponding Stop bit is sent. This allows the user to preload the transmit FIFO with the next transmit byte following the Break character (typically, the Sync character in the LIN specification).

The TRMT bit of the TXSTA register indicates when the transmit operation is active or Idle, just as it does during normal transmission. See Figure 26-9 for the timing of the Break character sequence.

#### 26.3.4.1 Break and Sync Transmit Sequence

The following sequence will start a message frame header made up of a Break, followed by an auto-baud Sync byte. This sequence is typical of a LIN bus master.

- 1. Configure the EUSART for the desired mode.
- 2. Set the TXEN and SENDB bits to enable the Break sequence.
- Load the TXREG with a dummy character to 3. initiate transmission (the value is ignored).
- Write '55h' to TXREG to load the Sync character 4 into the transmit FIFO buffer.
- After the Break has been sent, the SENDB bit is 5. reset by hardware and the Sync character is then transmitted.

When the TXREG becomes empty, as indicated by the TXIF, the next data byte can be written to TXREG.

#### Write to TXREG Dummy Write **BRG** Output (Shift Clock) TX (pin) Start bit bit 0 bit 1 Stop bit Break TXIF bit (Transmit Interrupt Flag) TRMT bit (Transmit Shift Empty Flag) SENDB Sampled Here Auto Cleared SENDB (send Break control bit)

#### 26.3.5 RECEIVING A BREAK CHARACTER

The Enhanced EUSART module can receive a Break character in two ways.

The first method to detect a Break character uses the FERR bit of the RCSTA register and the Received data as indicated by RCREG. The Baud Rate Generator is assumed to have been initialized to the expected baud rate.

A Break character has been received when;

- RCIF bit is set
- FERR bit is set
- RCREG = 00h

The second method uses the Auto-Wake-up feature described in Section 26.3.3 "Auto-Wake-up on Break". By enabling this feature, the EUSART will sample the next two transitions on RX/DT, cause an RCIF interrupt, and receive the next data byte followed by another interrupt.

Note that following a Break character, the user will typically want to enable the Auto-Baud Detect feature. For both methods, the user can set the ABDEN bit of the BAUDCON register before placing the EUSART in Sleep mode.

#### FIGURE 26-9: SEND BREAK CHARACTER SEQUENCE

# 28.0 IN-CIRCUIT SERIAL PROGRAMMING™ (ICSP™)

ICSP<sup>™</sup> programming allows customers to manufacture circuit boards with unprogrammed devices. Programming can be done after the assembly process allowing the device to be programmed with the most recent firmware or a custom firmware. Five pins are needed for ICSP<sup>™</sup> programming:

- ICSPCLK
- ICSPDAT
- MCLR/VPP
- VDD
- Vss

In Program/Verify mode the Program Memory, User IDs and the Configuration Words are programmed through serial communications. The ICSPDAT pin is a bidirectional I/O used for transferring the serial data and the ICSPCLK pin is the clock input. For more information on ICSP™ refer to the "*PIC16193X/PIC16LF193X Memory Programming Specification*" (DS41360A).

# 28.1 High-Voltage Programming Entry Mode

The device is placed into High-Voltage Programming Entry mode by holding the ICSPCLK and ICSPDAT pins low then raising the voltage on MCLR/VPP to VIHH.

# 28.2 Low-Voltage Programming Entry Mode

The Low-Voltage Programming Entry mode allows the PIC<sup>®</sup> Flash MCUs devices to be programmed using VDD only, without high voltage. When the LVP bit of Configuration Words is set to '1', the low-voltage ICSP programming entry is enabled. To disable the Low-Voltage ICSP mode, the LVP bit must be programmed to '0'.

Entry into the Low-Voltage Programming Entry mode requires the following steps:

- 1. MCLR is brought to VIL.
- 2. A 32-bit key sequence is presented on ICSPDAT, while clocking ICSPCLK.

Once the key sequence is complete,  $\overline{\text{MCLR}}$  must be held at VIL for as long as Program/Verify mode is to be maintained.

If low-voltage programming is enabled (LVP = 1), the  $\overline{\text{MCLR}}$  Reset function is automatically enabled and cannot be disabled. See **Section 7.4 "MCLR**" for more information.

The LVP bit can only be reprogrammed to '0' by using the High-Voltage Programming mode.

# 28.3 Common Programming Interfaces

Connection to a target device is typically done through an ICSP<sup>™</sup> header. A commonly found connector on development tools is the RJ-11 in the 6P6C (6-pin, 6 connector) configuration. See Figure 28-1.





# PIC16(L)F1847

| 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>11-bit immediate value is loaded into<br>PC bits <10:0>. The upper bits of PC<br>are loaded from PCLATH<4:3>. GOTO<br>is a 2-cycle instruction. |

| INCFSZ           | Increment f, Skip if 0                                                                                                                                                                                                                                                                                                          |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] 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. |  |  |  |

| INCF             | Increment f                                                                                                                                                               | IORWF            | Inclusive OR W with f                                                                                                                                                      |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] INCF f,d                                                                                                                                                 | Syntax:          | [ <i>label</i> ] IORWF f,d                                                                                                                                                 |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                           | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                         |
| 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'. |



FIGURE 31-8: IDD MAXIMUM, EC OSCILLATOR, MEDIUM-POWER MODE, PIC16LF1847 ONLY



28-Lead Ultra Thin Plastic Quad Flat, No Lead Package (MV) - 4x4 mm Body [UQFN] With 0.40 mm Contact Length

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



|                            | MILLIMETERS |          |      |      |
|----------------------------|-------------|----------|------|------|
| Dimension                  | MIN         | NOM      | MAX  |      |
| Contact Pitch E            |             | 0.40 BSC |      |      |
| Optional Center Pad Width  | W2          |          |      | 2.35 |
| Optional Center Pad Length | T2          |          |      | 2.35 |
| Contact Pad Spacing        | C1          |          | 4.00 |      |
| Contact Pad Spacing        | C2          |          | 4.00 |      |
| Contact Pad Width (X28)    | X1          |          |      | 0.20 |
| Contact Pad Length (X28)   | Y1          |          |      | 0.80 |
| Distance Between Pads      |             | 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-2152A