



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

| Betalls                    |                                                                                 |
|----------------------------|---------------------------------------------------------------------------------|
| Product Status             | Active                                                                          |
| Core Processor             | PIC                                                                             |
| Core Size                  | 16-Bit                                                                          |
| Speed                      | 32MHz                                                                           |
| Connectivity               | I <sup>2</sup> C, IrDA, LINbus, SPI, UART/USART                                 |
| Peripherals                | Brown-out Detect/Reset, DMA, I <sup>2</sup> S, LVD, POR, PWM, WDT               |
| Number of I/O              | 22                                                                              |
| Program Memory Size        | 256КВ (85.5К х 24)                                                              |
| Program Memory Type        | FLASH                                                                           |
| EEPROM Size                | -                                                                               |
| RAM Size                   | 16K × 8                                                                         |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 3.6V                                                                       |
| Data Converters            | A/D 10x12b                                                                      |
| Oscillator Type            | Internal                                                                        |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                               |
| Mounting Type              | Surface Mount                                                                   |
| Package / Case             | 28-SSOP (0.209", 5.30mm Width)                                                  |
| Supplier Device Package    | 28-SSOP                                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic24fj256ga702t-i-ss |
|                            |                                                                                 |

Email: info@E-XFL.COM

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

| Pin                  | Pin Number/Grid Locator     |                     | Innut          |                    |     |                 |                                                                             |
|----------------------|-----------------------------|---------------------|----------------|--------------------|-----|-----------------|-----------------------------------------------------------------------------|
| Function             | 28-Pin SOIC,<br>SSOP, SPDIP | 28-Pin QFN,<br>UQFN | 44-Pin<br>TQFP | 48-Pin<br>QFN/TQFP | I/O | Input<br>Buffer | Description                                                                 |
| PGC1                 | 5                           | 2                   | 22             | 24                 | I   | ST              | ICSP™ Programming Clock                                                     |
| PGC2                 | 22                          | 19                  | 9              | 10                 | Ι   | ST              |                                                                             |
| PGC3                 | 15                          | 12                  | 42             | 46                 | Ι   | ST              |                                                                             |
| PGD1                 | 4                           | 1                   | 21             | 23                 | I/O | DIG/ST          | ICSP Programming Data                                                       |
| PGD2                 | 21                          | 18                  | 8              | 9                  | I/O | DIG/ST          |                                                                             |
| PGD3                 | 14                          | 11                  | 41             | 45                 | I/O | DIG/ST          |                                                                             |
| PMA0                 | —                           | —                   | 3              | 3                  | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<0>/<br>Address Latch Low                       |
| PMA1                 | —                           | —                   | 2              | 2                  | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<1>/<br>Address Latch High                      |
| PMA2                 | _                           | —                   | 12             | 13                 | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<2>                                             |
| PMA3                 | _                           | _                   | 38             | 41                 | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<3>                                             |
| PMA4                 | —                           | _                   | 37             | 40                 | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<4>                                             |
| PMA5                 | _                           | _                   | 4              | 4                  | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<5>                                             |
| PMA6                 | _                           | _                   | 5              | 5                  | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<6>                                             |
| PMA7                 | —                           | —                   | 13             | 14                 | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<7>                                             |
| PMA8                 | —                           | —                   | 32             | 35                 | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<8>                                             |
| PMA9                 | _                           | —                   | 35             | 38                 | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<9>                                             |
| PMA14/PMCS/<br>PMCS1 | _                           | —                   | 15             | 16                 | I/O | DIG/ST/<br>TTL  | Parallel Master Port Address<14>/<br>Slave Chip Select/Chip Select 1 Strobe |

#### TABLE 1-3: PIC24FJ256GA705 FAMILY PINOUT DESCRIPTIONS (CONTINUED)

Legend: TTL = TTL input buffer ANA = Analog level input/output DIG = Digital input/output ST = Schmitt Trigger input buffer  $I^2C = I^2C/SMBus$  input buffer

XCVR = Dedicated Transceiver

© 2016 Microchip Technology Inc.

## 2.0 GUIDELINES FOR GETTING STARTED WITH 16-BIT MICROCONTROLLERS

## 2.1 Basic Connection Requirements

Getting started with the PIC24FJ256GA705 family of 16-bit microcontrollers requires attention to a minimal set of device pin connections before proceeding with development.

The following pins must always be connected:

- All VDD and Vss pins (see Section 2.2 "Power Supply Pins")
- All AVDD and AVss pins, regardless of whether or not the analog device features are used (see Section 2.2 "Power Supply Pins")
- MCLR pin (see Section 2.3 "Master Clear (MCLR) Pin")

 VCAP pin (see Section 2.4 "Voltage Regulator Pin (VCAP)")

These pins must also be connected if they are being used in the end application:

- PGCx/PGDx pins used for In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) and debugging purposes (see **Section 2.5 "ICSP Pins**")
- OSCI and OSCO pins when an external oscillator source is used

(see Section 2.6 "External Oscillator Pins")

Additionally, the following pins may be required:

• VREF+/VREF- pins used when external voltage reference for analog modules is implemented

**Note:** The AVDD and AVss pins must always be connected, regardless of whether any of the analog modules are being used.

The minimum mandatory connections are shown in Figure 2-1.

#### FIGURE 2-1: RECOMMENDED MINIMUM CONNECTIONS



#### Key (all values are recommendations):

C1 through C6: 0.1  $\mu$ F, 50V ceramic

C7: 10 µF, 16V or greater, ceramic

R1: 10 kΩ

R2: 100Ω to 470Ω

- Note 1: See Section 2.4 "Voltage Regulator Pin (VCAP)" for an explanation of voltage regulator pin connections.
  - 2: The example shown is for a PIC24F device with five VDD/Vss and AVDD/AVss pairs. Other devices may have more or less pairs; adjust the number of decoupling capacitors appropriately.

## 7.0 RESETS

Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information, refer to the "dsPIC33/PIC24 Family Reference Manual", "Reset" (DS39712), which is available from the Microchip web site (www.microchip.com). The information in this data sheet supersedes the information in the FRM.

The Reset module combines all Reset sources and controls the device Master Reset Signal, SYSRST. The following is a list of device Reset sources:

- POR: Power-on Reset
- MCLR: Master Clear Pin Reset
- SWR: RESET Instruction
- WDT: Watchdog Timer Reset
- · BOR: Brown-out Reset
- CM: Configuration Mismatch Reset
- TRAPR: Trap Conflict Reset
- · IOPUWR: Illegal Opcode Reset
- UWR: Uninitialized W Register Reset

A simplified block diagram of the Reset module is shown in Figure 7-1.

Any active source of Reset will make the SYSRST signal active. Many registers associated with the CPU and peripherals are forced to a known Reset state. Most registers are unaffected by a Reset; their status is unknown on POR and unchanged by all other Resets.

**Note:** Refer to the specific peripheral or CPU section of this manual for register Reset states.

All types of device Reset will set a corresponding status bit in the RCON register to indicate the type of Reset (see Register 7-1). A POR will clear all bits, except for the BOR and POR (RCON<1:0>) bits, which are set. The user may set or clear any bit at any time during code execution. The RCON bits only serve as status bits. Setting a particular Reset status bit in software will not cause a device Reset to occur.

The RCON register also has other bits associated with the Watchdog Timer and device power-saving states. The function of these bits is discussed in other sections of this data sheet.

Note: The status bits in the RCON register should be cleared after they are read so that the next RCON register values after a device Reset will be meaningful.

#### FIGURE 7-1: RESET SYSTEM BLOCK DIAGRAM



© 2016 Microchip Technology Inc.

| Oscillator Mode                                    | Oscillator Source | POSCMD<1:0> | FNOSC<2:0> | Notes   |
|----------------------------------------------------|-------------------|-------------|------------|---------|
| Oscillator with Frequency Division (OSCFDIV)       | Internal/External | 11          | 111        | 1, 2, 3 |
| Low-Power RC Oscillator (LPRC)                     | Internal          | 11          | 101        | 3       |
| Secondary (Timer1) Oscillator<br>(SOSC)            | Secondary         | 11          | 100        | 3       |
| Primary Oscillator (XT) with PLL<br>Module (XTPLL) | Primary           | 01          | 011        |         |
| Primary Oscillator (EC) with PLL<br>Module (ECPLL) | Primary           | 00          | 011        |         |
| Primary Oscillator (HS)                            | Primary           | 10          | 010        |         |
| Primary Oscillator (XT)                            | Primary           | 01          | 010        |         |
| Primary Oscillator (EC)                            | Primary           | 00          | 010        |         |
| Fast RC Oscillator with PLL Module (FRCPLL)        | Internal          | 11          | 001        | 3       |
| Fast RC Oscillator (FRC)                           | Internal          | 11          | 000        | 3       |

#### TABLE 9-1: CONFIGURATION BIT VALUES FOR CLOCK SELECTION

**Note 1:** The input oscillator to the OSCFDIV Clock mode is determined by the RCDIV<2:0> (CLKDIV<10:8) bits. At POR, the default value selects the FRC module.

- 2: This is the default Oscillator mode for an unprogrammed (erased) device.
- 3: OSCO pin function is determined by the OSCIOFCN Configuration bit.

## 9.3 Control Registers

The operation of the oscillator is controlled by five Special Function Registers:

- OSCCON
- CLKDIV
- OSCTUN
- OSCDIV
- OSCFDIV

The OSCCON register (Register 9-1) is the main control register for the oscillator. It controls clock source switching and allows the monitoring of clock sources. OSCCON is protected by a write lock to prevent inadvertent clock switches. See **Section 9.4** "**Clock Switching Operation**" for more information. The CLKDIV register (Register 9-2) controls the features associated with Doze mode, as well as the postscalers for the OSCFDIV Clock mode and the PLL module.

The OSCTUN register (Register 9-3) allows the user to fine-tune the FRC Oscillator over a range of approximately  $\pm 1.5\%$ .

The OSCDIV and OSCFDIV registers provide control for the system oscillator frequency divider.

#### REGISTER 11-31: RPINR29: PERIPHERAL PIN SELECT INPUT REGISTER 29

| U-0                                | U-0 | U-0                                     | U-0                                | U-0   | U-0   | U-0   | U-0   |
|------------------------------------|-----|-----------------------------------------|------------------------------------|-------|-------|-------|-------|
| —                                  |     | —                                       |                                    | _     | —     | _     | —     |
| bit 15                             |     |                                         |                                    |       |       |       | bit 8 |
|                                    |     |                                         |                                    |       |       |       |       |
| U-0                                | U-0 | R/W-1                                   | R/W-1                              | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
| _                                  | —   | SS3R5                                   | SS3R4                              | SS3R3 | SS3R2 | SS3R1 | SS3R0 |
| bit 7                              |     |                                         |                                    |       |       |       | bit 0 |
|                                    |     |                                         |                                    |       |       |       |       |
| Legend:                            |     |                                         |                                    |       |       |       |       |
| R = Readable bit W = Writable bit  |     | oit                                     | U = Unimplemented bit, read as '0' |       |       |       |       |
| -n = Value at POR '1' = Bit is set |     | '0' = Bit is cleared x = Bit is unknown |                                    |       | nown  |       |       |

bit 15-6 Unimplemented: Read as '0'

bit 5-0 SS3R<5:0>: Assign SPI3 Slave Select Input (SS3IN) to Corresponding RPn or RPIn Pin bits

## 15.0 OUTPUT COMPARE WITH DEDICATED TIMERS

Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information, refer to the "dsPIC33/PIC24 Family Reference Manual", "Output Compare with Dedicated Timer" (DS70005159), which is available from the Microchip web site (www.microchip.com). The information in this data sheet supersedes the information in the FRM.

All devices in the PIC24FJ256GA705 family feature three independent output compare modules. Each of these modules offers a wide range of configuration and operating options for generating pulse trains on internal device events, and can produce Pulse-Width Modulated (PWM) waveforms for driving power applications.

Key features of the output compare module include:

- Hardware-Configurable for 32-Bit Operation in All modes by Cascading Two Adjacent modules
- Synchronous and Trigger modes of Output Compare Operation with up to 31 User-Selectable Sync/Trigger Sources Available
- Two Separate Period registers (a main register, OCxR, and a secondary register, OCxRS) for Greater Flexibility in Generating Pulses of Varying Widths
- Configurable for Single Pulse or Continuous Pulse Generation on an Output Event, or Continuous PWM Waveform Generation
- Up to 6 Clock Sources Available for Each module, Driving a Separate Internal 16-Bit Counter

### 15.1 General Operating Modes

#### 15.1.1 SYNCHRONOUS AND TRIGGER MODES

When the output compare module operates in a Free-Running mode, the internal 16-bit counter, OCxTMR, runs counts up continuously, wrapping around from 0xFFFF to 0x0000 on each overflow. Its period is synchronized to the selected external clock source. Compare or PWM events are generated each time a match between the internal counter and one of the Period registers occurs.

In Synchronous mode, the module begins performing its compare or PWM operation as soon as its selected clock source is enabled. Whenever an event occurs on the selected Sync source, the module's internal counter is reset. In Trigger mode, the module waits for a Sync event from another internal module to occur before allowing the counter to run.

Free-Running mode is selected by default or any time that the SYNCSEL<4:0> bits (OCxCON2<4:0>) are set to '00000'. Synchronous or Trigger modes are selected any time the SYNCSELx bits are set to any value except '00000'. The OCTRIG bit (OCxCON2<7>) selects either Synchronous or Trigger mode; setting the bit selects Trigger mode operation. In both modes, the SYNCSELx bits determine the Sync/Trigger source.

#### 15.1.2 CASCADED (32-BIT) MODE

By default, each module operates independently with its own set of 16-Bit Timer and Duty Cycle registers. To increase resolution, adjacent even and odd modules can be configured to function as a single 32-bit module. (For example, Modules 1 and 2 are paired, as are Modules 3 and 4, and so on.) The odd numbered module (OCx) provides the Least Significant 16 bits of the 32-bit register pairs and the even numbered module (OCy) provides the Most Significant 16 bits. Wrap-arounds of the OCx registers cause an increment of their corresponding OCy registers.

Cascaded operation is configured in hardware by setting the OC32 bit (OCxCON2<8>) for both modules. For more details on cascading, refer to the *"dsPIC33/ PIC24 Family Reference Manual"*, **"Output Compare with Dedicated Timer"** (DS70005159).

#### 16.1 Time Base Generator

The Timer Clock Generator (TCG) generates a clock for the module's internal time base using one of the clock signals already available on the microcontroller. This is used as the time reference for the module in its three major modes. The internal time base is shown in Figure 16-2. There are eight inputs available to the clock generator, which are selected using the CLKSEL<2:0> bits (CCPxCON1L<10:8>). Available sources include the FRC and LPRC, the Secondary Oscillator and the TCLKI external clock inputs. The system clock is the default source (CLKSEL<2:0> = 000). On PIC24FJ256GA705 family devices, clock sources to the MCCPx module must be synchronized with the system clock. As a result, when clock sources are selected, clock input timing restrictions or module operating restrictions may exist.



### FIGURE 16-2: TIMER CLOCK GENERATOR

| R/W-0                 | R/W-0                                                                                                                                    | U-0                                                                                  | U-0            | R/W-0                           | R/W-0               | R/W-0               | R/W-0               |  |  |  |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|----------------|---------------------------------|---------------------|---------------------|---------------------|--|--|--|
| OPSSRC <sup>(1)</sup> | RTRGEN <sup>(2)</sup>                                                                                                                    | _                                                                                    |                | OPS3 <sup>(3)</sup>             | OPS2 <sup>(3)</sup> | OPS1 <sup>(3)</sup> | OPS0 <sup>(3)</sup> |  |  |  |
| bit 15                |                                                                                                                                          |                                                                                      |                |                                 |                     |                     | bit 8               |  |  |  |
| R/W-0                 | R/W-0                                                                                                                                    | R/W-0                                                                                | R/W-0          | R/W-0                           | R/W-0               | R/W-0               | R/W-0               |  |  |  |
| TRIGEN                | ONESHOT                                                                                                                                  | ALTSYNC                                                                              | SYNC4          | SYNC3                           | SYNC2               | SYNC1               | SYNC0               |  |  |  |
| bit 7                 |                                                                                                                                          |                                                                                      |                |                                 |                     |                     | bit                 |  |  |  |
| Legend:               |                                                                                                                                          |                                                                                      |                |                                 |                     |                     |                     |  |  |  |
| R = Readable          | e bit                                                                                                                                    | W = Writable I                                                                       | oit            | U = Unimplem                    | nented bit, rea     | d as '0'            |                     |  |  |  |
| -n = Value at         |                                                                                                                                          | '1' = Bit is set                                                                     |                | '0' = Bit is clea               |                     | x = Bit is unkr     | iown                |  |  |  |
|                       |                                                                                                                                          |                                                                                      |                |                                 |                     |                     |                     |  |  |  |
| bit 15                | OPSSRC: Ou                                                                                                                               | Itput Postscaler                                                                     | Source Selec   | ct bit <sup>(1)</sup>           |                     |                     |                     |  |  |  |
|                       |                                                                                                                                          |                                                                                      |                | er output events                | 6                   |                     |                     |  |  |  |
|                       | • •                                                                                                                                      | ostscaler scales                                                                     |                | terrupt events                  |                     |                     |                     |  |  |  |
| bit 14                |                                                                                                                                          | trigger Enable                                                                       |                |                                 | 1                   |                     |                     |  |  |  |
|                       |                                                                                                                                          |                                                                                      |                | e TRIGEN bit =<br>en the TRIGEN |                     |                     |                     |  |  |  |
| bit 13-12             | <ul> <li>0 = Time base may not be retriggered when the TRIGEN bit = 1</li> <li>Unimplemented: Read as '0'</li> </ul>                     |                                                                                      |                |                                 |                     |                     |                     |  |  |  |
| bit 11-8              | •                                                                                                                                        |                                                                                      |                | cale Select bits <sup>(3</sup>  | 3)                  |                     |                     |  |  |  |
|                       | <b>OPS3&lt;3:0&gt;:</b> CCPx Interrupt Output Postscale Select bits <sup>(3)</sup><br>1111 = Interrupt every 16th time base period match |                                                                                      |                |                                 |                     |                     |                     |  |  |  |
|                       | 1110 = Interro                                                                                                                           | upt every 15th t                                                                     | ime base peri  | od match                        |                     |                     |                     |  |  |  |
|                       | <br>0100 = Intern                                                                                                                        | upt every 5th tir                                                                    | na hasa nario  | d match                         |                     |                     |                     |  |  |  |
|                       |                                                                                                                                          |                                                                                      | •              | d match or 4th i                | nput capture e      | event               |                     |  |  |  |
|                       |                                                                                                                                          |                                                                                      |                | d match or 3rd i                |                     |                     |                     |  |  |  |
|                       |                                                                                                                                          |                                                                                      |                | od match or 2nd                 |                     |                     |                     |  |  |  |
| bit 7                 |                                                                                                                                          | -                                                                                    | -              | od match or inpu                | li capiule eve      | i it                |                     |  |  |  |
|                       |                                                                                                                                          | <b>RIGEN:</b> CCPx Trigger Enable bit<br>= Trigger operation of time base is enabled |                |                                 |                     |                     |                     |  |  |  |
|                       | 0 = Trigger operation of time base is disabled                                                                                           |                                                                                      |                |                                 |                     |                     |                     |  |  |  |
| bit 6                 | ONESHOT: C                                                                                                                               | ne-Shot Mode                                                                         | Enable bit     |                                 |                     |                     |                     |  |  |  |
|                       |                                                                                                                                          | t Trigger mode<br>t Trigger mode                                                     |                | igger mode dura                 | ation is set by     | OSCNT<2:0>          |                     |  |  |  |
| bit 5                 | ALTSYNC: C                                                                                                                               | CPx Clock Sele                                                                       | ect bit        |                                 |                     |                     |                     |  |  |  |
|                       |                                                                                                                                          |                                                                                      |                | dule synchroniza                |                     |                     |                     |  |  |  |
|                       |                                                                                                                                          | -                                                                                    |                | gnal is the Time                | Base Reset/re       | ollover event       |                     |  |  |  |
| bit 4-0               | SYNC<4:0>: CCPx Synchronization Source Select bits                                                                                       |                                                                                      |                |                                 |                     |                     |                     |  |  |  |
|                       | See Table 16-                                                                                                                            | 5 for the definit                                                                    | ion of inputs. |                                 |                     |                     |                     |  |  |  |
| Note 1: Th            | is control bit ha                                                                                                                        | is no function ir                                                                    | Input Captur   | e modes.                        |                     |                     |                     |  |  |  |
| 2: Th                 | is control bit ha                                                                                                                        | is no function w                                                                     | hen TRIGEN     | = 0.                            |                     |                     |                     |  |  |  |
|                       | · ·                                                                                                                                      | •                                                                                    | 5 to 1:16 (010 | 00-1111), will re               | sult in a FIFO      | buffer overflow f   | or                  |  |  |  |
| Inr                   | out Canture mo                                                                                                                           | 169                                                                                  |                |                                 |                     |                     |                     |  |  |  |

### REGISTER 16-2: CCPxCON1H: CCPx CONTROL 1 HIGH REGISTERS

Input Capture modes.

## 17.1 Master Mode Operation

Perform the following steps to set up the SPIx module for Master mode operation:

- 1. Disable the SPIx interrupts in the respective IECx register.
- 2. Stop and reset the SPIx module by clearing the SPIEN bit.
- 3. Clear the receive buffer.
- Clear the ENHBUF bit (SPIxCON1L<0>) if using Standard Buffer mode or set the bit if using Enhanced Buffer mode.
- If SPIx interrupts are not going to be used, skip this step. Otherwise, the following additional steps are performed:
  - a) Clear the SPIx interrupt flags/events in the respective IFSx register.
  - b) Write the SPIx interrupt priority and sub-priority bits in the respective IPCx register.
  - c) Set the SPIx interrupt enable bits in the respective IECx register.
- 6. Write the Baud Rate register, SPIxBRGL.
- 7. Clear the SPIROV bit (SPIxSTATL<6>).
- 8. Write the desired settings to the SPIxCON1L register with MSTEN (SPIxCON1L<5>) = 1.
- Enable SPI operation by setting the SPIEN bit (SPIxCON1L<15>).
- 10. Write the data to be transmitted to the SPIxBUFL and SPIxBUFH registers. Transmission (and reception) will start as soon as data is written to the SPIxBUFL/H registers.

## 17.2 Slave Mode Operation

The following steps are used to set up the SPIx module for the Slave mode of operation:

- 1. If using interrupts, disable the SPIx interrupts in the respective IECx register.
- 2. Stop and reset the SPIx module by clearing the SPIEN bit.
- 3. Clear the receive buffer.
- Clear the ENHBUF bit (SPIxCON1L<0>) if using Standard Buffer mode or set the bit if using Enhanced Buffer mode.
- 5. If using interrupts, the following additional steps are performed:
  - a) Clear the SPIx interrupt flags/events in the respective IFSx register.
  - b) Write the SPIx interrupt priority and sub-priority bits in the respective IPCx register.
  - c) Set the SPIx interrupt enable bits in the respective IECx register.

- 6. Clear the SPIROV bit (SPIxSTATL<6>).
- 7. Write the desired settings to the SPIxCON1L register with MSTEN (SPIxCON1L<5>) = 0.
- Enable SPI operation by setting the SPIEN bit (SPIxCON1L<15>).
- 9. Transmission (and reception) will start as soon as the master provides the serial clock.

The following additional features are provided in Slave mode:

- Slave Select Synchronization:
- The SSx pin allows a Synchronous Slave mode. If the SSEN bit (SPIxCON1L<7>) is set, transmission and reception are enabled in Slave mode only if the SSx pin is driven to a low state. The port output or other peripheral outputs must not be driven in order to allow the SSx pin to function as an input. If the SSEN bit is set and the SSx pin is driven high, the SDOx pin is no longer driven and will tri-state, even if the module is in the middle of a transmission. An aborted transmission will be tried again the next time the SSx pin is driven low using the data held in the SPIxTXB register. If the SSEN bit is not set, the SSx pin does not affect the module operation in Slave mode.
- SPITBE Status Flag Operation: The SPITBE bit (SPIxSTATL<3>) has a different function in the Slave mode of operation. The following describes the function of SPITBE for various settings of the Slave mode of operation:
  - If SSEN (SPIxCON1L<7>) is cleared, the SPITBE bit is cleared when SPIxBUF is loaded by the user code. It is set when the module transfers SPIxTXB to SPIxTXSR. This is similar to the SPITBE bit function in Master mode.
  - If SSEN is set, SPITBE is cleared when SPIxBUF is loaded by the user code. However, it is set only when the SPIx module completes data transmission. A transmission will be aborted when the SSx pin goes high and may be retried at a later time. So, each data word is held in SPIxTXB until all bits are transmitted to the receiver.

## 18.2 Setting Baud Rate When Operating as a Bus Master

To compute the Baud Rate Generator reload value, use Equation 18-1.

# EQUATION 18-1: COMPUTING BAUD RATE RELOAD VALUE<sup>(1,2,3)</sup>

 $FSCL = \frac{FCY}{(I2CxBRG + 2) * 2}$ 

or:

$$I2CxBRG = \left[\frac{FCY}{(FSCL * 2)} - 2\right]$$

**Note 1:** Based on Fcy = Fosc/2; Doze mode and PLL are disabled.

2: These clock rate values are for guidance only. The actual clock rate can be affected by various systemlevel parameters. The actual clock rate should be measured in its intended application.

**3:** BRG values of 0 and 1 are forbidden.

## 18.3 Slave Address Masking

The I2CxMSK register (Register 18-4) designates address bit positions as "don't care" for both 7-Bit and 10-Bit Addressing modes. Setting a particular bit location (= 1) in the I2CxMSK register causes the slave module to respond, whether the corresponding address bit value is a '0' or a '1'. For example, when I2CxMSK is set to '0010000000', the slave module will detect both addresses, '000000000' and '001000000'.

To enable address masking, the Intelligent Peripheral Management Interface (IPMI) must be disabled by clearing the STRICT bit (I2CxCONL<11>).

**Note:** As a result of changes in the I<sup>2</sup>C protocol, the addresses in Table 18-2 are reserved and will not be Acknowledged in Slave mode. This includes any address mask settings that include any of these addresses.

| Required System FSCL | Fox    | I2CxB     | RG Value      |             |
|----------------------|--------|-----------|---------------|-------------|
|                      | FCY    | (Decimal) | (Hexadecimal) | Actual FscL |
| 100 kHz              | 16 MHz | 78        | 4E            | 100 kHz     |
| 100 kHz              | 8 MHz  | 38        | 26            | 100 kHz     |
| 100 kHz              | 4 MHz  | 18        | 12            | 100 kHz     |
| 400 kHz              | 16 MHz | 18        | 12            | 400 kHz     |
| 400 kHz              | 8 MHz  | 8         | 8             | 400 kHz     |
| 400 kHz              | 4 MHz  | 3         | 3             | 400 kHz     |
| 1 MHz                | 16 MHz | 6         | 6             | 1.000 MHz   |
| 1 MHz                | 8 MHz  | 2         | 2             | 1.000 MHz   |

## TABLE 18-1: I2Cx CLOCK RATES<sup>(1,2)</sup>

Note 1: Based on FCY = FOSC/2; Doze mode and PLL are disabled.

2: These clock rate values are for guidance only. The actual clock rate can be affected by various system-level parameters. The actual clock rate should be measured in its intended application.

| Slave Address | R/W Bit | Description                            |  |  |  |
|---------------|---------|----------------------------------------|--|--|--|
| 0000 000      | 0       | General Call Address <sup>(2)</sup>    |  |  |  |
| 0000 000      | 1       | Start Byte                             |  |  |  |
| 0000 001      | x       | Cbus Address                           |  |  |  |
| 0000 01x      | х       | Reserved                               |  |  |  |
| 0000 1xx      | x       | HS Mode Master Code                    |  |  |  |
| 1111 0xx      | x       | 10-Bit Slave Upper Byte <sup>(3)</sup> |  |  |  |
| 1111 1xx      | х       | Reserved                               |  |  |  |

Note 1: The address bits listed here will never cause an address match independent of address mask settings.

- 2: This address will be Acknowledged only if GCEN = 1.
- 3: A match on this address can only occur on the upper byte in 10-Bit Addressing mode.

| R/W-0      | U-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | HC, R/W-0                                                                                                                                                                                              | R/W-1                                                                                                                                                                                     | R/W-0                                                                                                                              | R/W-0                                                                                          | R/W-0                                                                    | R/W-0                                      |  |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--------------------------------------------|--|
| I2CEN      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | I2CSIDL                                                                                                                                                                                                | SCLREL <sup>(1)</sup>                                                                                                                                                                     | STRICT                                                                                                                             | A10M                                                                                           | DISSLW                                                                   | SMEN                                       |  |
| bit 15     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                        |                                                                                                                                                                                           |                                                                                                                                    |                                                                                                | •                                                                        | bit                                        |  |
|            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                        |                                                                                                                                                                                           |                                                                                                                                    |                                                                                                |                                                                          |                                            |  |
| R/W-0      | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W-0                                                                                                                                                                                                  | HC, R/W-0                                                                                                                                                                                 | HC, R/W-0                                                                                                                          | HC, R/W-0                                                                                      | HC, R/W-0                                                                | HC, R/W-0                                  |  |
| GCEN       | STREN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ACKDT                                                                                                                                                                                                  | ACKEN                                                                                                                                                                                     | RCEN                                                                                                                               | PEN                                                                                            | RSEN                                                                     | SEN                                        |  |
| bit 7      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                        |                                                                                                                                                                                           |                                                                                                                                    |                                                                                                |                                                                          | bit                                        |  |
|            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                        |                                                                                                                                                                                           | 4                                                                                                                                  |                                                                                                |                                                                          |                                            |  |
| Legend:    | HC = Hardware Clearable bit<br>lable bit U = Unimplemented bit, read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                        |                                                                                                                                                                                           |                                                                                                                                    |                                                                                                |                                                                          |                                            |  |
| R = Reada  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | W = Writable                                                                                                                                                                                           |                                                                                                                                                                                           | •                                                                                                                                  |                                                                                                |                                                                          |                                            |  |
| -n = Value | at POR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | '1' = Bit is set                                                                                                                                                                                       |                                                                                                                                                                                           | '0' = Bit is clea                                                                                                                  | ared                                                                                           | x = Bit is unkn                                                          | iown                                       |  |
| bit 15     | 1 = Enables t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Enable bit (writ<br>he I2Cx module<br>the I2Cx modul                                                                                                                                                   | e and configure                                                                                                                                                                           | s the SDAx an                                                                                                                      |                                                                                                |                                                                          | S                                          |  |
| bit 14     | Unimplemen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ted: Read as '                                                                                                                                                                                         | )'                                                                                                                                                                                        |                                                                                                                                    |                                                                                                |                                                                          |                                            |  |
| bit 13     | I2CSIDL: I2C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | x Stop in Idle M                                                                                                                                                                                       | lode bit                                                                                                                                                                                  |                                                                                                                                    |                                                                                                |                                                                          |                                            |  |
|            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <ul> <li>1 = Discontinues module operation when device enters Idle mode</li> <li>0 = Continues module operation in Idle mode</li> </ul>                                                                |                                                                                                                                                                                           |                                                                                                                                    |                                                                                                |                                                                          |                                            |  |
| bit 12     | Module resets<br><u>If STREN = 0</u><br>1 = Releases<br>0 = Forces clo<br><u>If STREN = 1</u><br>1 = Releases<br>0 = Holds cloo<br><b>STRICT:</b> I2C><br>1 = Strict ress<br>In Slave<br>that categories<br>In Master<br>0 = Reserved<br>In Slave of the start | clock<br>ock low (clock s<br>clock<br>ck low (clock st<br>ctrict Reserve<br>erved addressin<br>Mode: The dev<br>gory are NACK<br>r Mode: The de<br>d addressing wi<br>Mode: The devia<br>match with an | 0) sets SCLRI<br>stretch)<br>retch); user ma<br>ed Address Rule<br>ng is enforced<br>vice doesn't res<br>ed.<br>vice is allowed<br>ould be Acknow<br>ice will respond<br>y of the reserve | EL = 1.<br>ay program this<br>e Enable bit<br>(for reserved a<br>spond to reserved<br>to generate ac<br>vledged<br>t to an address | bit to '0', clock<br>ddresses, refer<br>ved address sp<br>ldresses with r<br>falling in the re | r to Table 18-2)<br>bace and addres<br>eserved address<br>served address | esses falling<br>ss space.<br>s space. Whe |  |
| bit 10     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | r Mode: Reserv<br>Slave Address                                                                                                                                                                        |                                                                                                                                                                                           |                                                                                                                                    |                                                                                                |                                                                          |                                            |  |
|            | 1 = I2CxADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | is a 10-bit slav<br>is a 7-bit slave                                                                                                                                                                   | e address                                                                                                                                                                                 |                                                                                                                                    |                                                                                                |                                                                          |                                            |  |
| bit 9      | DISSLW: Slev                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | w Rate Control                                                                                                                                                                                         | Disable bit                                                                                                                                                                               |                                                                                                                                    |                                                                                                |                                                                          |                                            |  |
|            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | control is disat<br>control is enab                                                                                                                                                                    |                                                                                                                                                                                           |                                                                                                                                    |                                                                                                | o disabled for 1                                                         | MHz mode)                                  |  |
|            | Automatically clear<br>of slave reception<br>ting the SCLREL<br>specified in <b>Secti</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | n. The user soft<br>bit. This delay                                                                                                                                                                    | ware must prov<br>must be greate                                                                                                                                                          | /ide a delay be<br>r than the mini                                                                                                 | tween writing t                                                                                | o the transmit b                                                         | ouffer and se                              |  |

## REGISTER 18-1: I2CxCONL: I2Cx CONTROL REGISTER LOW

**2:** Automatically cleared to '0' at the beginning of slave transmission.

## 19.1 UARTx Baud Rate Generator (BRG)

The UARTx module includes a dedicated, 16-bit Baud Rate Generator. The UxBRG register controls the period of a free-running, 16-bit timer. Equation 19-1 shows the formula for computation of the baud rate when BRGH = 0.

## EQUATION 19-1: UARTX BAUD RATE WITH BRGH = $0^{(1,2)}$

Baud Rate = 
$$\frac{FCY}{16 \cdot (UxBRG + 1)}$$
  
 $UxBRG = \frac{FCY}{16 \cdot Baud Rate} - 1$   
Note 1: FCY denotes the instruction cycle  
clock frequency (FOSC/2).  
2: Based on FCY = FOSC/2; Doze mo

**2:** Based on FCY = FOSC/2; Doze mode and PLL are disabled.

Example 19-1 shows the calculation of the baud rate error for the following conditions:

- Fcy = 4 MHz
- Desired Baud Rate = 9600

The maximum baud rate (BRGH = 0) possible is FCY/16 (for UxBRG = 0) and the minimum baud rate possible is FCY/(16 \* 65536).

Equation 19-2 shows the formula for computation of the baud rate when BRGH = 1.

## EQUATION 19-2: UARTX BAUD RATE WITH BRGH = $1^{(1,2)}$

Baud Rate = 
$$\frac{FCY}{4 \cdot (UxBRG + 1)}$$
  
UxBRG =  $\frac{FCY}{4 \cdot Baud Rate} - 1$ 

- **Note 1:** FCY denotes the instruction cycle clock frequency.
  - 2: Based on Fcy = Fosc/2; Doze mode and PLL are disabled.

The maximum baud rate (BRGH = 1) possible is FCY/4 (for UxBRG = 0) and the minimum baud rate possible is FCY/(4 \* 65536).

Writing a new value to the UxBRG register causes the BRG timer to be reset (cleared). This ensures the BRG does not wait for a timer overflow before generating the new baud rate.

## EXAMPLE 19-1: BAUD RATE ERROR CALCULATION (BRGH = 0)<sup>(1)</sup>

Desired Baud Rate = FCY/(16 (UxBRG + 1))Solving for UxBRG Value: **UxBRG** = ((FCY/Desired Baud Rate)/16) - 1**UxBRG** = ((400000/9600)/16) - 1UxBRG = 25 Calculated Baud Rate = 4000000/(16(25+1))= 9615 Error = (Calculated Baud Rate – Desired Baud Rate) Desired Baud Rate = (9615 - 9600)/9600 = 0.16%Note 1: Based on Fcy = Fosc/2; Doze mode and PLL are disabled.

## 22.0 32-BIT PROGRAMMABLE CYCLIC REDUNDANCY CHECK (CRC) GENERATOR

Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information, refer to the "dsPIC33/PIC24 Family Reference Manual", "32-Bit Programmable Cyclic Redundancy Check (CRC)" (DS30009729), which is available from the Microchip web site (www.microchip.com). The information in this data sheet supersedes the information in the FRM.

**CRC BLOCK DIAGRAM** 

**FIGURE 22-1:** 

The 32-bit programmable CRC generator provides a hardware implemented method of quickly generating checksums for various networking and security applications. It offers the following features:

- User-Programmable CRC Polynomial Equation, up to 32 Bits
- Programmable Shift Direction (little or big-endian)
- Independent Data and Polynomial Lengths
- Configurable Interrupt Output
- Data FIFO

Figure 22-1 displays a simplified block diagram of the CRC generator. A simple version of the CRC shift engine is displayed in Figure 22-2.

#### CRCDATL CRCDATH **FIFO Empty** Variable FIFO (4x32, 8x16 or 16x8) Event CRCISEL CRCWDATH CRCWDATL 1 CRC Interrupt LENDIAN 0 Shift Buffer **CRC Shift Engine** Shift 0 Complete Event Shifter Clock 2 \* FCY

#### FIGURE 22-2: CRC SHIFT ENGINE DETAIL



© 2016 Microchip Technology Inc.

## 23.1 Control Registers

The CLCx module is controlled by the following registers:

- CLCxCONL
- CLCxCONH
- CLCxSEL
- CLCxGLSL
- CLCxGLSH

The CLCx Control registers (CLCxCONL and CLCxCONH) are used to enable the module and interrupts, control the output enable bit, select output polarity and select the logic function. The CLCx Control registers also allow the user to control the logic polarity of not only the cell output, but also some intermediate variables. The CLCx Input MUX Select register (CLCxSEL) allows the user to select up to 4 data input sources using the 4 data input selection multiplexers. Each multiplexer has a list of 8 data sources available.

The CLCx Gate Logic Input Select registers (CLCxGLSL and CLCxGLSH) allow the user to select which outputs from each of the selection MUXes are used as inputs to the input gates of the logic cell. Each data source MUX outputs both a true and a negated version of its output. All of these 8 signals are enabled, ORed together by the logic cell input gates.

## REGISTER 23-1: CLCxCONL: CLCx CONTROL REGISTER (LOW)

| R/W-0        | U-0                                     | U-0                                                                                                                | U-0 | R/W-0            | R/W-0            | U-0             | U-0   |  |  |
|--------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------|-----|------------------|------------------|-----------------|-------|--|--|
| LCEN         | _                                       | _                                                                                                                  | —   | INTP             | INTN             | _               | —     |  |  |
| bit 15       |                                         |                                                                                                                    |     |                  |                  |                 | bit 8 |  |  |
|              |                                         |                                                                                                                    |     |                  |                  |                 |       |  |  |
| R/W-0        | R-0                                     | R/W-0                                                                                                              | U-0 | U-0              | R/W-0            | R/W-0           | R/W-0 |  |  |
| LCOE         | LCOUT                                   | LCPOL                                                                                                              | —   | —                | MODE2            | MODE1           | MODE0 |  |  |
| bit 7        |                                         |                                                                                                                    |     |                  |                  |                 | bit 0 |  |  |
| Legend:      |                                         |                                                                                                                    |     |                  |                  |                 |       |  |  |
| R = Readab   | le bit                                  | W = Writable                                                                                                       | bit | U = Unimplen     | nented bit, read | d as '0'        |       |  |  |
| -n = Value a | t POR                                   | '1' = Bit is set                                                                                                   |     | '0' = Bit is cle | ared             | x = Bit is unkr | iown  |  |  |
|              |                                         |                                                                                                                    |     |                  |                  |                 |       |  |  |
| bit 15       | LCEN: CLCx                              |                                                                                                                    |     |                  |                  |                 |       |  |  |
|              |                                         | enabled and mi<br>disabled and ha                                                                                  |     |                  |                  |                 |       |  |  |
| bit 14-12    |                                         | ted: Read as '                                                                                                     | •   | ulpuls           |                  |                 |       |  |  |
| bit 11       | -                                       | Positive Edge In                                                                                                   |     | e bit            |                  |                 |       |  |  |
|              |                                         | •                                                                                                                  | •   | ng edge occurs   | on LCOUT         |                 |       |  |  |
|              |                                         | will not be gen                                                                                                    |     | 0 0              |                  |                 |       |  |  |
| bit 10       |                                         | Negative Edge                                                                                                      |     |                  |                  |                 |       |  |  |
|              |                                         | will be generate<br>will not be gene                                                                               |     | ng edge occurs   | s on LCOUT       |                 |       |  |  |
| bit 9-8      |                                         | ted: Read as '                                                                                                     |     |                  |                  |                 |       |  |  |
| bit 7        | •                                       | Port Enable bi                                                                                                     |     |                  |                  |                 |       |  |  |
|              |                                         | t pin output is e                                                                                                  |     |                  |                  |                 |       |  |  |
|              | 0 = CLCx port pin output is disabled    |                                                                                                                    |     |                  |                  |                 |       |  |  |
| bit 6        | LCOUT: CLCx Data Output Status bit      |                                                                                                                    |     |                  |                  |                 |       |  |  |
|              | 1 = CLCx output high                    |                                                                                                                    |     |                  |                  |                 |       |  |  |
| bit 5        | 0 = CLCx output low                     |                                                                                                                    |     |                  |                  |                 |       |  |  |
| DIUD         | LCPOL: CLCx Output Polarity Control bit |                                                                                                                    |     |                  |                  |                 |       |  |  |
|              |                                         | <ul> <li>1 = The output of the module is inverted</li> <li>0 = The output of the module is not inverted</li> </ul> |     |                  |                  |                 |       |  |  |
| bit 4-3      | Unimplemen                              | ted: Read as '                                                                                                     | )'  |                  |                  |                 |       |  |  |
|              |                                         |                                                                                                                    |     |                  |                  |                 |       |  |  |



## EQUATION 24-1: A/D CONVERSION CLOCK PERIOD

$$TAD = TCY (ADCS + 1)$$

$$ADCS = \frac{TAD}{TCY} - 1$$

**Note:** Based on TCY = 2/FOSC; Doze mode and PLL are disabled.

NOTES:

## 29.3 On-Chip Voltage Regulator

All PIC24FJ256GA705 family devices power their core digital logic at a nominal 1.8V. This may create an issue for designs that are required to operate at a higher typical voltage, such as 3.3V. To simplify system design, all devices in the PIC24FJ256GA705 family incorporate an on-chip regulator that allows the device to run its core logic from VDD.

This regulator is always enabled. It provides a constant voltage (1.8V nominal) to the digital core logic, from a VDD of about 2.1V, all the way up to the device's VDDMAX. It does not have the capability to boost VDD levels. In order to prevent "brown-out" conditions when the voltage drops too low for the regulator, the Brown-out Reset occurs. Then, the regulator output follows VDD with a typical voltage drop of 300 mV.

A low-ESR capacitor (such as ceramic) must be connected to the VCAP pin (Figure 29-1). This helps to maintain the stability of the regulator. The recommended value for the filter capacitor (CEFC) is provided in **Section 32.1 "DC Characteristics"**.

# FIGURE 29-1: CONNECTIONS FOR THE ON-CHIP REGULATOR



#### 29.3.1 ON-CHIP REGULATOR AND POR

The voltage regulator takes approximately 10  $\mu$ s for it to generate output. During this time, designated as TVREG, code execution is disabled. TVREG is applied every time the device resumes operation after any power-down, including Sleep mode. TVREG is determined by the status of the VREGS bit (RCON<8>) and the WDTWIN<1:0> Configuration bits (FWDT<9:8>). Refer to **Section 32.0 "Electrical Characteristics"** for more information on TVREG.

| Note: | For more information, see Section 32.0<br>"Electrical Characteristics". The informa- |
|-------|--------------------------------------------------------------------------------------|
|       | tion in this data sheet supersedes the information in the FRM.                       |

#### 29.3.2 VOLTAGE REGULATOR STANDBY MODE

The on-chip regulator always consumes a small incremental amount of current over IDD/IPD, including when the device is in Sleep mode, even though the core digital logic does not require power. To provide additional savings in applications where power resources are critical, the regulator can be made to enter Standby mode, on its own, whenever the device goes into Sleep mode. This feature is controlled by the VREGS bit (RCON<8>). Clearing the VREGS bit enables the Standby mode. When waking up from Standby mode, the regulator needs to wait for TVREG to expire before wake-up.

#### 29.3.3 LOW-VOLTAGE RETENTION REGULATOR

When in Sleep mode, PIC24FJ256GA705 family devices may use a separate low-power, low-voltage retention regulator to power critical circuits. This regulator, which operates at 1.2V nominal, maintains power to data RAM and the RTCC while all other core digital logic is powered down. The low-voltage retention regulator is described in more detail in Section 10.2.4 "Low-Voltage Retention Regulator".

## 30.0 DEVELOPMENT SUPPORT

The PIC<sup>®</sup> microcontrollers (MCU) and dsPIC<sup>®</sup> digital signal controllers (DSC) are supported with a full range of software and hardware development tools:

- · Integrated Development Environment
- MPLAB<sup>®</sup> X IDE Software
- Compilers/Assemblers/Linkers
  - MPLAB XC Compiler
  - MPASM<sup>™</sup> Assembler
  - MPLINK<sup>™</sup> Object Linker/ MPLIB<sup>™</sup> Object Librarian
  - MPLAB Assembler/Linker/Librarian for Various Device Families
- · Simulators
  - MPLAB X SIM Software Simulator
- · Emulators
  - MPLAB REAL ICE™ In-Circuit Emulator
- In-Circuit Debuggers/Programmers
  - MPLAB ICD 3
  - PICkit™ 3
- Device Programmers
  - MPLAB PM3 Device Programmer
- Low-Cost Demonstration/Development Boards, Evaluation Kits and Starter Kits
- Third-party development tools

#### 30.1 MPLAB X Integrated Development Environment Software

The MPLAB X IDE is a single, unified graphical user interface for Microchip and third-party software, and hardware development tool that runs on Windows<sup>®</sup>, Linux and Mac  $OS^{®}$  X. Based on the NetBeans IDE, MPLAB X IDE is an entirely new IDE with a host of free software components and plug-ins for high-performance application development and debugging. Moving between tools and upgrading from software simulators to hardware debugging and programming tools is simple with the seamless user interface.

With complete project management, visual call graphs, a configurable watch window and a feature-rich editor that includes code completion and context menus, MPLAB X IDE is flexible and friendly enough for new users. With the ability to support multiple tools on multiple projects with simultaneous debugging, MPLAB X IDE is also suitable for the needs of experienced users.

Feature-Rich Editor:

- Color syntax highlighting
- Smart code completion makes suggestions and provides hints as you type
- Automatic code formatting based on user-defined rules
- · Live parsing

User-Friendly, Customizable Interface:

- Fully customizable interface: toolbars, toolbar buttons, windows, window placement, etc.
- · Call graph window
- Project-Based Workspaces:
- · Multiple projects
- Multiple tools
- · Multiple configurations
- · Simultaneous debugging sessions

File History and Bug Tracking:

- · Local file history feature
- Built-in support for Bugzilla issue tracker

| TABLE 32-11: | INTERNAL | <b>VOLTAGE REGUL</b> | ATOR SPECIFICATIONS |
|--------------|----------|----------------------|---------------------|
|--------------|----------|----------------------|---------------------|

| <b>Operating Conditions:</b> -40°C < TA < +85°C (unless otherwise stated) |        |                                         |      |     |      |       |                                                                    |  |  |  |  |
|---------------------------------------------------------------------------|--------|-----------------------------------------|------|-----|------|-------|--------------------------------------------------------------------|--|--|--|--|
| Param<br>No.                                                              | Symbol | Characteristics                         | Min  | Тур | Max  | Units | Comments                                                           |  |  |  |  |
| DVR                                                                       | TVREG  | Voltage Regulator Start-up Time         |      | 10  | -    | μS    | VREGS = 0 with any POR or<br>BOR                                   |  |  |  |  |
| DVR10                                                                     | Vbg    | Internal Band Gap Reference             | 1.14 | 1.2 | 1.26 | V     |                                                                    |  |  |  |  |
| DVR11                                                                     | Tbg    | Band Gap Reference<br>Start-up Time     | _    | 1   | -    | ms    |                                                                    |  |  |  |  |
| DVR20                                                                     | Vrgout | Regulator Output Voltage                | 1.6  | 1.8 | 2.0  | V     | Vdd > 1.9V                                                         |  |  |  |  |
| DVR21                                                                     | CEFC   | External Filter Capacitor Value         | 10   | —   | —    | μF    | Series resistance < $3\Omega$<br>recommended; < $5\Omega$ required |  |  |  |  |
| DVR30                                                                     | Vlvr   | Low-Voltage Regulator<br>Output Voltage |      | 1.2 | _    | V     | $RETEN = 1, \overline{LPCFG} = 0$                                  |  |  |  |  |

#### TABLE 32-12: HIGH/LOW-VOLTAGE DETECT CHARACTERISTICS Г

| <b>Operating Conditions:</b> -40°C < TA < +85°C (unless otherwise stated) |        |                                          |                                  |      |      |      |       |                           |  |  |  |
|---------------------------------------------------------------------------|--------|------------------------------------------|----------------------------------|------|------|------|-------|---------------------------|--|--|--|
| Param<br>No.                                                              | Symbol | Characteristic                           |                                  | Min  | Тур  | Max  | Units | Conditions                |  |  |  |
| DC18                                                                      | Vhlvd  | HLVD Voltage on VDD<br>Transition        | HLVDL<3:0> = 0100 <sup>(1)</sup> | 3.45 | _    | 3.73 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 0101                | 3.25 |      | 3.58 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 0110                | 2.95 |      | 3.25 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 0111                | 2.75 | —    | 3.04 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 1000                | 2.65 |      | 2.92 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 1001                | 2.45 | —    | 2.70 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 1010                | 2.35 |      | 2.60 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 1011                | 2.25 | —    | 2.49 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 1100                | 2.15 | —    | 2.39 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 1101                | 2.08 | —    | 2.28 | V     |                           |  |  |  |
|                                                                           |        |                                          | HLVDL<3:0> = 1110                | 2.00 |      | 2.15 | V     |                           |  |  |  |
| DC101                                                                     | VTHL   | HLVD Voltage on<br>HLVDIN Pin Transition | HLVDL<3:0> = 1111                | _    | 1.20 | —    | V     |                           |  |  |  |
| DC105                                                                     | TONLVD | HLVD Module Enable Time                  |                                  | _    | 5    |      | μS    | From POR or<br>HLVDEN = 1 |  |  |  |

**Note 1:** Trip points for values of HLVD<3:0>, from '0000' to '0011', are not implemented.

# 28-Lead Ultra Thin Plastic Quad Flat, No Lead Package (M6) - 4x4x0.6 mm Body [UQFN] With Corner Anchors

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



Microchip Technology Drawing C04-333-M6 Rev B Sheet 1 of 2