

# HIGHLIGHTS

This section of the manual contains the following topics:

| 7.1  | Introduction                          | 7-2  |
|------|---------------------------------------|------|
| 7.2  | CPU Clocking                          | 7-4  |
| 7.3  | Oscillator Configuration Registers    | 7-5  |
| 7.4  | Special Function Registers            | 7-8  |
| 7.5  | Primary Oscillator (Posc)             | 7-16 |
| 7.6  | Internal Fast RC (FRC) Oscillator     | 7-20 |
| 7.7  | Phase-Locked Loop (PLL)               | 7-21 |
| 7.8  | Low-Power Secondary Oscillator (Sosc) |      |
| 7.9  | Low-Power RC (LPRC) Oscillator        |      |
| 7.10 | Auxiliary Oscillator                  | 7-28 |
| 7.11 | Auxiliary Phase-Locked Loop (APLL)    | 7-29 |
| 7.12 | Fail-Safe Clock Monitor (FSCM)        | 7-32 |
| 7.13 | Clock Switching                       | 7-33 |
| 7.14 | Two-Speed Start-up                    | 7-37 |
| 7.15 | Register Maps                         |      |
| 7.16 | Related Application Notes             | 7-39 |
| 7.17 | Revision History                      | 7-40 |

7

**Note:** This family reference manual section is meant to serve as a complement to device data sheets. Depending on the device variant, this manual section may not apply to all dsPIC33E/PIC24E devices.

Please consult the note at the beginning of the "**Oscillator**" chapter in the current device data sheet to check whether this document supports the device you are using.

Device data sheets and family reference manual sections are available for download from the Microchip Worldwide Web site at: http://www.microchip.com

# 7.1 INTRODUCTION

The dsPIC33E/PIC24E oscillator system includes these characteristics:

- Four external and internal oscillator options
- Auxiliary oscillator that provides clock source to the USB module
- On-chip Phase-Locked Loop (PLL) to boost internal operating frequency on select internal and external oscillator sources
- · On-the-fly clock switching between various clock sources
- Doze mode for system power savings
- Fail-Safe Clock Monitor (FSCM) that detects clock failure and permits safe application recovery or shutdown
- Nonvolatile Configuration bits for clock source selection

A block diagram of the dsPIC33E/PIC24E oscillator system is shown in Figure 7-1.



Figure 7-1: **Oscillator System Block Diagram** 

Oscillator

# 7.2 CPU CLOCKING

The system clock (Fosc) source can be provided by one of the following options:

- Primary Oscillator (Posc) on the OSC1 and OSC2 pins
- · Secondary Oscillator (Sosc) on the SOSCI and SOSCO pins
- · Internal Fast RC Oscillator (FRC) with optional clock divider
- Internal Low-Power RC Oscillator (LPRC)
- · Primary Oscillator with PLL
- Internal Fast RC Oscillator with PLL

The system clock source is divided by two to produce the internal instruction cycle clock. In this document, the instruction cycle clock is denoted by Fcy. The timing diagram in Figure 7-2 illustrates the relationship between the system clock (Fosc), the instruction cycle clock (Fcy) and the Program Counter (PC).

The internal instruction cycle clock (FcY) can be output on the OSC2 I/O pin if the Primary Oscillator mode or the HS mode is not selected as the clock source. For more information see **Section 7.5 "Primary Oscillator (Posc)**".





# 7.3 OSCILLATOR CONFIGURATION REGISTERS

Oscillator Configuration registers are located in the program memory space, and are not Special Function Registers (SFRs). These two registers are mapped into program memory space and are programmed at the time of device programming.

#### FOSCSEL: Oscillator Source Selection Register

FOSCSEL selects the initial oscillator source and start-up option. FOSCSEL contains the following Configuration bit:

The FNOSC<2:0> Configuration bits in the Oscillator Source Selection register (FOSCSEL<2:0>) determine the clock source that is used at a Power-on Reset (POR). Thereafter, the clock source can be changed between permissible clock sources with clock switching.

The Internal FRC Oscillator with postscaler (FRCDIVN) is the default (unprogrammed) selection.

#### FOSC: Oscillator Configuration Register

FOSC configures the Primary Oscillator mode, OSCO pin function, peripheral pin select, and the fail-safe and clock switching modes. FOSC contains the following Configuration bits:

- POSCMD (FOSC<1:0>) Configuration bits select the operation mode of the Posc.
- OSCIOFNC (FOSC<2>) Configuration bit selects the OSC2 pin function, except in HS or Medium-Speed Oscillator (XT) mode.

If OSCIOFNC is unprogrammed ('1'), the FCY clock is output on the OSC2 pin. If OSCIOFNC is programmed ('0'), the OSC2 pin becomes a general purpose I/O pin.

Table 7-1 lists the configuration settings that select the device oscillator source and operating mode at a POR.

| Oscillator<br>Source | Oscillator Mode                                 | FNOSC<br>Value | POSCMD<br>Value | Note |
|----------------------|-------------------------------------------------|----------------|-----------------|------|
| S0                   | Fast RC Oscillator (FRC)                        | 000            | XX              | 1    |
| S1                   | Fast RC Oscillator with PLL (FRCPLL)            | 001            | XX              | 1    |
| S2                   | Primary Oscillator (EC)                         | 010            | 00              | 1    |
| S2                   | Primary Oscillator (XT)                         | 010            | 01              |      |
| S2                   | Primary Oscillator (HS)                         | 010            | 10              |      |
| S3                   | Primary Oscillator with PLL (ECPLL)             | 011            | 00              | 1    |
| S3                   | Primary Oscillator with PLL (XTPLL)             | 011            | 01              |      |
| S3                   | Primary Oscillator with PLL (HSPLL)             | 011            | 10              |      |
| S4                   | Secondary Oscillator (SOSC)                     | 100            | XX              | 1    |
| S5                   | Low-Power RC (LPRC) Oscillator                  | 101            | XX              | 1    |
| S6                   | Fast RC Oscillator with ÷ 16 divider (FRCDIV16) | 110            | XX              | 1    |
| S7                   | Fast RC Oscillator with + N divider (FRCDIVN)   | 111            | XX              | 1, 2 |

Table 7-1: Configuration Bit Values for Clock Selection

Note 1: OSC2 pin function is determined by the OSCIOFNC Configuration bit.

2: Default oscillator mode for an unprogrammed (erased) device.

| U                                     | U   | U                | U        | U                                       | U   | U          | U     |  |
|---------------------------------------|-----|------------------|----------|-----------------------------------------|-----|------------|-------|--|
| _                                     | _   | —                | —        | —                                       | _   |            | —     |  |
| bit 15                                |     | •                |          |                                         |     |            | bit 8 |  |
|                                       |     |                  |          |                                         |     |            |       |  |
| R/P                                   | U   | U                | U        | U                                       | R/P | R/P        | R/P   |  |
| IESO                                  | —   | —                | —        | —                                       |     | FNOSC<2:0> |       |  |
| bit 7                                 |     |                  |          |                                         |     |            | bit 0 |  |
|                                       |     |                  |          |                                         |     |            |       |  |
| Legend:                               |     |                  |          |                                         |     |            |       |  |
| R = Readable bit P = Programmable bit |     |                  | able bit | U = Unused bits, program to Logic '1'   |     |            |       |  |
| -n = Value at                         | POR | '1' = Bit is set |          | '0' = Bit is cleared x = Bit is unknown |     |            | nown  |  |

### Register 7-1: FOSCSEL: Oscillator Source Selection Register

bit 15-8 Reserved: Reserved bits must be programmed as '1'

- bit 7 **IESO:** Internal External Start-up Option bit
  - 1 = Start-up device with Internal FRC, then automatically switch to the user-selected oscillator source when ready
  - 0 = Start-up device with user-selected oscillator source
- bit 6-3 **Reserved:** Reserved bits must be programmed as '1'
- bit 2-0 **FNOSC<2:0>:** Initial Oscillator Source Selection bits
  - 111 = Fast RC Oscillator with Divide by N (FRCDIVN)
    - 110 = Fast RC Oscillator with Divide by 16 (FRCDIV16)
    - 101 = Low-Power RC Oscillator (LPRC)
    - 100 = Secondary Oscillator (Sosc)
    - 011 = Primary Oscillator with PLL (XTPLL, HSPLL, ECPLL)
    - 010 = Primary Oscillator (XT, HS, EC)
    - 001 = Fast RC Oscillator with PLL (FRCPLL)
    - 000 = Fast RC Oscillator (FRC)

| U      | U | U | U | U | U | U | U     |
|--------|---|---|---|---|---|---|-------|
| _      | — | _ | — | _ | _ | — | —     |
| bit 15 |   |   |   |   |   |   | bit 8 |

| R/P        | R/P | R/P                    | U | U | R/P      | R/P  | R/P     |
|------------|-----|------------------------|---|---|----------|------|---------|
| FCKSM<1:0> |     | IOL1WAY <sup>(1)</sup> | — | _ | OSCIOFNC | POSC | MD<1:0> |
| bit 7      |     |                        |   |   |          |      | bit 0   |

| Legend:           |                      |                          |                    |
|-------------------|----------------------|--------------------------|--------------------|
| R = Readable bit  | P = Programmable bit | U = Unused bits, program | to Logic '1'       |
| -n = Value at POR | '1' = Bit is set     | '0' = Bit is cleared     | x = Bit is unknown |

| bit 15-8 | <b>December</b> December hits must be pregrammed as '1'  |
|----------|----------------------------------------------------------|
| 0-61 10  | <b>Reserved:</b> Reserved bits must be programmed as '1' |

- 1x = Clock switching is disabled, Fail-Safe Clock Monitor is disabled
- 01 = Clock switching is enabled, Fail-Safe Clock Monitor is disabled
- 00 = Clock switching is enabled, Fail-Safe Clock Monitor is enabled
- bit 5 **IOL1WAY:** Peripheral Pin Select Configuration bit<sup>(1)</sup>
  - 1 = Allow only one reconfiguration
  - 0 = Allow multiple reconfigurations
- bit 4-3 **Reserved:** Reserved bits must be programmed as '1'
- bit 2 **OSCIOFNC:** OSC2 Pin Function bit (except in XT and HS modes) 1 = OSC2 is the clock output and the instruction cycle (FcY) clock is output on the OSC2 pin
  - 0 = OSC2 is a general purpose digital I/O pin
- bit 1-0 **POSCMD<1:0>:** Primary Oscillator Mode Selection bits
  - 11 = Primary oscillator disabled
  - 10 = HS Crystal Oscillator mode
  - 01 = XT Crystal Oscillator mode
  - 00 = EC (External Clock) mode
  - Note 1: The IOL1WAY bit is not available on all dsPIC33E/PIC24E devices. For more information, refer to the specific device data sheet.

# 7.4 SPECIAL FUNCTION REGISTERS

These Special Function Registers provide run-time control and status of the oscillator system:

#### OSCCON: Oscillator Control Register(2)

This register controls clock switching and provides status information that allows current clock source, PLL lock and clock fail conditions to be monitored.

#### CLKDIV: Clock Divisor Register

This register controls the Doze mode and selects the PLL prescaler, PLL postscaler and FRC postscaler.

### • PLLFBD: PLL Feedback Divisor Register

This register selects the PLL feedback divisor.

#### OSCTUN: FRC Oscillator Tuning Register

This register is used to tune the Internal FRC oscillator frequency in software. It allows the FRC oscillator frequency to be adjusted over a range of  $\pm 12\%$ .

#### ACLKCONx: Auxiliary Clock Control Register 1

This register controls and provides prescaler and postscaler values for the Auxiliary PLL module.

#### ACLKDIVx: Auxiliary Clock Control Register 2

This register selects the PLL feedback divisor for the Auxiliary PLL module.

**Note:** The oscillator Special Function Registers (OSCCON, CLKDIV, PLLFBD, OSCTUN, ACLKCONx and ACLKDIVx) are reset only on a Power-on Reset (POR).

| U-0           | R-y                                                                                          | R-y                               | R-y                                                                                | U-0                                     | R/W-y       | R/W-y                                            | R/W-y      |  |  |
|---------------|----------------------------------------------------------------------------------------------|-----------------------------------|------------------------------------------------------------------------------------|-----------------------------------------|-------------|--------------------------------------------------|------------|--|--|
| —             |                                                                                              | COSC<2:0>                         |                                                                                    | _                                       |             | NOSC<2:0>                                        |            |  |  |
| bit 15        |                                                                                              |                                   |                                                                                    |                                         |             |                                                  | bit        |  |  |
| R/S-0         | R/W-0                                                                                        | R-O                               | U-0                                                                                | R/C-0                                   | U-0         | R/W-0                                            | R/W-0      |  |  |
| CLKLOCK       | IOLOCK <sup>(1)</sup>                                                                        | LOCK                              |                                                                                    | CF                                      | _           | LPOSCEN                                          | OSWEN      |  |  |
| bit 7         |                                                                                              |                                   |                                                                                    |                                         |             |                                                  | bit        |  |  |
| Legend:       |                                                                                              | U= Unimplem                       | ented bit, rea                                                                     | ad as '0'                               | y = Depends | on FOSCSEL <f< td=""><td>NOSC&gt; bits</td></f<> | NOSC> bits |  |  |
| R = Readable  | bit                                                                                          | W = Writable                      | bit                                                                                | C = Clearable                           | e bit       | S = Settable b                                   | oit        |  |  |
| -n = Value at | POR                                                                                          | '1' = Bit is set                  |                                                                                    | '0' = Bit is cle                        | ared        | x = Bit is unkn                                  | own        |  |  |
| bit 15        | Unimplemen                                                                                   | ted: Read as '                    | 0'                                                                                 |                                         |             |                                                  |            |  |  |
| bit 14-12     | COSC<2:0>:                                                                                   | Current Oscilla                   | ator Selectior                                                                     | h bits (read-only                       | )           |                                                  |            |  |  |
|               | 101 = Low-Po<br>100 = Second<br>011 = Primary<br>010 = Primary<br>001 = Fast R               | ower RC Oscill<br>dary Oscillator | ator (LPRC)<br>(Sosc)<br>h PLL (XTPL<br>ſ, HS, EC)<br>th PLL (FRCI                 | 16 (FRCDIV16)<br>L, HSPLL, ECP<br>PLL)  |             |                                                  |            |  |  |
| bit 11        | Unimplemen                                                                                   | ted: Read as '                    | 0'                                                                                 |                                         |             |                                                  |            |  |  |
| bit 10-8      | NOSC<2:0>: New Oscillator Selection bits                                                     |                                   |                                                                                    |                                         |             |                                                  |            |  |  |
|               | 110 = Fast R<br>101 = Low-Pc<br>100 = Second<br>011 = Primar<br>010 = Primar<br>001 = Fast R | ower RC Oscill<br>dary Oscillator | th Divide by<br>ator (LPRC)<br>(Sosc)<br>h PLL (XTPL<br>f, HS, EC)<br>th PLL (FRCI | 16 (FRCDIV16)<br>L, HSPLL, ECP          | 'LL)        |                                                  |            |  |  |
| bit 7         |                                                                                              | lock Lock Ena                     |                                                                                    |                                         |             |                                                  |            |  |  |
|               | 1 = Clock swi                                                                                | tching is disabl                  | ed, system c                                                                       | lock source is lo                       | ocked       | SC<7:6>) = 01):<br>by clock switchin             | g          |  |  |
| bit 6         |                                                                                              | ipheral Pin Sel                   |                                                                                    |                                         |             |                                                  |            |  |  |
|               |                                                                                              |                                   |                                                                                    |                                         | 0           | isters are not allo<br>registers are allo        |            |  |  |
| bit 5         | -                                                                                            | ock Status bit                    |                                                                                    |                                         |             | 0                                                |            |  |  |
|               | 1 = Indicates                                                                                | that PLL is in le                 | ock or PLL st                                                                      | tart-up timer is s<br>-up timer is in p |             | is disabled                                      |            |  |  |
| bit 4         |                                                                                              | ted: Read as '                    |                                                                                    |                                         | 0           |                                                  |            |  |  |
| bit 3         | CF: Clock Fai                                                                                |                                   | ad or cleared                                                                      | l by application)                       |             |                                                  |            |  |  |

- **Note 1:** The IOLOCK bit is not available on all dsPIC33E/PIC24E devices. For more information, refer to the specific device data sheet.
  - 2: Writes to this register require an unlock sequence. For more information and examples see 7.13 "Clock Switching".

### **Register 7-3:** OSCCON: Oscillator Control Register<sup>(2)</sup> (Continued)

- bit 2 Unimplemented: Read as '0'
- bit 1 LPOSCEN: Secondary Oscillator (Sosc) Enable bit
  - 1 = Enable secondary oscillator
    - 0 = Disable secondary oscillator
- bit 0 OSWEN: Oscillator Switch Enable bit
  - 1 = Request oscillator switch to selection specified by the NOSC<2:0> bits
  - 0 = Oscillator switch is complete
  - **Note 1:** The IOLOCK bit is not available on all dsPIC33E/PIC24E devices. For more information, refer to the specific device data sheet.
    - 2: Writes to this register require an unlock sequence. For more information and examples see 7.13 "Clock Switching".

| R/W-0        | R/W-0                        | R/W-0                                              | R/W-0         | R/W-0                | R/W-0           | R/W-0               | R/W-1           |  |  |  |  |
|--------------|------------------------------|----------------------------------------------------|---------------|----------------------|-----------------|---------------------|-----------------|--|--|--|--|
| ROI          |                              | DOZE<2:0>                                          |               | DOZEN <sup>(1)</sup> |                 | FRCDIV<2:0>         |                 |  |  |  |  |
| bit 15       |                              |                                                    |               |                      |                 |                     | bit 8           |  |  |  |  |
|              |                              |                                                    |               |                      |                 |                     |                 |  |  |  |  |
| R/W-0        | R/W-0                        | U-0                                                | R/W-0         | R/W-0                | R/W-0           | R/W-0               | R/W-0           |  |  |  |  |
| PLLP         | OST<1:0>                     | —                                                  |               |                      | PLLPRE<4:0      | )>                  |                 |  |  |  |  |
| bit 7        |                              |                                                    |               |                      |                 |                     | bit C           |  |  |  |  |
| Legend:      |                              |                                                    |               |                      |                 |                     |                 |  |  |  |  |
| R = Readab   | le bit                       | W = Writable t                                     | oit           | U = Unimplen         | nented bit, rea | ıd as '0'           |                 |  |  |  |  |
| -n = Value a | t POR                        | '1' = Bit is set                                   |               | '0' = Bit is clea    | ared            | x = Bit is unkno    | own             |  |  |  |  |
| bit 15       |                              | r on Interrupt bit                                 |               |                      |                 |                     |                 |  |  |  |  |
|              |                              | will clear the DC<br>have no effect                |               |                      | ock, and the pe | eripheral clock rat | io is set to 1: |  |  |  |  |
| bit 14-12    | •                            | Processor Cloc                                     |               |                      |                 |                     |                 |  |  |  |  |
| 51( 14-12    | 111 = FCY di                 |                                                    | K INCOUCTION  |                      |                 |                     |                 |  |  |  |  |
|              | 110 <b>= Fcy di</b>          |                                                    |               |                      |                 |                     |                 |  |  |  |  |
|              | 101 <b>= Fcy di</b>          |                                                    |               |                      |                 |                     |                 |  |  |  |  |
|              | 100 = Fcy di<br>011 = Fcy di | •                                                  |               |                      |                 |                     |                 |  |  |  |  |
|              | 010 = FCY di                 |                                                    |               |                      |                 |                     |                 |  |  |  |  |
|              | 001 <b>= Fcy di</b>          |                                                    |               |                      |                 |                     |                 |  |  |  |  |
|              |                              | vided by 1 (defa                                   | ,             |                      |                 |                     |                 |  |  |  |  |
| bit 11       |                              | e Mode Enable                                      |               | otwoon the nori      | aboral clocks   | and the processo    | r clocks        |  |  |  |  |
|              |                              | or clock and peri                                  |               |                      |                 | and the processo    |                 |  |  |  |  |
| bit 10-8     | FRCDIV<2:0                   | >: Internal Fast                                   | RC Oscillato  | or Postscaler bit    | 5               |                     |                 |  |  |  |  |
|              |                              | 111 = FRC divided by 256                           |               |                      |                 |                     |                 |  |  |  |  |
|              |                              | 110 = FRC divided by 64<br>101 = FRC divided by 32 |               |                      |                 |                     |                 |  |  |  |  |
|              | 101 <b>– FRC d</b>           |                                                    |               |                      |                 |                     |                 |  |  |  |  |
|              | 011 <b>= FRC d</b>           | •                                                  |               |                      |                 |                     |                 |  |  |  |  |
|              | 010 = FRC d                  | -                                                  | 14 )          |                      |                 |                     |                 |  |  |  |  |
|              | 001 = FRC d                  | livided by 2 (defa<br>livided by 1                 | auit)         |                      |                 |                     |                 |  |  |  |  |
| bit 7-6      |                              | •                                                  | Dutput Divide | er Select bits (al   | so denoted as   | 'N2', PLL postso    | aler)           |  |  |  |  |
|              | 11 = Output                  |                                                    | ·             |                      |                 | •                   |                 |  |  |  |  |
|              |                              | 10 = Reserved (defaults to output divided by 2)    |               |                      |                 |                     |                 |  |  |  |  |
|              | 01 = Output                  | divided by 2<br>divided by 1 (de <sup>.</sup>      | fault)        |                      |                 |                     |                 |  |  |  |  |
| bit 5        |                              | nted: Read as '0                                   |               |                      |                 |                     |                 |  |  |  |  |
| bit 4-0      | -                            |                                                    |               | ıt Divider Select    | hits (also den  | oted as 'N1', PLL   | nrescaler)      |  |  |  |  |
|              |                              | ut divided by 33                                   |               |                      |                 |                     |                 |  |  |  |  |
|              | •                            | ,                                                  |               |                      |                 |                     |                 |  |  |  |  |
|              | •                            |                                                    |               |                      |                 |                     |                 |  |  |  |  |
|              | •                            |                                                    |               |                      |                 |                     |                 |  |  |  |  |
|              |                              | ut divided by 3                                    |               |                      |                 |                     |                 |  |  |  |  |
|              | 00000 = inpl                 | ut divided by 2 (                                  |               |                      |                 |                     |                 |  |  |  |  |

**Note 1:** This bit is cleared when the ROI bit is set and an interrupt occurs.

Oscillator

| Register 7-5:    | PLLFBD: P                                                                    | LL Feedback I    | Divisor Regis        | ster                        |       |                    |           |  |  |  |
|------------------|------------------------------------------------------------------------------|------------------|----------------------|-----------------------------|-------|--------------------|-----------|--|--|--|
| U-0              | U-0                                                                          | U-0              | U-0                  | U-0                         | U-0   | U-0                | R/W-0     |  |  |  |
| —                | _                                                                            | —                | _                    | —                           | _     | _                  | PLLDIV<8> |  |  |  |
| bit 15           |                                                                              |                  |                      |                             |       |                    | bit 8     |  |  |  |
| R/W-0            | R/W-0                                                                        | R/W-0            | R/W-0                | R/W-0                       | R/W-0 | R/W-0              | R/W-0     |  |  |  |
| N/W-0            | N/W-0                                                                        | N/W-0            | -                    | V<7:0>                      | N/W-0 | N/W-0              | N/W-0     |  |  |  |
| bit 7            |                                                                              |                  | I LLDI               | V ~1.02                     |       |                    | bit C     |  |  |  |
|                  |                                                                              |                  |                      |                             |       |                    |           |  |  |  |
| Legend:          |                                                                              |                  |                      |                             |       |                    |           |  |  |  |
| R = Readable b   | pit                                                                          | W = Writable bit |                      | U = Unimplemented bit, read |       | d as '0'           |           |  |  |  |
| -n = Value at Po | OR                                                                           | '1' = Bit is set | '0' = Bit is cleared |                             | ared  | x = Bit is unknown |           |  |  |  |
|                  |                                                                              |                  | _                    |                             |       |                    |           |  |  |  |
| bit 15-9         | Unimplemented: Read as '0'                                                   |                  |                      |                             |       |                    |           |  |  |  |
| bit 8-0          | PLLDIV<8:0>: PLL Feedback Divisor bits (also denoted as 'M', PLL multiplier) |                  |                      |                             |       |                    |           |  |  |  |
|                  | 11111111 <b>= 513</b>                                                        |                  |                      |                             |       |                    |           |  |  |  |
|                  | •                                                                            |                  |                      |                             |       |                    |           |  |  |  |
|                  | •                                                                            |                  |                      |                             |       |                    |           |  |  |  |
|                  | •                                                                            |                  |                      |                             |       |                    |           |  |  |  |
|                  | 000110000                                                                    | = 50             |                      |                             |       |                    |           |  |  |  |
|                  | •                                                                            |                  |                      |                             |       |                    |           |  |  |  |
|                  | •                                                                            |                  |                      |                             |       |                    |           |  |  |  |
|                  | •                                                                            |                  |                      |                             |       |                    |           |  |  |  |
|                  | 000000010                                                                    |                  |                      |                             |       |                    |           |  |  |  |

# Register 7-5: PLLFBD: PLL Feedback Divisor Register

000000000 = 2 (default)

7

Oscillator

| Register 7-6:    | OSCTUN:           | FRC Oscillator                                        | Tuning Reg  | ister                       |        |                    |       |
|------------------|-------------------|-------------------------------------------------------|-------------|-----------------------------|--------|--------------------|-------|
| U-0              | U-0               | U-0                                                   | U-0         | U-0                         | U-0    | U-0                | U-0   |
| —                | _                 | —                                                     | _           | —                           | —      | —                  | _     |
| bit 15           |                   |                                                       |             |                             |        |                    | bit 8 |
|                  |                   | DAMO                                                  | DANO        | DAMA                        | DAMA   | DAMA               | DAMO  |
| U-0              | U-0               | R/W-0                                                 | R/W-0       | R/W-0                       | R/W-0  | R/W-0              | R/W-0 |
|                  | _                 |                                                       |             | IUN                         | N<5:0> |                    |       |
| bit 7            |                   |                                                       |             |                             |        |                    | bit 0 |
|                  |                   |                                                       |             |                             |        |                    |       |
| Legend:          |                   |                                                       |             |                             |        |                    |       |
| R = Readable b   | it                | W = Writable bit                                      |             | U = Unimplemented bit, read |        | d as '0'           |       |
| -n = Value at PC | DR                | '1' = Bit is set                                      |             | '0' = Bit is cleared        |        | x = Bit is unknown |       |
|                  |                   |                                                       |             |                             |        |                    |       |
| bit 15-6         | Unimpleme         | nted: Read as '                                       | 0'          |                             |        |                    |       |
| bit 5-0          | TUN<5:0>: F       | RC Oscillator                                         | Funing bits |                             |        |                    |       |
|                  |                   | enter frequency                                       |             |                             |        |                    |       |
|                  | 011110 <b>= C</b> | enter frequency                                       | + 11.25% (8 | .20 MHz)                    |        |                    |       |
|                  | •                 |                                                       |             |                             |        |                    |       |
|                  | •                 |                                                       |             |                             |        |                    |       |
|                  | •                 |                                                       |             |                             |        |                    |       |
|                  | 000000 <b>= C</b> | enter frequency<br>enter frequency<br>enter frequency | (7.37 MHz n | ominal)                     |        |                    |       |
|                  | •                 |                                                       |             |                             |        |                    |       |
|                  | •                 |                                                       |             |                             |        |                    |       |
|                  | •                 |                                                       |             |                             |        |                    |       |
|                  | _                 |                                                       |             |                             |        |                    |       |

100001= Center frequency – 11.625% (6.52 MHz) 100000= Center frequency – 12% (6.49 MHz)

| R/W-0           | R/W-0                                                                                                               | R/W-0                                                                                          | R/W-0                                        | R/W-0             | R/W-0                                          | R/W-0            | U-0   |
|-----------------|---------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------|-------------------|------------------------------------------------|------------------|-------|
| ENAPLL          | APLLCK                                                                                                              | SELACLK                                                                                        | AOSC                                         | MD<1:0>           | ASRCSEL                                        | FRCSEL           | _     |
| bit 15          |                                                                                                                     |                                                                                                |                                              |                   |                                                |                  | bit 8 |
| R/W-0           | R/W-0                                                                                                               | R/W-0                                                                                          | U-0                                          | U-0               | R/W-0                                          | R/W-0            | R/W-0 |
|                 | PLLPOST<2:0                                                                                                         |                                                                                                | _                                            | _                 | A                                              | PLLPRE<2:0>      |       |
| bit 7           |                                                                                                                     |                                                                                                |                                              |                   |                                                |                  | bit   |
| Legend:         |                                                                                                                     |                                                                                                |                                              |                   |                                                |                  |       |
| R = Readable    | bit                                                                                                                 | W = Writable I                                                                                 | oit                                          | U = Unimple       | emented bit, read                              | as '0'           |       |
| -n = Value at P | POR                                                                                                                 | '1' = Bit is set                                                                               |                                              | ʻ0' = Bit is cl   |                                                | x = Bit is unkno | own   |
| bit 15          | 1 = APLL is e                                                                                                       | enabled, the US                                                                                | B clock sour                                 | ce is the APLL    | L as USB Clock S<br>output<br>clock to the APL |                  |       |
| bit 14          | APLLCK: AP                                                                                                          | PLL Phase-Lock                                                                                 | ed Status bit                                | :                 |                                                |                  |       |
|                 | 0 = APLL is n                                                                                                       |                                                                                                |                                              |                   |                                                |                  |       |
| bit 13          | SELACLK: S                                                                                                          | Select Auxiliary                                                                               | Clock Source                                 | e for Auxiliary ( | Clock Divider bit                              |                  |       |
|                 |                                                                                                                     |                                                                                                |                                              |                   | k for auxiliary clo<br>ary clock divider       | ck divider       |       |
|                 | 11 = EC (Ext<br>10 = XT (Cry<br>01 = HS (Hig                                                                        | 0>: Auxiliary Osernal Clock) Os<br>stal) Oscillator r<br>h-Speed) Oscill<br>y oscillator disal | cillator mode<br>node select<br>ator mode se | e select<br>elect |                                                |                  |       |
| bit 10          | 1 = Primary c                                                                                                       | Select Reference                                                                               | clock source                                 | for APLL          | t                                              |                  |       |
| bit 9           | -                                                                                                                   | oscillator is the<br>lect FRC as Re                                                            |                                              |                   | DII hit                                        |                  |       |
| bit 9           | 1 = FRC is cl                                                                                                       | ock source for A                                                                               | \PLL                                         |                   | ource for APLL (c                              | letermined by A  |       |
| bit 8           | -                                                                                                                   | -                                                                                              | -                                            |                   |                                                | letermined by F  |       |
| bit 7-5         | Unimplemented: Read as '0'<br>APLLPOST<2:0>: Select PLL VCO Output Divider bits                                     |                                                                                                |                                              |                   |                                                |                  |       |
|                 | 111 = Dividea<br>110 = Dividea<br>101 = Dividea<br>100 = Dividea<br>011 = Dividea<br>010 = Dividea<br>001 = Dividea | d by 2<br>d by 2<br>d by 4<br>d by 8<br>d by 16<br>d by 32                                     |                                              |                   |                                                |                  |       |
| bit 4-3         | Unimplemen                                                                                                          | ted: Read as '                                                                                 | )'                                           |                   |                                                |                  |       |
| bit 2-0         | 111 = Dividea<br>110 = Dividea<br>101 = Dividea<br>100 = Dividea<br>011 = Dividea<br>010 = Dividea<br>001 = Dividea | d by 10<br>d by 6<br>d by 5<br>d by 4<br>d by 3                                                | Detector In                                  | out Divider bits  |                                                |                  |       |

| Register 7-8: | ACLKDIVx: Auxiliary | / Clock Control Register 2 |
|---------------|---------------------|----------------------------|
| Rogiotor / O. | AGENEINA Auxinury   |                            |

| U                                 |     | •                |              | U                                       |          |              |       |
|-----------------------------------|-----|------------------|--------------|-----------------------------------------|----------|--------------|-------|
| U-0                               | U-0 | U-0              | U-0          | U-0                                     | U-0      | U-0          | U-0   |
| —                                 | —   | —                |              |                                         |          |              |       |
| bit 15                            |     |                  |              |                                         |          |              | bit 8 |
|                                   |     |                  |              |                                         |          |              |       |
| U-0                               | U-0 | U-0              | U-0          | U-0                                     | R/W-0    | R/W-0        | R/W-0 |
|                                   |     | —                |              |                                         |          | APLLDIV<2:0> |       |
| bit 7                             |     |                  |              |                                         |          |              | bit 0 |
|                                   |     |                  |              |                                         |          |              |       |
| Legend:                           |     |                  |              |                                         |          |              |       |
| R = Readable bit W = Writable bit |     | bit              | U = Unimplei | mented bit, read                        | l as '0' |              |       |
| -n = Value at P                   | OR  | '1' = Bit is set |              | '0' = Bit is cleared x = Bit is unknown |          | nown         |       |

bit 15-3 Unimplemented: Read as '0'

| bit 2-0 | APLLDIV<2:0>: PLL Feedback Divisor bits (PLL multiplier ratio) |
|---------|----------------------------------------------------------------|
|         | 111 - 94                                                       |

7

# 7.5 PRIMARY OSCILLATOR (Posc)

The Primary Oscillator (Posc) is available on the OSC1 and OSC2 pins of the dsPIC33E/PIC24E device family. This connection enables an external crystal (or ceramic resonator) to provide the clock to the device. Optionally, it can be used with the internal PLL to boost the system frequency (Fosc) to 120 MHz for 60 MIPS execution. The primary oscillator provides three modes of operation.

#### Medium Speed Oscillator (XT Mode)

The XT mode is a medium gain, medium frequency mode used to work with crystal frequencies of 3.5 MHz to 10 MHz.

#### • High-Speed Oscillator (HS Mode)

The HS mode is a high-gain, high-frequency mode used to work with crystal frequencies of 10 MHz to 25 MHz.

#### • External Clock Source Operation (EC Mode)

If the on-chip oscillator is not used, the EC mode allows the internal oscillator to be bypassed. The device clocks are generated from an external source (0.8 MHz to 80 MHz) and input on the OSC1 pin.

The FNOSC<2:0> Configuration bits in the Oscillator Source Selection register (FOSCSEL<2:0>) specify the primary oscillator clock source at Power-on Reset. The POSCMD<1:0> Configuration bits in the Oscillator Configuration register (FOSC<1:0>) specify the Primary Oscillator mode. Table 7-2 provides the options selected by specific bit configurations, which are programmed at the time of device programming.

| FNOSC<br>Value | POSCMD | Primary Oscillator Source and Mode                         |  |  |
|----------------|--------|------------------------------------------------------------|--|--|
| 010            | 00     | rimary Oscillator: External Clock Mode (EC)                |  |  |
| 010            | 01     | Primary Oscillator: Medium Frequency Mode (XT)             |  |  |
| 010            | 10     | Primary Oscillator: High-Frequency Mode (HS)               |  |  |
| 011            | 00     | rimary Oscillator with PLL: External Clock Mode (ECPLL)    |  |  |
| 011            | 01     | Primary Oscillator with PLL: Medium Frequency Mode (XTPLL) |  |  |
| 011            | 10     | Primary Oscillator with PLL: High-Frequency Mode (HSPLL)   |  |  |

Table 7-2: Primary Oscillator Clock Source Options

Figure 7-3 is a recommended crystal oscillator circuit diagram for the dsPIC33E/PIC24E device. Capacitors, C1 and C2, form the load capacitance for the crystal. The optimum load capacitance (CL) for a given crystal is specified by the crystal manufacturer. Load capacitance can be calculated as shown in Equation 7-1.



Figure 7-3: Crystal or Ceramic Resonator Operation (XT or HS Oscillator Mode)

Equation 7-1: Crystal Load Capacitance

$$CL = CS + \frac{C1 \ge C2}{C1 + C2}$$

Note: Where Cs is the stray capacitance.

Assuming C1 = C2, Equation 7-2 gives the capacitor value (C1, C2) for a given load and stray capacitance.

#### Equation 7-2: External Capacitor for Crystal

 $C1 = C2 = 2 \ge (CL - CS)$ 

For more information on crystal oscillators and their operation refer to **Section 7.16** "Related **Application Notes**".

### 7.5.1 Oscillator Start-up Time

As the device voltage increases from Vss, the oscillator will start its oscillations. The time required for the oscillator to start oscillating depends on these factors:

- Crystal and resonator frequency
- Capacitor values used (C1 and C2 in Figure 7-3)
- Device VDD rise time
- · System temperature
- Series resistor value and type if used
- Oscillator mode selection of device (selects the gain of the internal oscillator inverter)
- Crystal quality
- Oscillator circuit layout
- System noise

Figure 7-4 illustrates a plot of a typical oscillator and resonator start-up.

#### Figure 7-4: Example Oscillator and Resonator Start-up Characteristics



To ensure that a crystal oscillator (or ceramic resonator) has started and stabilized, an Oscillator Start-up Timer (OST) is provided with the Primary Oscillator (Posc) and the Secondary Oscillator (Sosc). The OST is a simple, 10-bit counter that counts 1024 cycles before releasing the oscillator clock to the rest of the system. This time-out period is denoted as Tost.

The amplitude of the oscillator signal must reach the VIL and VIH thresholds for the oscillator pins before the OST can begin to count cycles. The TOST interval is required every time the oscillator restarts (that is, on POR, BOR and wake-up from Sleep mode).

After the primary oscillator is enabled, it takes a finite amount of time to start oscillating. This delay is denoted as TOSCD. After TOSCD, the OST timer takes 1024 clock cycles (TOST) to release the clock. The total delay for the clock to be ready is TOSCD + TOST. If the PLL is used, an additional delay is required for the PLL to lock (see Section 7.7 "Phase-Locked Loop (PLL)").

Primary oscillator start-up behavior is illustrated in Figure 7-5, where the CPU begins toggling an I/O pin when it starts execution after the TOSCD + TOST interval.



Figure 7-5: Oscillator Start-up Characteristics

## 7.5.2 Primary Oscillator Pin Functionality

The primary oscillator pins (OSC1 and OSC2) can be used for other functions when the oscillator is not being used. The POSCMD<1:0> Configuration bits in the Oscillator Configuration register (FOSC<1:0>) determine the oscillator pin function. The OSCIOFNC bit (FOSC<2>) determines the OSC2 pin function.

### POSCMD: Primary Oscillator Mode Selection bits:

- 11 = Primary Oscillator mode disabled
- 10 = HS Oscillator mode selected
- 01 = XT Oscillator mode selected
- 00 = External Clock mode selected

### OSCIOFNC: OSC2 Pin Function bit (except in XT and HS modes):

- 1 = OSC2 is the clock output, and the instruction cycle (FcY) clock is output on the OCS2 pin (see Figure 7-6)
- 0 = OSC2 is a general purpose digital I/O pin (see Figure 7-7)

The oscillator pin functions are provided in Table 7-3.

| Oscillator Source    | OSCIOFNC<br>Value | POSCMD<1:0><br>Value | OSC1 <sup>(1)</sup><br>Pin Function | OSC2 <sup>(2)</sup><br>Pin Function |
|----------------------|-------------------|----------------------|-------------------------------------|-------------------------------------|
| Primary OSC Disabled | 1                 | 11                   | Digital I/O                         | Clock Output (FCY)                  |
| Primary OSC Disabled | 0                 | 11                   | Digital I/O                         | Digital I/O                         |
| HS                   | х                 | 10                   | OSC1                                | OSC2                                |
| XT                   | х                 | 01                   | OSC1                                | OSC2                                |
| EC                   | 1                 | 00                   | OSC1                                | Clock Output (FCY)                  |
| EC                   | 0                 | 00                   | OSC1                                | Digital I/O                         |

Table 7-3: Clock Pin Function Selection

**Note 1:** OSC1 pin function is determined by the Primary Oscillator Mode (POSCMOD<1:0>) Configuration bits.

**2:** OSC2 pin function is determined by the Primary Oscillator Mode (POSCMOD<1:0>) and the OSC2 Pin Function (OSCIOFNC) Configuration bits.





### Figure 7-7: OSC2 Pin for Digital I/O (in EC Mode)



# 7.6 INTERNAL FAST RC (FRC) OSCILLATOR

The Internal Fast RC (FRC) oscillator provides a nominal 7.37 MHz clock without requiring an external crystal or ceramic resonator, which results in system cost savings for applications that do not require a precise clock reference.

The application software can tune the frequency of the oscillator from -12% to +11.625% (30 kHz steps) of the nominal frequency value using the FRC Oscillator Tuning bits (TUN<5:0>) in the FRC Oscillator Tuning register (OSCTUN<5:0>).

**Note:** Refer to the specific device data sheet for the accuracy of the FRC clock frequency over temperature and voltage variations.

The internal FRC oscillator starts immediately. Unlike a crystal oscillator, which can take several milliseconds to begin oscillation, the Internal FRC starts oscillating immediately.

The Initial Oscillator Source Selection Configuration bits (FNOSC<2:0>) in the Oscillator Source Selection register (FOSCSEL<2:0>) select the FRC clock source. The FRC clock source options at the time of a Power-on Reset are provided in Table 7-4. The Configuration bits are programmed at the time of device programming.

| FNOSC<2:0> Value | Primary Oscillator Source and Mode                 |
|------------------|----------------------------------------------------|
| 000              | FRC Oscillator (FRC)                               |
| 001              | FRC Oscillator with PLL (FRCPLL)                   |
| 110              | FRC Oscillator: Postscaler divide by 16 (FRCDIV16) |
| 111              | FRC Oscillator: Postscaler divide by N (FRCDIVN)   |

Table 7-4: FRC Clock Source Options

### 7.6.1 FRC Postscaler Mode (FRCDIVN)

In FRC Postscaler mode, a variable postscaler divides the FRC clock output and allows a lower frequency to be chosen. The postscaler is controlled by the Internal Fast RC Oscillator Postscaler bits (FRCDIV<2:0>) in the Clock Divisor register (CLKDIV<10:8>), which allows 8 settings, from 1:1 to 1:256, to be chosen.

| Table 7-5: | Internal Fast RC Oscillator Postscaler Settings |
|------------|-------------------------------------------------|
|------------|-------------------------------------------------|

| FRCDIV<2:0> Value | Internal FRC Oscillator Settings |
|-------------------|----------------------------------|
| 000               | FRC divide by 1                  |
| 001               | FRC divide by 2 (default)        |
| 010               | FRC divide by 4                  |
| 011               | FRC divide by 8                  |
| 100               | FRC divide by 16                 |
| 101               | FRC divide by 32                 |
| 110               | FRC divide by 64                 |
| 111               | FRC divide by 256                |

Optionally, the FRC postscaler output can be used with the internal PLL to boost the system frequency (Fosc) to 120 MHz for 60 MIPS instruction cycle execution speed.

**Note:** The FRC divider should not be changed dynamically when operating in internal FRC with PLL.

- To change the FRC divider:
- 1. Switch the clock to non-PLL mode (for example, Internal FRC).
- 2. Make the necessary changes.
- 3. Switch the clock back to the PLL mode.

# 7.7 PHASE-LOCKED LOOP (PLL)

The primary oscillator and Internal FRC oscillator sources can optionally use an on-chip PLL to obtain higher operating speeds. Figure 7-8 illustrates a block diagram of the PLL module.





For PLL operation, the Phase Frequency Detector (PFD) input frequency and Voltage Controlled Oscillator (VCO) output frequency must meet the following requirements:

- The PFD input frequency (FREF) must be in the range of 3 MHz to 5.5 MHz
- The VCO output frequency (Fvco) must be in the range of 120 MHz to 340 MHz

The PLL Phase Detector Input Divider Select bits (PLLPRE<4:0>) in the Clock Divisor register (CLKDIV<4:0>) specify the input divider ratio (N1), which is used to scale down the input clock (FIN) to meet the PFD input frequency range of 3 MHz to 5.5 MHz.

The PLL Feedback Divisor bits (PLLDIV<8:0>) in the PLL Feedback Divisor register (PLLFBD<8:0>) specify the divider ratio (M), which scales down the VCO frequency (Fvco) for feedback to the PFD. The VCO frequency (Fvco) is 'M' times the input reference clock (FREF).

The PLL VCO Output Divider Select bits (PLLPOST<1:0>) in the Clock Divisor register (CLKDIV<7:6>) specify the divider ratio (N2) to limit the system clock frequency (Fosc) to 120 MHz.

Equation 7-3 provides the relation between input frequency (FIN) and output frequency (FOSC).

Equation 7-3: Fosc Calculation

 $Fosc = FIN \times \left(\frac{M}{N1 \times N2}\right) = FIN \times \left(\frac{(PLLDIV + 2)}{(PLLPRE + 2) \times 2(PLLPOST + 1)}\right)$ Where, N1 = PLLPRE + 2 $N2 = 2 \times (PLLPOST + 1)$ M = PLLDIV + 2

Equation 7-4 provides the relation between input frequency (FIN) and VCO frequency (FVCO).

Equation 7-4: Fvco Calculation

$$FVCO = FIN \times \left(\frac{M}{N1}\right) = FIN \times \left(\frac{(PLLDIV + 2)}{(PLLPRE + 2)}\right)$$

## 7.7.1 Input Clock Limitation at Start-up for PLL Mode

Table 7-6 provides the default values of the PLL Prescaler, PLL Postscaler and PLL Feedback Divisor Configuration bits at Power-on Reset.

Table 7-6: PLL Mode Defaults

| Register    | Bit Field    | Value at POR Reset | PLL Divider Ratio |
|-------------|--------------|--------------------|-------------------|
| CLKDIV<4:0> | PLLPRE<4:0>  | 00000              | N1 = 2            |
| CLKDIV<7:6> | PLLPOST<1:0> | 00                 | N2 = 1            |
| PLLFBD<8:0> | PLLDIV<8:0>  | 000000000          | M = 2             |

Given these Reset values, the following equations provide the relationship between input frequency (FIN) and PFD input frequency (FREF), VCO frequency (FVCO) and system clock frequency (FOSC) at Power-on Reset.

Equation 7-5: FREF at Power-on Reset

$$FREF = FIN\left(\frac{1}{N1}\right) = 0.5(FIN)$$

Equation 7-6: Fvco at Power-on Reset

$$Fvco = Fin\left(\frac{M}{N1}\right) = Fin\left(\frac{2}{2}\right) = Fin$$

Equation 7-7: Fosc at Power-on Reset

$$FOSC = FIN\left(\frac{M}{N1 \cdot N2}\right) = FIN$$

To use the PLL and to ensure that the PFD input frequency (FREF) and the VCO frequency are in the specified frequency range to meet the PLL requirements follow these process:

- 1. Power-up the device with the internal FRC or the primary oscillator without PLL.
- 2. Change the PLLDIV, PLLPRE and PLLPOST bit values, based on the input frequency, to meet these PLL requirements:
  - The PFD input frequency (FREF) must be in the range of 3.0 MHz to 5.5 MHz
  - The VCO output frequency (Fvco) must be in the range of 120 MHz to 340 MHz
- 3. Switch the clock to the PLL mode in software.

# 7.7.2 PLL Lock Status

Whenever the PLL input frequency, the PLL prescaler or the PLL feedback divisor is changed, the PLL requires a finite amount of time (TLOCK) to synchronize to the new settings.

TLOCK is applied when the PLL is selected as the clock source at Power-on Reset, or during a clock switching operation. The value of TLOCK is relative to the time at which the clock is available to the PLL input. For example, with the POSC, TLOCK starts after the OST delay. For more information about oscillator start-up delay, see **Section 7.5.1 "Oscillator Start-up Time"**. Also, refer to the specific device data sheet for more information about typical TLOCK values.

The LOCK bit in the Oscillator Control register (OSCCON<5>) is a read-only status bit that indicates the lock status of the PLL. The LOCK bit is cleared at Power-on Reset, and on a clock switch operation, when the PLL is selected as the destination clock source. It remains clear when any clock source not using the PLL is selected. It is advisable to wait for the LOCK bit to be set before executing other code after a clock switch event in which the PLL is enabled.

**Note:** PLL Prescaler (PLLPRE) and PLL Feedback Divisor (PLLDIV) bits should not be changed when operating in PLL mode. You must clock switch to a non-PLL mode (e.g., Internal FRC) to make the necessary changes and then clock switch back to the PLL mode.

### 7.7.2.1 SETUP FOR USING PLL WITH PRIMARY OSCILLATOR (Posc)

The following process is used to set up the PLL to operate the device at 60 MIPS with a 10 MHz external crystal:

1. To execute instructions at 60 MHz, ensure that the required system clock frequency is:

 $Fosc = 2 \times Fcy = 120 \text{ MHz}$ 

- 2. To set up the PLL and meet the requirements of the PLL, follow these steps:
  - a) Select the PLL postscaler to meet the VCO output frequency requirement (120 MHz < FvcO < 340 MHz).
    - Select a PLL postscaler ratio of N2 = 2
    - Ensure that Fvco = (Fosc x N2) = 240 MHz
  - b) Select the PLL prescaler to meet the PFD input frequency requirement (3 MHz < FREF < 5.5 MHz).</li>
    - Select a PLL prescaler ratio of N1 = 2
    - Ensure that FREF = (FIN ÷ N1) = 5 MHz
  - c) Select the PLL feedback divisor to generate the required VCO output frequency based on the PFD input frequency.
    - FVCO = FREF x M
    - M = Fvco ÷ Fref = 48
  - d) Configure the FNOSC<2:0> bits (FOSCSEL<2:0>) to select a clock source without the PLL (for example, Internal FRC) at Power-on Reset.
  - e) In the main program, change the PLL prescaler, PLL postscaler and PLL feedback divisor values to those just decided on in the previous steps, and then perform a clock switch to the PLL mode.

Example 7-1 illustrates code for using the PLL with the primary oscillator. (See also **Section 7.13 "Clock Switching"** for example code for clock switching.)

7

#### Example 7-1: Code Example for Using PLL with Primary Oscillator (Posc)

```
// Select Internal FRC at POR
FOSCSEL (FNOSC FRC);
// Enable Clock Switching and Configure POSC in XT mode
FOSC (FCKSM CSECMD & OSCIOFNC OFF & POSCMD XT);
int main()
// Configure PLL prescaler, PLL postscaler, PLL divisor
                       // M=48
PI_{J}FBD=46:
                                // N2=2
// N1=2
CLKDIVbits.PLLPOST=0;
CLKDIVbits.PLLPRE=0;
// Initiate Clock Switch to Primary Oscillator with PLL (NOSC=0b011)
_builtin_write_OSCCONH(0x03);
builtin write OSCCONL(0x01);
// Wait for Clock switch to occur
while (OSCCONbits.COSC!= 0b011)
// Wait for PLL to lock
while (OSCCONbits.LOCK!= 1) {};
}
```

### 7.7.2.2 SETUP FOR USING PLL WITH 7.37 MHz INTERNAL FRC

The following process is used to set up the PLL to operate the device at 60 MIPS with a 7.37 MHz Internal FRC.

1. To execute instruction at 60 MHz, ensure that the system clock frequency is:

Fosc = 2 x Fcy = 120 MHz

- 2. To set up the PLL and meet the requirements of the PLL, follow these steps:
  - a) Select the PLL postscaler to meet VCO output frequency requirement (120 MHz < Fvco < 340 MHz).
    - Select a PLL postscaler ratio of N2 = 2
    - Ensure that Fvco = (Fosc x N2) = 240 MHz
  - b) Select the PLL prescaler to meet PFD input frequency requirement (3 MHz < FREF < 5.5 MHz).
    - Select a PLL prescaler ratio of N1 = 2
    - Ensure that FREF = (FIN ÷ N1) = 3.68 MHz
  - c) Select the PLL feedback divisor to generate required VCO output frequency based on the PFD input frequency.
    - FVCO = FREF x M
    - M = Fvco ÷ Fref = 65
  - d) Configure the FNOSC<2:0> bits (FOSCSEL<2:0>) to select a clock source without PLL (for example, Internal FRC) at Power-on Reset.
  - e) In the main program, change the PLL prescaler, PLL postscaler and PLL feedback divisor to meet the user and PLL requirement, and then perform clock switch to the PLL mode.

Example 7-2 illustrates code for using PLL with a 7.37 MHz Internal FRC. (See also **Section 7.13 "Clock Switching"** for example code for clock switching.)

```
Example 7-2: Code Example for Using PLL with 7.37 MHz Internal FRC
```

```
// Select Internal FRC at POR
FOSCSEL (FNOSC FRC);
// Enable Clock Switching and Configure Primary Oscillator in XT mode
_FOSC(FCKSM_CSECMD & OSCIOFNC_OFF & POSCMD_XT);
int main()
{
// Configure PLL prescaler, PLL postscaler, PLL divisor
                       // M=65
PLLFBD=63;
                                // N2=2
CLKDIVbits.PLLPOST=0;
                                // N1=2
CLKDIVbits.PLLPRE=0;
// Initiate Clock Switch to FRC oscillator with PLL (NOSC=0b001)
_builtin_write_OSCCONH(0x01);
builtin write OSCCONL(0x01);
// Wait for Clock switch to occur
while (OSCCONbits.COSC!= 0b001)
// Wait for PLL to lock
while (OSCCONbits.LOCK!= 1) {};
```

# 7.8 LOW-POWER SECONDARY OSCILLATOR (Sosc)

The Low-Power Secondary Oscillator (SOSC) enables a 32.768 kHz watch crystal to be attached to the dsPIC33E/PIC24E device as a secondary crystal clock source for low-power operation. It uses the SOSCI and SOSCO pins. The low-power secondary oscillator can also drive Timer1 for Real-Time Clock (RTC) applications.

## 7.8.1 Secondary Oscillator for System Clock

The low-power secondary oscillator is enabled as the system clock when:

- The Initial Oscillator Source Selection Configuration bits (FNOSC<2:0>) in the Oscillator Source Selection register (FOSCSEL<2:0>) are appropriately set to select the secondary oscillator at a Power-on Reset
- The user-assigned software initiates a clock switch to the secondary oscillator for low-power operation.

If the low-power secondary oscillator is not used to provide the system clock, or if the device enters Sleep mode, it is disabled to save power.

### 7.8.2 Secondary Oscillator Start-up Delay

When the low-power secondary oscillator is enabled, it takes a finite amount of time to start oscillating. Refer to **Section 7.5.1 "Oscillator Start-up Time"** for details.

### 7.8.3 Continuous Secondary Oscillator Operation

Optionally, you can leave the secondary oscillator running at all times. The secondary oscillator is always enabled if the Secondary Oscillator Enable bit (LPOSCEN) is set in the Oscillator Control register (OSCCON<1>).

There are two reasons to leave the low-power secondary oscillator running:

- Keeping the oscillator on at all times allows a fast switch to the 32 kHz system clock for lower power operation. Returning to the faster main oscillator still requires an oscillator start-up time if it is a crystal type source. For more information, see Section 7.5.1 "Oscillator Start-up Time".
- The oscillator should remain on at all times when Timer1 is being used as a Real-Time Clock.
  - Note: In Sleep mode, all clock sources (Primary Oscillator, Internal FRC and LPRC Oscillator) are shut down, with the exception of the low-power secondary oscillator. The low-power secondary oscillator can be active in Sleep mode if the Secondary Oscillator Enable bit (LPOSCEN) is set in the Oscillator Control register (OSCCON<1>).

# 7.9 LOW-POWER RC (LPRC) OSCILLATOR

The Low-Power RC (LPRC) oscillator provides a nominal clock frequency of 32 kHz. The LPRC is the clock source for the Power-up Timer (PWRT), Watchdog Timer (WDT) and Fail-safe Clock Monitor (FSCM) circuits. It can also be used to provide a low-frequency clock source option for the device in those applications where power consumption is critical and timing accuracy is not required.

**Note:** The clock frequency of the LPRC oscillator will vary depending on the device voltage and operating temperature. Refer to the "**Electrical Characteristics**" section in the specific device data sheet for more information.

# 7.9.1 LPRC Oscillator for System Clock

The LPRC oscillator is selected as the system clock when:

- The Initial Oscillator Source Selection bits (FNOSC<2:0>) in the Oscillator Source Selection register (FOSCSEL<2:0>) are appropriately set to select the LPRC oscillator at Power-on Reset
- User-assigned software initiates a clock switch to the LPRC oscillator for low-power operation

# 7.9.2 Enabling the LPRC Oscillator

The LPRC oscillator is the clock source for the PWRT, WDT and FSCM. The LPRC oscillator is enabled at Power-on Reset, if the Power-on Reset Timer Value Select bits (FPWRT<2:0>) in the POR Configuration Fuse register (FPOR<2:0>) are programmed to a non-zero value.

The LPRC oscillator remains enabled under these conditions:

- The FSCM is enabled.
- The WDT is enabled.
- The LPRC oscillator is selected as the system clock.

If none of these conditions is true, the LPRC oscillator shuts off after the PWRT expires. The LPRC oscillator is shut off in Sleep mode.

**Note:** LPRC runs in Sleep mode only if the Watchdog Timer is enabled. Under all other conditions, LPRC is disabled in Sleep mode.

## 7.9.3 LPRC Oscillator Start-up Delay

The LPRC oscillator starts up immediately, unlike a crystal oscillator, which can take several milliseconds to begin oscillation.

# 7.10 AUXILIARY OSCILLATOR

The Auxiliary Oscillator (ACLK) is used by other device modules, for example, the Universal Serial Bus (USB) module, which needs to operate at a frequency unrelated to the system clock. The auxiliary oscillator can use one of the following as its clock source:

- Crystal (XT): Crystal and ceramic resonators in the range of 3.5 MHz to 10 MHz
- High-Speed Crystal (HS): Crystals in the range of 10 Hz to 40 Hz. The external crystal is connected to the SOSCI and SOSCO pins
- External Clock (EC): External clock signal up to 64 MHz. The external clock signal is directly applied to the SOSCI pin

### 7.10.1 Enabling the Auxiliary Oscillator

To enable the Auxiliary Oscillator mode, the Enable Auxiliary PLL bit (ENAPLL) must be set in the Auxiliary Clock control register (ACLKCONx<15>). The Auxiliary Oscillator Mode bits (AOSCMD<1:0>) allow four oscillator mode settings, as listed in Table 7-7.

 Table 7-7:
 Auxiliary Oscillator and External Oscillator Mode Settings

| AOSCMD<1:0> Bit Value | Oscillator Mode Setting                         |
|-----------------------|-------------------------------------------------|
| 11                    | EC (External Clock) Mode Select                 |
| 10                    | XT (Crystal) Oscillator Mode Select             |
| 01                    | HS (High-Speed) Oscillator Mode Select          |
| 00                    | Auxiliary Oscillator Disabled (default setting) |

**Note:** By default, the USB module is clocked by the primary oscillator with PLL.

### 7.10.2 Auxiliary Clock Source

The desired reference clock source for the auxiliary PLL can be selected by setting the appropriate clock source select bits in the Auxiliary Clock Control Register 1 (ACLKCONx).

Set the Auxiliary Reference Clock Select bit (ASRCSEL) to use the primary oscillator as the clock source or clear this bit to use the auxiliary oscillator as the clock source.

Set the FRC Select bit (FRCSEL) to use the FRC as the clock source, or clear this bit to use the auxiliary or primary oscillator selected by the ASRCSEL bit as the clock source.

Set the Select Clock Source to Auxiliary Clock Divider bit (SELACLK) in the Auxiliary Clock Control Register 1 (ACLKCONx) to select the auxiliary PLL or oscillators to provide the clock source for the auxiliary clock divider.

Clearing the SELACLK bit will cause the primary PLL output to act as the clock source to the auxiliary clock divider.

# 7.11 AUXILIARY PHASE-LOCKED LOOP (APLL)

The auxiliary oscillator uses an on-chip PLL to obtain different auxiliary clock speeds. Figure 7-9 shows a block diagram of the APLL module.





For operation of the APLL, the Auxiliary Phase Frequency Detector (APFD) input frequency and the Auxiliary Voltage Controlled Oscillator (Avco) output frequency must meet the following requirements:

- The APFD input frequency (AFREF) must be in the range of 3 MHz to 5.5 MHz.
- The AVCO output frequency (AFvco) must be in the range of 60 MHz to 120 MHz.

The APLL Phase Detector Input Divider bits (APLLPRE<2:0>) in the Auxiliary Clock Control Register 1 (ACLKCONx<2:0>) specify the input divider ratio (N1), which is used to scale down the Auxiliary PLL Input (AFIN) clock to meet the APFD input frequency range of 3 MHz to 5.5 MHz.

The Auxiliary PLL Feedback Divisor bits (APLLDIV<2:0>) in the Auxiliary Clock Control Register 2 (ACLKDOVx<2:0>) specify the divider ratio (M), which scales down the Avco frequency (AFvco) for feedback to the APFD. The Avco frequency (AFvco) is M times the APFD input frequency (AFREF).

The APLL VCO Output Divider Select bits (APLLPOST<2:0>) in the Auxiliary Clock Control Register 1 (ACLKCONx<7:5>) specify the divider ratio (N2).

The correct combination of the APLL Phase Detector Input Divider bits (APLLPRE<2:0>), the Auxiliary PLL Feedback Divisor bits (APLLDIV<2:0>), and the APLL VCO Output Divider bits (APLLPOST<2:0>) will provide the 48 MHz Auxiliary Clock (ACLK) frequency needed by the USB module.

Equation 7-8 shows the relationship between the Auxiliary PLL Input (AFIN) clock frequency and the Auxiliary Clock (ACLK) frequency.

Equation 7-8: ACLK Calculation

$$ACLK = AFIN \times \left(\frac{M}{N1 \times N2}\right)$$
  
=  $AFIN \times \frac{(APLLDIV + 15)}{(APLLPRE + 1)(APLLPOST + 1)}$   
Where,  
 $N1 = APLLPRE + 1$   
 $N2 = APLLPOST + 1$   
 $M = APLLDIV + 15$ 

Note: When APLLDIV<2:0> = 111, substitute (APLLDIV + 15) with (APLLDIV + 18) in Equation 7-8.

Equation 7-9 shows the relationship between the Auxiliary PLL Input (AFIN) clock frequency and the Avco Frequency (AFvco).

#### Equation 7-9: AFvco Calculation

$$AFVCO = AFIN \times \left(\frac{M}{N}\right)$$
$$= AFIN \times \left(\frac{(PLLDIV + 15)}{(APLLPRE + 1)}\right)$$

### 7.11.1 APLL Lock Status

Whenever the APLL input frequency, the APLL Phase Detector Input Divider bits (APLLPRE<2:0>), the Auxiliary PLL Feedback Divisor bits (APLLDIV<2:0>) and the APLL VCO Output Divider bits (APLLPOST<2:0>) are changed, the APLL requires a finite amount of time to synchronize to the new settings.

The Auxiliary PLL Lock status bit (APLLCK) in the Auxiliary Clock Control Register 1 (ACLKCONx<14>) is a read-only status bit that indicates the lock status of the APLL. The lock status bit is cleared at Power-on Reset or during an auxiliary clock switch operation.

7.11.1.1 SETUP FOR USING APLL WITH AUXILIARY OSCILLATOR

- 1. Clear the ASRCSEL bit to choose the auxiliary oscillator as the clock source for the APLL.
- 2. Clear the FRCSEL bit to choose the auxiliary oscillator at the clock source for the APLL.
- 3. Set the SELACLK bit to choose the auxiliary PLL or oscillators to provide the source clock for the auxiliary clock divider.
- 4. Follow these steps to configure the APLL Phase Detector Input Divider bits (APLLPRE<2:0>), the Auxiliary PLL Feedback Divisor bits (APLLDIV<2:0>) and the APLL VCO Output Divider bits (APLLPOST<2:0>) to set up the APLL for a 48 MHz ACLK (used by the USB module) using an 8 MHz auxiliary oscillator:
  - a) Select the APLL VCO output divider to meet the Avco output frequency requirement (60 MHz < Fvco < 120 MHz).
    - Select an APLL VCO output divider ratio of N2 = 2
    - Ensure that Fvco = (ACLK x N2) = 96 MHz
  - b) Select the APLL phase detector input divider to meet the APFD input frequency requirement (3 MHz < FREF < 5.5 MHz).
    - Select an APLL phase detector input divider ratio of N1 = 2
    - Ensure that AFREF = (AFIN ÷ N1) = 4 MHz
  - c) Select the auxiliary PLL feedback divisor to generate the required VCO output frequency based on the PFD input frequency.
    - AFvco = AFref x M
    - M = AFvco ÷ AFref = 24
- 5. Enable the auxiliary PLL by setting the ENAPLL bit.

Example 7-3 provides code for using the APLL with the auxiliary oscillator.

#### Example 7-3: Code Example for Using the APLL with the Auxiliary Oscillator

### 7.11.1.2 SETUP FOR USING APLL WITH PRIMARY OSCILLATOR

- 1. Set the ASRCSEL bit to choose the primary oscillator as the clock source for the APLL.
- 2. Clear the FRCSEL bit to choose the primary oscillator as the clock source for the APLL.
- 3. Set the SELACLK bit to choose the auxiliary PLL or oscillators to provide the clock source for the auxiliary clock divider.
- 4. Follow these steps to configure the APLL Phase Detector Input Divider bits (APLL-PRE<2:0>), the Auxiliary PLL Feedback Divisor bits (APLLDIV<2:0>) and the APLL VCO Output Divider bits (APLLPOST<2:0>) to set up the APLL for a 48 MHz ACLK (used by the USB module) using an 8 MHz auxiliary oscillator:
  - a) Select the APLL VCO output divider to meet the Avco output frequency requirement (60 MHz < Fvco < 120 MHz).</li>
    - Select an APLL VCO output divider ratio of N2 = 2
    - Ensure that Fvco = (ACLK x N2) = 96 MHz
  - b) Select the APLL phase detector input divider to meet the APFD input frequency requirement (3 < FREF < 5.5 MHz).
    - Select an APLL phase detector input divider ratio of N1 = 2
    - Ensure that AFREF = (AFIN ÷ N1) = 4 MHz
  - c) Select the auxiliary PLL feedback divisor to generate the required VCO output frequency based on the PFD input frequency.
    - AFVCO = AFREF x M
    - M=AFvco ÷ AFref = 24
- 5. Enable the auxiliary PLL by setting the ENAPLL bit.

Example 7-4 provides code for using the APLL with the primary oscillator.

Example 7-4: Code Example for Using the APLL with the Primary Oscillator

# 7.12 FAIL-SAFE CLOCK MONITOR (FSCM)

The Fail-Safe Clock Monitor (FSCM) allows the device to continue to operate in the event of an oscillator failure. The FSCM function is enabled by programming the Clock Switching Mode Configuration bits (FCKSM<1:0>) in the Oscillator Configuration register (FOSC<7:6>) at the time of device programming. When FSCM is enabled (FCKSM<1:0> = 00), the LPRC internal oscillator will run at all times (except during the Sleep mode).

The FSCM monitors the system clock. If it does not detect a system clock within a specific period of time (typically 2 ms, maximum 4 ms), it generates a clock failure trap and switches the system clock to the FRC oscillator. The user-assigned application has the option to either attempt to restart the oscillator or execute a controlled shutdown.

**Note:** When the device is in Sleep mode, if the clock fails, the FSCM does not wake-up the device.

The FSCM module takes the following actions when it switches to the FRC oscillator:

- The Current Oscillator Selection COSC<2:0> bits (OSCCON<14:12>) are loaded with '000' (Internal FRC).
- The Clock Fail (CF) detect bit (OSCCON<3>) is set to indicate the clock failure.
- The Oscillator Switch Enable (OSWEN) control bit (OSCCON<0>) is cleared to cancel any pending clock switches.

# 7.12.1 FSCM Delay

The FSCM monitors the system clock for activity after the system clock is ready and the nominal delay (TFSCM) has elapsed.

The FSCM delay (TFSCM) is applied when the FSCM is enabled and the primary or secondary oscillator is selected as the system clock.

For more information, refer to **Section 8. "Reset"** (DS70192). For the recent documentation, visit Microchip web site at www.microchip.com.

**Note:** Refer to the "**Electrical Characteristics**" section of the specific device data sheet for TFSCM values.

## 7.12.2 FSCM and WDT

The FSCM and WDT use the LPRC oscillator as their time base. In the event of a clock failure, the WDT is unaffected and continues to run on the LPRC.

# 7.13 CLOCK SWITCHING

Clock switching can be initiated as a result of a hardware event or a software request. A typical scenario includes:

- Two-Speed Start-up sequence upon Power-on Reset, which initially uses the internal FRC oscillator for quick start-up and then automatically switches to the selected clock source when the clock is ready.
- Fail-Safe Clock Monitor automatically switches to the Internal FRC oscillator on a clock failure.
- User-assigned application software requests clock switching by setting the OSWEN bit (OSCCON<0>), causing the hardware to switch to the clock source selected by the NOSC<2:0> bits (OSCCON<10:8>) when the clock is ready.

In each of these cases, the clock switch event assures that the proper make-before-break sequence is executed. That is, the new clock source is ready before the old clock is deactivated and code continues to execute as clock switching occurs.

Certain dsPIC33E/PIC24E devices feature the Phase-Locked Loop Enable (PLLKEN) bit in the Fuse Configuration register (FWDT<5>). Setting this bit will cause the device to wait until the PLL locks before switching to the PLL clock source. When this bit is set to '0', the device will not wait for the PLL lock and will proceed with the clock switch. The default setting for this bit is '1'. Refer to **Section 25. "Device Configuration"** (DS70194) for more information.

With few limitations, applications are free to switch between any of the four clock sources (Posc, Sosc, FRC and LPRC) under software control at any time. To limit the possible side effects that could result from this flexibility, dsPIC33E/PIC24E devices have a safeguard lock built into the switch process. That is, the OSCCON register is write-protected during clock switching.

### 7.13.1 Enabling Clock Switching

The Clock Switching Mode Configuration bits (FCKSM<1:0>) in the Oscillator Configuration register (FOSC<7:6>) must be programmed to enable clock switching and the Fail-Safe Clock Monitor (see Table 7-8).

| FCKSM<1:0> Values | Clock Switching<br>Configuration | FSCM Configuration |
|-------------------|----------------------------------|--------------------|
| 1x                | Disabled                         | Disabled           |
| 01                | Enabled                          | Disabled           |
| 00                | Enabled                          | Enabled            |

 Table 7-8:
 Configurable Clock Switching Modes

The first bit determines if clock switching is enabled ('0') or disabled ('1'). The second bit determines if the FSCM is enabled ('0') or disabled ('1'). FSCM can only be enabled if clock switching is also enabled. If clock switching is disabled ('1'), the value of the second bit is irrelevant.

### 7.13.2 Clock Switch Sequence

The recommended process for a clock switch is as follows:

- 1. Read the COSC<2:0> bits (OSCCON<14:12>) to determine the current oscillator source (if this information is relevant to the application).
- 2. Execute the unlock sequence to allow a write to the high byte of the OSCCON register.
- 3. Write the appropriate value to the NOSC<2:0> control bits (OSCCON<10:8>) for the new oscillator source.
- 4. Execute the unlock sequence to allow a write to the low byte of the OSCCON register.
- 5. Set the OSWEN bit (OSCCON<0>) to initiate the oscillator switch.

7

After the previous steps are completed, the clock switch logic performs the following tasks:

- 1. The clock switching hardware compares the COSC<2:0> status bits (OSCCON<14:12>) with the new value of the NOSC<2:0> control bits (OSCCON<10:8>). If they are the same, the clock switch is a redundant operation. In this case, the OSWEN bit (OSCCON<0>) is cleared automatically and the clock switch is aborted.
- If a valid clock switch has been initiated, the PLL LOCK (OSCCON<5>) and CF (OSCCON<3>) status bits are cleared.
- 3. The new oscillator is turned on by the hardware (if it is not running). If a crystal oscillator (the Posc or Sosc) must be turned on, the hardware waits for TOSCD until the crystal starts oscillating and TOST expires. If the new source uses the PLL, the hardware waits until a PLL lock is detected (OSCCON<5> = 1).
- 4. The hardware waits for the new clock source to stabilize and then performs the clock switch.
- 5. The hardware clears the OSWEN bit (OSCCON<0>) to indicate a successful clock transition. In addition, the NOSC<2:0> bit (OSCCON<10:8>) values are transferred to the COSC<2:0> status bits (OSCCON<14:12>).
- The old clock source is turned off at this time, with the exception of LPRC (if WDT or FSCM is enabled) or Sosc (if SOSCEN remains set). The timing of the transition between clock sources is illustrated in Figure 7-10.

**Note 1:** Clock switching between the XT, HS and EC Primary Oscillator modes is not possible without reprogramming the device.

- 2: Direct clock switching between PLL modes is not possible. For example, clock switching should not occur between the primary oscillator with PLL and the internal FRC oscillator with PLL.
- 3: Setting the CLKLOCK bit (OSCCON<7>) prevents clock switching when clock switching is enabled and Fail-Safe Clock Monitoring is disabled by Configuration bits, FCKSM<1:0> (FOSC<7:6>) = 01. The CLKLOCK bit (OSCCON<7>) cannot be cleared after it is set by the software; it clears on Power-on Reset.
- **4:** The processor continues to execute code throughout the clock switching sequence. Timing-sensitive code should not be executed during this time.
- The clock switch will not wait for the PLL lock if the PLLKEN bit in the FWDT Fuse Configuration (FWDT<5>) register is set to '0'.





The following are recommended code sequences for a clock switch:

- 1. Disable interrupts during the OSCCON register unlock and write sequence.
- 2. Execute the unlock sequence for the OSCCON high byte. In two, back-to-back instructions:
  - Write 0x78 to OSCCON<15:8>
  - Write 0x9A to OSCCON<15:8>
- 3. In the instruction immediately following the unlock sequence, write the new oscillator source to the NOSC<2:0> control bits (OSCCON<10:8>).
- 4. Execute the unlock sequence for the OSCCON low byte. In two, back-to-back instructions:
  - Write 0x46 to OSCCON<7:0>
  - Write 0x57 to OSCCON<7:0>
- 5. In the instruction immediately following the unlock sequence, set the OSWEN bit (OSCCON<0>).
- 6. Continue to execute code that is not clock-sensitive (optional).
- 7. Check to see if the OSWEN bit (OSCCON<0>) is '0'. If it is, the switch was successful.



Example 7-5 illustrates the code sequence for unlocking the OSCCON register and switching from FRC with PLL clock to the LPRC clock source.

#### Example 7-5: Code Example for Clock Switching

```
;Place the New Oscillator Selection (NOSC=0b101) in WO
MOV #0x15,w0
;OSCCONH (high byte) Unlock Sequence
MOV #OSCCONH, w1
MOV #0x78, w2
MOV #0x9A, w3
MOV.B w2, [w1] ; Write 0x78
MOV.B w3, [w1] ; Write 0x9A
;Set New Oscillator Selection
MOV.B w0, [w1]
; Place 0x01 in W0 for setting clock switch enabled bit
MOV #0x01, w0
;OSCCONL (low byte) Unlock Sequence
MOV #OSCCONL, w1
MOV #0x46, w2
MOV #0x57, w3
MOV.B w2, [w1] ; Write 0x46
MOV.B w3, [w1] ; Write 0x57
; Enable Clock Switch
MOV.B w0, [w1] ; Request Clock Switching by Setting OSWEN bit
wait:
           OSCCONL, #OSWEN
   btsc
   bra
           wait
```

# 7.13.3 Clock Switching Consideration

When you incorporate clock switching into an application, consider these points when designing the code:

- The OSCCON unlock sequence is extremely timing critical. The OSCCON register byte is only writable for one instruction cycle following the sequence. Some high-level languages, such as C, may not preserve the timing-sensitive sequence of instructions when compiled. When clock switching is required for an application written in a high-level language, it is good to create the routine in assembler and link it to the application, and then calling it as a function when it is required.
- If the destination clock source is a crystal oscillator, the clock switch time will be dominated by the oscillator start-up time.
- If the new clock source does not start or not present, the clock switching hardware will continue to run from the current clock source. User-assigned software can detect this situation because the OSWEN bit (OSCCON<0>) remains set indefinitely.
- If the new clock source uses the PLL, a clock switch will not occur until lock has been achieved. User-assigned software can detect a loss of PLL lock because the LOCK bit (OSCCON<5>) is cleared and the OSWEN bit (OSCCON<0>) is set.
- Switching to a low-frequency clock source, like secondary oscillator, will result in slow device operation.

## 7.13.4 Aborting a Clock Switch

If a clock switch does not complete, the clock switch logic can be reset by clearing the OSWEN bit (OSCCON<0>). When OSWEN is cleared, the clock switch process is aborted, the Oscillator Start-up Timer (if applicable) is stopped and reset, and the PLL (if applicable) is stopped.

Typical assembly code for aborting a clock switch is shown in Example 7-6. A clock switch procedure can be aborted at any time. A clock switch that is already in progress can also be aborted by performing a second clock switch.

Example 7-6: Aborting a Clock Switch

| MOV   | #OSCCON,W1        | ; | pointer to OSCCON        |
|-------|-------------------|---|--------------------------|
| MOV.b | #0x46,W2          | ; | first unlock code        |
| MOV.b | #0x57 <b>,</b> W3 | ; | second unlock code       |
| MOV.b | W2, [W1]          | ; | write first unlock code  |
| MOV.b | W3, [W1]          | ; | write second unlock code |
| BCLR  | OSCCON, #OSWEN    | ; | ABORT the switch         |
| 1     |                   |   |                          |

## 7.13.5 Entering Sleep Mode During a Clock Switch

If the device enters Sleep mode during a clock switch operation, the clock switch operation is aborted. The processor keeps the old clock selection and the OSWEN bit is cleared. The PWRSAV instruction is then executed normally.

It is useful to perform a clock switch to the Internal FRC oscillator before entering Sleep mode, as this will ensure fast wake-up from Sleep mode.

# 7.14 TWO-SPEED START-UP

The Internal External Start-up Option Configuration bit (IESO) in the Oscillator Source Selection register (FOSCSEL<7>) specifies whether to start the device with a user-selected oscillator source or to initially start with the Internal FRC, and then switch to the user-selected oscillator. If this bit is set to '1', the device will always power-up on the internal FRC oscillator, regardless of the other oscillator source settings (FOSCSEL<2:0>). Then, the device switches to the specified oscillator when it is ready.

Unless FSCM is enabled, the FRC oscillator is turned off immediately after the clock switch is completed. The Two-Speed Start-up option is a faster way to get the device up and running, and works independently of the state of the Clock Switching Mode Configuration bits, FCKSM<1:0> (FOSC<7:6>).

Two-Speed Start-up is useful when an external oscillator is selected by the FNOSC<2:0> Configuration bits (FOSCSEL<2:0>) and a crystal-based oscillator (either a primary or secondary oscillator) has a longer start-up time. As an internal RC oscillator, the FRC clock source is available immediately following Power-on Reset. With Two-Speed Start-up, the device starts executing code in its default oscillator configuration (FRC). It continues to operate in this mode until the specified external oscillator source becomes stable, at which time, it switches to that source.

User code can check which clock source is currently providing the device clocking by checking the status of the COSC<2:0> bits (OSCCON<14:12>) against the NOSC<2:0> bits (OSCCON<10:8>). If these two sets of bits match, the clock switch is completed successfully and the device is running from the intended clock source.

**Note:** Two-Speed Start-up is redundant if the selected device clock source is FRC.

# 7.15 REGISTER MAPS

Table 7-9 maps the bit functions for the Oscillator Special Function Control registers. Table 7-10 maps the bit functions for the Oscillator Configuration registers.

 Table 7-9:
 Oscillator Special Function Control Registers

| File Name | 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 |
|-----------|--------|--------|-----------|--------|---------|---------|-------------------------|-------|-----------------------|-----------------------------|-----------------------|------------------|-------|---------|-------|---------------------|---------------|
| OSCCON    | —      |        | COSC<2:0> |        | _       | Ν       | NOSC<2:0> CLKLOCK IOLOG |       | IOLOCK <sup>(2)</sup> | LOCK                        | _                     | CF               | _     | LPOSCEN | OSWEN | <sub>7700</sub> (1) |               |
| CLKDIV    | ROI    |        | DOZE<2:0> |        | DOZEN   | FF      | RCDIV<2:0               | >     | PLLPO                 | PLLPOST<1:0> — PLLPRE<4::0> |                       |                  |       |         |       |                     | 0100          |
| PLLFBD    | _      | _      | _         | _      | _       | _       | _                       |       | PLLDIV<8:0>           |                             |                       |                  |       |         | 0000  |                     |               |
| OSCTUN    | _      | _      | _         | _      | _       | _       | _                       | _     | _                     | _                           | TUN<5:0>              |                  |       |         |       | 0000                |               |
| ACLKCONx  | ENAPLL | APLLCK | SELACLK   | AOSCN  | 1D<1:0> | ASRCSEL | FRCSEL                  | _     | AP                    | LLPOST<2:0                  | 2:0> — — APLLPRE<2:0> |                  |       | >       | 0000  |                     |               |
| ACLKDIVx  | —      | _      | _         | _      | _       | _       | _                       | _     | —                     | _                           | _                     | — — APLLDIV<2:0> |       |         | >     | 0000                |               |

Legend: x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal.

Note 1: OSCCON register Reset values are dependent on the FOSCSEL Configuration bits and by type of Reset.

2: The IOLOCK bit is not available on all dsPIC33E/PIC24E devices. For more information, refer to the specific device data sheet.

#### Table 7-10: Oscillator Configuration Registers

| File Name | 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  |
|-----------|--------|--------|--------|--------|--------|--------|-------|-------|------------|-------|------------------------|-------|-------|------------|-------|--------|
| FOSCSEL   | _      | _      | _      | _      | _      | _      | _     | —     | IESO —     |       | _                      | _     |       | FNOSC<2:0> |       |        |
| FOSC      | _      | _      |        | _      |        |        |       | _     | FCKSM<1:0> |       | IOL1WAY <sup>(1)</sup> | _     |       | OSCIOFNC   | POSCM | 0<1:0> |

**Legend:** x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal.

Note 1: The IOL1WAY bit is not available on all dsPIC33E/PIC24E devices. For more information, refer to the specific device data sheet.

# 7.16 RELATED APPLICATION NOTES

This section lists application notes that pertain to this section of the manual. These application notes may not be written specifically for the dsPIC33E/PIC24E Product Family, but the concepts are pertinent and could be used with modification and possible limitations. The current application notes related to the Oscillator module include:

| Title                                                                                                   | Application Note # |
|---------------------------------------------------------------------------------------------------------|--------------------|
| PIC <sup>®</sup> Microcontroller Oscillator Design Guide                                                | AN588              |
| Low-Power Design using PIC <sup>®</sup> Microcontrollers                                                | AN606              |
| Crystal Oscillator Basics and Crystal Selection for $rfPIC^{\texttt{®}}$ and $PIC^{\texttt{®}}$ Devices | AN826              |

**Note:** Visit the Microchip Web site (www.microchip.com) for additional Application Notes and code examples for the dsPIC33E/PIC24E family of devices.

7

# 7.17 REVISION HISTORY

### Revision A (January 2009)

This is the initial release of this document.

### Revision B (July 2010)

This revision includes the following updates:

- Removed the watermark from all code examples
- Updated all code examples (Example 7-1 through Example 7-5) with the exception of Example 7-6
- Added Note 2 and updated the Oscillator System Block Diagram (see Figure 7-1)
- Added Note 2 to the Oscillator Control Register (see Register 7-3)
- Renamed the Auxiliary Clock Control Register 1 to ACLKCONx (see Register 7-7)
- Renamed the Auxiliary Clock Control Register 2 to ACLKDIVx (see Register 7-8)
- Updated the Crystal or Ceramic Resonator Operation (XT or HS Oscillator Mode) diagram (see Figure 7-3)
- Changed the PFD input frequency (FREF) end range value from 3.5 MHz to 5.5 MHz in step 2 of **7.7.1** "Input Clock Limitation at Start-up for PLL Mode"
- Updated the second paragraph in 7.7.2 "PLL Lock Status"
- Updated step 3 of the second clock switching sequence in 7.13.2 "Clock Switch Sequence"
- Added shaded note after the ACLK Calculation (see Equation 7-8)
- Additional minor corrections such as language and formatting updates are incorporated throughout the document

#### Note the following details of the code protection feature on Microchip devices:

- · Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

# QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV ISO/TS 16949:2002

#### Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART, PIC<sup>32</sup> logo, rfPIC and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MXDEV, MXLAB, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Application Maestro, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Octopus, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, REAL ICE, rfLAB, Select Mode, Total Endurance, TSHARC, UniWinDriver, WiperLock and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

All other trademarks mentioned herein are property of their respective companies.

© 2010, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.



ISBN: 978-1-60932-374-5

Microchip received ISO/TS-16949:2002 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.



# WORLDWIDE SALES AND SERVICE

#### AMERICAS

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://support.microchip.com Web Address: www.microchip.com

Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Boston Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075

**Cleveland** Independence, OH Tel: 216-447-0464 Fax: 216-447-0643

**Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

Detroit Farmington Hills, MI Tel: 248-538-2250 Fax: 248-538-2260

Kokomo, IN Tel: 765-864-8360 Fax: 765-864-8387

Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

Santa Clara Santa Clara, CA Tel: 408-961-6444 Fax: 408-961-6445

Toronto Mississauga, Ontario, Canada Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Asia Pacific Office Suites 3707-14, 37th Floor Tower 6, The Gateway Harbour City, Kowloon Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431 Australia - Sydney

Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

**China - Beijing** Tel: 86-10-8528-2100 Fax: 86-10-8528-2104

**China - Chengdu** Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

**China - Chongqing** Tel: 86-23-8980-9588 Fax: 86-23-8980-9500

**China - Hong Kong SAR** Tel: 852-2401-1200 Fax: 852-2401-3431

China - Nanjing Tel: 86-25-8473-2460

Fax: 86-25-8473-2470 China - Qingdao Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

**China - Shanghai** Tel: 86-21-5407-5533 Fax: 86-21-5407-5066

China - Shenyang Tel: 86-24-2334-2829 Fax: 86-24-2334-2393

**China - Shenzhen** Tel: 86-755-8203-2660 Fax: 86-755-8203-1760

**China - Wuhan** Tel: 86-27-5980-5300 Fax: 86-27-5980-5118

**China - Xian** Tel: 86-29-8833-7252 Fax: 86-29-8833-7256

**China - Xiamen** Tel: 86-592-2388138 Fax: 86-592-2388130

**China - Zhuhai** Tel: 86-756-3210040 Fax: 86-756-3210049

### ASIA/PACIFIC

India - Bangalore Tel: 91-80-3090-4444 Fax: 91-80-3090-4123

**India - New Delhi** Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune Tel: 91-20-2566-1512 Fax: 91-20-2566-1513

**Japan - Yokohama** Tel: 81-45-471- 6166 Fax: 81-45-471-6122

Korea - Daegu Tel: 82-53-744-4301 Fax: 82-53-744-4302

Korea - Seoul Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934

Malaysia - Kuala Lumpur Tel: 60-3-6201-9857 Fax: 60-3-6201-9859

**Malaysia - Penang** Tel: 60-4-227-8870 Fax: 60-4-227-4068

Philippines - Manila Tel: 63-2-634-9065 Fax: 63-2-634-9069

Singapore Tel: 65-6334-8870 Fax: 65-6334-8850

Taiwan - Hsin Chu Tel: 886-3-6578-300 Fax: 886-3-6578-370

**Taiwan - Kaohsiung** Tel: 886-7-536-4818 Fax: 886-7-536-4803

Taiwan - Taipei Tel: 886-2-2500-6610 Fax: 886-2-2508-0102

**Thailand - Bangkok** Tel: 66-2-694-1351 Fax: 66-2-694-1350

### EUROPE

Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393 Denmark - Copenhagen Tel: 45-4450-2828 Fax: 45-4485-2829

France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

**Italy - Milan** Tel: 39-0331-742611 Fax: 39-0331-466781

Netherlands - Drunen Tel: 31-416-690399 Fax: 31-416-690340

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

**UK - Wokingham** Tel: 44-118-921-5869 Fax: 44-118-921-5820

01/05/10