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 - Microcontrollers</u>" | Details | | |----------------------------|--------------------------------------------------------------------------------| | 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, LVD, POR, PWM, WDT | | Number of I/O | 37 | | Program Memory Size | 16KB (5.5K x 24) | | Program Memory Type | FLASH | | EEPROM Size | 512 x 8 | | RAM Size | 2K x 8 | | Voltage - Supply (Vcc/Vdd) | 2V ~ 5V | | Data Converters | A/D 22x10b/12b; D/A 2x8b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 44-TQFP | | Supplier Device Package | 44-TQFP (10x10) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic24fv16km204t-i-pt | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong ### Pin Diagrams (Continued) | ED2/INT2/ | |-----------| | 1/CN12/ | | | | | | | | | 1 | | 1 | | 1 | | 1 | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | , | | | Legend: Values in indicate pin function differences between PIC24F(V)XXKM202 and PIC24F(V)XXKM102 devices. Note 1: Exposed pad on underside of device is connected to Vss. ### **Table of Contents** | 1.0 | Device Overview | | |-------|-------------------------------------------------------------|-----| | 2.0 | Guidelines for Getting Started with 16-Bit Microcontrollers | 29 | | 3.0 | CPU | | | 4.0 | Memory Organization | 41 | | 5.0 | Flash Program Memory | 67 | | 6.0 | Data EEPROM Memory | | | 7.0 | Resets | 79 | | 8.0 | Interrupt Controller | 85 | | 9.0 | Oscillator Configuration | 121 | | 10.0 | Power-Saving Features | 131 | | 11.0 | I/O Ports | 137 | | 12.0 | Timer1 | 141 | | 13.0 | Capture/Compare/PWM/Timer Modules (MCCP and SCCP) | 143 | | 14.0 | Master Synchronous Serial Port (MSSP) | | | 15.0 | Universal Asynchronous Receiver Transmitter (UART) | 173 | | 16.0 | Real-Time Clock and Calendar (RTCC) | 181 | | 17.0 | Configurable Logic Cell (CLC) | 195 | | 18.0 | High/Low-Voltage Detect (HLVD) | 207 | | | 12-Bit A/D Converter with Threshold Detect | | | 20.0 | 8-Bit Digital-to-Analog Converter (DAC) | 229 | | 21.0 | Dual Operational Amplifier Module | 233 | | 22.0 | Comparator Module | 235 | | 23.0 | Comparator Voltage Reference | 239 | | 24.0 | Charge Time Measurement Unit (CTMU) | 241 | | 25.0 | Special Features | 249 | | 26.0 | Development Support | 261 | | 27.0 | Electrical Characteristics | 265 | | | Packaging Information | | | Appe | endix A: Revision History | 325 | | Index | X | 327 | | The I | Microchip Web Site | 333 | | Custo | omer Change Notification Service | 333 | | Custo | omer Support | 333 | | Produ | uct Identification System | 335 | TABLE 1-3: DEVICE FEATURES FOR THE PIC24FV16KM204 FAMILY | TABLE 1-3: DEVICE FEATURES FO | 71 111E 1 10E+1 V 1 | OKINEOT I AIN | · · · · · · · · · · · · · · · · · · · | T | | | | | | |--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------------|-----------------|--|--|--|--|--| | Features | PIC24FV16KM204 | PIC24FV08KM204 | PIC24FV16KM202 | PIC24FV08KM202 | | | | | | | Operating Frequency | | DC-32 MHz | | | | | | | | | Program Memory (bytes) | 16K | 8K | 16K | 8K | | | | | | | Program Memory (instructions) | 5632 | 2816 | 5632 | 2816 | | | | | | | Data Memory (bytes) | | 20 | )48 | l | | | | | | | Data EEPROM Memory (bytes) | | 5 | 12 | | | | | | | | Interrupt Sources (soft vectors/NMI traps) | | 40 ( | 36/4) | | | | | | | | Voltage Range | | ` | -5.5V | | | | | | | | I/O Ports | PORTA<1<br>PORTB<<br>PORTC | RTA<7,5:0><br>RTB<15:0> | | | | | | | | | Total I/O Pins | 37 23 | | | | | | | | | | Timers | (One 16-bit timer, five MCCPs/SCCPs with up to two 16/32 timers each | | | | | | | | | | Capture/Compare/PWM modules<br>MCCP<br>SCCP | | | 3<br>2 | | | | | | | | Serial Communications<br>MSSP<br>UART | | | 2<br>2 | | | | | | | | Input Change Notification Interrupt | 36 | | | 22 | | | | | | | 12-Bit Analog-to-Digital Module (input channels) | 22 | | | 19 | | | | | | | Analog Comparators | | | 3 | | | | | | | | 8-Bit Digital-to-Analog Converters | | | 2 | | | | | | | | Operational Amplifiers | | | 2 | | | | | | | | Charge Time Measurement Unit (CTMU) | | Y | ′es | | | | | | | | Real-Time Clock and Calendar (RTCC) | | Y | 'es | | | | | | | | Configurable Logic Cell (CLC) | | | 2 | | | | | | | | Resets (and delays) | POR, BOR, RESET Instruction, MCLR, WDT, Illegal Opcode, REPEAT Instruction, Hardware Traps, Configuration Word Mismatch (PWRT, OST, PLL Lock) | | | | | | | | | | Instruction Set | 76 Base Inst | tructions, Multipl | e Addressing N | Node Variations | | | | | | | Packages | 44-Pin QFI<br>48-Pin U | | 28-Pin<br>SPDIP/SSOP/SOIC/QFN | | | | | | | TABLE 1-5: PIC24FV16KM204 FAMILY PINOUT DESCRIPTION (CONTINUED) | | F | | | | | FV | | | | | | | | | |----------|----------------------------------|----------------------------------|---------------|------------------------|----------------|----------------------------------|----------------------------------|---------------|------------------------|----------------|-----|--------|-----------------------------|--| | | | I | Pin Numb | er | | | ı | in Numb | er | | | | | | | Function | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | I/O | Buffer | Description | | | OSCI | 7 | 9 | 6 | 30 | 33 | 7 | 9 | 6 | 30 | 33 | Ι | ANA | Primary Oscillator Input | | | OSCO | 8 | 10 | 7 | 31 | 34 | 8 | 10 | 7 | 31 | 34 | 0 | ANA | Primary Oscillator Output | | | PGEC1 | 5 | 5 | 2 | 22 | 24 | 5 | 5 | 2 | 22 | 24 | I/O | ST | ICSP Clock 1 | | | PGED1 | 4 | 4 | 1 | 21 | 23 | 4 | 4 | 1 | 21 | 23 | I/O | ST | ICSP Data 1 | | | PGEC2 | 2 | 22 | 19 | 9 | 10 | 2 | 22 | 19 | 9 | 10 | I/O | ST | ICSP Clock 2 | | | PGED2 | 3 | 21 | 18 | 8 | 9 | 3 | 21 | 18 | 8 | 9 | I/O | ST | ICSP Data 2 | | | PGEC3 | 10 | 15 | 12 | 42 | 46 | 10 | 15 | 12 | 42 | 46 | I/O | ST | ICSP Clock 3 | | | PGED3 | 9 | 14 | 11 | 41 | 45 | 9 | 14 | 11 | 41 | 45 | I/O | ST | ICSP Data 3 | | | PWRLCLK | 10 | 12 | 9 | 34 | 37 | 10 | 12 | 9 | 34 | 37 | I | ST | RTCC Power Line Clock Input | | | RA0 | 2 | 2 | 27 | 19 | 21 | 2 | 2 | 27 | 19 | 21 | I/O | ST | PORTA Pins | | | RA1 | 3 | 3 | 28 | 20 | 22 | 3 | 3 | 28 | 20 | 22 | I/O | ST | PORTA Pins | | | RA2 | 7 | 9 | 6 | 30 | 33 | 7 | 9 | 6 | 30 | 33 | I/O | ST | PORTA Pins | | | RA3 | 8 | 10 | 7 | 31 | 34 | 8 | 10 | 7 | 31 | 34 | I/O | ST | PORTA Pins | | | RA4 | 10 | 12 | 9 | 34 | 37 | 10 | 12 | 9 | 34 | 37 | I/O | ST | PORTA Pins | | | RA5 | 1 | 1 | 26 | 18 | 19 | 1 | 1 | 26 | 18 | 19 | I/O | ST | PORTA Pins | | | RA6 | 14 | 20 | 17 | 7 | 7 | _ | _ | _ | _ | _ | I/O | ST | PORTA Pins | | | RA7 | _ | 19 | 16 | 6 | 6 | _ | 19 | 16 | 6 | 6 | I/O | ST | PORTA Pins | | | RA8 | _ | _ | _ | 32 | 35 | _ | _ | _ | 32 | 35 | I/O | ST | PORTA Pins | | | RA9 | _ | 1 | _ | 35 | 38 | _ | _ | _ | 35 | 38 | I/O | ST | PORTA Pins | | | RA10 | _ | 1 | _ | 12 | 13 | _ | _ | _ | 12 | 13 | I/O | ST | PORTA Pins | | | RA11 | _ | 1 | _ | 13 | 14 | _ | _ | _ | 13 | 14 | I/O | ST | PORTA Pins | | | RB0 | 4 | 4 | 1 | 21 | 23 | 4 | 4 | 1 | 21 | 23 | I/O | ST | PORTB Pins | | | RB1 | 5 | 5 | 2 | 22 | 24 | 5 | 5 | 2 | 22 | 24 | I/O | ST | PORTB Pins | | | RB2 | 6 | 6 | 3 | 23 | 25 | 6 | 6 | 3 | 23 | 25 | I/O | ST | PORTB Pins | | | RB3 | _ | 7 | 4 | 24 | 26 | _ | 7 | 4 | 24 | 26 | I/O | ST | PORTB Pins | | | RB4 | 9 | 11 | 8 | 33 | 36 | 9 | 11 | 8 | 33 | 36 | I/O | ST | PORTB Pins | | | RB5 | _ | 14 | 11 | 41 | 45 | _ | 14 | 11 | 41 | 45 | I/O | ST | PORTB Pins | | | RB6 | _ | 15 | 12 | 42 | 46 | _ | 15 | 12 | 42 | 46 | I/O | ST | PORTB Pins | | | RB7 | 11 | 16 | 13 | 43 | 47 | 11 | 16 | 13 | 43 | 47 | I/O | ST | PORTB Pins | | | RB8 | 12 | 17 | 14 | 44 | 48 | 12 | 17 | 14 | 44 | 48 | I/O | ST | PORTB Pins | | **Legend:** ANA = Analog level input/output, ST = Schmitt Trigger input buffer, I<sup>2</sup>C™ = I<sup>2</sup>C/SMBus input buffer # 4.2.2 DATA MEMORY ORGANIZATION AND ALIGNMENT To maintain backward compatibility with PIC® devices and improve Data Space memory usage efficiency, the PIC24F instruction set supports both word and byte operations. As a consequence of byte accessibility, all EA calculations are internally scaled to step through word-aligned memory. For example, the core recognizes that Post-Modified Register Indirect Addressing mode [Ws++] will result in a value of Ws + 1 for byte operations and Ws + 2 for word operations. Data byte reads will read the complete word, which contains the byte, using the LSB of any EA to determine which byte to select. The selected byte is placed onto the LSB of the data path. That is, the data memory and the registers are organized as two parallel, byte-wide entities with shared (word) address decode, but separate write lines. Data byte writes only write to the corresponding side of the array or register, which matches the byte address. All word accesses must be aligned to an even address. Misaligned word data fetches are not supported, so care must be taken when mixing byte and word operations, or translating from 8-bit MCU code. If a misaligned read or write is attempted, an address error trap will be generated. If the error occurred on a read, the instruction underway is completed; if it occurred on a write, the instruction will be executed, but the write will not occur. In either case, a trap is then executed, allowing the system and/or user to examine the machine state prior to execution of the address Fault. All byte loads into any W register are loaded into the LSB; the MSB is not modified. A Sign-Extend (SE) instruction is provided to allow the users to translate 8-bit signed data to 16-bit signed values. Alternatively, for 16-bit unsigned data, users can clear the MSB of any W register by executing a Zero-Extend (ZE) instruction on the appropriate address. Although most instructions are capable of operating on word or byte data sizes, it should be noted that some instructions operate only on words. #### 4.2.3 NEAR DATA SPACE The 8-Kbyte area between 0000h and 1FFFh is referred to as the Near Data Space. Locations in this space are directly addressable via a 13-bit absolute address field within all memory direct instructions. The remainder of the Data Space is addressable indirectly. Additionally, the whole Data Space is addressable using MoV instructions, which support Memory Direct Addressing (MDA) with a 16-bit address field. For PIC24FV16KM204 family devices, the entire implemented data memory lies in Near Data Space (NDS). #### 4.2.4 SFR SPACE The first 2 Kbytes of the Near Data Space, from 0000h to 07FFh, are primarily occupied with Special Function Registers (SFRs). These are used by the PIC24F core and peripheral modules for controlling the operation of the device. SFRs are distributed among the modules that they control and are generally grouped together by that module. Much of the SFR space contains unused addresses; these are read as '0'. The SFR space, where the SFRs are actually implemented, is provided in Table 4-2. Each implemented area indicates a 32-byte region where at least one address is implemented as an SFR. A complete listing of implemented SFRs, including their addresses, is provided in Table 4-3 through Table 4-26. TABLE 4-2: IMPLEMENTED REGIONS OF SFR DATA SPACE | | SFR Space Address | | | | | | | | | | | | | |------|-------------------|-----------|-----------------|----------|-----------|------|------|-------|--|--|--|--|--| | | xx00 | xx20 | xx40 | xx60 | xx80 | xxA0 | xxC0 | xxE0 | | | | | | | 000h | | Core | | ICN | | | _ | | | | | | | | 100h | Timers | CLC | | | MCCP/SCCP | | | | | | | | | | 200h | MSSP | UART | Op Amp | DAC | I/O | | | | | | | | | | 300h | | A/D/C | CMTU | | _ | _ | _ | _ | | | | | | | 400h | _ | _ | _ | _ | _ | _ | _ | ANSEL | | | | | | | 500h | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | | 600h | _ | RTCC/Comp | _ | Band Gap | <u> </u> | | | | | | | | | | 700h | _ | _ | System/<br>HLVD | NVM/PMD | _ | _ | _ | _ | | | | | | **Legend:** — = No implemented SFRs in this block. | TABLE 4-5: | INTERRUPT CONTROLLER REGISTER MAP | | |------------|------------------------------------|--| | IADLL TJ. | INTERNO I CONTINUELLI NEGISTEN MAI | | | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|---------|---------|---------|--------|---------|---------|---------|--------|---------|---------|---------|---------|----------|----------|----------|---------------| | INTCON1 | 80h | NSTDIS | _ | _ | _ | _ | | _ | _ | _ | | _ | MATHERR | ADDRERR | STKERR | OSCFAIL | _ | 0000 | | INTCON2 | 82h | ALTIVT | DISI | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | INT2EP | INT1EP | INT0EP | 0000 | | IFS0 | 84h | NVMIF | _ | AD1IF | U1TXIF | U1RXIF | _ | _ | CCT2IF | CCT1IF | CCP4IF | CCP3IF | _ | T1IF | CCP2IF | CCP1IF | INT0IF | 0000 | | IFS1 | 86h | U2TXIF | U2RXIF | INT2IF | CCT4IF | CCT3IF | _ | _ | _ | _ | CCP5IF | _ | INT1IF | CNIF | CMIF | BCL1IF | SSP1IF | 0000 | | IFS2 | 88h | _ | _ | _ | _ | _ | _ | CCT5IF | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | IFS3 | 8Ah | _ | RTCIF | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | BCL2IF | SSP2IF | _ | 0000 | | IFS4 | 8Ch | DAC2IF | DAC1IF | CTMUIF | _ | _ | _ | _ | HLVDIF | _ | _ | _ | _ | _ | U2ERIF | U1ERIF | _ | 0000 | | IFS5 | 8Eh | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ULPWUIF | 0000 | | IFS6 | 90h | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLC2IF | CLC1IF | 0000 | | IEC0 | 94h | NVMIE | _ | AD1IE | U1TXIE | U1RXIE | _ | _ | CCT2IE | CCT1IE | CCP4IE | CCP3IE | _ | T1IE | CCP2IE | CCP1IE | INT0IE | 0000 | | IEC1 | 96h | U2TXIE | U2RXIE | INT2IE | CCT4IE | CCT3IE | _ | _ | _ | _ | CCP5IE | _ | INT1IE | CNIE | CMIE | BCL1IE | SSP1IE | 0000 | | IEC2 | 98h | _ | _ | _ | _ | _ | _ | CCT5IE | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | IEC3 | 9Ah | _ | RTCIE | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | BCL2IE | SSP2IE | _ | 0000 | | IEC4 | 9Ch | DAC2IE | DAC1IE | CTMUIE | _ | _ | _ | _ | HLVDIE | _ | _ | _ | _ | _ | U2ERIE | U1ERIE | _ | 0000 | | IEC5 | 9Eh | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ULPWUIE | 0000 | | IEC6 | A0h | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLC2IE | CLC1IE | 0000 | | IPC0 | A4h | _ | T1IP2 | T1IP1 | T1IP0 | _ | CCP2IP2 | CCP2IP1 | CCP2IP0 | _ | CCP1IP2 | CCP1IP1 | CCP1IP0 | _ | INT0IP2 | INT0IP1 | INT0IP0 | 4444 | | IPC1 | A6h | _ | CCT1IP2 | CCT1IP1 | CCT1IP0 | _ | CCP4IP2 | CCP4IP1 | CCP4IP0 | _ | CCP3IP2 | CCP3IP1 | CCP3IP0 | _ | _ | _ | _ | 4440 | | IPC2 | A8h | _ | U1RXIP2 | U1RXIP1 | U1RXIP0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | CCT2IP2 | CCT2IP1 | CCT2IP0 | 4004 | | IPC3 | AAh | _ | NVMIP2 | NVMIP1 | NVMIP0 | _ | _ | _ | _ | _ | AD1IP2 | AD1IP1 | AD1IP0 | _ | U1TXIP2 | U1TXIP1 | U1TXIP0 | 4044 | | IPC4 | ACh | _ | CNIP2 | CNIP1 | CNIP0 | _ | CMIP2 | CMIP1 | CMIP0 | _ | BCL1IP2 | BCL1IP1 | BCL1IP0 | _ | SSP1IP2 | SSP1IP1 | SSP1IP0 | 4444 | | IPC5 | AEh | _ | _ | _ | _ | _ | CCP5IP2 | CCP5IP1 | CCP5IP0 | _ | _ | _ | _ | _ | INT1IP2 | INT1IP1 | INT1IP0 | 0404 | | IPC6 | B0h | _ | CCT3IP2 | CCT3IP1 | CCT3IP0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 4000 | | IPC7 | B2h | _ | U2TXIP2 | U2TXIP1 | U2TXIP0 | _ | U2RXIP2 | U2RXIP1 | U2RXIP0 | _ | INT2IP2 | INT2IP1 | INT2IP0 | _ | CCT4IP2 | CCT4IP1 | CCT4IP0 | 4444 | | IPC10 | B8h | _ | _ | _ | _ | _ | _ | _ | _ | _ | CCT5IP2 | CCT5IP1 | CCT5IP0 | _ | _ | _ | _ | 0040 | | IPC12 | BCh | _ | _ | _ | _ | _ | BCL2IP2 | BCL2IP1 | BCL2IP0 | _ | SSP2IP2 | SSP2IP1 | SSP2IP0 | _ | _ | _ | _ | 0440 | | IPC15 | C2h | _ | _ | _ | _ | _ | RTCIP2 | RTCIP1 | RTCIP0 | _ | _ | _ | _ | _ | _ | _ | _ | 0400 | | IPC16 | C4h | _ | _ | _ | _ | _ | U2ERIP2 | U2ERIP1 | U2ERIP0 | _ | U1ERIP2 | U1ERIP1 | U1ERIP0 | _ | _ | _ | _ | 0440 | | IPC18 | C8h | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | HLVDIP2 | HLVDIP1 | HLVDIP0 | 0004 | | IPC19 | CAh | _ | DAC2IP2 | DAC2IP1 | DAC2IP0 | _ | DAC1IP2 | DAC1IP1 | DAC1IP0 | _ | CTMUIP2 | CTMUIP1 | CTMUIP0 | _ | _ | _ | _ | 4440 | | IPC20 | CCh | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ULPWUIP2 | ULPWUIP1 | ULPWUIP0 | 0004 | | IPC24 | D4h | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLC2IP2 | CLC2IP1 | CLC2IP0 | _ | CLC1IP2 | CLC1IP1 | CLC1IP0 | 0044 | | INTTREG | E0h | CPUIRQ | _ | VHOLD | _ | ILR3 | ILR2 | ILR1 | ILR0 | _ | VECNUM6 | VECNUM5 | VECNUM4 | VECNUM3 | VECNUM2 | VECNUM1 | VECNUM0 | 0000 | **Legend:** x = unknown, u = unchanged, --= unimplemented, q = value depends on condition, r = reserved. # 4.3.3 READING DATA FROM PROGRAM MEMORY USING PROGRAM SPACE VISIBILITY The upper 32 Kbytes of Data Space may optionally be mapped into a 16K word page of the program space. This provides transparent access of stored constant data from the Data Space without the need to use special instructions (i.e., TBLRDL/H). Program space access through the Data Space occurs if the MSb of the Data Space, EA, is '1' and PSV is enabled by setting the PSV bit in the CPU Control (CORCON<2>) register. The location of the program memory space to be mapped into the Data Space is determined by the Program Space Visibility Page Address register (PSVPAG). This 8-bit register defines any one of 256 possible pages of 16K words in program space. In effect, PSVPAG functions as the upper 8 bits of the program memory address, with the 15 bits of the EA functioning as the lower bits. By incrementing the PC by 2 for each program memory word, the lower 15 bits of Data Space addresses directly map to the lower 15 bits in the corresponding program space addresses. Data reads from this area add an additional cycle to the instruction being executed, since two program memory fetches are required. Although each Data Space address, 8000h and higher, maps directly into a corresponding program memory address (see Figure 4-7), only the lower 16 bits of the 24-bit program word are used to contain the data. The upper 8 bits of any program space locations used as data should be programmed with '1111 1111' or '0000 0000' to force a NOP. This prevents possible issues should the area of code ever be accidentally executed. **Note:** PSV access is temporarily disabled during Table Reads/Writes. For operations that use PSV and are executed outside a REPEAT loop, the MOV and MOV.D instructions will require one instruction cycle in addition to the specified execution time. All other instructions will require two instruction cycles in addition to the specified execution time. For operations that use PSV, which are executed inside a REPEAT loop, there will be some instances that require two instruction cycles in addition to the specified execution time of the instruction: - · Execution in the first iteration - · Execution in the last iteration - Execution prior to exiting the loop due to an interrupt - Execution upon re-entering the loop after an interrupt is serviced Any other iteration of the REPEAT loop will allow the instruction accessing data, using PSV, to execute in a single cycle. #### 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 on Resets, refer to the "PIC24F Family Reference Manual", "Reset with Programmable Brown-out Reset" (DS39728). 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: Pin Reset SWR: RESET Instruction · WDTR: Watchdog Timer Reset · BOR: Brown-out Reset LPBOR: Low-Power BOR • TRAPR: Trap Conflict Reset IOPUWR: Illegal Opcode ResetUWR: Uninitialized W Register Reset A simplified block discreme of the Deast made 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 Power-on Reset (POR) and unchanged by all other Resets. Note: Refer to the specific peripheral or **Section 3.0 "CPU"** of this data sheet 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 Power-on Reset will clear all bits except for the BOR and POR bits (RCON<1:0>) 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 (WDT) and device power-saving states. The function of these bits is discussed in other sections of this manual. Note: The status bits in the RCON register should be cleared after they are read so that the next RCON register value after a device Reset will be meaningful. FIGURE 7-1: RESET SYSTEM BLOCK DIAGRAM #### REGISTER 8-1: SR: ALU STATUS REGISTER | U-0 R-0, HSC | |--------|-----|-----|-----|-----|-----|-----|-------------------| | _ | _ | _ | _ | _ | _ | _ | DC <sup>(1)</sup> | | bit 15 | | | | | | | bit 8 | | R/W-0, HSC | R/W-0, HSC | R/W-0, HSC | R-0, HSC | R/W-0, HSC | R/W-0, HSC | R/W-0, HSC | R/W-0, HSC | |-----------------------|-----------------------|-----------------------|-------------------|------------------|-------------------|------------------|------------------| | IPL2 <sup>(2,3)</sup> | IPL1 <sup>(2,3)</sup> | IPL0 <sup>(2,3)</sup> | RA <sup>(1)</sup> | N <sup>(1)</sup> | OV <sup>(1)</sup> | Z <sup>(1)</sup> | C <sup>(1)</sup> | | bit 7 | | | | | | | bit 0 | | Legend: | HSC = Hardware Settable/0 | HSC = Hardware Settable/Clearable bit | | | | | | | | | |-------------------|---------------------------|---------------------------------------|--------------------|--|--|--|--|--|--|--| | R = Readable bit | W = Writable bit | U = Unimplemented bit, read as '0' | | | | | | | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | | | | | | | bit 15-9 Unimplemented: Read as '0' bit 7-5 IPL<2:0>: CPU Interrupt Priority Level Status bits<sup>(2,3)</sup> 111 = CPU Interrupt Priority Level is 7 (15); user interrupts are disabled 110 = CPU Interrupt Priority Level is 6 (14) 101 = CPU Interrupt Priority Level is 5 (13) 100 = CPU Interrupt Priority Level is 4 (12) 011 = CPU Interrupt Priority Level is 3 (11) 010 = CPU Interrupt Priority Level is 2 (10) 001 = CPU Interrupt Priority Level is 1 (9) 000 = CPU Interrupt Priority Level is 0 (8) **Note 1:** See Register 3-1 for the description of these bits, which are not dedicated to interrupt control functions. 2: The IPL<2:0> bits are concatenated with the IPL3 bit (CORCON<3>) to form the CPU Interrupt Priority Level. The value in parentheses indicates the Interrupt Priority Level if IPL3 = 1. 3: The IPLx Status bits are read-only when NSTDIS (INTCON1<15>) = 1. Note: Bit 8 and bits 4 through 0 are described in Section 3.0 "CPU". #### REGISTER 8-4: INTCON2: INTERRUPT CONTROL REGISTER 2 | R/W-0 | R-0, HSC | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | |--------|----------|-----|-----|-----|-----|-----|-------| | ALTIVT | DISI | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-----|--------|--------|--------| | _ | _ | _ | _ | _ | INT2EP | INT1EP | INT0EP | | bit 7 | | | | | | | bit 0 | **Legend:** HSC = Hardware Settable/Clearable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 ALTIVT: Enable Alternate Interrupt Vector Table bit 1 = Uses Alternate Interrupt Vector Table (AIVT) 0 = Uses standard (default) Interrupt Vector Table (IVT) bit 14 DISI: DISI Instruction Status bit 1 = DISI instruction is active 0 = DISI instruction is not active bit 13-3 **Unimplemented:** Read as '0' bit 2 INT2EP: External Interrupt 2 Edge Detect Polarity Select bit 1 = Interrupt is on the negative edge0 = Interrupt is on the positive edge bit 1 INT1EP: External Interrupt 1 Edge Detect Polarity Select bit 1 = Interrupt is on the negative edge0 = Interrupt is on the positive edge bit 0 INTOEP: External Interrupt 0 Edge Detect Polarity Select bit 1 = Interrupt is on the negative edge0 = Interrupt is on the positive edge #### REGISTER 8-6: IFS1: INTERRUPT FLAG STATUS REGISTER 1 | R/W-0, HS | R/W-0, HS | R/W-0, HS | R/W-0, HS | R/W-0, HS | U-0 | U-0 | U-0 | |-----------|-----------|-----------|-----------|-----------|-----|-----|-------| | U2TXIF | U2RXIF | INT2IF | CCT4IF | CCT3IF | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-0, HS | U-0 | R/W-0, HS | R/W-0, HS | R/W-0, HS | R/W-0, HS | R/W-0, HS | |-------|-----------|-----|-----------|-----------|-----------|-----------|-----------| | _ | CCP5IF | _ | INT1IF | CNIF | CMIF | BCL1IF | SSP1IF | | bit 7 | | | | | | | bit 0 | **Legend:** HS = Hardware Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 U2TXIF: UART2 Transmitter Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 14 U2RXIF: UART2 Receiver Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 13 INT2IF: External Interrupt 2 Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 12 CCT4IF: Capture/Compare 4 Timer Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 11 CCT3IF: Capture/Compare 3 Timer Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 10-7 **Unimplemented:** Read as '0' bit 6 CCP5IF: Capture/Compare 5 Event Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 5 **Unimplemented:** Read as '0' bit 4 **INT1IF:** External Interrupt 1 Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 3 CNIF: Input Change Notification Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 2 **CMIF:** Comparator Interrupt Flag Status Bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 1 **BCL1IF:** MSSP1 I<sup>2</sup>C™ Bus Collision Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 0 SI2C1IF: MSSP1 SPI/I<sup>2</sup>C Event Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred #### REGISTER 8-16: IEC4: INTERRUPT ENABLE CONTROL REGISTER 4 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | |--------|--------|--------|-----|-----|-----|-----|--------| | DAC2IE | DAC1IE | CTMUIE | _ | _ | _ | _ | HLVDIE | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | |-------|-----|-----|-----|-----|--------|--------|-------| | _ | _ | _ | _ | _ | U2ERIE | U1ERIE | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 DAC2IE: Digital-to-Analog Converter 2 Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 14 DAC1IE: Digital-to-Analog Converter 1 Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 13 **CTMUIE:** CTMU Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 12-9 **Unimplemented:** Read as '0' bit 8 **HLVDIE**: High/Low-Voltage Detect Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 7-3 **Unimplemented:** Read as '0' bit 2 U2ERIE: UART2 Error Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 1 **U1ERIE:** UART1 Error Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 0 **Unimplemented:** Read as '0' NOTES: ### REGISTER 16-2: RTCPWC: RTCC CONFIGURATION REGISTER 2<sup>(1)</sup> | R/W-0 |--------|--------|---------|---------|------------------------|------------------------|---------|---------| | PWCEN | PWCPOL | PWCCPRE | PWCSPRE | RTCCLK1 <sup>(2)</sup> | RTCCLK0 <sup>(2)</sup> | RTCOUT1 | RTCOUT0 | | bit 15 | | | | | | | bit 8 | | U-0 |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **PWCEN:** Power Control Enable bit 1 = Power control is enabled 0 = Power control is disabled bit 14 **PWCPOL:** Power Control Polarity bit 1 = Power control output is active-high 0 = Power control output is active-low bit 13 PWCCPRE: Power Control/Stability Prescaler bits 1 = PWC stability window clock is divide-by-2 of source RTCC clock 0 = PWC stability window clock is divide-by-1 of source RTCC clock bit 12 **PWCSPRE:** Power Control Sample Prescaler bits 1 = PWC sample window clock is divide-by-2 of source RTCC clock 0 = PWC sample window clock is divide-by-1 of source RTCC clock bit 11-10 RTCCLK<1:0>: RTCC Clock Select bits(2) Determines the source of the internal RTCC clock, which is used for all RTCC timer operations. 00 = External Secondary Oscillator (SOSC) 01 = Internal LPRC Oscillator 10 = External power line source - 50 Hz 11 = External power line source - 60 Hz bit 9-8 RTCOUT<1:0>: RTCC Output Select bits Determines the source of the RTCC pin output. 00 = RTCC alarm pulse 01 = RTCC seconds clock 10 = RTCC clock 11 = Power control bit 7-0 **Unimplemented:** Read as '0' **Note 1:** The RTCPWC register is only affected by a POR. **2:** When a new value is written to these register bits, the Seconds Value register should also be written to properly reset the clock prescalers in the RTCC. #### REGISTER 16-3: ALCFGRPT: ALARM CONFIGURATION REGISTER | R/W-0 |--------|-------|--------|--------|--------|--------|----------|----------| | ALRMEN | CHIME | AMASK3 | AMASK2 | AMASK1 | AMASK0 | ALRMPTR1 | ALRMPTR0 | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|-------|-------|-------|-------| | ARPT7 | ARPT6 | ARPT5 | ARPT4 | ARPT3 | ARPT2 | ARPT1 | ARPT0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **ALRMEN:** Alarm Enable bit 1 = Alarm is enabled (cleared automatically after an alarm event whenever ARPT<7:0> = 00h and CHIME = 0) 0 = Alarm is disabled bit 14 CHIME: Chime Enable bit 1 = Chime is enabled; ARPT<7:0> bits are allowed to roll over from 00h to FFh 0 = Chime is disabled; ARPT<7:0> bits stop once they reach 00h bit 13-10 AMASK<3:0>: Alarm Mask Configuration bits 0000 = Every half second 0001 = Every second 0010 = Every 10 seconds 0011 = Every minute 0100 = Every 10 minutes 0101 = Every hour 0110 = Once a day 0111 = Once a week 1000 = Once a month 1001 = Once a year (except when configured for February 29<sup>th</sup>, once every 4 years) 101x = Reserved – do not use 11xx = Reserved – do not use bit 9-8 **ALRMPTR<1:0>:** Alarm Value Register Window Pointer bits Points to the corresponding Alarm Value registers when reading the ALRMVALH and ALRMVALL registers. The ALRMPTR<1:0> value decrements on every read or write of ALRMVALH until it reaches '00'. THE ALIXWIT TIX 1.02 value decrements on every read of write of ALIXWIA ALRMVAL<15:8>: 00 = ALRMMIN 01 = ALRMWD 10 = ALRMMNTH 11 = Unimplemented ALRMVAL<7:0>: 00 = ALRMSEC 01 = ALRMHR 10 = ALRMDAY 11 = Unimplemented bit 7-0 ARPT<7:0>: Alarm Repeat Counter Value bits 11111111 = Alarm will repeat 255 more times . 00000000 = Alarm will not repeat The counter decrements on any alarm event; it is prevented from rolling over from 00h to FFh unless CHIME = 1. ### 22.0 COMPARATOR MODULE 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 on the Comparator module, refer to the "PIC24F Family Reference Manual", "Scalable Comparator Module" (DS39734). The comparator module provides three dual input comparators. The inputs to the comparator can be configured to use any one of four external analog inputs, as well as a voltage reference input from either the Internal Band Gap Buffer 1 (BGBUF1) or the comparator voltage reference generator. The comparator outputs may be directly connected to the CxOUT pins. When the respective COE bit equals '1', the I/O pad logic makes the unsynchronized output of the comparator available on the pin. A simplified block diagram of the module is shown in Figure 22-1. Diagrams of the possible individual comparator configurations are shown in Figure 22-2. Each comparator has its own control register, CMxCON (Register 22-1), for enabling and configuring its operation. The output and event status of all three comparators is provided in the CMSTAT register (Register 22-2). FIGURE 22-1: COMPARATOR x MODULE BLOCK DIAGRAM #### TABLE 27-4: HIGH/LOW-VOLTAGE DETECT CHARACTERISTICS Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for Extended | Param<br>No. | Symbol | Chara | cteristic | Min | Тур | Max | Units | Conditions | |--------------|--------|-----------------|----------------------------------|------|-----|------|-------|------------| | DC18 | VHLVD | HLVD Voltage on | HLVDL<3:0> = 0000 <sup>(2)</sup> | _ | _ | 1.90 | V | | | | | VDD Transition | HLVDL<3:0> = 0001 | 1.88 | | 2.13 | V | | | | | | HLVDL<3:0> = 0010 | 2.09 | _ | 2.35 | V | | | | | | HLVDL<3:0> = 0011 | 2.25 | | 2.53 | V | | | | | | HLVDL<3:0> = 0100 | 2.35 | | 2.62 | V | | | | | | HLVDL<3:0> = 0101 | 2.55 | _ | 2.84 | V | | | | | | HLVDL<3:0> = 0110 | 2.80 | | 3.10 | V | | | | | | HLVDL<3:0> = 0111 | 2.95 | | 3.25 | V | | | | | | HLVDL<3:0> = 1000 | 3.09 | _ | 3.41 | V | | | | | | HLVDL<3:0> = 1001 | 3.27 | _ | 3.59 | V | | | | | | HLVDL<3:0> = 1010 <sup>(1)</sup> | 3.46 | | 3.79 | V | | | | | | HLVDL<3:0> = 1011 <sup>(1)</sup> | 3.62 | _ | 4.01 | V | | | | | | HLVDL<3:0> = 1100 <sup>(1)</sup> | 3.91 | | 4.26 | V | | | | | | HLVDL<3:0> = 1101 <sup>(1)</sup> | 4.18 | | 4.55 | V | | | | | | HLVDL<3:0> = 1110 <sup>(1)</sup> | 4.49 | _ | 4.87 | V | | Note 1: These trip points should not be used on PIC24FXXKMXXX devices. 2: This trip point should not be used on PIC24FVXXKMXXX devices. #### TABLE 27-5: BOR TRIP POINTS Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for Extended | Param<br>No. | Sym | Characteristic | | | Тур | Max | Units | Conditions | |--------------|-----|--------------------|----------------|------|------|------|-------|--------------------------| | DC15 | | BOR Hysteresis | BOR Hysteresis | | 5 | _ | mV | | | DC19 | | BOR Voltage on VDD | BORV<1:0> = 00 | - | _ | _ | _ | Valid for LPBOR (Note 1) | | | | Transition | BORV<1:0> = 01 | 2.90 | 3 | 3.38 | V | | | | | | BORV<1:0> = 10 | 2.53 | 2.7 | 3.07 | V | | | | | BORV<1:0> = 11 | | 1.75 | 1.85 | 2.05 | V | (Note 2) | | | | | BORV<1:0> = 11 | 1.95 | 2.05 | 2.16 | V | (Note 3) | Note 1: LPBOR re-arms the POR circuit but does not cause a BOR. 2: This is valid for PIC24F (3.3V) devices. 3: This is valid for PIC24FV (5V) devices. ### FIGURE 27-18: MSSPx I<sup>2</sup>C™ BUS DATA TIMING ### TABLE 27-36: I<sup>2</sup>C™ BUS DATA REQUIREMENTS (MASTER MODE) | Param.<br>No. | Symbol | Charac | teristic | Min | Max | Units | Conditions | |---------------|---------|------------------|--------------|------------------|------|-------|-------------------------------------| | 100 | THIGH | Clock High Time | 100 kHz mode | 2(Tosc)(BRG + 1) | | | | | | | | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | 101 | TLOW | Clock Low Time | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | | | | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | 102 | Tr | SDAx and SCLx | 100 kHz mode | _ | 1000 | ns | CB is specified to be from | | | | Rise Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | 10 to 400 pF | | 103 | TF | SDAx and SCLx | 100 kHz mode | _ | 300 | ns | CB is specified to be from | | | | Fall Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | 10 to 400 pF | | 90 | Tsu:sta | Start Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | Only relevant for Repeated | | | | Setup Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | Start condition | | 91 | THD:STA | Start Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | After this period, the first | | | | Hold Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | | clock pulse is generated | | 106 | THD:DAT | Data Input | 100 kHz mode | 0 | _ | ns | | | | | Hold Time | 400 kHz mode | 0 | 0.9 | μS | | | 107 | TSU:DAT | Data Input | 100 kHz mode | 250 | _ | ns | (Note 1) | | | | Setup Time | 400 kHz mode | 100 | _ | ns | | | 92 | Tsu:sto | Stop Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | | | Setup Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | 109 | TAA | Output Valid | 100 kHz mode | _ | 3500 | ns | | | | | from Clock | 400 kHz mode | _ | 1000 | ns | | | 110 | TBUF | Bus Free Time | 100 kHz mode | 4.7 | _ | μS | Time the bus must be free | | | | | 400 kHz mode | 1.3 | _ | μS | before a new transmission can start | | D102 | Св | Bus Capacitive L | oading | | 400 | pF | | Note 1: A Fast mode I²C bus device can be used in a Standard mode I²C bus system, but Parameter 107 ≥ 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCLx signal. If such a device does stretch the LOW period of the SCLx signal, it must output the next data bit to the SDAx line, Parameter 102 + Parameter 107 = 1000 + 250 = 1250 ns (for 100 kHz mode), before the SCLx line is released. ### 28-Lead Skinny Plastic Dual In-Line (SP) - 300 mil Body [SPDIP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | | INCHES | | | | |----------------------------|----------|----------|--------|-------|--|--| | Dimensio | n Limits | MIN | NOM | MAX | | | | Number of Pins | N | 28 | | | | | | Pitch | е | .100 BSC | | | | | | Top to Seating Plane | Α | _ | - | .200 | | | | Molded Package Thickness | A2 | .120 | .135 | .150 | | | | Base to Seating Plane | A1 | .015 | _ | _ | | | | Shoulder to Shoulder Width | Е | .290 | .310 | .335 | | | | Molded Package Width | E1 | .240 | .285 | .295 | | | | Overall Length | D | 1.345 | 1.365 | 1.400 | | | | Tip to Seating Plane | L | .110 | .130 | .150 | | | | Lead Thickness | С | .008 | .010 | .015 | | | | Upper Lead Width | b1 | .040 | .050 | .070 | | | | Lower Lead Width | b | .014 | .018 | .022 | | | | Overall Row Spacing § | eB | _ | - | .430 | | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic. - 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side. - 4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing C04-070B 48-Lead Ultra Thin Plastic Quad Flat, No Lead Package (MV) - 6x6 mm Body [UQFN] With 0.40 mm Contact Length **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging RECOMMENDED LAND PATTERN | Units | | MILLIMETERS | | | | |----------------------------|----|-------------|------|------|--| | Dimension Limits | | MIN | NOM | MAX | | | Contact Pitch | E | 0.40 BSC | | | | | Optional Center Pad Width | W2 | | | 4.45 | | | Optional Center Pad Length | T2 | | | 4.45 | | | Contact Pad Spacing | C1 | | 6.00 | | | | Contact Pad Spacing | C2 | | 6.00 | | | | Contact Pad Width (X28) | X1 | | | 0.20 | | | Contact Pad Length (X28) | Y1 | | | 0.80 | | | Distance Between Pads | G | 0.20 | | | | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2153A