



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              | 12                                                                         |
| Program Memory Size        | 3.5KB (2K x 14)                                                            |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 128 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 5.5V                                                                |
| Data Converters            | A/D 8x10b                                                                  |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 14-SOIC (0.154", 3.90mm Width)                                             |
| Supplier Device Package    | 14-SOIC                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f1823t-i-sl |

Email: info@E-XFL.COM

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

| Name                                                | Function         | Input<br>Type      | Output<br>Type | Description                            |
|-----------------------------------------------------|------------------|--------------------|----------------|----------------------------------------|
| RA5/CLKIN/OSC1/T1OSI/T1CKI                          | RA5              | TTL                | CMOS           | General purpose I/O.                   |
|                                                     | CLKIN            | CMOS               |                | External clock input (EC mode).        |
|                                                     | OSC1             | XTAL               |                | Crystal/Resonator (LP, XT, HS modes).  |
|                                                     | T10SI            | XTAL               | XTAL           | Timer1 oscillator connection.          |
|                                                     | T1CKI            | ST                 | _              | Timer1 clock input.                    |
| RC0/AN4/CPS4/C2IN+/SCL/                             | RC0              | TTL                | CMOS           | General purpose I/O.                   |
| SCK                                                 | AN4              | AN                 |                | A/D Channel 4 input.                   |
|                                                     | CPS4             | AN                 |                | Capacitive sensing input 4.            |
|                                                     | C2IN+            | AN                 |                | Comparator C2 positive input.          |
|                                                     | SCL              | l <sup>2</sup> C™  | OD             | I <sup>2</sup> C <sup>™</sup> clock.   |
|                                                     | SCK              | ST                 | CMOS           | SPI clock.                             |
| RC1/AN5/CPS5/C12IN1-/SDA/                           | RC1              | TTL                | CMOS           | General purpose I/O.                   |
| SDI                                                 | AN5              | AN                 | _              | A/D Channel 5 input.                   |
|                                                     | CPS5             | AN                 | _              | Capacitive sensing input 5.            |
|                                                     | C12IN1-          | AN                 | _              | Comparator C1 or C2 negative input.    |
|                                                     | SDA              | I <sup>2</sup> C™  | OD             | I <sup>2</sup> C™ data input/output.   |
|                                                     | SDI              | CMOS               |                | SPI data input.                        |
| RC2/AN6/CPS6/C12IN2-/P1D/                           | RC2              | TTL                | CMOS           | General purpose I/O.                   |
| SDO <sup>(1)</sup> /MDCIN1                          | AN6              | AN                 |                | A/D Channel 6 input.                   |
|                                                     | CPS6             | AN                 |                | Capacitive sensing input 6.            |
|                                                     | C12IN2-          | AN                 |                | Comparator C1 or C2 negative input.    |
|                                                     | P1D              |                    | CMOS           | PWM output.                            |
|                                                     | SDO              | _                  | CMOS           | SPI data output.                       |
|                                                     | MDCIN1           | ST                 |                | Modulator Carrier Input 1.             |
| RC3/AN7/CPS7/C12IN3-/P1C/                           | RC6              | TTL                | CMOS           | General purpose I/O.                   |
| SS <sup>(1)</sup> /MDMIN                            | AN7              | AN                 |                | A/D Channel 6 input.                   |
|                                                     | CPS7             | AN                 | _              | Capacitive sensing input 6.            |
|                                                     | C12IN3-          | AN                 | _              | Comparator C1 or C2 negative input.    |
|                                                     | P1C              |                    | CMOS           | PWM output.                            |
|                                                     | SS               | ST                 |                | Slave Select input.                    |
|                                                     | MDMIN            | ST                 |                | Modulator source input.                |
| RC4/C2OUT/SRNQ/P1B/CK <sup>(1)</sup> /              | RC4              | TTL                | CMOS           | General purpose I/O.                   |
| TX <sup>(1)</sup> /MDOUT                            | C2OUT            |                    | CMOS           | Comparator C2 output.                  |
|                                                     | SRNQ             |                    | CMOS           | SR latch inverting output.             |
|                                                     | P1B              | _                  | CMOS           | PWM output.                            |
|                                                     | СК               | ST                 | CMOS           | USART synchronous clock.               |
|                                                     | ТΧ               |                    | CMOS           | USART asynchronous transmit.           |
|                                                     | MDOUT            | _                  | CMOS           | Modulator output.                      |
| RC5/P1A/CCP1/DT <sup>(1)</sup> /RX <sup>(1)</sup> / | RC5              | TTL                | CMOS           | General purpose I/O.                   |
| MDCIN2                                              | P1A              | —                  | CMOS           | PWM output.                            |
|                                                     | CCP1             | ST                 | CMOS           | Capture/Compare/PWM 1.                 |
|                                                     | DT               | ST                 | CMOS           | USART synchronous data.                |
|                                                     | RX               | ST                 |                | USART asynchronous input.              |
|                                                     | MDCIN2           | ST                 |                | Modulator Carrier Input 2.             |
| Legend: AN = Analog input or c                      | output CMC       | DS= CMC            | DS compa       | atible input or output OD = Open Drain |
| HV = High Voltage                                   | TIPUL ST<br>XTAI | - Schi<br>L = Crys | stal           |                                        |

### TABLE 1-3: PIC16(L)F1823 PINOUT DESCRIPTION (CONTINUED)

Note 1: Pin functions can be assigned to one of two pin locations via software. See APFCON register (Register 12-1).

## 2.0 ENHANCED MID-RANGE CPU

This family of devices contain an enhanced mid-range 8-bit CPU core. The CPU has 49 instructions. Interrupt capability includes automatic context saving. The hardware stack is 16 levels deep and has Overflow and Underflow Reset capability. Direct, Indirect, and Relative addressing modes are available. Two File Select Registers (FSRs) provide the ability to read program and data memory.

- · Automatic Interrupt Context Saving
- 16-level Stack with Overflow and Underflow
- File Select Registers
- Instruction Set

### 2.1 Automatic Interrupt Context Saving

During interrupts, certain registers are automatically saved in shadow registers and restored when returning from the interrupt. This saves stack space and user code. See **Section 8.5 "Automatic Context Saving"**, for more information.

### 2.2 16-Level Stack with Overflow and Underflow

These devices have an external stack memory 15 bits wide and 16 words deep. A Stack Overflow or Underflow will set the appropriate bit (STKOVF or STKUNF) in the PCON register, and if enabled will cause a software Reset. See section **Section 3.4 "Stack"** for more details.

### 2.3 File Select Registers

There are two 16-bit File Select Registers (FSR). FSRs can access all file registers and program memory, which allows one data pointer for all memory. When an FSR points to program memory, there is one additional instruction cycle in instructions using INDF to allow the data to be fetched. General purpose memory can now also be addressed linearly, providing the ability to access contiguous data larger than 80 bytes. There are also new instructions to support the FSRs. See **Section 3.5 "Indirect Addressing"** for more details.

### 2.4 Instruction Set

There are 49 instructions for the enhanced mid-range CPU to support the features of the CPU. See **Section 29.0 "Instruction Set Summary"** for more details.

| REGISTER 10-1: | WDTCON: WATCHDOG TIMER CONTROL REGISTER |
|----------------|-----------------------------------------|
|                |                                         |

| U-0              | U-0                                         | R/W-0/0                                                       | R/W-1/1         | R/W-0/0         | R/W-1/1          | R/W-1/1        | R/W-0/0      |  |  |
|------------------|---------------------------------------------|---------------------------------------------------------------|-----------------|-----------------|------------------|----------------|--------------|--|--|
| _                |                                             |                                                               |                 | WDTPS<4:0>      |                  |                | SWDTEN       |  |  |
| bit 7            |                                             |                                                               |                 |                 |                  |                | bit 0        |  |  |
|                  |                                             |                                                               |                 |                 |                  |                |              |  |  |
| Legend:          |                                             |                                                               |                 |                 |                  |                |              |  |  |
| R = Readable     | = Readable bit W = Writable bit             |                                                               |                 |                 | nented bit, read | l as '0'       |              |  |  |
| u = Bit is unch  | Bit is unchanged x = Bit is unknown         |                                                               |                 |                 | at POR and BC    | R/Value at all | other Resets |  |  |
| '1' = Bit is set |                                             | '0' = Bit is clea                                             | ared            |                 |                  |                |              |  |  |
|                  |                                             |                                                               |                 |                 |                  |                |              |  |  |
| bit 7-6          | Unimplemen                                  | ted: Read as '                                                | 0'              |                 |                  |                |              |  |  |
| bit 5-1          | WDTPS<4:0                                   | >: Watchdog Ti                                                | mer Period S    | elect bits      |                  |                |              |  |  |
|                  | Bit Value = F                               | Prescale Rate                                                 |                 |                 |                  |                |              |  |  |
|                  | 00000 = 1:3                                 | 32 (Interval 1 m                                              | s typ)          |                 |                  |                |              |  |  |
|                  | 00001 = 1:6                                 | 64 (Interval 2 m                                              | s typ)          |                 |                  |                |              |  |  |
|                  | 00010 = 1:1                                 | 28 (Interval 4 r                                              | ns typ)         |                 |                  |                |              |  |  |
|                  | 00011 = 1.2<br>00100 = 1.5                  | 512 (Interval 6 i<br>512 (Interval 16                         | ms typ)         |                 |                  |                |              |  |  |
|                  | 00101 = 1:1                                 | 024 (Interval 3                                               | 2 ms typ)       |                 |                  |                |              |  |  |
|                  | 00110 = 1:2                                 | 2048 (Interval 6                                              | 4 ms typ)       |                 |                  |                |              |  |  |
|                  | 00111 = 1:4                                 | 1096 (Interval 1                                              | 28 ms typ)      |                 |                  |                |              |  |  |
|                  | 01000 = 1:8                                 | 3192 (Interval 2                                              | 56 ms typ)      |                 |                  |                |              |  |  |
|                  | 01001 = 1.1                                 | 16384 (Interval<br>82768 (Interval                            | 512  ms typ     |                 |                  |                |              |  |  |
|                  | 01010 = 1.0<br>01011 = 1.6                  | 35536 (Interval                                               | 2s typ) (Rese   | et value)       |                  |                |              |  |  |
|                  | 01100 = 1:1                                 | 131072 (2 <sup>17</sup> ) (Ir                                 | terval 4s typ)  |                 |                  |                |              |  |  |
|                  | 01101 = 1:2                                 | 262144 (2 <sup>18</sup> ) (Ir                                 | terval 8s typ)  | 1               |                  |                |              |  |  |
|                  | 01110 = 1:5                                 | 524288 (2 <sup>19</sup> ) (Ir                                 | terval 16s typ  | D)              |                  |                |              |  |  |
|                  | 01111 = 1:1                                 | 1048576 (2 <sup>20</sup> ) (                                  | Interval 32s ty | /p)             |                  |                |              |  |  |
|                  | 10000 = 1.2<br>10001 = 1.4                  | 2097 152 (2 <sup>-1</sup> ) (<br>1194304 (2 <sup>22</sup> ) ( | Interval 048 ly | /p)<br>tvp)     |                  |                |              |  |  |
|                  | 10010 = 1.8                                 | 3388608 (2 <sup>23</sup> ) (                                  | Interval 256s   | typ)            |                  |                |              |  |  |
|                  |                                             |                                                               |                 | •••             |                  |                |              |  |  |
|                  | 10011 = Re                                  | served. Result                                                | s in minimum    | interval (1:32) |                  |                |              |  |  |
|                  | •                                           |                                                               |                 |                 |                  |                |              |  |  |
|                  | •                                           |                                                               |                 |                 |                  |                |              |  |  |
|                  | 11111 = Re                                  | served. Result                                                | s in minimum    | interval (1:32) |                  |                |              |  |  |
| bit 0            | SWDTEN: So                                  | oftware Enable/                                               | Disable for W   | /atchdog Timer  | bit              |                |              |  |  |
|                  | <u>If WDTE&lt;1:0&gt; = 00</u> :            |                                                               |                 |                 |                  |                |              |  |  |
|                  | This bit is ignored.                        |                                                               |                 |                 |                  |                |              |  |  |
|                  | $\frac{\text{If WDTE} < 1:0> = 01:}{1 - 1}$ |                                                               |                 |                 |                  |                |              |  |  |
|                  | $\perp = VVDIIST$                           | urned off                                                     |                 |                 |                  |                |              |  |  |
|                  | If WDTE<1:0                                 | > = 1x:                                                       |                 |                 |                  |                |              |  |  |
|                  | This bit is ign                             | ored.                                                         |                 |                 |                  |                |              |  |  |

### REGISTER 11-6: EECON2: EEPROM CONTROL 2 REGISTER

| W-0/0            | W-0/0    | W-0/0             | W-0/0     | W-0/0             | W-0/0            | W-0/0            | W-0/0       |
|------------------|----------|-------------------|-----------|-------------------|------------------|------------------|-------------|
|                  |          |                   | EEPROM Co | ontrol Register 2 |                  |                  |             |
| bit 7            |          |                   |           |                   |                  |                  | bit 0       |
|                  |          |                   |           |                   |                  |                  |             |
| Legend:          |          |                   |           |                   |                  |                  |             |
| R = Readable     | bit      | W = Writable      | bit       | U = Unimplen      | nented bit, read | as '0'           |             |
| S = Bit can onl  | y be set | x = Bit is unkr   | nown      | -n/n = Value a    | at POR and BO    | R/Value at all o | ther Resets |
| '1' = Bit is set |          | '0' = Bit is clea | ared      |                   |                  |                  |             |

### bit 7-0 Data EEPROM Unlock Pattern bits

To unlock writes, a 55h must be written first, followed by an AAh, before setting the WR bit of the EECON1 register. The value written to this register is used to unlock the writes. There are specific timing requirements on these writes. Refer to **Section 11.2.2** "Writing to the Data EEPROM Memory" for more information.

### TABLE 11-3: SUMMARY OF REGISTERS ASSOCIATED WITH DATA EEPROM

| Name   | Bit 7                                               | Bit 6               | Bit 5       | Bit 4 | Bit 3  | Bit 2  | Bit 1 | Bit 0 | Register<br>on Page |
|--------|-----------------------------------------------------|---------------------|-------------|-------|--------|--------|-------|-------|---------------------|
| EECON1 | EEPGD                                               | CFGS                | LWLO        | FREE  | WRERR  | WREN   | WR    | RD    | 110                 |
| EECON2 | EEPROM Control Register 2 (not a physical register) |                     |             |       |        |        |       | 111*  |                     |
| EEADRL | EEADRL<7:0>                                         |                     |             |       |        |        | 109   |       |                     |
| EEADRH | (2) EEADRH<6:0>                                     |                     |             |       |        |        | 109   |       |                     |
| EEDATL | EEDATL<7:0>                                         |                     |             |       |        |        | 109   |       |                     |
| EEDATH |                                                     | _                   | EEDATH<5:0> |       |        |        | 109   |       |                     |
| INTCON | GIE                                                 | PEIE                | TMR0IE      | INTE  | IOCIE  | TMR0IF | INTF  | IOCIF | 86                  |
| PIE2   | OSFIE                                               | C2IE <sup>(1)</sup> | C1IE        | EEIE  | BCL1IE | _      | _     | _     | 88                  |
| PIR2   | OSFIF                                               | C2IF <sup>(1)</sup> | C1IF        | EEIF  | BCL1IF | —      | —     | —     | 90                  |

Legend: — = unimplemented location, read as '0'. Shaded cells are not used by Data EEPROM module. \* Page provides register information.

Note 1: PIC16(L)F1823 only.

2: Unimplemented. Read as '1'.

## 13.0 INTERRUPT-ON-CHANGE

The PORTA pins can be configured to operate as Interrupt-On-Change (IOC) pins. An interrupt can be generated by detecting a signal that has either a rising edge or a falling edge. Any individual PORTA pin, or combination of PORTA pins, can be configured to generate an interrupt. The interrupt-on-change module has the following features:

- Interrupt-on-Change enable (Master Switch)
- Individual pin configuration
- · Rising and falling edge detection
- Individual pin interrupt flags

Figure 13-1 is a block diagram of the IOC module.

### 13.1 Enabling the Module

To allow individual PORTA pins to generate an interrupt, the IOCIE bit of the INTCON register must be set. If the IOCIE bit is disabled, the edge detection on the pin will still occur, but an interrupt will not be generated.

### 13.2 Individual Pin Configuration

For each PORTA pin, a rising edge detector and a falling edge detector are present. To enable a pin to detect a rising edge, the associated IOCAPx bit of the IOCAP register is set. To enable a pin to detect a falling edge, the associated IOCANx bit of the IOCAN register is set.

A pin can be configured to detect rising and falling edges simultaneously by setting both the IOCAPx bit and the IOCANx bit of the IOCAP and IOCAN registers, respectively.

### 13.3 Interrupt Flags

The IOCAFx bits located in the IOCAF register are status flags that correspond to the Interrupt-on-change pins of PORTA. If an expected edge is detected on an appropriately enabled pin, then the status flag for that pin will be set, and an interrupt will be generated if the IOCIE bit is set. The IOCIF bit of the INTCON register reflects the status of all IOCAFx bits.

### 13.4 Clearing Interrupt Flags

The individual status flags, (IOCAFx bits), can be cleared by resetting them to zero. If another edge is detected during this clearing operation, the associated status flag will be set at the end of the sequence, regardless of the value actually being written.

In order to ensure that no detected edge is lost while clearing flags, only AND operations masking out known changed bits should be performed. The following sequence is an example of what should be performed.

### EXAMPLE 13-1: CLEARING INTERRUPT FLAGS (PORTA EXAMPLE)

MOVLW 0xff XORWF IOCAF, W ANDWF IOCAF, F

### 13.5 Operation in Sleep

The interrupt-on-change interrupt sequence will wake the device from Sleep mode, if the IOCIE bit is set.

If an edge is detected while in Sleep mode, the IOCAF register will be updated prior to the first instruction executed out of Sleep.

## 15.0 TEMPERATURE INDICATOR MODULE

This family of devices is equipped with a temperature circuit designed to measure the operating temperature of the silicon die. The circuit's range of operating temperature falls between of  $-40^{\circ}$ C and  $+85^{\circ}$ C. The output is a voltage that is proportional to the device temperature. The output of the temperature indicator is internally connected to the device ADC.

The circuit may be used as a temperature threshold detector or a more accurate temperature indicator, depending on the level of calibration performed. A one-point calibration allows the circuit to indicate a temperature closely surrounding that point. A two-point calibration allows the circuit to sense the entire range of temperature more accurately. Reference Application Note AN1333, "Use and Calibration of the Internal Temperature Indicator" (DS01333) for more details regarding the calibration process.

## 15.1 Circuit Operation

Figure 15-1 shows a simplified block diagram of the temperature circuit. The proportional voltage output is achieved by measuring the forward voltage drop across multiple silicon junctions.

Equation 15-1 describes the output characteristics of the temperature indicator.

### EQUATION 15-1: VOUT RANGES

High Range: VOUT = VDD - 4VT

Low Range: VOUT = VDD - 2VT

The temperature sense circuit is integrated with the Fixed Voltage Reference (FVR) module. See **Section 14.0 "Fixed Voltage Reference (FVR)"** for more information.

The circuit is enabled by setting the TSEN bit of the FVRCON register. When disabled, the circuit draws no current.

The circuit operates in either high or low range. The high range, selected by setting the TSRNG bit of the FVRCON register, provides a wider output voltage. This provides more resolution over the temperature range, but may be less consistent from part to part. This range requires a higher bias voltage to operate and thus, a higher VDD is needed.

The low range is selected by clearing the TSRNG bit of the FVRCON register. The low range generates a lower voltage drop and thus, a lower bias voltage is needed to operate the circuit. The low range is provided for low voltage operation.

### FIGURE 15-1: T

### TEMPERATURE CIRCUIT DIAGRAM



### 15.2 Minimum Operating VDD vs. Minimum Sensing Temperature

When the temperature circuit is operated in low range, the device may be operated at any operating voltage that is within specifications.

When the temperature circuit is operated in high range, the device operating voltage, VDD, must be high enough to ensure that the temperature circuit is correctly biased.

Table 15-1 shows the recommended minimum VDD vs. range setting.

TABLE 15-1: RECOMMENDED VDD VS. RANGE

| Min. VDD, TSRNG = 1 | Min. VDD, TSRNG = 0 |
|---------------------|---------------------|
| 3.6V                | 1.8V                |

### **15.3 Temperature Output**

The output of the circuit is measured using the internal analog to digital converter. A channel is reserved for the temperature circuit output. Refer to **Section 16.0 "Analog-to-Digital Converter (ADC) Module"** for detailed information.

### 15.3.1 ADC ACQUISITION TIME

To ensure accurate temperature measurements, the user must wait at least 200 usec after the ADC input multiplexer is connected to the temperature indicator output before the conversion is performed. In addition, the user must wait 200 usec between sequential conversions of the temperature indicator output.

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

| 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    | bit     | U = Unimpler   | nented bit, read | d as '0'       |              |
| u = Bit is unch  | anged   | x = Bit is unkne  | own     | -n/n = Value a | at POR and BC    | R/Value at all | other Resets |
| '1' = Bit is set |         | '0' = Bit is clea | red     |                |                  |                |              |

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

### **REGISTER 16-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.

| FIGURE 21-6:           | TIMER1 GATE SINGLI                      | E-PULSE AND TOGGLE COMBINED MODE                       |
|------------------------|-----------------------------------------|--------------------------------------------------------|
| TMR1GE                 |                                         |                                                        |
| T1GPOL                 |                                         |                                                        |
| T1GSPM                 |                                         |                                                        |
| T1GTM                  |                                         |                                                        |
| T1GG <u>O/</u><br>DONE | ✓ Set by software<br>Counting enabled   | on                                                     |
| T1G_IN                 |                                         |                                                        |
| Т1СКІ                  |                                         |                                                        |
| T1GVAL                 |                                         |                                                        |
| Timer1                 | Ν                                       | N + 1 N + 2 N + 3 N + 4                                |
| TMR1GIF                | <ul> <li>Cleared by software</li> </ul> | Set by hardware on Cleared by falling edge of T1GVAL — |
|                        |                                         |                                                        |

### 

### 24.4.3 ENHANCED PWM AUTO-SHUTDOWN MODE

The PWM mode supports an Auto-Shutdown mode that will disable the PWM outputs when an external shutdown event occurs. Auto-Shutdown mode places the PWM output pins into a predetermined state. This mode is used to help prevent the PWM from damaging the application.

The auto-shutdown sources are selected using the CCP1AS<2:0> bits of the CCP1AS register. A shutdown event may be generated by:

- A logic '0' on the FLT0 pin
- A logic '1' on a Comparator (C1) output

A shutdown condition is indicated by the CCP1ASE (Auto-Shutdown Event Status) bit of the CCP1AS register. If the bit is a '0', the PWM pins are operating normally. If the bit is a '1', the PWM outputs are in the shutdown state.

When a shutdown event occurs, two things happen:

The CCP1ASE bit is set to '1'. The CCP1ASE will remain set until cleared in firmware or an auto-restart occurs (see **Section 24.4.4 "Auto-Restart Mode"**).

The enabled PWM pins are asynchronously placed in their shutdown states. The PWM output pins are grouped into pairs [P1A/P1C] and [P1B/P1D]. The state of each pin pair is determined by the PSS1AC and PSS1BD bits of the CCP1AS register. Each pin pair may be placed into one of three states:

- Drive logic '1'
- Drive logic '0'
- Tri-state (high-impedance)

- Note 1: The auto-shutdown condition is a levelbased signal, not an edge-based signal. As long as the level is present, the autoshutdown will persist.
  - 2: Writing to the CCP1ASE bit is disabled while an auto-shutdown condition persists.
  - 3: Once the auto-shutdown condition has been removed and the PWM restarted (either through firmware or auto-restart) the PWM signal will always restart at the beginning of the next PWM period.
  - 4: Prior to an auto-shutdown event caused by a comparator output or FLT0 pin event, a software shutdown can be triggered in firmware by setting the CCP1ASE bit of the CCP1AS register to '1'. The autorestart feature tracks the active status of a shutdown caused by a comparator output or FLT0 pin event only. If it is enabled at this time, it will immediately clear this bit and restart the ECCP module at the beginning of the next PWM period.

| FIGURE 24-14: | PWM AUTO-SHUTDOWN WITH FIRMWARE RESTART (P1RSEN = 0) |
|---------------|------------------------------------------------------|
|               |                                                      |







### REGISTER 25-5: SSP1MSK: SSP1 MASK REGISTER

| 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      |  |
|------------------------------------------------------------------------------------------------------|-------------|--------------------|-----------------|------------------------------------|---------------|------------------|--------------|--|
|                                                                                                      |             |                    | MSK             | <7: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 a                     | at POR and BO | R/Value at all c | other Resets |  |
| '1' = Bit is set                                                                                     |             | '0' = Bit is cle   | ared            |                                    |               |                  |              |  |
|                                                                                                      |             |                    |                 |                                    |               |                  |              |  |
| bit 7-1                                                                                              | MSK<7:1>:   | Mask bits          |                 |                                    |               |                  |              |  |
| 1 = The received address bit n is compared to SSP1ADD <n> to detect I<sup>2</sup>C address match</n> |             |                    |                 |                                    |               |                  | atch         |  |
|                                                                                                      | 0 = The rec | eived address b    | it n is not use | d to detect I <sup>2</sup> C       | address match |                  |              |  |

### bit 0 MSK<0>: Mask bit for I<sup>2</sup>C Slave mode, 10-bit Address

 $I^2C$  Slave mode, 10-bit address (SSP1M<3:0> = 0111 or 1111):

1 = The received address bit 0 is compared to SSP1ADD<0> to detect  $I^2C$  address match

0 = The received address bit 0 is not used to detect I<sup>2</sup>C address match

I<sup>2</sup>C Slave mode, 7-bit address, the bit is ignored

### REGISTER 25-6: SSP1ADD: MSSP1 ADDRESS AND BAUD RATE REGISTER (I<sup>2</sup>C MODE)

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

### Master mode:

| bit 7-0 | ADD<7:0>: Baud Rate Clock Divider bits          |
|---------|-------------------------------------------------|
|         | SCL pin clock period = ((ADD<7:0> + 1) *4)/Fosc |

### <u>10-Bit Slave mode — Most Significant Address byte:</u>

- bit 7-3 **Not used:** Unused for Most Significant Address byte. Bit state of this register is a "don't care". Bit pattern sent by master is fixed by I<sup>2</sup>C specification and must be equal to '11110'. However, those bits are compared by hardware and are not affected by the value in this register.
- bit 2-1 ADD<2:1>: Two Most Significant bits of 10-bit address
- bit 0 Not used: Unused in this mode. Bit state is a "don't care".

### <u>10-Bit Slave mode — Least Significant Address byte:</u>

bit 7-0 ADD<7:0>: Eight Least Significant bits of 10-bit address

### 7-Bit Slave mode:

| bit 7-1 ADD<7:1>: 7-bit address |  |
|---------------------------------|--|
|---------------------------------|--|

bit 0 Not used: Unused in this mode. Bit state is a "don't care".

### 26.1 EUSART Asynchronous Mode

The EUSART transmits and receives data using the standard non-return-to-zero (NRZ) format. NRZ is implemented with two levels: a VOH mark state which represents a '1' data bit, and a VOL space state which represents a '0' data bit. NRZ refers to the fact that consecutively transmitted data bits of the same value stay at the output level of that bit without returning to a neutral level between each bit transmission. An NRZ transmission port idles in the mark state. Each character transmission consists of one Start bit followed by eight or nine data bits and is always terminated by one or more Stop bits. The Start bit is always a space and the Stop bits are always marks. The most common data format is eight bits. Each transmitted bit persists for a period of 1/(Baud Rate). An on-chip dedicated 8-bit/16-bit Baud Rate Generator is used to derive standard baud rate frequencies from the system oscillator. See Table 26-5 for examples of baud rate configurations.

The EUSART transmits and receives the LSb first. The EUSART's transmitter and receiver are functionally independent, but share the same data format and baud rate. Parity is not supported by the hardware, but can be implemented in software and stored as the ninth data bit.

### 26.1.1 EUSART ASYNCHRONOUS TRANSMITTER

The EUSART transmitter block diagram is shown in Figure 26-1. The heart of the transmitter is the serial Transmit Shift Register (TSR), which is not directly accessible by software. The TSR obtains its data from the transmit buffer, which is the TXREG register.

### 26.1.1.1 Enabling the Transmitter

The EUSART transmitter is enabled for asynchronous operations by configuring the following three control bits:

- TXEN = 1
- SYNC = 0
- SPEN = 1

All other EUSART control bits are assumed to be in their default state.

Setting the TXEN bit of the TXSTA register enables the transmitter circuitry of the EUSART. Clearing the SYNC bit of the TXSTA register configures the EUSART for asynchronous operation. Setting the SPEN bit of the RCSTA register enables the EUSART and automatically configures the TX/CK I/O pin as an output. If the TX/CK pin is shared with an analog peripheral, the analog I/O function must be disabled by clearing the corresponding ANSEL bit.

**Note 1:** The TXIF Transmitter Interrupt flag is set when the TXEN enable bit is set.

### 26.1.1.2 Transmitting Data

A transmission is initiated by writing a character to the TXREG register. If this is the first character, or the previous character has been completely flushed from the TSR, the data in the TXREG is immediately transferred to the TSR register. If the TSR still contains all or part of a previous character, the new character data is held in the TXREG until the Stop bit of the previous character has been transmitted. The pending character in the TXREG is then transferred to the TSR in one TCY immediately following the Stop bit sequence commences immediately following the transfer of the data to the TSR from the TXREG.

### 26.1.1.3 Transmit Interrupt Flag

The TXIF interrupt flag bit of the PIR1 register is set whenever the EUSART transmitter is enabled and no character is being held for transmission in the TXREG. In other words, the TXIF bit is only clear when the TSR is busy with a character and a new character has been queued for transmission in the TXREG. The TXIF flag bit is not cleared immediately upon writing TXREG. TXIF becomes valid in the second instruction cycle following the write execution. Polling TXIF immediately following the TXREG write will return invalid results. The TXIF bit is read-only, it cannot be set or cleared by software.

The TXIF interrupt can be enabled by setting the TXIE interrupt enable bit of the PIE1 register. However, the TXIF flag bit will be set whenever the TXREG is empty, regardless of the state of TXIE enable bit.

To use interrupts when transmitting data, set the TXIE bit only when there is more data to send. Clear the TXIE interrupt enable bit upon writing the last character of the transmission to the TXREG.

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

#### Break and Sync Transmit Sequence 26.3.4.1

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)

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

### **RECEIVING A BREAK CHARACTER** 26.3.5

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.

## 30.0 ELECTRICAL SPECIFICATIONS

## Absolute Maximum Ratings<sup>(†)</sup>

| Ambient temperature under bias                                                                                   | 40°C to +125°C                |
|------------------------------------------------------------------------------------------------------------------|-------------------------------|
| Storage temperature                                                                                              | 65°C to +150°C                |
| Voltage on VDD with respect to Vss, PIC12F1822/16F1823                                                           | 0.3V to +6.5V                 |
| Voltage on VDD with respect to Vss, PIC12LF1822/16LF1823                                                         | 0.3V to +4.0V                 |
| Voltage on MCLR with respect to Vss                                                                              | 0.3V to +9.0V                 |
| Voltage on all other pins with respect to Vss                                                                    | 0.3V to (VDD + 0.3V)          |
| Total power dissipation <sup>(1)</sup>                                                                           | 800 mW                        |
| Maximum current out of Vss pin, -40°C $\leq$ TA $\leq$ +85°C for industrial                                      | 210 mA                        |
| Maximum current out of Vss pin, -40°C $\leq$ TA $\leq$ +125°C for extended                                       | 95 mA                         |
| Maximum current into VDD pin, -40°C $\leq$ TA $\leq$ +85°C for industrial                                        | 150 mA                        |
| Maximum current into VDD pin, -40°C $\leq$ TA $\leq$ +125°C for extended                                         | 70 mA                         |
| Clamp current, IK (VPIN < 0 or VPIN > VDD)                                                                       | ± 20 mA                       |
| Maximum output current sunk by any I/O pin                                                                       | 25 mA                         |
| Maximum output current sourced by any I/O pin                                                                    | 25 mA                         |
| <b>Note 1:</b> Power dissipation is calculated as follows: PDIS = VDD x {IDD $-\sum$ IOH} + $\sum$ {(VDD $-\sum$ | - Vон) x Iон} + ∑(Vol x Iol). |

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





© 2010-2015 Microchip Technology Inc.









FIGURE 31-51: COMPARATOR RESPONSE TIME OVER TEMPERATURE, NORMAL-POWER MODE (CxSP = 1)



### 8-Lead Plastic Dual Flat, No Lead Package (MF) - 3x3x0.9mm Body [DFN]

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



### RECOMMENDED LAND PATTERN

|                            | Units | N        | <b>ILLIMETER</b> | S    |  |
|----------------------------|-------|----------|------------------|------|--|
| Dimensior                  | MIN   | NOM      | MAX              |      |  |
| Contact Pitch E            |       | 0.65 BSC |                  |      |  |
| Optional Center Pad Width  | W2    |          |                  | 2.40 |  |
| Optional Center Pad Length | T2    |          |                  | 1.55 |  |
| Contact Pad Spacing        | C1    |          | 3.10             |      |  |
| Contact Pad Width (X8)     | X1    |          |                  | 0.35 |  |
| Contact Pad Length (X8)    | Y1    |          |                  | 0.65 |  |
| Distance Between Pads      | G     | 0.30     |                  |      |  |

### Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

Microchip Technology Drawing No. C04-2062B

### 14-Lead Plastic Thin Shrink Small Outline (ST) - 4.4 mm Body [TSSOP]

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



### **RECOMMENDED LAND PATTERN**

|                          | MILLIMETERS |      |          |      |
|--------------------------|-------------|------|----------|------|
| Dimensior                | MIN         | NOM  | MAX      |      |
| Contact Pitch            | E           |      | 0.65 BSC |      |
| Contact Pad Spacing      | C1          |      | 5.90     |      |
| Contact Pad Width (X14)  | X1          |      |          | 0.45 |
| Contact Pad Length (X14) | Y1          |      |          | 1.45 |
| 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-2087A