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 | dsPIC | | Core Size | 16-Bit | | Speed | 16 MIPs | | Connectivity | I <sup>2</sup> C, IrDA, LINbus, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, POR, PWM, WDT | | Number of I/O | 21 | | Program Memory Size | 32KB (11K x 24) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 1K x 16 | | Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V | | Data Converters | A/D 8x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 28-VQFN Exposed Pad | | Supplier Device Package | 28-QFN (6x6) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/dspic33fj32gp102-i-ml | | dsPIC33FJ16(GP/MC)101/102 AND dsPIC33FJ32(GP/MC)101/102/104 | | |-------------------------------------------------------------|--| | NOTES: | | PSV and Table Data Access Y Data Bus Control Block X Data Bus Interrupt **PORTA** Controller 16 16 16 16 Data Latch Data Latch 23 PCU PCH PCL Y RAM X RAM **PORTB** 23 Program Counter Address Address Loop Control Latch Latch Control Logic Logic 23 16 16 Remappable Address Generator Units Address Latch Program Memory EA MUX ROM Latch Data Latch 24 16 Instruction Decode and Control Instruction Reg 16 Control Signals **DSP** Engine to Various Blocks 16 x 16 OSC2/CLKO OSC1/CLKI Power-up W Register Array Timing Generation Divide Support Timer 16 Oscillator $\boxtimes \longleftrightarrow$ FRC/LPRC Start-up Time Oscillators Power-on Reset 16-Bit ALU Precision Watchdog Band Gap Reference 16 Brown-out Voltage Regulator Reset $\boxtimes$ $\boxtimes$ $\boxtimes$ VCAP VDD, VSS MCLR External OC/ Timers CTMU UART1 ADC1 RTCC Interrupts 1-5 PWM1-2 1-3 Comparators **PWM** IC1-IC3 I2C1 CNx 6-ch Not all pins or features are implemented on all device pinout configurations. See the "Pin Diagrams" section for the specific pins Note: and features present on each device. FIGURE 1-1: dsPIC33FJ16(GP/MC)101/102 AND dsPIC33FJ32(GP/MC)101/102/104 BLOCK DIAGRAM #### REGISTER 7-26: IPC16: INTERRUPT PRIORITY CONTROL REGISTER 16 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |-------|--------|--------|--------|-----|-------------------------|-------------------------|-------------------------| | _ | U1EIP2 | U1EIP1 | U1EIP0 | _ | FLTB1IP2 <sup>(1)</sup> | FLTB1IP1 <sup>(1)</sup> | FLTB1IP0 <sup>(1)</sup> | | 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-7 Unimplemented: Read as '0' bit 6-4 **U1EIP<2:0>:** UART1 Error Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3 Unimplemented: Read as '0' bit 2-0 FLTB1IP<2:0>: PWM1 Fault B Interrupt Priority bits<sup>(1)</sup> 111 = Interrupt is Priority 7 (highest priority interrupt) • • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled Note 1: These bits are available in dsPIC(16/32)MC102/104 devices only. ### 8.3 Clock Switching Operation Applications are free to switch among any of the four clock sources (Primary, LP, FRC and LPRC) under software control at any time. To limit the possible side effects of this flexibility, dsPIC33FJ16(GP/MC)101/102 and dsPIC33FJ32(GP/MC)101/102/104 devices have a safeguard lock built into the switch process. Note: Primary Oscillator mode has three different submodes (MS, HS and EC), which are determined by the POSCMD<1:0> Configuration bits. While an application can switch to and from Primary Oscillator mode in software, it cannot switch among the different primary submodes without reprogramming the device. #### 8.3.1 ENABLING CLOCK SWITCHING To enable clock switching, the FCKSM1 Configuration bit in the FOSC Configuration register must be programmed to '0'. (Refer to **Section 23.1 "Configuration Bits"** for further details.) If the FCKSM1 Configuration bit is unprogrammed ('1'), the clock switching function and Fail-Safe Clock Monitor function are disabled. This is the default setting. The NOSCx control bits (OSCCON<10:8>) do not control the clock selection when clock switching is disabled. However, the COSCx bits (OSCCON<14:12>) reflect the clock source selected by the FNOSCx Configuration bits. The OSWEN control bit (OSCCON<0>) has no effect when clock switching is disabled; it is held at '0' at all times. #### 8.3.2 OSCILLATOR SWITCHING SEQUENCE Performing a clock switch requires this basic sequence: - If desired, read the COSC bits (OSCCON<14:12>) to determine the current oscillator source. - Perform the unlock sequence to allow a write to the OSCCON register high byte. - Write the appropriate value to the NOSCx control bits (OSCCON<10:8>) for the new oscillator source. - 4. Perform the unlock sequence to allow a write to the OSCCON register low byte. - Set the OSWEN bit (OSCCON<0>) to initiate the oscillator switch. Once the basic sequence is completed, the system clock hardware responds automatically as follows: - The clock switching hardware compares the COSCx status bits with the new value of the NOSCx control bits. If they are the same, the clock switch is a redundant operation. In this case, the OSWEN bit is cleared automatically and the clock switch is aborted. - If a valid clock switch has been initiated, the LOCK and CF (OSCCON<5,3>) status bits are cleared. - The new oscillator is turned on by the hardware if it is not currently running. If a crystal oscillator must be turned on, the hardware waits until the Oscillator Start-up Timer (OST) expires. If the new source is using the PLL, the hardware waits until a PLL lock is detected (LOCK = 1). - The hardware waits for 10 clock cycles from the new clock source and then performs the clock switch. - The hardware clears the OSWEN bit to indicate a successful clock transition. In addition, the NOSCx bit values are transferred to the COSCx status bits. - The old clock source is turned off at this time, with the exception of LPRC (if WDT or FSCM is enabled) or LP (if LPOSCEN remains set). - Note 1: The processor continues to execute code throughout the clock switching sequence. Timing-sensitive code should not be executed during this time. - 2: Direct clock switches between any Primary Oscillator mode with PLL and FRCPLL mode are not permitted. This applies to clock switches in either direction. In these instances, the application must switch to FRC mode as a transition clock source between the two PLL modes. - 3: Refer to "Oscillator (Part VI)" (DS70644) in the "dsPIC33/PIC24 Family Reference Manual" for details. #### 8.4 Fail-Safe Clock Monitor (FSCM) The Fail-Safe Clock Monitor (FSCM) allows the device to continue to operate even in the event of an oscillator failure. The FSCM function is enabled by programming. If the FSCM function is enabled, the LPRC internal oscillator runs at all times (except during Sleep mode) and is not subject to control by the Watchdog Timer. In the event of an oscillator failure, the FSCM generates a clock failure trap event and switches the system clock over to the FRC oscillator. Then, the application program can either attempt to restart the oscillator or execute a controlled shutdown. The trap can be treated as a Warm Reset by simply loading the Reset address into the oscillator fail trap vector. If the PLL multiplier is used to scale the system clock, the internal FRC is also multiplied by the same factor on clock failure. Essentially, the device switches to FRC with PLL on a clock failure. #### 10.0 I/O PORTS Note 1: This data sheet summarizes the features of the dsPIC33FJ16(GP/MC)101/102 and dsPIC33FJ32(GP/MC)101/102/104 family devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "I/O Ports" (DS70193) in the "dsPIC33/PIC24 Family Reference Manual", which is available from the Microchip web site (www.microchip.com). 2: Some registers and associated bits described in this section may not be available on all devices. Refer to Section 4.0 "Memory Organization" in this data sheet for device-specific register and bit information. All of the device pins (except VDD, VSS, MCLR and OSC1/CLKI) are shared among the peripherals and the parallel I/O ports. All I/O input ports feature Schmitt Trigger inputs for improved noise immunity. #### 10.1 Parallel I/O (PIO) Ports Generally a parallel I/O port that shares a pin with a peripheral is subservient to the peripheral. The peripheral's output buffer data and control signals are provided to a pair of multiplexers. The multiplexers select whether the peripheral or the associated port has ownership of the output data and control signals of the I/O pin. The logic also prevents "loop through," in which a port's digital output can drive the input of a peripheral that shares the same pin. Figure 10-1 shows how ports are shared with other peripherals and the associated I/O pin to which they are connected. When a peripheral is enabled and the peripheral is actively driving an associated pin, the use of the pin as a general purpose output pin is disabled. The I/O pin can be read, but the output driver for the parallel port bit is disabled. If a peripheral is enabled, but the peripheral is not actively driving a pin, that pin can be driven by a port. All port pins have three registers directly associated with their operation as digital I/O. The Data Direction register (TRISx) determines whether the pin is an input or an output. If the data direction bit is a '1', the pin is an input. All port pins are defined as inputs after a Reset. Reads from the Output Latch (LATx) register read the latch. Writes to the Output Latch register write the latch. Reads from the port (PORTx) read the port pins, while writes to the port pins write the latch. Any bit and its associated data and control registers that is not valid for a particular device will be disabled. This means the corresponding LATx and TRISx registers and the port pin will read as zeros. When a pin is shared with another peripheral or function that is defined as an input only, it is nevertheless regarded as a dedicated port because there is no other competing source of outputs. #### REGISTER 10-8: RPINR18: PERIPHERAL PIN SELECT INPUT REGISTER 18 | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | |--------|-----|-----|---------|---------|---------|---------|---------| | _ | _ | _ | U1CTSR4 | U1CTSR3 | U1CTSR2 | U1CTSR1 | U1CTSR0 | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | |-------|-----|-----|--------|--------|--------|--------|--------| | _ | _ | _ | U1RXR4 | U1RXR3 | U1RXR2 | U1RXR1 | U1RXR0 | | 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-13 Unimplemented: Read as '0' bit 12-8 **U1CTSR<4:0>:** Assign UART1 Clear-to-Send (U1CTS) to the Corresponding RPn Pin bits 11111 = Input tied to Vss 11110 = Reserved . 11010 = Reserved 11001 = Input tied to RP25 . 00001 = Input tied to RP1 00000 = Input tied to RP0 bit 7-5 **Unimplemented:** Read as '0' bit 4-0 U1RXR<4:0>: Assign UART1 Receive (U1RX) to the Corresponding RPn Pin bits 11111 = Input tied to Vss 11110 = Reserved . 11010 = Reserved 11001 = Input tied to RP25 : . 00001 = Input tied to RP1 00000 = Input tied to RP0 #### 15.4 PWM Control Registers #### REGISTER 15-1: PXTCON: PWMX TIME BASE CONTROL REGISTER | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | |--------|-----|--------|-----|-----|-----|-----|-------| | PTEN | _ | PTSIDL | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 |--------|--------|--------|--------|---------|---------|--------|--------| | PTOPS3 | PTOPS2 | PTOPS1 | PTOPS0 | PTCKPS1 | PTCKPS0 | PTMOD1 | PTMOD0 | | 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 PTEN: PWMx Time Base Timer Enable bit 1 = PWMx time base is on 0 = PWMx time base is off bit 14 Unimplemented: Read as '0' bit 13 PTSIDL: PWMx Time Base Stop in Idle Mode bit 1 = PWMx time base halts in CPU Idle mode 0 = PWMx time base runs in CPU Idle mode bit 12-8 Unimplemented: Read as '0' bit 7-4 PTOPS<3:0>: PWMx Time Base Output Postscale Select bits 1111 = 1:16 postscale • • 0001 = 1:2 postscale 0000 = 1:1 postscale bit 3-2 PTCKPS<1:0>: PWMx Time Base Input Clock Prescale Select bits 11 = PWMx time base input clock period is 64 Tcy (1:64 prescale) 10 = PWMx time base input clock period is 16 Tcy (1:16 prescale) 01 = PWMx time base input clock period is 4 Tcy (1:4 prescale) 00 = PWMx time base input clock period is Tcy (1:1 prescale) bit 1-0 PTMOD<1:0>: PWMx Time Base Mode Select bits 11 = PWMx time base operates in a Continuous Up/Down Count mode with interrupts for double PWM updates 10 = PWMx time base operates in a Continuous Up/Down Count mode 01 = PWMx time base operates in Single Pulse mode 00 = PWMx time base operates in a Free-Running mode #### 16.1 SPI Helpful Tips - In Frame mode, if there is a possibility that the master may not be initialized before the slave: - a) If FRMPOL (SPIxCON2<13>) = 1, use a pull-down resistor on SSx. - b) If FRMPOL = 0, use a pull-up resistor on $\overline{SSx}$ . **Note:** This insures that the first frame transmission after initialization is not shifted or corrupted. - In Non-Framed 3-Wire mode (i.e., not using SSx from a master): - a) If CKP (SPIxCON1<6>) = 1, always place a pull-up resistor on SSx. - b) If CKP = 0, always place a pull-down resistor on $\overline{SSx}$ . Note: This will insure that during power-up and initialization, the master/slave will not lose sync due to an errant SCK transition that would cause the slave to accumulate data shift errors for both transmit and receive, appearing as corrupted data. FRMEN (SPIxCON2<15>) = 1 and SSEN (SPIxCON1<7>) = 1 are exclusive and invalid. In Frame mode, SCKx is continuous and the Frame Sync pulse is active on the SSx pin, which indicates the start of a data frame. **Note:** Not all third-party devices support Frame mode timing. Refer to the SPI electrical characteristics for details. - 4. In Master mode only, set the SMP bit (SPIxCON1<9>) to a '1' for the fastest SPI data rate possible. The SMP bit can only be set at the same time or after the MSTEN bit (SPIxCON1<5>) is set. - 5. To avoid invalid slave read data to the master, the user's master software must ensure enough time for slave software to fill its write buffer before the user application initiates a master write/read cycle. It is always advisable to preload the SPIxBUF Transmit register in advance of the next master transaction cycle. SPIxBUF is transferred to the SPIx Shift register and is empty once the data transmission begins. - The SPI related pins (SDI1, SDO1, SCK1) are located at fixed positions in the dsPIC33FJ16(GP/ MC)10X devices. The same pins are remappable in the dsPIC33FJ32(GP/MC)10X devices. #### 16.2 SPI Resources Many useful resources are provided on the main product page of the Microchip web site for the devices listed in this data sheet. This product page, which can be accessed using this link, contains the latest updates and additional information. In the event you are not able to access the product page using the link above, enter this URL in your browser: http://www.microchip.com/wwwproducts/Devices.aspx?dDocName=en554109 #### 16.2.1 KEY RESOURCES - "Serial Peripheral Interface (SPI)" (DS70206) in the "dsPIC33/PIC24 Family Reference Manual". - Code Samples - · Application Notes - · Software Libraries - Webinars Note: - All related "dsPIC33/PIC24 Family Reference Manual" sections - Development Tools #### REGISTER 17-2: I2CxSTAT: I2Cx STATUS REGISTER (CONTINUED) bit 4 **P:** Stop bit 1 = Indicates that a Stop bit has been detected last 0 = Stop bit was not detected last Hardware sets or clears when Start, Repeated Start or Stop is detected. bit 3 S: Start bit 1 = Indicates that a Start (or Repeated Start) bit has been detected last 0 = Start bit was not detected last Hardware sets or clears when Start, Repeated Start or Stop is detected. bit 2 R\_W: Read/Write Information bit (when operating as I<sup>2</sup>C slave) 1 = Read – Indicates data transfer is output from slave 0 = Write – Indicates data transfer is input to slave Hardware sets or clears after reception of an I<sup>2</sup>C device address byte. bit 1 RBF: Receive Buffer Full Status bit 1 = Receive is complete, I2CxRCV is full 0 = Receive is not complete, I2CxRCV is empty Hardware sets when I2CxRCV is written with received byte. Hardware clears when software reads I2CxRCV. bit 0 TBF: Transmit Buffer Full Status bit 1 = Transmit in progress, I2CxTRN is full 0 = Transmit complete, I2CxTRN is empty Hardware sets when software writes to I2CxTRN. Hardware clears at completion of data transmission. DS70000652F-page 218 #### REGISTER 19-3: AD1CON3: ADC1 CONTROL REGISTER 3 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-----|-----|----------------------|----------------------|----------------------|----------------------|----------------------| | ADRC | _ | _ | SAMC4 <sup>(1)</sup> | SAMC3 <sup>(1)</sup> | SAMC2 <sup>(1)</sup> | SAMC1 <sup>(1)</sup> | SAMC0 <sup>(1)</sup> | | bit 15 | | | | | | | bit 8 | | R/W-0 |----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------| | ADCS7 <sup>(2)</sup> | ADCS6 <sup>(2)</sup> | ADCS5 <sup>(2)</sup> | ADCS4 <sup>(2)</sup> | ADCS3 <sup>(2)</sup> | ADCS2 <sup>(2)</sup> | ADCS1 <sup>(2)</sup> | ADCS0 <sup>(2)</sup> | | 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 ADRC: ADC1 Conversion Clock Source bit 1 = ADC1 internal RC clock 0 = Clock derived from system clock bit 14-13 Unimplemented: Read as '0' SAMC<4:0>: Auto-Sample Time bits(1) bit 12-8 11111 = 31 TAD 00001 = 1 TAD00000 = 0 TAD ADCS<7:0>: ADC1 Conversion Clock Select bits(2) bit 7-0 11111111 = Reserved 01000000 = Reserved $001111111 = TCY \cdot (ADCS < 7:0 > + 1) = 64 \cdot TCY = TAD$ $00000010 = TCY \cdot (ADCS < 7:0 > + 1) = 3 \cdot TCY = TAD$ $00000001 = Tcy \cdot (ADCS < 7:0 > + 1) = 2 \cdot Tcy = TAD$ $000000000 = Tcy \cdot (ADCS < 7:0 > + 1) = 1 \cdot Tcy = TAD$ **Note 1:** This bit is only used if SSRC<2:0> (AD1CON1<7:5>) = 1. 2: This bit is not used if ADRC (AD1CON3<15>) = 1. #### 20.0 COMPARATOR MODULE Note 1: This data sheet summarizes the features of the dsPIC33FJ16(GP/MC)101/102 and dsPIC33FJ32(GP/MC)101/102/104 device families. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Comparator with Blanking" (DS70647) in the "dsPIC33/PIC24 Family Reference Manual', which is available from the Microchip web site (www.microchip.com). > 2: Some registers and associated bits described in this section may not be available on all devices. Refer to Section 4.0 "Memory Organization" in this data sheet for device-specific register and bit information. The comparator module provides three comparators that can be configured in different ways. As shown in Figure 20-1, individual comparator options are specified by the comparator module's Special Function Register (SFR) control bits. These options allow users to: - Select the edge for trigger and interrupt generation - Select low-power control - Configure the comparator voltage reference and band gap - · Configure output blanking and masking The comparator operating mode is determined by the input selections (i.e., whether the input voltage is compared to a second input voltage) to an internal voltage reference. #### **FIGURE 20-1: COMPARATOR I/O OPERATING MODES** for the specified voltage range. ### 20.1 Comparator Control Registers #### REGISTER 20-1: CMSTAT: COMPARATOR STATUS REGISTER | R/W-0 | U-0 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | |--------|-----|-----|-----|-----|-------|-------|-------| | CMSIDL | _ | _ | _ | _ | C3EVT | C2EVT | C1EVT | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | |-------|-----|-----|-----|-----|-------|-------|-------| | _ | _ | _ | _ | _ | C3OUT | C2OUT | C1OUT | | 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 CMSIDL: Comparator Stop in Idle Mode bit 1 = Discontinues operation of all comparators when device enters Idle mode 0 = Continues operation of all comparators in Idle mode bit 14-11 Unimplemented: Read as '0' bit 10 C3EVT: Comparator 3 Event Status bit 1 = Comparator event occurred 0 = Comparator event did not occur bit 9 **C2EVT:** Comparator 2 Event Status bit 1 = Comparator event occurred 0 = Comparator event did not occur bit 8 C1EVT: Comparator 1 Event Status bit 1 = Comparator event occurred0 = Comparator event did not occur bit 7-3 **Unimplemented:** Read as '0' bit 2 C3OUT: Comparator 3 Output Status bit When CPOL = 0: 1 = VIN+ > VIN- 0 = VIN+ < VIN-When CPOL = 1: 1 = VIN+ < VIN- 0 = VIN+ > VIN- bit 1 C2OUT: Comparator 2 Output Status bit When CPOL = 0: 1 = VIN+ > VIN-0 = VIN+ < VIN-When CPOL = 1: 1 = VIN+ < VIN-0 = VIN+ > VIN- bit 0 C10UT: Comparator 1 Output Status bit When CPOL = 0: 1 = VIN+ > VIN-0 = VIN+ < VIN-When CPOL = 1: 1 = VIN+ < VIN-0 = VIN+ > VIN- #### REGISTER 21-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> = 0x00 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 0x00 to 0xFF 0 = Chime is disabled; ARPT<7:0> bits stop once they reach 0x00 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 29th, 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 ALRMVALH and ALRMVALL registers; the ALRMPTR<1:0> value decrements on every read or write of ALRMVALH until it reaches '00'. 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. The counter is prevented from rolling over from 0x00 to 0xFF unless CHIME = 1. ## REGISTER 21-7: RTCVAL (WHEN RTCPTR<1:0> = 00): RTCC MINUTES AND SECONDS VALUE REGISTER | U-0 | R/W-x |--------|---------------------------|-------|---------|---------|---------|---------|-------| | _ | - MINTEN2 MINTEN1 MINTEN0 | | MINONE3 | MINONE2 | MINONE1 | MINONE0 | | | bit 15 | | | | | | bit 8 | | | U-0 | R/W-x |-------|---------|---------|---------|---------|---------|---------|---------| | _ | SECTEN2 | SECTEN1 | SECTEN0 | SECONE3 | SECONE2 | SECONE1 | SECONE0 | | 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 **Unimplemented:** Read as '0' bit 14-12 MINTEN<2:0>: Binary Coded Decimal Value of Minute's Tens Digit bits Contains a value from 0 to 5. bit 11-8 MINONE<3:0>: Binary Coded Decimal Value of Minute's Ones Digit bits Contains a value from 0 to 9. bit 7 **Unimplemented:** Read as '0' bit 6-4 SECTEN<2:0>: Binary Coded Decimal Value of Second's Tens Digit bits Contains a value from 0 to 5. bit 3-0 **SECONE<3:0>:** Binary Coded Decimal Value of Second's Ones Digit bits Contains a value from 0 to 9. # REGISTER 21-10: ALRMVAL (WHEN ALRMPTR<1:0> = 00): ALARM MINUTES AND SECONDS VALUE REGISTER | U-0 | J-0 R/W-x R/W-x | | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | |--------|---------------------------|--|---------|---------|---------|---------|---------| | _ | - MINTEN2 MINTEN1 MINTEN0 | | MINTEN0 | MINONE3 | MINONE2 | MINONE1 | MINONE0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-x |-------|---------------------------|-------|---------|---------|---------|---------|-------| | _ | — SECTEN2 SECTEN1 SECTEN0 | | SECONE3 | SECONE2 | SECONE1 | SECONE0 | | | 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 **Unimplemented:** Read as '0' bit 14-12 MINTEN<2:0>: Binary Coded Decimal Value of Minute's Tens Digit bits Contains a value from 0 to 5. bit 11-8 MINONE<3:0>: Binary Coded Decimal Value of Minute's Ones Digit bits Contains a value from 0 to 9. bit 7 Unimplemented: Read as '0' bit 6-4 SECTEN<2:0>: Binary Coded Decimal Value of Second's Tens Digit bits Contains a value from 0 to 5. bit 3-0 **SECONE<3:0>:** Binary Coded Decimal Value of Second's Ones Digit bits Contains a value from 0 to 9. TABLE 23-4: dsPIC33F CONFIGURATION BITS DESCRIPTION (CONTINUED) | Bit Field | Description | |--------------|-----------------------------------------------------------------------------------------------------------------------------| | WDTPRE | Watchdog Timer Prescaler bit | | | 1 = 1:128 | | | 0 = 1:32 | | WDTPOST<3:0> | Watchdog Timer Postscaler bits | | | 1111 = 1:32,768 | | | 1110 = 1:16,384 | | | • | | | • | | | | | | 0001 = 1:2<br>0000 = 1:1 | | DLLIZEN | | | PLLKEN | PLL Lock Enable bit | | | 1 = Clock switch to PLL will wait until the PLL lock signal is valid 0 = Clock switch will not wait for the PLL lock signal | | ALTIOC | Alternate I <sup>2</sup> C <sup>TM</sup> Pins bit | | ALTI2C | | | | $1 = I^2C$ is mapped to SDA1/SCL1 pins<br>$0 = I^2C$ is mapped to ASDA1/ASCL1 pins | | ICS<1:0> | ICD Communication Channel Select bits | | 103<1.0> | 11 = Communicate on PGEC1 and PGED1 | | | 10 = Communicate on PGEC1 and PGED1 | | | 01 = Communicate on PGEC3 and PGED3 | | | 00 = Reserved, do not use | | PWMPIN | Motor Control PWM Module Pin Mode bit | | | 1 = PWM module pins controlled by PORT register at device Reset (tri-stated) | | | 0 = PWM module pins controlled by PWM module at device Reset (configured as output pins) | | HPOL | Motor Control PWM High Side Polarity bit | | | 1 = PWM module high side output pins have active-high output polarity | | | 0 = PWM module high side output pins have active-low output polarity | | LPOL | Motor Control PWM Low Side Polarity bit | | | 1 = PWM module low side output pins have active-high output polarity | | | 0 = PWM module low side output pins have active-low output polarity | FIGURE 26-5: TIMER1/2/3 EXTERNAL CLOCK TIMING CHARACTERISTICS TABLE 26-22: TIMER1 EXTERNAL CLOCK TIMING REQUIREMENTS<sup>(1)</sup> | AC CHARACTERISTICS (UI | | | | | d Operating Cotherwise stands temperature | ted)<br>-40° | C ≤ TA ≤ +85°C<br>C ≤ TA ≤ +125°C | for Ind | | |------------------------|-----------|-------------------------------------------------------------------------------------------------------------|--------------------------|----|-------------------------------------------|--------------|-----------------------------------|---------|---------------------------------------------------| | Param<br>No. | Symbol | Charac | eteristic <sup>(2)</sup> | | Min | Тур | Max | Units | Conditions | | TA10 | ТтхН | T1CK High<br>Time | Synchronous<br>mode | | Greater of:<br>20 or<br>(Tcy + 20)/N | _ | _ | ns | Must also meet Parameter TA15, N = prescale value | | | | | Asynchronou | us | 35 | _ | | ns | (1, 8, 64, 256) | | TA11 | TTXL | T1CK Low<br>Time | Synchronous<br>mode | | Greater of:<br>20 ns or<br>(Tcy + 20)/N | _ | _ | ns | Must also meet Parameter TA15, N = prescale value | | | | | Asynchronou | us | 10 | _ | _ | ns | (1, 8, 64, 256) | | TA15 | ТтхР | T1CK Input<br>Period | Synchronous<br>mode | | Greater of:<br>40 or<br>2 Tcy + 40)/N | _ | | ns | N = prescale value<br>(1, 8, 64, 256) | | OS60 | Ft1 | SOSC1/T1CK Oscillator<br>Input Frequency Range<br>(oscillator enabled by setting<br>the TCS (T1CON<1>) bit) | | ng | DC | _ | 50 | kHz | | | TA20 | TCKEXTMRL | Delay from Ex<br>Clock Edge to | | | 0.75 Tcy + 40 | | 1.75 Tcy + 40 | ns | | Note 1: Timer1 is a Type A. 2: These parameters are characterized by similarity, but are not tested in manufacturing. TABLE 26-42: SPIX SLAVE MODE (FULL-DUPLEX, CKE = 1, CKP = 1, SMP = 0) TIMING REQUIREMENTS FOR dsPIC33FJ32(GP/MC)10X | AC CH | ARACTERIS | TICS | Standard Op<br>(unless other<br>Operating ter | erwise st | t <b>ated)</b><br>e -40° | C ≤ TA ≤ | +85°C for Industrial<br>+125°C for Extended | |--------------|-----------------------|----------------------------------------------------------------------------|-----------------------------------------------|--------------------|--------------------------|----------|---------------------------------------------| | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min | Typ <sup>(2)</sup> | Max | Units | Conditions | | SP70 | TscP | Maximum SCKx Input Frequency | _ | | 11 | MHz | See Note 3 | | SP72 | TscF | SCKx Input Fall Time | _ | | _ | ns | See Parameter DO32 and <b>Note 4</b> | | SP73 | TscR | SCKx Input Rise Time | _ | 1 | 1 | ns | See Parameter DO31 and <b>Note 4</b> | | SP30 | TdoF | SDOx Data Output Fall Time | _ | | | ns | See Parameter DO32 and <b>Note 4</b> | | SP31 | TdoR | SDOx Data Output Rise Time | _ | ı | 1 | ns | See Parameter DO31 and <b>Note 4</b> | | SP35 | TscH2doV,<br>TscL2doV | SDOx Data Output Valid after SCKx Edge | _ | 6 | 20 | ns | | | SP36 | TdoV2scH,<br>TdoV2scL | SDOx Data Output Setup to First SCKx Edge | 30 | | | ns | | | SP40 | TdiV2scH,<br>TdiV2scL | Setup Time of SDIx Data Input to SCKx Edge | 30 | | _ | ns | | | SP41 | TscH2diL,<br>TscL2diL | Hold Time of SDIx Data Input to SCKx Edge | 30 | | _ | ns | | | SP50 | TssL2scH,<br>TssL2scL | $\overline{SSx} \downarrow \text{ to SCKx} \uparrow \text{ or SCKx Input}$ | 120 | | 1 | ns | | | SP51 | TssH2doZ | SSx ↑ to SDOx Output<br>High-Impedance | 10 | _ | 50 | ns | See Note 4 | | SP52 | TscH2ssH<br>TscL2ssH | SSx after SCKx Edge | 1.5 Tcy + 40 | _ | _ | ns | See Note 4 | | SP60 | TssL2doV | SDOx Data Output Valid after SSx Edge | _ | _ | 50 | ns | | Note 1: These parameters are characterized, but are not tested in manufacturing. 4: Assumes 50 pF load on all SPIx pins. <sup>2:</sup> Data in "Typ" column is at 3.3V, +25°C unless otherwise stated. <sup>3:</sup> The minimum clock period for SCKx is 91 ns. Therefore, the SCKx clock generated by the master must not violate this specification. TABLE 26-44: SPIX SLAVE MODE (FULL-DUPLEX, CKE = 0, CKP = 0, SMP = 0) TIMING REQUIREMENTS FOR dsPIC33FJ32(GP/MC)10X | AC CHA | ARACTERIST | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \leq \text{TA} \leq +125^{\circ}\text{C}$ for Extended | | | | | | |--------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------------|-----|-------|--------------------------------------| | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min | Typ <sup>(2)</sup> | Max | Units | Conditions | | SP70 | TscP | Maximum SCKx Input Frequency | _ | _ | 11 | MHz | See Note 3 | | SP72 | TscF | SCKx Input Fall Time | _ | | _ | ns | See Parameter DO32 and <b>Note 4</b> | | SP73 | TscR | SCKx Input Rise Time | _ | | _ | ns | See Parameter DO31 and <b>Note 4</b> | | SP30 | TdoF | SDOx Data Output Fall Time | _ | | _ | ns | See Parameter DO32 and <b>Note 4</b> | | SP31 | TdoR | SDOx Data Output Rise Time | _ | | _ | ns | See Parameter DO31 and <b>Note 4</b> | | SP35 | TscH2doV,<br>TscL2doV | SDOx Data Output Valid after SCKx Edge | _ | 6 | 20 | ns | | | SP36 | TdoV2scH,<br>TdoV2scL | SDOx Data Output Setup to First SCKx Edge | 30 | | _ | ns | | | SP40 | TdiV2scH,<br>TdiV2scL | Setup Time of SDIx Data Input to SCKx Edge | 30 | | _ | ns | | | SP41 | TscH2diL,<br>TscL2diL | Hold Time of SDIx Data Input to SCKx Edge | 30 | | _ | ns | | | SP50 | TssL2scH,<br>TssL2scL | SSx ↓ to SCKx ↑ or SCKx Input | 120 | _ | _ | ns | | | SP51 | TssH2doZ | SSx ↑ to SDOx Output<br>High-Impedance | 10 | _ | 50 | ns | See Note 4 | | SP52 | TscH2ssH<br>TscL2ssH | SSx after SCKx Edge | 1.5 Tcy + 40 | | | ns | See Note 4 | - Note 1: These parameters are characterized, but are not tested in manufacturing. - 2: Data in "Typ" column is at 3.3V, +25°C unless otherwise stated. - **3:** The minimum clock period for SCKx is 91 ns. Therefore, the SCKx clock generated by the Master must not violate this specification. - 4: Assumes 50 pF load on all SPIx pins.