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 | MIPS32® M4K™ | | Core Size | 32-Bit Single-Core | | Speed | 40MHz | | Connectivity | CANbus, I <sup>2</sup> C, IrDA, LINbus, PMP, SPI, UART/USART, USB OTG | | eripherals | Brown-out Detect/Reset, DMA, I <sup>2</sup> S, POR, PWM, WDT | | lumber of I/O | 81 | | rogram Memory Size | 512KB (512K x 8) | | rogram Memory Type | FLASH | | EPROM Size | - | | AM Size | 64K x 8 | | oltage - Supply (Vcc/Vdd) | 2.3V ~ 3.6V | | ata Converters | A/D 48x10b | | scillator Type | Internal | | perating Temperature | -40°C ~ 85°C (TA) | | ounting Type | Surface Mount | | ackage / Case | 100-TQFP | | upplier Device Package | 100-TQFP (12x12) | | urchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic32mx570f512l-i-pt | REGISTER 9-1: DMACON: DMA CONTROLLER CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|------------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | | 15:8 | ON <sup>(1)</sup> | _ | _ | SUSPEND | DMABUSY <sup>(1)</sup> | _ | _ | _ | | 7.0 | U-0 | 7: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 31-16 Unimplemented: Read as '0' bit 15 ON: DMA On bit<sup>(1)</sup> 1 = DMA module is enabled0 = DMA module is disabled bit 14-13 **Unimplemented:** Read as '0' bit 12 **SUSPEND:** DMA Suspend bit 1 = DMA transfers are suspended to allow CPU uninterrupted access to data bus 0 = DMA operates normally bit 11 **DMABUSY:** DMA Module Busy bit<sup>(1)</sup> 1 = DMA module is active 0 = DMA module is disabled and not actively transferring data bit 10-0 Unimplemented: Read as '0' **Note 1:** When using 1:1 PBCLK divisor, the user's software should not read/write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit. ### REGISTER 9-9: DCHxINT: DMA CHANNEL 'x' INTERRUPT CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | | _ | _ | - | _ | _ | _ | _ | | 00.40 | R/W-0 | 23:16 | CHSDIE | CHSHIE | CHDDIE | CHDHIE | CHBCIE | CHCCIE | CHTAIE | CHERIE | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R/W-0 | 7:0 | CHSDIF | CHSHIF | CHDDIF | CHDHIF | CHBCIF | CHCCIF | CHTAIF | CHERIF | 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 31-24 Unimplemented: Read as '0' bit 23 CHSDIE: Channel Source Done Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 22 CHSHIE: Channel Source Half Empty Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 21 **CHDDIE:** Channel Destination Done Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 20 **CHDHIE:** Channel Destination Half Full Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 19 CHBCIE: Channel Block Transfer Complete Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 18 CHCCIE: Channel Cell Transfer Complete Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 17 CHTAIE: Channel Transfer Abort Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 16 CHERIE: Channel Address Error Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 15-8 Unimplemented: Read as '0' bit 7 CHSDIF: Channel Source Done Interrupt Flag bit 1 = Channel Source Pointer has reached end of source (CHSPTR = CHSSIZ) 0 = No interrupt is pending bit 6 CHSHIF: Channel Source Half Empty Interrupt Flag bit 1 = Channel Source Pointer has reached midpoint of source (CHSPTR = CHSSIZ/2) 0 = No interrupt is pending bit 5 CHDDIF: Channel Destination Done Interrupt Flag bit 1 = Channel Destination Pointer has reached end of destination (CHDPTR = CHDSIZ) 0 = No interrupt is pending #### REGISTER 9-16: DCHxCSIZ: DMA CHANNEL 'x' CELL-SIZE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--| | 31:24 | U-0 | | | | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | 22:46 | U-0 | | | | 23:16 | _ | _ | - | _ | _ | _ | _ | _ | | | | | 45.0 | R/W-0 | | | | 15:8 | CHCSIZ<15:8> | | | | | | | | | | | | 7.0 | R/W-0 | | | | 7:0 | | | | CHCSIZ | <7: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 31-16 Unimplemented: Read as '0' bit 15-0 CHCSIZ<15:0>: Channel Cell-Size bits 111111111111111 = 65,535 bytes transferred on an event : • 0000000000000010 = 2 bytes transferred on an event 0000000000000001= 1 byte transferred on an event 000000000000000 = 65,536 bytes transferred on an event ### REGISTER 9-17: DCHxCPTR: DMA CHANNEL 'x' CELL POINTER REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | _ | _ | 1 | _ | _ | _ | | 23:16 | U-0 | | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R-0 | 15:8 | | | | CHCPTR | <15:8> | | | | | 7:0 | R-0 | 7:0 | | • | • | CHCPTF | R<7: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 31-16 Unimplemented: Read as '0' bit 15-0 CHCPTR<7:0>: Channel Cell Progress Pointer bits 111111111111111 = 65,535 bytes have been transferred since the last event • $\begin{array}{l} \tt 000000000000001 = 1 \ byte \ has \ been \ transferred \ since \ the \ last \ event \\ \tt 0000000000000000 = 0 \ bytes \ have \ been \ transferred \ since \ the \ last \ event \\ \end{array}$ **Note:** When in Pattern Detect mode, this register is reset on a pattern detect. #### REGISTER 10-18: U1BDTP2: USB BDT PAGE 2 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--| | 31:24 | U-0 | | | | | | 31.24 | - | 1 | - | 1 | 1 | - | - | - | | | | | | | 22:46 | U-0 | | | | | | 23:16 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | 15:8 | U-0 | | | | | | 15.6 | _ | - | - | - | 1 | _ | - | - | | | | | | | 7:0 | R/W-0 | | | | | | 7:0 | BDTPTRH<23:16> | | | | | | | | | | | | | 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 31-8 Unimplemented: Read as '0' bit 7-0 BDTPTRH<23:16>: BDT Base Address bits This 8-bit value provides address bits 23 through 16 of the BDT base address, which defines the starting location of the BDT in system memory. The 32-bit BDT base address is 512-byte aligned. ### REGISTER 10-19: U1BDTP3: USB BDT PAGE 3 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | - | _ | 1 | - | - | - | - | 1 | | 23:16 | U-0 | 23.10 | _ | _ | - | _ | - | - | _ | 1 | | 15:8 | U-0 | 15.6 | _ | _ | - | _ | - | - | _ | 1 | | 7:0 | R/W-0 | 7.0 | | | | BDTPTR | U<31:24> | | | | 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 31-8 Unimplemented: Read as '0' bit 7-0 BDTPTRU<31:24>: BDT Base Address bits This 8-bit value provides address bits 31 through 24 of the BDT base address, defines the starting location of the BDT in system manager. of the BDT in system memory. The 32-bit BDT base address is 512-byte aligned. #### REGISTER 10-21: U1EP0-U1EP15: USB ENDPOINT CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | - | _ | - | - | 1 | - | - | - | | 23:16 | U-0 | 23.10 | - | _ | - | | - | - | - | - | | 15:8 | U-0 | 15.6 | _ | _ | _ | _ | _ | _ | _ | _ | | 7:0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7.0 | LSPD | RETRYDIS | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 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 31-8 Unimplemented: Read as '0' bit 7 LSPD: Low-Speed Direct Connection Enable bit (Host mode and U1EP0 only) 1 = Direct connection to a low-speed device enabled 0 = Direct connection to a low-speed device disabled; hub required with PRE\_PID bit 6 RETRYDIS: Retry Disable bit (Host mode and U1EP0 only) 1 = Retry NAKed transactions disabled 0 = Retry NAKed transactions enabled; retry done in hardware bit 5 **Unimplemented:** Read as '0' bit 4 **EPCONDIS:** Bidirectional Endpoint Control bit If EPTXEN = 1 and EPRXEN = 1: 1 = Disable Endpoint n from Control transfers; only TX and RX transfers allowed 0 = Enable Endpoint n for Control (SETUP) transfers, TX and RX transfers also allowed Otherwise, this bit is ignored. bit 3 EPRXEN: Endpoint Receive Enable bit 1 = Endpoint n receive enabled 0 = Endpoint n receive disabled bit 2 **EPTXEN:** Endpoint Transmit Enable bit 1 = Endpoint n transmit enabled 0 = Endpoint n transmit disabled bit 1 EPSTALL: Endpoint Stall Status bit 1 = Endpoint n was stalled 0 = Endpoint n was not stalled bit 0 EPHSHK: Endpoint Handshake Enable bit 1 = Endpoint Handshake enabled 0 = Endpoint Handshake disabled (typically used for isochronous endpoints) TABLE 11-12: PORTF REGISTER MAP FOR PIC32MX230F128L, PIC32MX530F128L, PIC32MX250F256L, PIC32MX570F512L, AND PIC32MX570F512L DEVICES ONLY | ess | | Bits | | | | | | | | | | | | | | | | | | |-----------------------------|---------------------------------|-----------|-------|-------|---------------|---------------|-------|-------|------|--------------|------|------|--------------|--------------|--------------|--------------|--------------|--------------|---------------| | Virtual Address<br>(BF88_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 6500 | ANSELF | 31:16 | | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0300 | ANOLLI | 15:0 | _ | - | ANSELE13 | ANSELE12 | _ | _ | _ | ANSELE8 | _ | - | _ | - | - | ANSELE2 | ANSELE1 | ANSELE0 | 3107 | | 6510 | TRISF | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0010 | 114101 | 15:0 | _ | _ | TRISF13 | TRISF12 | _ | _ | _ | TRISF8 | _ | _ | TRISF5 | TRISF4 | TRISF3 | TRISF2 | TRISF1 | TRISF0 | 313F | | 6520 | PORTF | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | 1 01(11 | 15:0 | _ | _ | RF13 | RF12 | _ | _ | _ | RF8 | _ | _ | RF5 | RF4 | RF3 | RF2 | RF1 | RF0 | xxxx | | 6530 | LATF | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | L/ (11 | 15:0 | _ | _ | LATF13 | LATF12 | _ | _ | _ | LATF8 | _ | _ | LATF5 | LATF4 | LATF3 | LATF2 | LATF1 | LATF0 | xxxx | | 6540 | ODCF | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0040 | ODGI | 15:0 | _ | - | ODCF13 | ODCF12 | _ | _ | _ | ODCF8 | _ | - | ODCF5 | ODCF4 | ODCF3 | ODCF2 | ODCF1 | ODCF0 | 0000 | | 6550 | CNPUF | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | OIVI OI | 15:0 | _ | _ | CNPUF13 | CNPUF12 | _ | _ | _ | CNPUF8 | _ | _ | CNPUF5 | CNPUF4 | CNPDF3 | CNPUF2 | CNPUF1 | CNPUF0 | 0000 | | 6560 | CNPDF | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | OIVI DI | 15:0 | _ | _ | CNPDF13 | CNPDF12 | _ | _ | _ | CNPDF8 | _ | _ | CNPDF5 | CNPFF4 | CNPDF3 | CNPDF2 | CNPDF1 | CNPDF0 | 0000 | | 6570 | CNCONF | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0070 | ONOON | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 6580 | CNENF | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | ONLIN | 15:0 | _ | - | CNIEF13 | CNIEF12 | _ | _ | _ | CNIEF8 | _ | - | CNIEF5 | CNIEF4 | CNIEF3 | CNIEF2 | CNIEF1 | CNIEF0 | 0000 | | | | 31:16 | | - | _ | | _ | _ | | _ | | - | _ | - | | _ | _ | - | 0000 | | 6590 | CNSTATF | 15:0 | _ | _ | CN<br>STATF13 | CN<br>STATF12 | _ | _ | _ | CN<br>STATF8 | _ | _ | CN<br>STATF5 | CN<br>STATF4 | CN<br>STATF3 | CN<br>STATF2 | CN<br>STATF1 | CN<br>STATF0 | 0000 | Legend: x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET and INV registers at its virtual address, plus an offset of 0x4, 0x8 and 0xC, respectively. See Section 11.2 "CLR, SET, and INV Registers" for ### 13.2 Control Registers ### TABLE 13-1: TIMER2 THROUGH TIMER5 REGISTER MAP | ess | | | | | | | | | | Ві | its | | | | | | | | | |-----------------------------|---------------------------------|-----------|---------------------|-------|-------|-------|-------|-------|------|------|--------|------|------------|------|------|------|------|------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0800 | T2CON | 31:16 | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | 120011 | 15:0 | ON | | SIDL | _ | _ | | _ | _ | TGATE | - | TCKPS<2:0: | > | T32 | _ | TCS | | 0000 | | 0810 | TMR2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0010 | TIVITAL | 15:0 | | | | | | | | TMR2 | <15:0> | | | | | | | | 0000 | | 0820 | PR2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | 11112 | 15:0 | | | | | | | | PR2< | 15:0> | | | | | | | | FFFF | | 0A00 | T3CON | 31:16 | _ | | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | | 0000 | | 0,400 | 13001 | 15:0 | ON | | SIDL | _ | _ | | _ | _ | TGATE | - | TCKPS<2:0: | > | _ | _ | TCS | | 0000 | | 0A10 | TMR3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0/110 | TIVITO | 15:0 | 0 TMR3<15:0> | | | | | | | | | 0000 | | | | | | | | | 0A20 | PR3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 07120 | 1110 | 15:0 | | | | | | | | PR3< | 15:0> | | | | | | | | FFFF | | 0000 | T4CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | 0000 | | 0000 | 1 10011 | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | TGATE | • | TCKPS<2:0 | > | T32 | _ | TCS | | 0000 | | 0C10 | TMR4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0010 | 11411 (1 | 15:0 | | | | | | | | TMR4 | <15:0> | | | | | | | | 0000 | | 0C20 | PR4 | 884 31:16 | | | | | | | | | | 0000 | | | | | | | | | 0020 | | 15:0 | 15:0 PR4<15:0> FFFF | | | | | | | | | | | FFFF | | | | | | | 0E00 | T5CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | 100011 | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | TGATE | • | TCKPS<2:0 | > | _ | _ | TCS | | 0000 | | 0E10 | TMR5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0210 | 1111110 | 15:0 | | | | | | | | | | | | | 0000 | | | | | | 0E20 | PR5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0220 | 1 110 | 15:0 | | | | | | | | PR5< | 15:0> | | | | | | | | FFFF | PIC32MX1XX/2XX/5XX 64/100-PIN FAMILY Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET and INV registers at their virtual addresses, plus offsets of 0x4, 0x8 and 0xC, respectively. See Section 11.2 "CLR, SET, and INV Registers" for more information. ### 14.0 WATCHDOG TIMER (WDT) Note: This data sheet summarizes the features of the PIC32MX1XX/2XX/5XX 64/100-pin Family family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 9. "Watchdog, Deadman, and Power-up Timers" (DS60001114) in the "PIC32 Family Reference Manual", which is available from the Microchip web site (www.microchip.com/PIC32). The Watchdog Timer (WDT), when enabled, operates from the internal Low-Power Oscillator (LPRC) clock source and can be used to detect system software malfunctions by resetting the device if the WDT is not cleared periodically in software. Various WDT time-out periods can be selected using the WDT postscaler. The WDT can also be used to wake the device from Sleep or Idle mode. The following are some of the key features of the WDT module: - · Configuration or software controlled - · User-configurable time-out period - · Can wake the device from Sleep or Idle FIGURE 14-1: WATCHDOG AND POWER-UP TIMER BLOCK DIAGRAM ### 18.1 Control Registers ### TABLE 18-1: I2C1 AND I2C2 REGISTER MAP | ess | | | | | | | | | | Bi | ts | | | | | | | | | |-----------------------------|---------------------------------|---------------|------------------------------------|--------|-------|--------|--------|-------|--------|-------|-------|-------------|--------------|--------------|----------|------|------|------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 5000 | I2C1CON | 31:16 | | _ | _ | _ | | _ | _ | | | _ | _ | _ | | | | | 0000 | | | | 15:0 | ON | | SIDL | SCLREL | STRICT | A10M | DISSLW | SMEN | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | BFFF | | 5010 | I2C1STAT | 31:16 | | | | _ | | _ | - | - | | - | | _ | _ | _ | _ | | 0000 | | | | | ACKSTAT | TRSTAT | | _ | | BCL | GCSTAT | ADD10 | IWCOL | I2COV | D_A | Р | S | R_W | RBF | TBF | 0000 | | 5020 | I2C1ADD | 31:16 | _ | _ | | _ | | | _ | _ | _ | _ | <u> </u> | <u> </u> | _ | _ | _ | | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | | | | | Address | Register | | | | | 0000 | | 5030 | I2C1MSK | 31:16<br>15:0 | | | _ | _ | | _ | _ | | | _ | Address M | ask Register | | _ | _ | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | | | | | Address ivia | isk Register | | | | | 0000 | | 5040 | 15:0 | | _ | | | _ | _ | _ | _ | | — Bau | ıd Rate Ger | orator Pog | ictor | _ | _ | _ | | 0000 | | | 31:16 | | | | | | | _ | _ | | | La Rate Ger | erator Neg | | _ | _ | _ | | 0000 | | 5050 | 50 I2C1TRN 31:16 | | | | | | | | | | | _ | | Transmit | Penister | | _ | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | — | — | _ | _ | | 0000 | | 5060 | I2C1RCV | 15:0 | _ | | | _ | | _ | _ | _ | | | | Receive | Register | | | | 0000 | | | | 31:16 | _ | _ | | _ | _ | _ | _ | | | _ | _ | _ | — | _ | _ | | 0000 | | 5100 | I2C2CON | 15:0 | ON | _ | SIDL | SCLREL | STRICT | A10M | DISSLW | SMEN | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | BFFF | | | | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 5110 | I2C2STAT | 15:0 | ACKSTAT | TRSTAT | _ | _ | _ | BCL | GCSTAT | ADD10 | IWCOL | I2COV | DΑ | Р | S | R W | RBF | TBF | 0000 | | | 1000400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 5120 | I2C2ADD | 15:0 | _ | _ | _ | _ | _ | _ | | | | • | Address | Register | | • | • | | 0000 | | 5130 | I2C2MSK | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 5130 | 12C2IVISK | 15:0 | _ | _ | _ | _ | _ | _ | | | | | Address Ma | ask Register | | | | | 0000 | | 5140 | I2C2BRG | 31:16 | _ | _ | | _ | - | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | 0000 | | 3140 | IZCZBRG | 15:0 | _ | _ | | _ | | | | | Bau | ıd Rate Ger | erator Reg | ister | | | | | 0000 | | 5150 | I2C2TRN | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 3130 | IZUZ I IXIV | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | Transmit | Register | | | | 0000 | | 5160 | I2C2RCV | 31:16 | | | | | | | | 0000 | | | | | | | | | | | 3100 | 12021101 | 15:0 | 5:0 — — — — — Receive Register 000 | | | | | | | | 0000 | | | | | | | | | **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table except I2CxRCV have corresponding CLR, SET and INV registers at their virtual addresses, plus offsets of 0x4, 0x8 and 0xC, respectively. See Section 11.2 "CLR, SET, and INV Registers" for more information. ### 19.1 Control Registers ### TABLE 19-1: UART1 THROUGH UART5 REGISTER MAP | ess ( | | a) | | | | | | | | Bi | ts | | | | | | | | s | |-----------------------------|-----------------------|-----------|--------|--------|--------|--------------------------|--------|-------|-------|-------------|-----------------------|---------|-------|----------|----------|------|--------|-------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 6000 | U1MODE <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | OTWODE | 15:0 | ON | | SIDL | IREN | RTSMD | | UEN | <1:0> | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSE | L<1:0> | STSEL | 0000 | | 6010 | U1STA <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | | _ | ADM_EN | | | | ADDR | R<7:0> | | | | 0000 | | 0010 | OIOIA | 15:0 | UTXISE | L<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT | URXISI | EL<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | FFFF | | 6020 | U1TXREG | 31:16 | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | OTTAINEO | 15:0 | _ | | _ | _ | _ | | _ | TX8 | | | | Transmit | Register | | | | 0000 | | 6030 | U1RXREG | 31:16 | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0030 | OTIVINEO | 15:0 | _ | | _ | _ | _ | | _ | RX8 | | | | Receive | Register | | | | 0000 | | 6040 | U1BRG <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0040 | O I DICO. | 15:0 | | | | | | | Bau | d Rate Gene | erator Pres | caler | | | | | | | 0000 | | 6200 | U2MODE <sup>(1)</sup> | 31:16 | _ | | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | OZIVIODE | 15:0 | ON | | SIDL | IREN | RTSMD | | UEN | <1:0> | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSE | L<1:0> | STSEL | 0000 | | 6210 | U2STA <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | ADM_EN | | | | ADDR | 2<7:0> | | | | 0000 | | 0210 | 02017( | 15:0 | UTXISE | L<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT | URXISI | EL<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | FFFF | | 6220 | U2TXREG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0220 | OZIMILO | 15:0 | _ | _ | _ | _ | _ | _ | _ | TX8 | | | | Transmit | Register | | | | 0000 | | 6230 | U2RXREG | 31:16 | _ | - | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | OZIVINEO | 15:0 | _ | _ | _ | _ | _ | _ | _ | RX8 | | | | Receive | Register | | | | 0000 | | 6240 | U2BRG <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0240 | OZDIKO | 15:0 | | | | | | | Bau | d Rate Gene | erator Pres | caler | | | | | | | 0000 | | 6400 | U3MODE <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0400 | COMODE | 15:0 | ON | _ | SIDL | IREN | RTSMD | _ | UEN | <1:0> | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSE | L<1:0> | STSEL | 0000 | | 6410 | U3STA <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | ADM_EN | | | | ADDR | 2<7:0> | | | | 0000 | | 3410 | 30017 | 15:0 | UTXISE | L<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT | URXISI | EL<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | FFFF | | 6420 | U3TXREG | 31:16 | _ | | _ | _ | _ | | _ | _ | | | _ | 0000 | | | | | | | J-72U | JUINNEG | 15:0 | _ | | _ | _ | _ | | _ | TX8 | TX8 Transmit Register | | | | | | 0000 | | | | 6430 | U3RXREG | 31:16 | _ | | _ | _ | _ | | _ | | | | | _ | 0000 | | | | | | 0700 | JUINNEG | 15:0 | _ | _ | _ | RX8 Receive Register 000 | | | | | | | 0000 | | | | | | | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: This register has corresponding CLR, SET and INV registers at its virtual address, plus an offset of 0x4, 0x8 and 0xC, respectively. See Section 11.2 "CLR, SET, and INV Registers" for more information. 2: This register is only available on 100-pin devices. ### REGISTER 21-1: RTCCON: RTC CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------------|-------------------|-------------------|-------------------|------------------------|-------------------|------------------------|------------------|--|--| | 24.24 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | | | 31:24 | _ | _ | _ | _ | _ | _ | CAL<9 | ):8> | | | | 23:16 | R/W-0 | | | 23.10 | CAL<7:0> | | | | | | | | | | | 15.0 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | | | 15:8 | ON <sup>(1,2)</sup> | _ | SIDL | _ | _ | _ | _ | _ | | | | 7:0 | R/W-0 | R-0 | U-0 | U-0 | R/W-0 | R-0 | R-0 | R/W-0 | | | | | RTSECSEL <sup>(3)</sup> | RTCCLKON | _ | 1 | RTCWREN <sup>(4)</sup> | RTCSYNC | HALFSEC <sup>(5)</sup> | RTCOE | | | 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 31-26 Unimplemented: Read as '0' bit 25-16 CAL<9:0>: RTC Drift Calibration bits, which contain a signed 10-bit integer value 0111111111 = Maximum positive adjustment, adds 511 RTC clock pulses every one minute • 000000001 = Minimum positive adjustment, adds 1 RTC clock pulse every one minute 0000000000 = No adjustment 1111111111 = Minimum negative adjustment, subtracts 1 RTC clock pulse every one minute • 100000000 = Maximum negative adjustment, subtracts 512 clock pulses every one minute bit 15 **ON:** RTCC On bit<sup>(1,2)</sup> 1 = RTCC module is enabled 0 = RTCC module is disabled bit 14 Unimplemented: Read as '0' bit 13 SIDL: Stop in Idle Mode bit 1 = Disables the PBCLK to the RTCC when CPU enters in Idle mode 0 = Continue normal operation in Idle mode bit 12-8 Unimplemented: Read as '0' bit 7 RTSECSEL: RTCC Seconds Clock Output Select bit<sup>(3)</sup> 1 = RTCC Seconds Clock is selected for the RTCC pin 0 = RTCC Alarm Pulse is selected for the RTCC pin bit 6 RTCCLKON: RTCC Clock Enable Status bit 1 = RTCC Clock is actively running 0 = RTCC Clock is not running bit 5-4 Unimplemented: Read as '0' **Note 1:** The ON bit is only writable when RTCWREN = 1. - 2: When using the 1:1 PBCLK divisor, the user software should not read/write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit. - **3:** Requires RTCOE = 1 (RTCCON<0>) for the output to be active. - **4:** The RTCWREN bit can be set only when the write sequence is enabled. - 5: This bit is read-only. It is cleared to '0' on a write to the seconds bit fields (RTCTIME<14:8>). Note: This register is reset only on a Power-on Reset (POR). ### REGISTER 23-5: C1TREC: CAN TRANSMIT/RECEIVE ERROR COUNT REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | | 31.24 | _ | _ | _ | - | _ | _ | _ | | | | 23:16 | U-0 | U-0 | R-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | | 23.10 | _ | _ | TXBO | TXBP | RXBP | TXWARN | RXWARN | EWARN | | | 15:8 | R-0 | | 15.6 | | | | TERRCI | NT<7:0> | | | | | | 7:0 | R-0 | | 7.0 | RERRCNT<7: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 31-22 Unimplemented: Read as '0' bit 21 **TXBO:** Transmitter in Error State Bus OFF (TERRCNT ≥ 256) bit 20 **TXBP:** Transmitter in Error State Bus Passive (TERRCNT ≥ 128) bit 19 **RXBP:** Receiver in Error State Bus Passive (RERRCNT ≥ 128) bit 18 **TXWARN:** Transmitter in Error State Warning (128 > TERRCNT ≥ 96) bit 17 **RXWARN:** Receiver in Error State Warning (128 > RERRCNT ≥ 96) bit 16 **EWARN:** Transmitter or Receiver is in Error State Warning bit 15-8 **TERRCNT<7:0>:** Transmit Error Counter bit 7-0 **RERRCNT<7:0>:** Receive Error Counter #### REGISTER 23-6: C1FSTAT: CAN FIFO STATUS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | | _ | _ | _ | _ | _ | _ | - | | 23:16 | U-0 | 23.10 | | _ | _ | _ | _ | _ | _ | - | | 15:8 | R-0 | 15.6 | FIFOIP15 | FIFOIP14 | FIFOIP13 | FIFOIP12 | FIFOIP11 | FIFOIP10 | FIFOIP9 | FIFOIP8 | | 7:0 | R-0 | 7.0 | FIFOIP7 | FIFOIP6 | FIFOIP5 | FIFOIP4 | FIFOIP3 | FIFOIP2 | FIFOIP1 | FIFOIP0 | 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 31-16 Unimplemented: Read as '0' bit 15-0 FIFOIP<15:0>: FIFOx Interrupt Pending bits 1 = One or more enabled FIFO interrupts are pending 0 = No FIFO interrupts are pending # REGISTER 23-17: C1FIFOINTn: CAN FIFO INTERRUPT REGISTER 'n' ('n' = 0 THROUGH 15) (CONTINUED) bit 9 **TXHALFIF:** FIFO Transmit FIFO Half Empty Interrupt Flag bit<sup>(1)</sup> TXEN = 1: (FIFO configured as a transmit buffer) 1 = FIFO is ≤ half full 0 = FIFO is > half full TXEN = 0: (FIFO configured as a receive buffer) Unused, reads '0' bit 8 **TXEMPTYIF:** Transmit FIFO Empty Interrupt Flag bit<sup>(1)</sup> TXEN = 1: (FIFO configured as a transmit buffer) 1 = FIFO is empty 0 = FIFO is not empty, at least 1 message queued to be transmitted TXEN = 0: (FIFO configured as a receive buffer) Unused, reads '0' bit 7-4 Unimplemented: Read as '0' bit 3 RXOVFLIF: Receive FIFO Overflow Interrupt Flag bit TXEN = 1: (FIFO configured as a transmit buffer) Unused, reads '0' TXEN = 0: (FIFO configured as a receive buffer) 1 = Overflow event has occurred 0 = No overflow event occured bit 2 **RXFULLIF:** Receive FIFO Full Interrupt Flag bit<sup>(1)</sup> $\underline{\mathsf{TXEN}} = 1$ : (FIFO configured as a transmit buffer) Unused, reads '0' TXEN = 0: (FIFO configured as a receive buffer) 1 = FIFO is full 0 = FIFO is not full ----- bit 1 **RXHALFIF:** Receive FIFO Half Full Interrupt Flag bit<sup>(1)</sup> $\overline{\text{TXEN}} = 1$ : (FIFO configured as a transmit buffer) Unused, reads '0' TXEN = 0: (FIFO configured as a receive buffer) 1 = FIFO is ≥ half full 0 = FIFO is < half full bit 0 RXNEMPTYIF: Receive Buffer Not Empty Interrupt Flag bit<sup>(1)</sup> TXEN = 1: (FIFO configured as a transmit buffer) Unused, reads '0' TXEN = 0: (FIFO configured as a receive buffer) 1 = FIFO is not empty, has at least 1 message 0 = FIFO is empty **Note 1:** This bit is read-only and reflects the status of the FIFO. #### REGISTER 25-1: CVRCON: COMPARATOR VOLTAGE REFERENCE CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22:16 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | U-0 | 15:8 | ON <sup>(1)</sup> | _ | _ | _ | _ | _ | _ | _ | | 7.0 | U-0 | R/W-0 | 7:0 | _ | CVROE | CVRR | CVRSS | | CVR< | <3: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 31-16 Unimplemented: Read as '0' bit 15 **ON:** Comparator Voltage Reference On bit<sup>(1)</sup> 1 = Module is enabled Setting this bit does not affect other bits in the register. 0 = Module is disabled and does not consume currentClearing this bit does not affect the other bits in the register. bit 14-7 Unimplemented: Read as '0' bit 6 CVROE: CVREFOUT Enable bit 1 = Voltage level is output on CVREFOUT pin 0 = Voltage level is disconnected from CVREFOUT pin bit 5 CVRR: CVREF Range Selection bit 1 = 0 to 0.625 CVRSRC, with CVRSRC/24 step size 0 = 0.25 CVRSRC to 0.719 CVRSRC, with CVRSRC/32 step size bit 4 CVRSS: CVREF Source Selection bit 1 = Comparator voltage reference source, CVRSRC = (VREF+) – (VREF-) 0 = Comparator voltage reference source, CVRSRC = AVDD - AVSS bit 3-0 **CVR<3:0>:** CVREF Value Selection $0 \le CVR<3:0> \le 15$ bits When CVRR = 1: CVREF = (CVR<3:0>/24) • (CVRSRC) When CVRR = 0: CVREF = 1/4 • (CVRSRC) + (CVR<3:0>/32) • (CVRSRC) **Note 1:** When using 1:1 PBCLK divisor, the user's software should not read/write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit. ### 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® X IDE Software - · Compilers/Assemblers/Linkers - MPLAB XC Compiler - MPASM<sup>TM</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<sup>®</sup> 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 31-36: ANALOG-TO-DIGITAL CONVERSION TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions (see Note 4): 2.5V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +105^{\circ}\text{C}$ for V-temp | | | | | | |--------------------|-----------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------|-------|-----------------------------------------------------------|--| | Param.<br>No. | Symbol | Characteristics | Min. | Typical <sup>(1)</sup> | Max. | Units | Conditions | | | Clock P | arameter | s | | | | | | | | AD50 | TAD | ADC Clock Period <sup>(2)</sup> | 65 | _ | _ | ns | See Table 31-35 | | | Convers | sion Rate | | | | | | | | | AD55 | TCONV | Conversion Time | _ | 12 TAD | _ | _ | _ | | | AD56 | FCNV | Throughput Rate (Sampling Speed) | _ | _ | 1000 | ksps | AVDD = 3.0V to 3.6V | | | | | | _ | _ | 400 | ksps | AVDD = 2.5V to 3.6V | | | AD57 | TSAMP | Sample Time | 1 TAD | _ | _ | _ | Tsamp must be ≥ 132 ns | | | Timing | Paramete | rs | | | | | | | | AD60 | TPCS | Conversion Start from Sample Trigger <sup>(3)</sup> | _ | 1.0 TAD | _ | _ | Auto-Convert Trigger<br>(SSRC<2:0> = 111)<br>not selected | | | AD61 | TPSS | Sample Start from Setting Sample (SAMP) bit | 0.5 TAD | | 1.5 TAD | _ | _ | | | AD62 | TCSS | Conversion Completion to Sample Start (ASAM = $1$ ) <sup>(3)</sup> | _ | 0.5 TAD | _ | _ | _ | | | AD63 | TDPU | Time to Stabilize Analog Stage from ADC Off to ADC On <sup>(3)</sup> | _ | _ | 2 | μS | _ | | Note 1: These parameters are characterized, but not tested in manufacturing. **<sup>2:</sup>** Because the sample caps will eventually lose charge, clock rates below 10 kHz can affect linearity performance, especially at elevated temperatures. **<sup>3:</sup>** Characterized by design but not tested. **<sup>4:</sup>** The ADC module is functional at VBORMIN < VDD < 2.5V, but with degraded performance. Unless otherwise stated, module functionality is tested, but not characterized. FIGURE 31-18: ANALOG-TO-DIGITAL CONVERSION (10-BIT MODE) TIMING CHARACTERISTICS (ASAM = 0, SSRC<2:0> = 000) - 1 Software sets ADxCON. SAMP to start sampling. - 2 Sampling starts after discharge period. TSAMP is described in Section 17. "10-bit Analog-to-Digital Converter (ADC)" (DS60001104) in the "PIC32 Family Reference Manual". - 3 Software clears ADxCON. SAMP to start conversion. - (4) Sampling ends, conversion sequence starts. - (5) Convert bit 9. - 6 Convert bit 8. - 7 Convert bit 0. - (8) One TAD for end of conversion. ### 100-Lead Plastic Thin Quad Flatpack (PF) - 14x14x1 mm Body, 2.00 mm [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | MILLIMETERS | | | | | |--------------------------|-------------|-----------|-----------|------|--| | Dimension Limits | | MIN | NOM | MAX | | | Number of Leads | N | | 100 | | | | Lead Pitch | е | | 0.50 BSC | | | | Overall Height | Α | 1 | ı | 1.20 | | | Molded Package Thickness | A2 | 0.95 | 1.00 | 1.05 | | | Standoff | A1 | 0.05 | _ | 0.15 | | | Foot Length | L | 0.45 | 0.60 | 0.75 | | | Footprint | L1 | 1.00 REF | | | | | Foot Angle | ф | 0° | 3.5° | 7° | | | Overall Width | E | | 16.00 BSC | | | | Overall Length | D | 16.00 BSC | | | | | Molded Package Width | E1 | | 14.00 BSC | | | | Molded Package Length | D1 | 14.00 BSC | | | | | Lead Thickness | С | 0.09 | _ | 0.20 | | | Lead Width | b | 0.17 | 0.22 | 0.27 | | | Mold Draft Angle Top | α | 11° | 12° | 13° | | | Mold Draft Angle Bottom | β | 11° | 12° | 13° | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Chamfers at corners are optional; size may vary. - 3. Dimensions D1 and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.25 mm per side. - 4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-110B ### 100-Lead Plastic Thin Quad Flatpack (PT) – 12x12x1 mm Body, 2.00 mm [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | MILLIMETERS | | | | |--------------------------|------------------|-------------|-----------|------|--| | | Dimension Limits | MIN | NOM | MAX | | | Number of Leads | N | | 100 | | | | Lead Pitch | е | | 0.40 BSC | | | | Overall Height | A | - | _ | 1.20 | | | Molded Package Thickness | A2 | 0.95 | 1.00 | 1.05 | | | Standoff | A1 | 0.05 | _ | 0.15 | | | Foot Length | L | 0.45 | 0.60 | 0.75 | | | Footprint | L1 | 1.00 REF | | | | | Foot Angle | ф | 0° | 3.5° | 7° | | | Overall Width | E | | 14.00 BSC | | | | Overall Length | D | 14.00 BSC | | | | | Molded Package Width | E1 | 12.00 BSC | | | | | Molded Package Length | D1 | | 12.00 BSC | | | | Lead Thickness | С | 0.09 | _ | 0.20 | | | Lead Width | b | 0.13 | 0.18 | 0.23 | | | Mold Draft Angle Top | α | 11° | 12° | 13° | | | Mold Draft Angle Bottom | β | 11° | 12° | 13° | | ### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Chamfers at corners are optional; size may vary. - 3. Dimensions D1 and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.25 mm per side. - 4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-100B