Datasheet
PIC18F87J50 FAMILY
DS39775C-page 40   © 2009 Microchip Technology Inc.
2.3 Oscillator Settings for USB
When the PIC18F87J10 family is used for USB
connectivity, a 6 MHz or 48 MHz clock must be
provided to the USB module for operation in either
Low-Speed or Full-Speed modes, respectively. This
may require some forethought in selecting an oscillator
frequency and programming the device.
The full range of possible oscillator configurations
compatible with USB operation is shown in Table 2-5.
2.3.1 LOW-SPEED OPERATION
The USB clock for Low-Speed mode is derived from the
primary oscillator or from the 96 MHz PLL. In order to
operate the USB module in Low-Speed mode, a 6 MHz
clock must be provided to the USB module. Due to the
way the clock dividers have been implemented in the
PIC18F87J50 family, the microcontroller core must run
at 24 MHz in order for the USB module to get the 6 MHz
clock needed for low-speed USB operation. Several
clocking schemes could be used to meet these two
required conditions. See Table 2-4 and Table 2-5 for
possible combinations which can be used for
low-speed USB operation.
TABLE 2-4: CLOCK FOR LOW-SPEED 
USB
REGISTER 2-1: OSCTUNE: OSCILLATOR TUNING REGISTER 
R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 
INTSRC PLLEN TUN5 TUN4 TUN3 TUN2 TUN1 TUN0
bit 7 bit 0
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
bit 7 INTSRC: Internal Oscillator Low-Frequency Source Select bit
1 = 31.25 kHz device clock derived from 8 MHz INTOSC source (divide-by-256 enabled)
0 = 31 kHz device clock derived directly from INTRC internal oscillator
bit 6
PLLEN: Frequency Multiplier Enable bit
1 = 96 MHz PLL is enabled
0 = 96 MHz PLL is disabled
bit 5-0 TUN5:TUN0: Frequency Tuning bits
011111 = Maximum frequency
011110 
•   •
•   •
•   •
000001 
000000 = Center frequency. Oscillator module is running at the calibrated frequency.
111111 
•   •
•   •
100000 = Minimum frequency
Clock 
Input
CPU 
Clock
CPDIV<1:0> USB Clock
48 24 <1, 1> 48/8 = 6 MHz
24 24 <1, 0> 24/4 = 6 MHz










