Contents

1. Introduction .......................................................................................................................... 3
   1.1. Key Features .................................................................................................................... 3
2. On-Chip Oscillator Overview .................................................................................................. 4
3. I/O Port Description .............................................................................................................. 5
4. Connectivity Guideline ......................................................................................................... 6
5. Power Management Options .................................................................................................. 7
Appendix: Design Entry ............................................................................................................ 8
   SB_LFOSC Usage with Verilog .................................................................................................. 8
   SB_HFOSC Usage with Verilog .................................................................................................. 8
   Technical Support Assistance ..................................................................................................... 9
Revision History .......................................................................................................................... 10

Figures

Figure 2.1. On-Chip Oscillator .................................................................................................... 4
Figure 4.1. Oscillator Calibration Example .................................................................................. 6
Figure 4.2. Oscillator Used for Dynamic Clock Calibration That Can Be Used On Service LED ......... 6

Tables

Table 3.1. SB_HFOSC I/O .......................................................................................................... 5
Table 3.2. SB_LFOSC ................................................................................................................. 5
1. Introduction

The iCE40™ family, specifically iCE40 Ultra™, iCE40 UltraLite™ and iCE40 UltraPlus™, features two on-chip oscillators. An ultra-low power 10 kHz oscillator is provided for Always-On applications and background polling that allow higher power processors to remain in power-down or sleep mode, conserving overall power consumption. A low power 48 MHz oscillator with output divider is provided for sensor management and pre-processing functions. These oscillators are intended for general clocking of internal logic and state machines.

1.1. Key Features

Two oscillators are available to users:

- SB_LFOSC – Low Frequency Oscillator
- SB_HFOSC – High Frequency Oscillator with output divider
2. On-Chip Oscillator Overview

You can access the two modules: SB_LFOSC and SB_HSOSC with enabled inputs and which you can dynamically control as shown in Figure 2.1.

SB_LFOSC runs at 10 kHz and SB_HSOSC runs at maximum 48 MHz with output divider by 1, 2, 4 or 8. SB_LFOSC and SB_HSOSC provide internal clock sources to user designs. These clocks can directly route to the global clock network or to local fabric.

![Figure 2.1. On-Chip Oscillator](image-url)
3. I/O Port Description

### Table 3.1. SB_HFOSC I/O

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKHFEN</td>
<td>I</td>
<td>Enabling CLKHF output to be oscillating. This does not stop the oscillator, but only disables the output.</td>
</tr>
<tr>
<td>CLKHF</td>
<td>O</td>
<td>Oscillator Clock Output.</td>
</tr>
<tr>
<td>CLKHFPU</td>
<td>I</td>
<td>Powering up the SB_HFOSC.</td>
</tr>
</tbody>
</table>

### Table 3.2. SB_LFOSC

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKLFEN</td>
<td>I</td>
<td>Enabling CLKLF output to be oscillating. This does not stop the oscillator, but only disables the output.</td>
</tr>
<tr>
<td>CLKLF</td>
<td>O</td>
<td>Oscillator Clock Output.</td>
</tr>
<tr>
<td>CLKLFPU</td>
<td>I</td>
<td>Powering up the SB_LFOSC.</td>
</tr>
</tbody>
</table>
4. Connectivity Guideline

The SB_HFOSC and SB_LFOSC can be used as clock source. Their outputs are available for the user. They should be connected to the global clock network or local fabric. By default, the outputs will be routed to global clock network. To route to local fabric, see the examples in the Appendix: Design Entry section.

Note that Oscillator cannot provide accurate frequency. For applications that require more accuracy, it is recommended to use calibration circuit to support the oscillator used as clock source. Figure 4.1 shows an example of the use of a reference clock that is only temporarily available for calibration.

![Figure 4.1. Oscillator Calibration Example](image)

The calibration circuit for Oscillator can be improved for the purpose of power saving as shown in Figure 4.2.

In this example, 10 kHz oscillator is always on. Calibrated divider provides timing for LED on-off. When LED is on, SB_LFOSC Enable turns on 48 MHz oscillator (SB_HFOSC turns on in two cycles). PWM FSM provides accurate PWM for LED. Power benefit is 48 MHz only when LED is on and minimum power when LED is off.

![Figure 4.2. Oscillator Used for Dynamic Clock Calibration That Can Be Used On Service LED](image)
5. Power Management Options

When disabled, the SB_LFOSC and SB_HFOSC are in standby mode by default and consume only DC leakage. It is suggested to always enable SB_LFOSC and enable SB_HFOSC after there is an activity detected and the products return to full power mode for data analysis/processing.
Appendix: Design Entry

The following examples illustrate SB_HFOSC and SB_LFOSC usage with VHDL and Verilog.

SB_LFOSC Usage with Verilog

**Synthesis Attributes**

```vhdl
/* synthesis ROUTE_THROUGH_FABRIC = <value> */
```

**Value:**

0: Use dedicated clock network. Default option.
1: Use fabric routes.

**Verilog Instantiation**

```vhdl
SB_LFOSC OSCInst1 (  .CLKLFEN(ENCLKLF),  .CLKLFPU(CLKLF_POWERUP),  .CLKLF(CLKLF) ) /* synthesis ROUTE_THROUGH_FABRIC= [0|1] */;
```

SB_HFOSC Usage with Verilog

**Synthesis Attributes**

```vhdl
/* synthesis ROUTE_THROUGH_FABRIC = <value> */
```

**Value:**

0: Use dedicated clock network. Default option.
1: Use fabric routes.

**Parameter Values**

The SB_HFOSC primitive contains the following parameter and their default values:

Parameter `CLKHF_DIV = 2'b00 : 00 = div1, 01 = div2, 10 = div4, 11 = div8 ; Default = "00"

**Verilog Instantiation**

```vhdl
SB_HFOSC OSCInst0 (  .CLKHFEN(ENCLKHF),  .CLKHPFU(CLKHF_POWERUP),  .CLKHF(CLKHF) ) /* synthesis ROUTE_THROUGH_FABRIC= [0|1] */;
```

Defparam OSCInst0.CLKHF_DIV = 2'b00;
Technical Support Assistance

Submit a technical support case via www.latticesemi.com/techsupport.
# Revision History

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>September 2017</td>
<td>1.4</td>
<td>Fixed the port name of SB_LFOSC and SB_HFOSC modules.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Changed document number from TN1296 to FPGA-TN-02008.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated document template.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Removed clock generation logic information from the Connectivity Guideline section.</td>
</tr>
<tr>
<td>June 2016</td>
<td>1.3</td>
<td>Updated Introduction section. Added iCE40 UltraPlus.</td>
</tr>
<tr>
<td>April 2015</td>
<td>1.2</td>
<td>Updated Connectivity Guideline section. Added example of clock generation logic.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated Technical Support Assistance section.</td>
</tr>
<tr>
<td>January 2015</td>
<td>1.1</td>
<td>Added support for iCE40 UltraLite.</td>
</tr>
<tr>
<td>June 2014</td>
<td>01.0</td>
<td>Initial release.</td>
</tr>
</tbody>
</table>

© 2014-2017 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal. All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.