# SiliconBlue ICE™ Technology Library

Version 2.3



| Version | Changes                                                     |
|---------|-------------------------------------------------------------|
| 2.0     | Added Version Number to document. Added sections on Default |
|         | Signal Values for unconnected ports. Modified               |
| 2.1     | Added PLL primitives                                        |
| 2.2     | Corrected SB_CARRY connections to LUT inputs                |
| 2.3     | Added iCE40 RAM, PLL primitives                             |
|         |                                                             |

# **Table of Contents**

| Register | Primitives               | 5    |
|----------|--------------------------|------|
| SB       | _DFF                     | 5    |
| SB_      | _DFFE                    | 7    |
| SB_      | _DFFSR                   | 9    |
| SB_      | _DFFR                    | . 11 |
| SB_      | _DFFSS                   | . 13 |
| SB_      | _DFFS                    | . 15 |
| SB_      | _DFFESR                  | . 17 |
| _        | _DFFER                   |      |
| SB_      | _DFFESS                  | . 21 |
| SB_      | _DFFES                   | . 23 |
| SB_      | _DFFN                    | . 25 |
| SB_      | _DFFNE                   | . 27 |
| SB_      | _DFFNSR                  | . 29 |
| SB_      | _DFFNR                   | . 31 |
| SB_      | _DFFNSS                  | . 33 |
| SB_      | _DFFNS                   | . 35 |
| SB_      | _DFFNESR                 | . 37 |
| _        | _DFFNER                  |      |
| SB_      | _DFFNESS                 | . 41 |
|          | _DFFNES                  |      |
| Combina  | ational Logic Primitives | . 45 |
| SB       | LUT4                     | . 45 |
| _        | <br>CARRY                |      |
| _        | AM Primitives            |      |
|          | Block RAM                |      |
| ICE65    | 6 BIOCK RAIVI            |      |
| SB_      | _RAM4K                   | . 54 |
| SB_      | _RAM4KNR                 | . 54 |
| SB_      | _RAM4KNW                 | . 54 |
| SB_      | _RAM4KNRW                | . 54 |
| iCE40    | Block RAM 55             |      |
| CD       | RAM256x16                | E0   |
| _        | RAM256x16NR              |      |
| _        |                          |      |
| _        | _RAM256x16NW             |      |
| _        | _RAM256x16NRNW           |      |
| _        | _RAM512x8                | _    |
| _        | _RAM512x8NR              |      |
| _        | _RAM512x8NW              |      |
| _        | _RAM512x8NRNW            |      |
| _        | _RAM1024x4               |      |
| SB_      | _RAM1024x4NR             | . 64 |

| SB_RAM1024x4NW                                                                                                     | 64             |
|--------------------------------------------------------------------------------------------------------------------|----------------|
| SB_RAM1024x4NRNW                                                                                                   | 64             |
| SB_RAM2048x2                                                                                                       | 67             |
| SB_RAM2048x2NR                                                                                                     | 67             |
| SB_RAM2048x2NW                                                                                                     | 67             |
| SB_RAM2048x2NRNW                                                                                                   | 67             |
| SB_RAM40_4K                                                                                                        | 68             |
| IO Primitives                                                                                                      | 70             |
| SB_IO                                                                                                              | 71             |
| Global Buffer Primitives                                                                                           | 75             |
| SB_GB_IO                                                                                                           | 75             |
| SB_GB Primitive                                                                                                    |                |
| PLL Primitives                                                                                                     | 77             |
| iCE65 PLL Primitives                                                                                               | 77             |
| SB_PLL_CORE                                                                                                        | 77             |
| SB_PLL_PAD                                                                                                         |                |
|                                                                                                                    |                |
|                                                                                                                    |                |
| SB_PLL_2_PADiCE40 PLL Primitives                                                                                   | 83             |
| SB_PLL_2_PADiCE40 PLL Primitives                                                                                   | 83<br>86       |
| SB_PLL_2_PADiCE40 PLL PrimitivesSB_PLL40_CORE                                                                      | 83<br>86<br>86 |
| SB_PLL_2_PAD iCE40 PLL Primitives SB_PLL40_CORE SB_PLL40_PAD                                                       |                |
| SB_PLL_2_PAD iCE40 PLL Primitives  SB_PLL40_CORE SB_PLL40_PAD SB_PLL40_2_PAD                                       |                |
| SB_PLL_2_PAD iCE40 PLL Primitives  SB_PLL40_CORE SB_PLL40_PAD SB_PLL40_2_PAD SB_PLL40_2F_CORE                      |                |
| SB_PLL_2_PAD iCE40 PLL Primitives  SB_PLL40_CORE SB_PLL40_PAD SB_PLL40_2_PAD                                       |                |
| SB_PLL_2_PAD iCE40 PLL Primitives  SB_PLL40_CORE  SB_PLL40_PAD  SB_PLL40_2_PAD  SB_PLL40_2F_CORE  SB_PLL40_2F_CORE |                |

# **Register Primitives**

# SB\_DFF D Flip-Flop

Data: D is loaded into the flip-flop during a rising clock edge transition.



| Inputs            |   |   | Output |
|-------------------|---|---|--------|
|                   | D | С | Q      |
|                   | 0 | 1 | 0      |
|                   | 1 | 1 | 1      |
| Power on<br>State | X | X | 0      |

| K | еу               |
|---|------------------|
| 1 | Rising Edge      |
|   | High logic level |
| 0 | Low logic level  |
| Χ | Don't care       |
| ? | Unknown          |
|   |                  |

#### HDL use

This register is inferred during synthesis and can also be explicitly instantiated.

# **Verilog Instantiation**

```
-- SB_DFF - D Flip-Flop.

SB_DFF_inst : SB_DFF
port map (
        Q => Q, -- Registered Output
        C => C, -- Clock
        D => D, -- Data
        );
```

-- End of SB\_DFF instantiation

#### SB\_DFFE

#### D Flip-Flop with Clock Enable

Data D is loaded into the flip-flop when Clock Enable E is high, during a rising clock edge transition.



|          | Inputs |    | Output            |
|----------|--------|----|-------------------|
| E        | D      | С  | Q                 |
| 0        | X      | Χ, | Previous <b>Q</b> |
| 1        | 0      | 1  | 0                 |
| 1        | 1      | 1  | 1                 |
| Power on | X      | X  | 0                 |
| State    |        |    |                   |

# Key ✓ Rising Edge 1 High logic level 0 Low logic level X Don't care ? Unknown

# **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0' Input C: Logic '0' Input E: Logic '1'

Note that explicitly connecting a logic '1' value to port E will result in a non-optimal implementation, since an extra LUT will be used to generate the logic '1'. It is recommended that the user leave the port E unconnected, or use the corresponding flip-flop without Enable functionality i.e. the DFF primitive.

#### **Verilog Instantiation**

```
// SB_DFFE - D Flip-Flop with Clock Enable.

SB_DFFE SB_DFFE_inst (
.Q(Q), // Registered Output
```

```
.C(C), // Clock
.D(D), // Data
.E(E), // Clock Enable
);

// End of SB_DFFE instantiation
```

-- SB\_DFFE - D Flip-Flop with Clock Enable.

-- End of SB\_DFFE instantiation

# SB\_DFFSR

#### D Flip-Flop with Synchronous Reset

Data: D is loaded into the flip-flop when Reset R is low during a rising clock edge transition.

Reset: R input is active high, overrides all other inputs and resets the Q output during a rising clock edge.



|          | Inputs |   | Output    |
|----------|--------|---|-----------|
| R        | D      | С | Q         |
| 1        | X      | 1 | 0         |
| X        | X      | 0 | No Change |
| 0        | 0      | 1 | 0         |
| 0        | 1      | 1 | 1         |
| Power on | X      | X | 0         |
| State    |        |   |           |

| K | <b>э</b> у      |
|---|-----------------|
|   | Rising Edge     |
| 1 | High logic leve |
| 0 | Low logic level |
| Χ | Don't care      |
| ? | Unknown         |

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0' Input C: Logic '0' Input R: Logic '0'

## **Verilog Instantiation**

```
// SB_DFFSR - D Flip-Flop, Reset is synchronous with the rising clock edge

SB_DFFSR
SB_DFFSR_inst (
.Q(Q), // Registered Output
```

```
.C(C), // Clock
.D(D), // Data
.R(R) // Synchronous Reset
);

// End of SB_DFFSR instantiation
```

-- SB\_DFFSR - D Flip-Flop, Reset is synchronous with the rising clock edge

```
SB_DFFSR_inst: SB_DFFSR
port map (
Q => Q, -- Registered Output
C => C, -- Clock
D => D, -- Data
R => R -- Synchronous Reset
);
```

-- End of SB\_DFFSR instantiation

# SB\_DFFR

#### D Flip-Flop with Asynchronous Reset

Data: D is loaded into the flip-flop when R is low during a rising clock edge transition.

Reset: R input is active high, overrides all other inputs and asynchronously resets the Q output.



| ]        | Inputs |    | Output |
|----------|--------|----|--------|
| R        | D      | С  | Q      |
| 1        | Χ      | X, | 0      |
| 0        | 0      | 1  | 0      |
| 0        | 1      | 1  | 1      |
| Power on | X      | X  | 0      |
| State    |        |    |        |

| Ke | <b>Э</b> У       |
|----|------------------|
| 1  | Rising Edge      |
| 1  | High logic level |
| 0  | Low logic level  |
| Χ  | Don't care       |
| ?  | Unknown          |

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0' Input C: Logic '0' Input R: Logic '0'

#### **Verilog Instantiation**

// SB\_DFFR - D Flip-Flop, Reset is asynchronous to the clock.

```
SB_DFFR SB_DFFR_inst (
.Q(Q), // Registered Output
.C(C), // Clock
```

```
.D(D), // Data
.R(R) // Asynchronous Reset
);

// End of SB_DFFR instantiation
```

-- SB\_DFFR - D Flip-Flop, Reset is asynchronous to the clock.

```
SB_DFFR_inst: SB_DFFR
port map (
Q => Q, -- Registered Output
C => C, -- Clock
D => D, -- Data
R => R -- Asynchronous Reset
);
```

-- End of SB\_DFFR instantiation

# SB DFFSS

#### D Flip-Flop with Synchronous Set

Data: D is loaded into the flip-flop when the Synchronous Set S is low during a rising clock edge transition.

Set: S input is active high, overrides all other inputs and synchronously sets the Q output.



| Inputs   |   |   | Output |
|----------|---|---|--------|
| S        | D | С | Q      |
| 1        | X | 1 | 1      |
| 0        | 0 | 1 | 0      |
| 0        | 1 | 1 | 1      |
| Power on | X | X | 0      |
| State    |   |   |        |

| Ke | <b></b>         |
|----|-----------------|
| 1  | Rising Edge     |
| 1  | High logic leve |
| 0  | Low logic level |
| Χ  | Don't care      |

? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0' Input C: Logic '0' Input S: Logic '0'

#### **Verilog Instantiation**

// SB\_DFFSS - D Flip-Flop, Set is synchronous with the rising clock edge,

```
SB_DFFSS SB_DFFSS_inst (
.Q(Q), // Registered Output
.C(C), // Clock
```

```
.D(D), // Data
.S(S) // Synchronous Set
);
```

// End of SB\_DFFSS instantiation

#### **VHDL** Instantiation

-- SB\_DFFSS - D Flip-Flop, Set is synchronous with the rising clock edge

-- End of SB\_DFFSS instantiation

# SB DFFS

#### D Flip-Flop with Asynchronous Set

Data: D is loaded into the flip-flop when S is low during a rising clock edge transition.

Set: S input is active high, and it overrides all other inputs and asynchronously sets the Q output.



|          | Output |   |   |
|----------|--------|---|---|
| S        | D      | С | Q |
| 1        | X      | X | 1 |
| 0        | 0      | 1 | 0 |
| 0        | 1      | 1 | 1 |
| Power on | X      | X | 0 |
| State    |        |   |   |

| K | <b>э</b> у       |
|---|------------------|
| 1 | Rising Edge      |
|   | High logic level |
| 0 | Low logic level  |
| Χ | Don't care       |
| ? | Unknown          |
|   |                  |

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0' Input C: Logic '0' Input S: Logic '0'

#### **Verilog Instantiation**

// SB\_DFFS - D Flip-Flop, Set is asynchronous to the rising clock edge

```
SB_DFFS SB_DFFS_inst (
.Q(Q), // Registered Output
.C(C), // Clock
.D(D), // Data
```

```
.S(S)  // Asynchronous Set
);
// End of SB_DFFS instantiation
```

-- SB\_DFFS - D Flip-Flop, Set is asynchronous to the rising clock edge

-- End of SB\_DFFS instantiation

# SB\_DFFESR

#### D Flip-Flop with Clock Enable and Synchronous Reset

Data: D is loaded into the flip-flop when Reset R is low and Clock Enable E is high during a rising clock edge transition.

Reset: R, when asserted with Clock Enable E high, synchronously resets the Q output during a rising clock edge.



|          | Output |   |   |                   |
|----------|--------|---|---|-------------------|
| R        | E      | D | С | Q                 |
| 1        | 1      | X | 1 | 0                 |
| X        | 0      | X | X | Previous <b>Q</b> |
| 0        | 1      | 0 | 1 | 0                 |
| 0        | 1      | 1 | 1 | 1                 |
| Power on | Χ      | X | Χ | 0                 |
| State    |        |   |   |                   |

Key

✓ Rising Edge

1 High logic level 0 Low logic level

X Don't care

? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input R: Logic '0'

Input E: Logic '1'

Note that explicitly connecting a Logic '1' value to port E will result in a non-optimal implementation, since an extra LUT will be used to generate the Logic '1'. If the user's intention is to keep the FF always

enabled, it is recommended that either port E be left unconnected, or the corresponding FF without a Clock Enable port be used.

#### **Verilog Instantiation**

```
// SB_DFFESR - D Flip-Flop, Reset is synchronous with rising clock edge
// Clock Enable.
       SB DFFESR
       SB_DFFESR_inst (
                              // Registered Output
       .Q(Q),
                              // Clock
       .C(C),
       .E(E),
                             // Clock Enable
       D(D),
                             // Data
                              // Synchronous Reset
       .R(R)
       );
// End of SB_DFFESR instantiation
```

#### **VHDL** Instantiation

```
-- SB_DFFESR - D Flip-Flop, Reset is synchronous with rising clock edge -- Clock Enable.
```

```
SB_DFFESR_inst: SB_DFFESR
port map (
Q => Q, -- Registered Output
C => C, -- Clock
E => E, -- Clock Enable
D => D, -- Data
R => R -- Synchronous Reset
);
```

-- End of SB\_DFFESR instantiation

## SB DFFER

#### D Flip-Flop with Clock Enable and Asynchronous Reset

Data: D is loaded into the flip-flop when Reset R is low and Clock Enable E is high during a rising clock edge transition.

Reset: R input is active high, overrides all other inputs and asynchronously resets the Q output.



|          | Output |   |   |                  |
|----------|--------|---|---|------------------|
| R        | E      | D | С | Q                |
| 1        | Χ      | X | Χ | 0                |
| 0        | 0      | X | Χ | Previous ${f Q}$ |
| 0        | 1      | 0 | 1 | 0                |
| 0        | 1      | 1 | 1 | 1                |
| Power on | X      | X | X | 0                |
| State    |        |   |   |                  |

| Key               |
|-------------------|
| ✓ Rising Edge     |
| 1 High logic leve |
| 0 Low logic level |
| X Don't care      |
| ? Unknown         |
|                   |
|                   |

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input R: Logic '0'

Input E: Logic '1'

Note that explicitly connecting a Logic '1' value to port E will result in a non-optimal implementation, since an extra LUT will be used to generate the Logic '1'. If the user's intention is to keep the FF always enabled, it is recommended that either port E be left unconnected, or the corresponding FF primitive without a Clock Enable port be used.

#### **Verilog Instantiation**

```
// SB_DFFER - D Flip-Flop, Reset is asynchronously on rising clock edge with Clock Enable.

SB_DFFER
SB_DFFER_inst (
.Q(Q),  // Registered Output
.C(C),  // Clock
.E(E),  // Clock Enable
.D(D),  // Data
.R(R)  // Asynchronously Reset
);

// End of SB_DFFER instantiation
```

**VHDL** Instantiation

```
-- SB_DFFER - D Flip-Flop, Reset is asynchronously -- on rising clock edge with Clock Enable.
```

```
SB_DFFER_inst: SB_DFFER
port map (
Q => Q, -- Registered Output
C => C, -- Clock
E => E, -- Clock Enable
D => D, -- Data
R => R -- Asynchronously Reset
);
```

End of SB\_DFFER instantiation

#### SB\_DFFESS

# D Flip-Flop with Clock Enable and Synchronous Set

Data: D is loaded into the flip-flop when S is low and E is high during a rising clock edge transition.

Set: Asserting S when Clock Enable E is high, synchronously sets the Q output.



|          | Output |   |   |                   |
|----------|--------|---|---|-------------------|
| S        | E      | D | С | Q                 |
| 1        | 1      | X | 1 | 1                 |
| 0        | 0      | X | X | Previous <b>Q</b> |
| 0        | 1      | 0 | 1 | 0                 |
| 0        | 1      | 1 | 1 | 1                 |
| Power on | X      | X | Х | 0                 |
| State    |        |   |   |                   |

Key

✓ Rising Edge

1 High logic level

0 Low logic level

X Don't care

? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input R: Logic '0'

Input S: Logic '0'

#### **Verilog Instantiation**

// SB\_DFFESS - D Flip-Flop, Set is synchronous with rising clock edge and Clock Enable.

SB\_DFFESS\_inst (

.Q(Q), // Registered Output

.C(C), // Clock

```
.E(E), // Clock Enable
.D(D), // Data
.S(S) // Synchronously Set
);

// End of SB_DFFESS instantiation
```

-- SB\_DFFESS - D Flip-Flop, Set is synchronous with rising clock edge and Clock Enable.

```
SB_DFFESS_inst: SB_DFFESS

port map (

Q => Q, -- Registered Output

C => C, -- Clock

E => E, -- Clock Enable

D => D, -- Data

S => S -- Synchronously Set

);
```

-- End of SB\_DFFESS instantiation

# SB\_DFFES

#### D Flip-Flop with Clock Enable and Asynchronous Set

Data: D is loaded into the flip-flop when S is low and E is high during a rising clock edge transition.

Set: S input is active high, overrides all other inputs and asynchronously sets the Q output.



|                   | Output |   |     |                   |
|-------------------|--------|---|-----|-------------------|
| S                 | Е      | D | CLK | Q                 |
| 1                 | X      | X | X   | 1                 |
| 0                 | 0      | X | X   | Previous <b>Q</b> |
| 0                 | 1      | 0 | 1   | 0                 |
| 0                 | 1      | 1 | 1   | 1                 |
| Power on<br>State | X      | X | X   | 0                 |

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0' Input C: Logic '0' Input S: Logic '0' Input E: Logic '1'

#### **Verilog Instantiation**

// SB\_DFFES - D Flip-Flop, Set is asynchronous on rising clock edge with Clock Enable.

```
SB_DFFES SB_DFFES_inst (
.Q(Q), // Registered Output
```

```
.C(C), // Clock

.E(E), // Clock Enable

.D(D), // Data

.S(S) // Asynchronously Set

);
```

// End of SB\_DFFES instantiation

#### **VHDL** Instantiation

-- SB\_DFFES - D Flip-Flop, Set is asynchronous on rising clock edge with Clock Enable.

```
SB_DFFES_inst: SB_DFFES

port map (
Q => Q, -- Registered Output
C => C, -- Clock
E => E, -- Clock Enable
D => D, -- Data
S => S -- Asynchronously Set
);
```

-- End of SB\_DFFES instantiation

# SB\_DFFN

# D Flip-Flop - Negative Edge Clock

Data: D is loaded into the flip-flop during the falling clock edge transition.



| ]        | Output |   |   |
|----------|--------|---|---|
|          | D      | С | Q |
|          | 0      | ¥ | 0 |
|          | 1      | ¥ | 1 |
| Power on | Χ      | Χ | 0 |
| State    |        |   |   |

#### Key

- ¥ Falling Edge
- 1 High logic level
- 0 Low logic level
- X Don't care
- ? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

```
Input D: Logic '0'
Input C: Logic '0'
```

#### **Verilog Instantiation**

```
// SB_DFFN - D Flip-Flop - Negative Edge Clock.

SB_DFFN
SB_DFFN_inst (
.Q(Q), // Registered Output
.C(C), // Clock
.D(D), // Data
);
```

```
// End of SB_DFFN instantiation
```

```
-- SB_DFFN - D Flip-Flop - Negative Edge Clock.

SB_DFFN_inst: SB_DFFN
port map (
Q => Q, -- Registered Output
C => C, -- Clock
D => D, -- Data
);
```

-- End of SB\_DFFN instantiation

# **SB\_DFFNE**

#### D Flip-Flop - Negative Edge Clock and Clock Enable

Data: D is loaded into the flip-flop when E is high, during the falling clock edge transition.



|          | Output |   |   |
|----------|--------|---|---|
| E        | D      | C | Q |
| 0        | Х      | Χ | 0 |
| 1        | 0      | ¥ | 0 |
| 1        | 1      | ¥ | 1 |
| Power on | X      | X | 0 |
| State    |        |   |   |

#### Key

- ← Falling Edge
  1 High logic level
- 0 Low logic level
- X Don't care
- ? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0' Input E: Logic '1'

Note that explicitly connecting a Logic '1' value to port E will result in a non-optimal implementation, since an extra LUT will be used to generate the Logic '1'. If the user's intention is to keep the FF always enabled, it is recommended that either port E be left unconnected, or the corresponding FF without a Clock Enable port be used.

#### **Verilog Instantiation**

// SB\_DFFNE - D Flip-Flop - Negative Edge Clock and Clock Enable.

```
SB_DFFNE SB_DFFNE_inst (
.Q(Q), // Registered Output
.C(C), // Clock
.D(D), // Data
.E(E), // Clock Enable
);

// End of SB_DFFNE instantiation
```

-- SB\_DFFNE - D Flip-Flop - Negative Edge Clock and Clock Enable.

-- End of SB\_DFFNE instantiation

# SB\_DFFNSR

# D Flip-Flop - Negative Edge Clock with Synchronous Reset

Data: D is loaded into the flip-flop when R is low during the falling clock edge transition.

Reset: R input is active high, overrides all other inputs and resets the Q output during the falling clock edge transition.



| Inputs   |   |   | Output    |
|----------|---|---|-----------|
| R        | D | С | Q         |
| 1        | X | ¥ | 0         |
| X        | X | 1 | No Change |
| 0        | 0 | X | 0         |
| 0        | 1 | × | 1         |
| Power on | X | Χ | 0         |
| State    |   |   |           |

#### Key

- Falling Edge
- 1 High logic level 0 Low logic level
- X Don't care
- X Don't care
  ? Unknown

**HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input R: Logic '0'

#### **Verilog Instantiation**

#### **VHDL Instantiation**

-- SB\_DFFNSR - D Flip-Flop - Negative Edge Clock, Reset is synchronous with the falling clock edge

```
SB_DFFNSR_inst: SB_DFFNSR

port map (
Q => Q, -- Registered Output
C => C, -- Clock
D => D, -- Data
R => R -- Synchronous Reset
);
```

-- End of SB\_DFFNSR instantiation

# SB\_DFFNR

#### D Flip-Flop - Negative Edge Clock with Asynchronous Reset

Data: D is loaded into the flip-flop when R is low during the falling clock edge transition.

Reset: R input is active high, overrides all other inputs and asynchronously resets the Q output.



| ]                 | Output |     |   |
|-------------------|--------|-----|---|
| R                 | D      | CLK | Q |
| 1                 | X      | Χ   | 0 |
| 0                 | 0      | X   | 0 |
| 0                 | 1      | A   | 1 |
| Power on<br>State | Х      | Х   | 0 |

#### Key

- ¥ Falling Edge
- 1 High logic level
- 0 Low logic level
- X Don't care
- ? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input R: Logic '0'

#### **Verilog Instantiation**

// SB\_DFFNR - D Flip-Flop - Negative Edge Clock, Reset is asynchronous to the clock.

SB\_DFFNR SB\_DFFNR\_inst (

.Q(Q), // Registered Output

.C(C), // Clock .D(D), // Data

-- SB\_DFFNR - D Flip-Flop - Negative Edge Clock, Reset is asynchronous to the clock.

```
SB_DFFNR_inst: SB_DFFNR
port map (
Q => Q, -- Registered Output
C => C, -- Clock
D => D, -- Data
R => R -- Asynchronously Reset
);
```

-- End of SB\_DFFNR instantiation

## SB DFFNSS

#### D Flip-Flop - Negative Edge Clock with Synchronous Set

Data: D is loaded into the flip-flop when S is low during the falling clock edge transition.

Set: S input is active high, overrides all other inputs and synchronously sets the Q output.



| Inputs   |   |   | Output |
|----------|---|---|--------|
| S        | D | С | Q      |
| 1        | X | Ä | 1      |
| 0        | 0 | ¥ | 0      |
| 0        | 1 | ¥ | 1      |
| Power on | Х | Χ | 0      |
| State    |   |   |        |

Key

Falling Edge

High logic level

Low logic level

Don't care

? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0' Input C: Logic '0'

Input S: Logic '0'

#### **Verilog Instantiation**

// SB\_DFFNSS - D Flip-Flop - Negative Edge Clock, Set is synchronous with the falling clock edge,

SB\_DFFNSS SB\_DFFNSS\_inst (
.Q(Q), // Registered Output

.C(C), // Clock .D(D), // Data

```
.S(S)  // Synchronous Set
);

// End of SB_DFFNSS instantiation
```

 $\mbox{--}$  SB\_DFFNSS - D Flip-Flop - Negative Edge Clock, Set is synchronous with the falling clock edge,  $\mbox{--}$  with .

```
SB_DFFNSS_inst: SB_DFFNSS
port map (
Q => Q, -- Registered Output
C => C, -- Clock
D => D, -- Data
S => S -- Synchronous Set
);
```

-- End of SB\_DFFNSS instantiation

# SB\_DFFNS

#### D Flip-Flop - Negative Edge Clock with Asynchronous Set

Data: D is loaded into the flip-flop when S is low during the falling clock edge transition.

Set: S input is active high, overrides all other inputs and asynchronously sets the Q output.



| Inputs   |   |   | Output |
|----------|---|---|--------|
| S        | D | С | Q      |
| 1        | Χ | Χ | 1      |
| 0        | 0 | ¥ | 0      |
| 0        | 1 | × | 1      |
| Power on | X | X | 0      |
| State    |   |   |        |

#### Key

Y Falling Edge

1 High logic level

0 Low logic level

X Don't care

? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input S: Logic '0'

#### **Verilog Instantiation**

// SB\_DFFNS - D Flip-Flop - Negative Edge Clock, Set is asynchronous to the falling clock edge,

SB\_DFFNS SB\_DFFNS\_inst (

.Q(Q), // Registered Output

.C(C), // Clock .D(D), // Data

.S(S) // Asynchronous Set

```
);
// End of SB_DFFNS instantiation
```

-- SB\_DFFNS - D Flip-Flop - Negative Edge Clock, Set is asynchronous to the falling clock edge

```
SB_DFFNS_inst: SB_DFFNS
port map (
Q => Q, -- Registered Output
C => C, -- Clock
D => D, -- Data
S => S -- Asynchronous Set
);
```

-- End of SB\_DFFNS instantiation

### SB DFFNESR

#### D Flip-Flop - Negative Edge Clock, Enable and Synchronous Reset

Data: D is loaded into the flip-flop when R is low and E is high during the falling clock edge transition.

Reset: Asserting R when the Clock Enable E is high, synchronously resets the Q output during the falling clock edge.



|          | Output |   |          |                   |
|----------|--------|---|----------|-------------------|
| R        | E      | D | С        | Q                 |
| 1        | 1      | Χ | ¥        | 0                 |
| X        | 0      | X | Х        | Previous <b>Q</b> |
| 0        | 1      | 0 | <b>,</b> | 0                 |
| 0        | 1      | 1 | ¥        | 1                 |
| Power on | Χ      | X | X        | 0                 |
| State    |        |   |          |                   |

Key

Y Falling Edge

1 High logic level 0 Low logic level

X Don't care

? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input R: Logic '0'

Input E: Logic '1'

Note that explicitly connecting a Logic '1' value to port E will result in a non-optimal implementation, since an extra LUT will be used to generate the Logic '1'. If the user's intention is to keep the FF always enabled, it is recommended that either port E be left unconnected, or the corresponding FF without a Clock Enable port be used.

# **Verilog Instantiation**

// SB\_DFFNESR - D Flip-Flop - Negative Edge Clock, Reset is synchronous with falling clock edge Clock Enable.

```
SB_DFFNESR SB_DFFNESR_inst (
.Q(Q), // Registered Output
.C(C), // Clock
.E(E), // Clock Enable
.D(D), // Data
.R(R) // Synchronous Reset
);
```

// End of SB\_DFFNESR instantiation

#### **VHDL Instantiation**

-- SB\_DFFNESR - D Flip-Flop - Negative Edge Clock, Reset is synchronous with falling clock edge Clock Enable.

```
SB_DFFNESR_inst: SB_DFFNESR
port map (
Q => Q, -- Registered Output
C => C, -- Clock
E => E, -- Clock Enable
D => D, -- Data
R => R -- Synchronous Reset
);
```

-- End of SB\_DFFNESR instantiation

### SB DFFNER

#### D Flip-Flop - Negative Edge Clock, Enable and Asynchronous Reset

Data: D is loaded into the flip-flop when R is low and E is high during the falling clock edge transition.

Reset: R input is active high, and it overrides all other inputs and asynchronously resets the Q output.



|          | Output |   |   |                   |
|----------|--------|---|---|-------------------|
| R        | E      | D | С | Q                 |
| 1        | X      | Х | Х | 0                 |
| 0        | 0      | Х | Х | Previous <b>Q</b> |
| 0        | 1      | 0 | X | 0                 |
| 0        | 1      | 1 | ¥ | 1                 |
| Power on | X      | X | X | 0                 |
| State    |        |   |   |                   |

| K  | ey               |
|----|------------------|
| ¥  | Falling Edge     |
| 1` | High logic level |
| 0  | Low logic level  |
| Χ  | Don't care       |
| ?  | Unknown          |
|    |                  |

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input R: Logic '0'

Input E: Logic '1'

Note that explicitly connecting a Logic '1' value to port E will result in a non-optimal implementation, since an extra LUT will be used to generate the Logic '1'. If the user's intention is to keep the FF always enabled, it is recommended that either port E be left unconnected, or the corresponding FF without a Clock Enable port be used.

# **Verilog Instantiation**

```
// SB_DFFNER - D Flip-Flop - Negative Edge Clock, Reset is asynchronously
// on falling clock edge and Clock Enable.
       SB_DFFNER
       SB_DFFNER_inst (
                     // Registered Output
       Q(Q)
       .C(C),
                     // Clock
                    // Clock Enable
       .E(E),
       D(D),
                     // Data
       .R(R)
                     // Asynchronously Reset
       );
// End of SB_DFFNER instantiation
```

#### **VHDL Instantiation**

-- SB\_DFFNER - D Flip-Flop - Negative Edge Clock, Reset is asynchronously -- on falling clock edge and Clock Enable.

```
SB_DFFNER_inst: SB_DFFNER

port map (

Q => Q, -- Registered Output

C => C, -- Clock

E => E, -- Clock Enable

D => D, -- Data

R => R -- Asynchronously Reset

);
```

-- End of SB\_DFFNER instantiation

## SB\_DFFNESS

# D Flip-Flop - Negative Edge Clock, Enable and Synchronous Set

Data: D is loaded into the flip-flop when S is low and E is high during the falling clock edge transition.

Set: S and E inputs high, synchronously sets the Q output on the falling clock edge transition.



|          | Output |   |   |                   |
|----------|--------|---|---|-------------------|
| S        | E      | D | С | Q                 |
| 1        | 1      | X | ¥ | 1                 |
| X        | 0      | X | Χ | Previous <b>Q</b> |
| 0        | 1      | 0 | ¥ | 0                 |
| 0        | 1      | 1 | X | 1                 |
| Power on | X      | X | X | 0                 |
| State    |        |   |   |                   |

Key

- ¥ Falling Edge
- 1 High logic level
- 0 Low logic level
- X Don't care
- ? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

#### **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input S: Logic '0'

Input E: Logic '1'

Note that explicitly connecting a Logic '1' value to port E will result in a non-optimal implementation, since an extra LUT will be used to generate the Logic '1'. If the user's intention is to keep the FF always enabled, it is recommended that either port E be left unconnected, or the corresponding FF without a Clock Enable port be used.

# **Verilog Instantiation**

```
// SB_DFFNESS - D Flip-Flop - Negative Edge Clock, Set is synchronous with falling clock edge, 
// and Clock Enable.

SB_DFFNESS SB_DFFNESS_inst (
.Q(Q), // Registered Output
.C(C), // Clock
.E(E), // Clock Enable
.D(D), // Data
.S(S) // Synchronously Set
);

// End of SB_DFFNESS instantiation
```

#### **VHDL Instantiation**

-- SB\_DFFNESS - D Flip-Flop - Negative Edge Clock, Set is synchronous with falling clock edge, -- and Clock Enable.

```
SB_DFFNESS_inst: SB_DFFNESS

port map (

Q => Q, -- Registered Output

C => C, -- Clock

E => E, -- Clock Enable

D => D, -- Data

S => S -- Synchronously Set

);
```

-- End of SB\_DFFNESS instantiation

### SB DFFNES

#### D Flip-Flop - Negative Edge Clock, Enable and Asynchronous Set

Data: D is loaded into the flip-flop when S is low and E is high during the falling clock edge transition.

Set: S input is active high, and it overrides all other inputs and asynchronously sets the Q output.



|          | Output |   |     |                   |
|----------|--------|---|-----|-------------------|
| S        | E      | D | CLK | Q                 |
| 1        | Χ      | X | Χ   | 1                 |
| 0        | 0      | X | Х   | Previous <b>Q</b> |
| 0        | 1      | 0 | ×   | 0                 |
| 0        | 1      | 1 | ¥   | 1                 |
| Power on | X      | X | Χ   | 0                 |
| State    |        |   |     |                   |

Key

- ¥ Falling Edge
- 1 High logic level
- 0 Low logic level
- X Don't care
- ? Unknown

#### **HDL** Usage

This register is inferred during synthesis and can also be explicitly instantiated.

## **Default Signal Values**

The iCEcube2 software assigns the following signal values to unconnected input ports:

Input D: Logic '0'

Input C: Logic '0'

Input S: Logic '0'

Input E: Logic '1'

Note that explicitly connecting a Logic '1' value to port E will result in a non-optimal implementation, since an extra LUT will be used to generate the Logic '1'. If the user's intention is to keep the FF always enabled, it is recommended that either port E be left unconnected, or the corresponding FF without a Clock Enable port be used.

# **Verilog Instantiation**

// SB\_DFFNES - D Flip-Flop - Negative Edge Clock, Set is asynchronous on falling clock edge with clock // Enable.

```
SB_DFFNES
SB_DFFNES_inst (
.Q(Q), // Registered Output
.C(C), // Clock
.E(E), // Clock Enable
.D(D), // Data
.S(S) // Asynchronously Set
);
```

// End of SB\_DFFNES instantiation

#### **VHDL** Instantiation

```
-- SB_DFFNES - D Flip-Flop - Negative Edge Clock, Set is asynchronous
```

-- on falling clock edge and Clock Enable.

```
SB_DFFNES_inst: SB_DFFNES

port map (

Q => Q, -- Registered Output

C => C, -- Clock

E => E, -- Clock Enable

D => D, -- Data

S => S -- Asynchronously Set

);
```

-- End of SB\_DFFNES instantiation

# **Combinational Logic Primitives**

# SB\_LUT4

The LUT unit is a simple ROM 4 input look-up function table.



#### **Initialization values**

LUT state initialization parameter LUT\_INIT = 16'hxxxx;

|            | Inputs |    |    | Output       |
|------------|--------|----|----|--------------|
| <b>I</b> 3 | I2     | I1 | 10 | О            |
| 0          | 0      | 0  | 0  | LUT_INIT[0]  |
| 0          | 0      | 0  | 1  | LUT_INIT[1]  |
| 0          | 0      | 1  | 0  | LUT_INIT[2]  |
| 0          | 0      | 1  | 1  | LUT_INIT[3]  |
| 0          | 1      | 0  | 0  | LUT_INIT[4]  |
| 0          | 1      | 0  | 1  | LUT_INIT[5]  |
| 0          | 1      | 1  | 0  | LUT_INIT[6]  |
| 0          | 1      | 1  | 1  | LUT_INIT[7]  |
| 1          | 0      | 0  | 0  | LUT_INIT[8]  |
| 1          | 0      | 0  | 1  | LUT_INIT[9]  |
| 1          | 0      | 1  | 0  | LUT_INIT[10] |
| 1          | 0      | 1  | 1  | LUT_INIT[11] |
| 1          | 1      | 0  | 0  | LUT_INIT[12] |
| 1          | 1      | 0  | 1  | LUT_INIT[13] |
| 1          | 1      | 1  | 0  | LUT_INIT[14] |
| 1          | 1      | 1  | 1  | LUT_INIT[15] |

#### **HDL** Usage

This primitive is inferred during synthesis and can also be explicitly instantiated.

# **Default Signal Values**

The iCEcube2 software assigns logic value '0' to unconnected input ports.

# Verilog Instantiation

```
// SB_LUT4 : 4-input Look-Up Table
SB LUT4
               SB_LUT4_inst (
.O (O),
               // output
.I0 (I0),
               // data input 0
               // data input 1
.I1 (I1),
               // data input 2
.I2 (I2),
.I3 (I3)
               // data input 3
);
defparam SB_LUT4_inst.LUT_INIT=16'hxxxx; //LUT state initialization parameter, 16 bits.
//End of SB_LUT4 instantiation
```

#### **VHDL** Instantiation

# SB\_CARRY

#### **Carry Logic**

The dedicated Carry Logic within each Logic Cell primarily accelerates and improves the efficiency of arithmetic logic such as adders, accumulators, subtracters, incrementers, decrementers, counters, ALUs, and comparators. The Carry Logic also supports a limited number of wide combinational logic functions.

The figure below illustrates the Carry Logic structure within a Logic Cell. The Carry Logic shares inputs with the associated Look-Up Table (LUT). The I1 and I2 inputs of the LUT directly feed the Carry Logic.. The carry input from the previous adjacent Logic Cell optionally provides an alternate input to the LUT4 function, supplanting the I3 input.

#### Carry Logic Structure within a Logic Cell





|    | Output |    |    |
|----|--------|----|----|
| 10 | I1     | CI | СО |
| 0  | 0      | Χ  | 0  |
| 0  | X      | 0  | 0  |
| X  | 1      | 1  | 1  |
| X  | 0      | 0  | 0  |
| 1  | X      | 1  | 1  |
| 1  | 1      | X  | 1  |

#### **HDL** Usage

This primitive is inferred during synthesis and can also be explicitly instantiated.

# **Default Signal Values**

The iCEcube2 software assigns logic value '0' to unconnected input ports.

# **Verilog Instantiation**

```
SB_CARRY my_carry_inst (
.CO(CO),
.I0(I0),
.I1(I1),
.CI(CI));
```

# **VHDL Instantiation**

```
my_carry_inst: SB_CARRY
port map (
CO => CO,
CI => CI,
I0 => I0,
I1 => I1
);
```

# **Block RAM Primitives**

The iCE architecture supports dual ported synchronous RAM, with 4096 bits, and a fixed 16 bit datawidth. The block is arranged as 256 x 16 bit words. The RAM block may be configured to be used as a RAM with data between 1-16 bits.

#### iCE65 Block RAM

Each iCE65 device includes multiple high-speed synchronous RAM blocks (RAM4K), each 4Kbit in size. A RAM4K block has separate write and read ports, each with independent control signals. Additionally, the write port has an Active-Low bit-line write-enable control; each write-port data bit has an individual write-enable control. By default, input and output data is 16 bits wide, although the data width is configurable using programmable logic and, if needed, multiple RAM4K blocks. The data contents of the RAM4K block are optionally pre-loaded during ICE device configuration.

### **RAM4K Naming Convention Rules**

The SiliconBlue Technologies convention for the RAM4K primitives with negedge Read or Write clock is that the base primitive name is post fixed with N and R or W according to the clock that is affected, as displayed in the table below.

| RAM Primitive Name | Description                             |
|--------------------|-----------------------------------------|
| SB_RAM4K           | Posedge Read clock, Posedge Write clock |
| SB_RAM4KNR         | Negedge Read clock, Posedge Write clock |
| SB_RAM4KNW         | Posedge Read clock, Negedge Write clock |
| SB_RAM4KNRNW       | Negedge Read clock, Negedge Write clock |



RAM4K blocks have separate write and read ports, each with independent control signals.

The data contents of the RAM4K block are optionally pre-loaded during ICE device configuration. If the RAM4K blocks are not pre-loaded during configuration, then the resulting configuration bitstream image is smaller.

If an unitialized RAM4K block is used in the application, then the application must initialize the RAM contents to guarantee the data value.

The following table lists the signals for both ports. Additionally, the write port has an active-Low bit-line write-enable control:

| RAM4K Block RAM Signals |           |                                                                  |  |  |  |
|-------------------------|-----------|------------------------------------------------------------------|--|--|--|
| Signal Name             | Direction | Description                                                      |  |  |  |
| WDATA[15:0]             | Input     | Write Data input                                                 |  |  |  |
| MASK[15:0]              | Input     | Bit-line Write Enable input, active low                          |  |  |  |
| WADDR[7:0]              | Input     | Write Address input. Selects up to 256 possible locations        |  |  |  |
| WE                      | Input     | Write Enable input, active high                                  |  |  |  |
| WCLK                    | Input     | Write Clock input, rising-edge active                            |  |  |  |
| WCLKE                   | Input     | Write Clock Enable input                                         |  |  |  |
| RDATA[15:0]             | Output    | Read Data output                                                 |  |  |  |
| RADDR[7:0]              | Input     | Read Address input. Selects one of 256 possible locations        |  |  |  |
| RE                      | Input     | Read Enable input, active high                                   |  |  |  |
| RCLK                    | Input     | Read Clock input, rising-edge active                             |  |  |  |
| RCLKE                   | Input     | Read Clock Enable input                                          |  |  |  |
| INIT_0,                 | Verilog   | RAM Initialization Data. Passed using 16 parameter strings, each |  |  |  |
| ,INIT_F                 | parameter | comprising 256 bits. (16x256=4096 total bits)                    |  |  |  |

# Write Operation

- 1. Supply a valid address on the WADDR[7:0] address input port
- 2. Supply valid data on the WDATA[15:0] data input port

To write or mask selected data bits, set the associated bit write MASK accordingly. For example, write operations on data bit Data[i] is controlled by the associated MASK[i] input: MASK[i] = 0: Enable write operations for data line Data[i]

- MASK[i] = 1: Mask write operations for data line Data[i]
- Enable the RAM4K write port (WE = 1)
- 3. Apply a rising clock edge on WCLK

| Operation       | WDATA[15:0]<br>Data | MASK[15:0]<br>Bit Enable | WADDR[7:0]<br>Address | WE<br>Enable | WCLK<br>Clock | RAM Location                 |
|-----------------|---------------------|--------------------------|-----------------------|--------------|---------------|------------------------------|
| Disabled        | X                   | X                        | Χ                     | Χ            | 0             | No Change                    |
| Disabled        | X                   | X                        | Χ                     | 0            | X             | No Change                    |
| Write<br>Data   | D[i]                | MASK[i]=0                | WADDR                 | 1            | 1             | RAM[WADDR[i]] =<br>D[i]      |
| Masked<br>Write | Х                   | MASK[i]=1                | WADDR                 | 1            | 1             | RAM[WADDR[i]]<br>= No Change |

### **Read Operation**

The following table describes various read operations for a RAM4K block. All RAM4K read operations are synchronized to the rising edge of RCLK.

| Operation                                                   | RADDR[7:0]<br>Address | RE<br>Enable | RCLK<br>Clock | RDATA[15:0] |
|-------------------------------------------------------------|-----------------------|--------------|---------------|-------------|
| After configuration, before first valid Read Data operation | X                     | X            | X             | Undefined   |
| Disabled                                                    | X                     | 0            | X             | No Change   |
| Read Data                                                   | RA                    | 1            | $\uparrow$    | RAM[RADDR]  |

To read data from the RAM4K block

- 1. Supply a valid address on the RADDR[7:0] address input port
- 2. Enable the RAM4K read port (RE = 1)
- 3. Apply a rising clock edge on RCLK

#### **Default Signal Values**

The iCEcube2 software assigns logic value '0' to all unconnected input ports, with the exception of the RCLKE and WCLKE ports.

The RCLKE and WCLKE ports are always enabled by default i.e. if left unconnected the software will automatically assign a logic value '1' to these ports. Note that explicitly connecting a logic '1' value to ports RCLKE and WCLKE will result in a non-optimal implementation, since an extra LUT will be used to generate the logic '1'. If the user's intention is to always maintain the clocks in an enabled state, it is recommended that these ports be left unconnected.

Note that the Read Enable (RE) and Write Enable (WE) ports are always disabled by default, since they are tied-off to logic '0' by the software, unless explicitly enabled by the user.

#### **Verilog Instantiation**

The following instantiation is for the base SB\_RAM4K, all other RAM4K based primitives share the same format with the only difference being the port name changes. All primitives share the same parameter for data initialization after power on reset.

// SB\_RAM4K with data initialization after power on reset

SB\_RAM4K\_SB\_RAM4K\_with\_INIT (.RDATA(RDATA), .RCLK(RCLK), .RCLKE(RCLKE), .RE(RE), .RADDRRADDR), .WCLK(WCLK), .WCLKE(WCLKE), .WE(WE), .WADDR(WADDR), .MASK(MASK), .WDATA(WDATA));

```
defparam SB_RAM4K_with_INIT.INIT_0 =
defparam SB RAM4K with INIT.INIT 1 =
defparam SB RAM4K with INIT.INIT 2 =
defparam SB_RAM4K_with_INIT.INIT_3 =
defparam SB_RAM4K_with_INIT.INIT_4 =
defparam SB_RAM4K_with_INIT.INIT_5 =
defparam SB_RAM4K_with_INIT.INIT_6 =
defparam SB RAM4K with INIT.INIT 7 =
defparam SB RAM4K with INIT.INIT 8 =
defparam SB RAM4K with INIT.INIT 9 =
defparam SB RAM4K with INIT.INIT A =
defparam SB_RAM4K_with_INIT.INIT_B =
```

#### **VHDL Instantiation**

- - SB\_RAM4K with data initialization after power on reset

```
SB RAM4K with INIT: SB RAM4K
generic map (
port map (
RDATA => RDATA,
RADDR => RADDR,
RCLK => RCLK,
RCLKE => RCLKE,
RE \Rightarrow RE,
WADDR => WADDR,
WCLK => WCLK,
WCLKE => WCLKE.
WDATA => WDATA,
MASK => MASK,
WE => WE
 );
```

The following are the complete list of RAM4K based primitives

#### SB RAM4K

SB\_RAM4K //Posedge clock RCLK WCLK (RDATA, RCLK, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

### SB RAM4KNR

SB\_RAM4KNR // Negative edged Read Clock - i.e. RCLKN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

#### SB\_RAM4KNW

SB\_RAM4KNW // Negative edged Write Clock - i.e. WCLKN (RDATA, RCLK, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

### SB\_RAM4KNRW

SB\_RAM4KNRNW // Negative edged Read and Write – i.e. RCLKN WRCKLN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

# iCE40 Block RAM

Each iCE40 device includes multiple high-speed synchronous RAM blocks, each 4Kbit in size. The RAM block has separate write and read ports, each with independent control signals. Each RAM block can be configured into a RAM block of size 256x16, 512x8, 1024x4 or 2048x2. The data contents of the RAM block are optionally pre-loaded during ICE device configuration.

The following table lists the supported dual port synchronous RAM configurations, each of 4Kbits in size. The RAM blocks can be directly instantiated in the top module and taken through iCube2 flow.

| Block RAM<br>Configuration                                           | Block<br>RAM<br>Size | WADDR<br>Port Size<br>(Bits) | WDATA<br>Port<br>Size<br>(Bits) | RADDR<br>Port<br>Size<br>(Bits) | RDATA<br>Port<br>Size<br>(Bits) | MASK Port<br>Size (Bits) |
|----------------------------------------------------------------------|----------------------|------------------------------|---------------------------------|---------------------------------|---------------------------------|--------------------------|
| SB_RAM256x16<br>SB_RAM256x16NR<br>SB_RAM256x16NW<br>SB_RAM256x16NRNW | 256x16<br>(4K)       | 8 [7:0]                      | 16 [15:0]                       | 8 [7:0]                         | 16 [15:0]                       | 16 [15:0]                |
| SB_RAM512x8<br>SB_RAM512x8NR<br>SB_RAM512x8NW<br>SB_RAM512x8NRNW     | 512x8<br>(4K)        | 9 [8:0]                      | 8 [7:0]                         | 8 [8:0]                         | 8 [7:0]                         | No Mask Port             |
| SB_RAM1024x4<br>SB_RAM1024x4NR<br>SB_RAM1024x4NW<br>SB_RAM1024x4NRNW | 1024x4<br>(4K)       | 10 [9:0]                     | 4 [3:0]                         | 10 [9:0]                        | 4 [3:0]                         | No Mask Port             |
| SB_RAM2048x2<br>SB_RAM2048x2NR<br>SB_RAM2048x2NW<br>SB_RAM2048x2NRNW | 2048x2<br>(4K)       | 11 [10:0]                    | 2 [1:0]                         | 10 [9:0]                        | 2 [1:0]                         | No Mask Port             |

The SiliconBlue Technologies convention for the iCE40 RAM primitives with negedge Read or Write clock is that the base primitive name is post fixed with N and R or W according to the clock that is affected, as displayed in the table below for 256x16 RAM block configuration.

| RAM Primitive Name | Description                             |  |  |
|--------------------|-----------------------------------------|--|--|
| SB_RAM256x16       | Posedge Read clock, Posedge Write clock |  |  |
| SB_RAM4256x16NR    | Negedge Read clock, Posedge Write clock |  |  |
| SB_RAM256x16NW     | Posedge Read clock, Negedge Write clock |  |  |
| SB_RAM256x16NRNW   | Negedge Read clock, Negedge Write clock |  |  |

#### SB\_RAM256x16



## Verilog Instantiation:

SB\_RAM256x16 ram256X16\_inst (

```
.RDATA(RDATA_c[15:0]),
   .RADDR(RADDR_c[7:0]),
   .RCLK(RCLK_c),
   .RCLKE(RCLKE_c),
   .RE(RE_c),
   .WADDR(WADDR_c[7:0]),
   .WCLK(WCLK_c),
   .WCLKE(WCLKE c),
   .WDATA(WDATA_c[15:0]),
   .WE(WE_c),
   .MASK(MASK c[15:0])
defparam ram256x16_inst.INIT_0 =
defparam ram256x16 inst.INIT 1 =
defparam ram256x16_inst.INIT_2 =
defparam ram256x16 inst.INIT 3 =
defparam ram256x16_inst.INIT_4 =
defparam ram256x16 inst.INIT 5 =
defparam ram256x16 inst.INIT 6 =
```

```
defparam ram 256x16 inst.INIT 7 =
defparam ram256x16 inst.INIT 8 =
defparam ram256x16 inst.INIT 9 =
defparam ram 256x16 inst.INIT A =
defparam ram256x16 inst.INIT B =
defparam ram256x16 inst.INIT C =
defparam ram 256x16 inst.INIT D =
defparam ram256x16 inst.INIT E =
defparam ram 256x16 inst.INIT F =
```

#### VHDL Instantiation:

```
ram256X16_inst: SB_RAM256x16
generic map (
port map (
 RDATA \Rightarrow RDATA c
 RADDR \Rightarrow RADDR c
 RCLK => RCLK c
 RCLKE => RCLKE c,
 RE \Rightarrow RE c
 WADDR => WADDR c,
 WCLK=> WCLK_c,
 WCLKE => WCLKE c,
 WDATA => WDATA c
 MASK => MASK c,
```

```
WE => WE_c
);
```

The following modules are the complete list of SB\_RAM256x16 based primitives

### SB RAM256x16

SB\_RAM256x16 //Posedge clock RCLK WCLK (RDATA, RCLK, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

# SB\_RAM256x16NR

SB\_RAM256x16NR // Negative edged Read Clock - i.e. RCLKN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

#### SB\_RAM256x16NW

SB\_RAM256x16NW // Negative edged Write Clock - i.e. WCLKN (RDATA, RCLK, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

# SB RAM256x16NRNW

SB\_RAM256x16NRNW // Negative edged Read and Write - i.e. RCLKN WRCKLN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

## SB\_RAM512x8



#### Verilog Instantiation:

```
SB_RAM512x8 ram512X8_inst (
   .RDATA(RDATA c[7:0]),
   .RADDR(RADDR_c[8:0]),
   .RCLK(RCLK_c),
   .RCLKE(RCLKE_c),
   .RE(RE c),
   .WADDR(WADDR c[8:0]),
   .WCLK(WCLK_c),
   .WCLKE(WCLKE_c),
   .WDATA(WDATA_c[7:0]),
   .WE(WE_c)
);
defparam ram512x8 inst.INIT 0 =
defparam ram512x8 inst.INIT 1 =
defparam ram512x8 inst.INIT 2 =
defparam ram512x8 inst.INIT 3 =
defparam ram512x8_inst.INIT_4 =
defparam ram512x8_inst.INIT_5 =
defparam ram512x8 inst.INIT 6 =
defparam ram512x8_inst.INIT_7 =
```

```
defparam ram512x8 inst.INIT 8 =
defparam ram512x8 inst.INIT 9 =
defparam ram512x8 inst.INIT A =
defparam ram512x8 inst.INIT B =
defparam ram512x8 inst.INIT C =
defparam ram512x8 inst.INIT D =
defparam ram512x8 inst.INIT E =
defparam ram512x8 inst.INIT F =
```

#### VHDL Instantiation:

```
ram512X8 inst: SB RAM512x8
generic map (
port map (
 RDATA => RDATA_c,
 RADDR => RADDR c,
 RCLK => RCLK c
 RCLKE => RCLKE c,
 RE \Rightarrow RE_c,
 WADDR => WADDR c,
 WCLK=> WCLK_c,
 WCLKE => WCLKE c,
 WDATA => WDATA c
 WE => WE c
 );
```

The following modules are the complete list of SB\_RAM512x8 based primitives

# $SB_RAM512x8$

SB\_RAM512x8 //Posedge clock RCLK WCLK (RDATA, RCLK, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

# SB\_RAM512x8NR

SB\_RAM512x8NR // Negative edged Read Clock - i.e. RCLKN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

# SB\_RAM512x8NW

SB\_RAM512x8NW // Negative edged Write Clock - i.e. WCLKN (RDATA, RCLK, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

### SB\_RAM512x8NRNW

SB\_RAM512x8NRNW // Negative edged Read and Write – i.e. RCLKN WRCKLN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

## SB\_RAM1024x4



#### Verilog Instantiation:

SB\_RAM1024x4 ram1024x4\_inst (

```
.RDATA(RDATA_c[3:0]),
   .RADDR(RADDR c[9:0]),
   .RCLK(RCLK_c),
   .RCLKE(RCLKE_c),
   .RE(RE_c),
   .WADDR(WADDR_c[3:0]),
   .WCLK(WCLK_c),
   .WCLKE(WCLKE_c),
   .WDATA(WDATA c[9:0]),
   .WE(WE_c)
);
defparam ram1024x4_inst.INIT_0 =
defparam ram1024x4 inst.INIT 1 =
defparam ram1024x4 inst.INIT 2 =
defparam ram1024x4 inst.INIT 3 =
defparam ram1024x4_inst.INIT_4 =
defparam ram1024x4_inst.INIT_5 =
defparam ram1024x4_inst.INIT_6 =
```

```
defparam ram1024x4 inst.INIT 7 =
defparam ram1024x4 inst.INIT 8 =
defparam ram1024x4 inst.INIT 9 =
defparam ram 1024x4 inst.INIT A =
defparam ram 1024x4 inst.INIT B =
defparam ram1024x4 inst.INIT C =
defparam ram 1024x4 inst.INIT D =
defparam ram1024x4 inst.INIT E =
defparam ram1024x4 inst.INIT F =
```

#### VHDL Instantiation:

```
Ram1024X4 inst: SB RAM1024x4
generic map (
port map (
 RDATA \Rightarrow RDATA_c,
 RADDR => RADDR_c,
 RCLK => RCLK c,
 RCLKE => RCLKE_c,
 RE => RE c
 WADDR => WADDR c,
 WCLK=> WCLK c,
 WCLKE => WCLKE c,
```

```
WDATA => WDATA_c,
WE => WE_c
);
```

The following modules are the complete list of SB\_RAM1024x4 based primitives

## SB RAM1024x4

SB\_RAM1024x4 //Posedge clock RCLK WCLK (RDATA, RCLK, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

# SB\_RAM1024x4NR

SB\_RAM1024x4NR // Negative edged Read Clock - i.e. RCLKN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

### SB\_RAM1024x4NW

SB\_RAM1024x4NW // Negative edged Write Clock - i.e. WCLKN (RDATA, RCLK, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

# SB RAM1024x4NRNW

SB\_RAM1024x4NRNW // Negative edged Read and Write - i.e. RCLKN WRCKLN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

## SB\_RAM2048x2



## Verilog Instantiation:

SB\_RAM2048x2 ram2048x2\_inst (

```
.RDATA(RDATA c[2:0]),
   .RADDR(RADDR_c[10:0]),
   .RCLK(RCLK_c),
   .RCLKE(RCLKE_c),
   .RE(RE_c),
   .WADDR(WADDR_c[2:0]),
   .WCLK(WCLK_c),
   .WCLKE(WCLKE_c),
   .WDATA(WDATA_c[10:0]),
   .WE(WE_c)
defparam ram2048x2_inst.INIT_0 =
defparam ram 2048x2 inst .INIT 1 =
defparam ram2048x2_inst .INIT_2 =
defparam ram2048x2 inst .INIT 3 =
defparam ram2048x2 inst .INIT 4 =
defparam ram2048x2 inst .INIT 5 =
defparam ram2048x2_inst .INIT_6 =
defparam ram2048x2_inst .INIT_7 =
defparam ram2048x2_inst .INIT_8 =
```

#### VHDL Instantiation:

```
Ram2048x2 inst: SB RAM2048x2
generic map (
port map (
 RDATA => RDATA_c,
 RADDR \Rightarrow RADDR_c,
 RCLK => RCLK_c,
 RCLKE \Rightarrow RCLKE c
 RE \Rightarrow RE c
 WADDR => WADDR_c,
 WCLK=> WCLK c.
 WCLKE => WCLKE c,
 WDATA \Rightarrow WDATA c
 WE => WE c
 );
```

The following modules are the complete list of SB\_RAM2048x2 based primitives

# *SB\_RAM2048x2*

SB\_RAM2048x2 //Posedge clock RCLK WCLK (RDATA, RCLK, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

# SB\_RAM2048x2NR

SB\_RAM2048x2NR // Negative edged Read Clock - i.e. RCLKN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLK, WCLKE, WE, WADDR, MASK, WDATA);

# SB\_RAM2048x2NW

SB\_RAM2048x2NW // Negative edged Write Clock - i.e. WCLKN (RDATA, RCLK, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

#### SB RAM2048x2NRNW

SB\_RAM2048x2NRNW // Negative edged Read and Write - i.e. RCLKN WRCKLN (RDATA, RCLKN, RCLKE, RE, RADDR, WCLKN, WCLKE, WE, WADDR, MASK, WDATA);

# $SB_RAM40_4K$

SB\_RAM40\_4K is the basic physical RAM primitive which can be instantiated and configured to different depth and dataports. The SB\_RAM40\_4K block has a size of 4K bits with separate write and read ports, each with independent control signals. By default, input and output data is 16 bits wide, although the data width is configurable using the READ\_MODE and WRITE\_MODE parameters. The data contents of the SB\_RAM40\_4K block are optionally pre-loaded during ICE device configuration.

#### SB\_RAM40\_4K Naming Convention Rules

| RAM Primitive Name | Description                             |  |  |
|--------------------|-----------------------------------------|--|--|
| SB_RAM40_4K        | Posedge Read clock, Posedge Write clock |  |  |
| SB_RAM40_4KNR      | Negedge Read clock, Posedge Write clock |  |  |
| SB_RAM40_4KNW      | Posedge Read clock, Negedge Write clock |  |  |
| SB_RAM40_4KNRNW    | Negedge Read clock, Negedge Write clock |  |  |



The following table lists the signals for both ports.

| SB_RAM40_4K RAM Port Signals |           |                                                                                                 |  |  |
|------------------------------|-----------|-------------------------------------------------------------------------------------------------|--|--|
| Signal Name                  | Direction | Description                                                                                     |  |  |
| WDATA[15:0]                  | Input     | Write Data input                                                                                |  |  |
| MASK[15:0]*                  | Input     | Bit-line Write Enable input, active low. Applicable only when WRITE_MODE parameter is set to 0. |  |  |
| WADDR[7:0]                   | Input     | Write Address input. Selects up to 256 possible locations                                       |  |  |
| WE                           | Input     | Write Enable input, active high                                                                 |  |  |
| WCLK                         | Input     | Write Clock input, rising-edge active                                                           |  |  |
| WCLKE                        | Input     | Write Clock Enable input                                                                        |  |  |
| RDATA[15:0]                  | Output    | Read Data output                                                                                |  |  |
| RADDR[7:0]                   | Input     | Read Address input. Selects one of 256 possible locations                                       |  |  |
| RE                           | Input     | Read Enable input, active high                                                                  |  |  |

| RCLK  | Input | Read Clock input, rising-edge active |
|-------|-------|--------------------------------------|
| RCLKE | Input | Read Clock Enable input              |

| Parameter<br>Name | Description                              | Parameter<br>Value | Configuration           |
|-------------------|------------------------------------------|--------------------|-------------------------|
| INIT_0,           | RAM Initialization Data. Passed using 16 | INIT_0 to          | Initialize the RAM with |
| ,INIT_F           | parameter strings, each comprising 256   | INIT_F             | predefined value        |
|                   | bits. (16x256=4096 total bits)           |                    |                         |
| WRITE_MODE        | Sets the RAM block write port            | 0                  | 256x16                  |
|                   | configuration                            | 1                  | 512x8                   |
|                   |                                          | 2                  | 1024x4                  |
|                   |                                          | 3                  | 2048x2                  |
| READ_MODE         | Sets the RAM block read port             | 0                  | 256x16                  |
|                   | configuration                            | 1                  | 512x8                   |
|                   |                                          | 2                  | 1024x4                  |
|                   |                                          | 3                  | 2048x2                  |

#### Verilog Instantiation:

```
// Physical RAM Instance without Pre Initialization
SB_RAM40_4K ram40_4kinst_physical (
     .RDATA(RDATA),
     .RADDR(RADDR),
     .WADDR(WADDR),
     .MASK(MASK),
     .WDATA(WDATA)
     .RCLKE(RCLKE),
     .RCLK(RCLK),
     .RE(RE),
     .WCLKE(WCLKE),
     .WCLK(WCLK),
     .WE(WE)
      );
defparam ram40_4kinst_physical.READ_MODE=0;
defparam ram40_4kinst_physical.WRITE_MODE=0;
```

#### VHDL Instantiation:

-- Physical RAM Instance without Pre Initialization

```
ram40_4kinst_physical: SB_RAM40_4K generic map (

READ_MODE => 0,

WRITE_MODE= >0

)
port map (

RDATA=>RDATA,
```

RADDR=>RADDR, WADDR=>WADDR, MASK=>MASK, WDATA=>WDATA, RCLKE=>RCLKE, RCLK=>RCLK, RE=>RE, WCLKE=>WCLKE, WCLK=>WCLK, WE=>WE

# **IO Primitives**

# SB\_IO

The SB\_IO block contains five registers. The following figure and Verilog template illustrate the complete user accessible logic diagram, and its Verilog instantiation.



#### **Default Signal Values**

The iCEcube2 software assigns the logic '0' value to all unconnected input ports except for CLOCK\_ENABLE.

Note that explicitly connecting a logic '1' value to port CLOCK\_ENABLE will result in a non-optimal implementation, since an extra LUT will be used to generate the Logic '1'. If the user's intention is to keep the Input and Output registers always enabled, it is recommended that port CLOCK\_ENABLE be left unconnected.

#### **Verilog Instantiation**

```
SB_IO IO_PIN_INST
       .PACKAGE_PIN (Package_Pin),
                                                    // User's Pin signal name
       .LATCH_INPUT_VALUE (latch_input_value), // Latches/holds the Input value
       .CLOCK ENABLE (clock enable),
                                                    // Clock Enable common to input and output
       clock
       .INPUT_CLK (input_clk),
                                                    // Clock for the input registers
                                                    // Clock for the output registers
       .OUTPUT_CLK (output_clk),
       .OUTPUT_ENABLE (output_enable),
                                                    // Output Pin Tristate/Enable control
       .D_OUT_0 (d_out_0),
                                                    // Data 0 - out to Pin/Rising clk edge
       .D_OUT_1 (d_out_1),
                                                    // Data 1 - out to Pin/Falling clk edge
       .D_IN_0 (d_in_0),
                                                    // Data 0 - Pin input/Rising clk edge
                                                    // Data 1 - Pin input/Falling clk edge
       .D_IN_1 (d_in_1)
);
defparam IO_PIN_INST.PIN_TYPE = 6'b000000;
                                                     // See Input and Output Pin Function Tables.
                                                    // Default value of PIN_TYPE = 6'000000
                                                    // i.e. an input pad, with the input signal
                                                     // registered.
defparam IO_PIN_INST.PULLUP = 1'b0;
                                                    // By default, the IO will have NO pull up. This
                                                    // parameter is used only on bank 0, 1, and 2.
                                                     //Ignored when it is placed at bank 3
                                                    // Specify the polarity of all FFs in the IO to be
defparam IO_PIN_INST.NEG_TRIGGER = 1'b0;
                                                    // falling edge when NEG_TRIGGER = 1.
                                                     // Default is rising edge
defparam IO_PIN_INST.IO_STANDARD = "SB_LVCMOS";
                                             // Other IO standards are supported in bank 3
                                             // only: SB_SSTL2_CLASS_2, SB_SSTL2_CLASS_1,
                                             // SB_SSTL18_FULL, SB_SSTL18_HALF, SB_MDDR10,
                                             // SB_MDDR8, SB_MDDR4, SB_MDDR2 etc.
```

#### **Input and Output Pin Function Tables**

Input and Output functions are independently selectable via PIN\_TYPE [1:0] and PIN\_TYPE [5:2] respectively. Specific IO functions are defined by the combination of both attributes. This means that the complete number of combinations is 64, although some combinations are not valid and not defined below. Note that the selection of IO Standards such as SSTL and LVCMOS are not defined by these tables.

|   | Input Pin Function Table   |               |   |                                                                                                                      |  |  |  |
|---|----------------------------|---------------|---|----------------------------------------------------------------------------------------------------------------------|--|--|--|
| # | Pin Function Mnemonic      | PIN_TYPE[1:0] |   | Functional Description of Package Pin<br>Input Operation                                                             |  |  |  |
| 1 | PIN_INPUT                  | 0             | 1 | Simple input pin (D_IN_0)                                                                                            |  |  |  |
| 2 | PIN_INPUT_LATCH            | 1             | 1 | Disables internal data changes on the physical input pin by latching the value.                                      |  |  |  |
| 3 | PIN_INPUT_REGISTERED       | 0             | 0 | Input data is registered in input cell                                                                               |  |  |  |
| 4 | PIN_INPUT_REGISTERED_LATCH | 1             | 0 | Disables internal data changes on the physical input pin by latching the value on the input register                 |  |  |  |
| 5 | PIN_INPUT_DDR              | 0             | 0 | Input 'DDR' data is clocked out on rising and falling clock edges. Use the D_IN_0 and D_IN_1 pins for DDR operation. |  |  |  |

|    | Output Pin Function table                            |     |               |   |      |                                                                                           |  |  |
|----|------------------------------------------------------|-----|---------------|---|------|-------------------------------------------------------------------------------------------|--|--|
| #  | Pin Function Mnemonic                                | PII | PIN_TYPE[5:2] |   | 5:2] | Functional Description of Package<br>Pin Output Operation                                 |  |  |
| 1  | PIN_NO_OUTPUT                                        | 0   | 0             | 0 | 0    | Disables the output function                                                              |  |  |
| 2  | PIN_OUTPUT                                           | 0   | 1             | 1 | 0    | Simple output pin, (no enable)                                                            |  |  |
| 3  | PIN_OUTPUT_TRISTATE                                  | 1   | 0             | 1 | 0    | The output pin may be tristated using the enable                                          |  |  |
| 4  | PIN_OUTPUT_ENABLE_REGISTERED                         | 1   | 1             | 1 | 0    | The output pin may be tristated using a registered enable signal                          |  |  |
| 5  | PIN_OUTPUT_REGISTERED                                | 0   | 1             | 0 | 1    | Output registered, (no enable)                                                            |  |  |
| 6  | PIN_OUTPUT_REGISTERED_ENABLE                         | 1   | 0             | 0 | 1    | Output registered with enable (enable is not registered)                                  |  |  |
| 7  | PIN_OUTPUT_REGISTERED_ENABLE_REGI<br>STERED          | 1   | 1             | 0 | 1    | Output registered and enable registered                                                   |  |  |
| 8  | PIN_OUTPUT_DDR                                       | 0   | 1             | 0 | 0    | Output 'DDR' data is clocked out on rising and falling clock edges                        |  |  |
| 9  | PIN_OUTPUT_DDR_ENABLE                                | 1   | 0             | 0 | 0    | Output data is clocked out on rising and falling clock edges                              |  |  |
| 10 | PIN_OUTPUT_DDR_ENABLE_REGISTERED                     | 1   | 1             | 0 | 0    | Output 'DDR' data with registered enable signal                                           |  |  |
| 11 | PIN_OUTPUT_REGISTERED_INVERTED                       | 0   | 1             | 1 | 1    | Output registered signal is inverted                                                      |  |  |
| 12 | PIN_OUTPUT_REGISTERED_ENABLEINV<br>ERTED             | 1   | 0             | 1 | 1    | Output signal is registered and inverted, (no enable function)                            |  |  |
| 13 | PIN_OUTPUT_REGISTERED_ENABLE_REGI<br>STERED_INVERTED | 1   | 1             | 1 | 1    | Output signal is registered and inverted, the enable/tristate control is also registered. |  |  |

# **Syntax Verilog Use**

defparam my\_generic\_IO.PIN\_TYPE = 6'b{Output Pin Function, Input Pin Function};

Output Pin Function is the bit vector associated with PIN\_TYPE[5:2] and Input Pin Function is the bit vector associated with PIN\_TYPE[1:0], resulting in a 6 bit value PIN\_TYPE[5:0]

### Example

defparam my\_DDR\_IO.PIN\_TYPE = 6'b110000; //PIN\_TYPE[5:2] = 1100, PIN\_TYPE[1:0] = 00

This creates a DDR IO pin whereby the input data is clocked in on both the rising and falling clock edges.

The output 'DDR' data is clocked out on rising and falling clock edges, and the output may be tri-stated, using the enable port of the SB\_IO.

# **Global Buffer Primitives**

# SB GB IO



### **Default Signal Values**

The iCEcube2 software assigns the logic '0' value to all unconnected input ports except for CLOCK\_ENABLE.

Note that explicitly connecting a logic '1' value to port CLOCK\_ENABLE will result in a non-optimal implementation, since an extra LUT will be used to generate the Logic '1'. If the user's intention is to keep the Input and Output registers always enabled, it is recommended that port CLOCK\_ENABLE be left unconnected.

### **Verilog Instantiation**

```
.OUTPUT_CLK (output_clk),
                                                  // The clock for the output registers
.OUTPUT_ENABLE (output_enable),
                                                  // Output Pin Tristate/Enable control
                                                  // Data 0 - out to Pin/Rising clk edge
.D_OUT_0 (d_out_0),
.D_OUT_1 (d_out_1),
                                                  // Data 1 - out to Pin/Falling clk edge
                                                  // Data 0 - Pin input/Rising clk edge
.D_IN_1 (d_in_0),
                                                  // Data 1 - Pin input/Falling clk edge
.D_IN_0 (d_in_1)
.GLOBAL BUFFER OUTPUT (Global Buffered User Clock)
                                                  // Example use - clock buffer driven from the input pin
defparam My_Clock_Buffer_Package_Pin.PIN_TYPE = Various;
                         //For details on PIN_TYPE and Pin Function Tables, refer to section on SB_IO
```

Note that this primitive is a superset of the SB\_IO primitive, and includes the connectivity to drive a Global Buffer. For example SB\_GB\_IO pins are likely to be used for external Clocks.

# SB GB Primitive



# **Verilog Instantiation**

```
SB_GB My_Global_Buffer_i ( // Required for a user's internally generated FPGA signal that is heavily loaded //and requires global buffering. For example, a user's logic-generated clock. .USER_SIGNAL_TO_GLOBAL_BUFFER (Users_internal_Clk), .GLOBAL_BUFFER_OUTPUT ( Global_Buffered_User_Signal) );
```

# PLL Primitives

The Phase Lock Loop (PLL) function is offered as a feature in certain devices of the iCE65 and iCE40 device family. .

It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

### iCE65 PLL Primitives

There are 3 primitives that represent the PLL function in the iCEcube2 software viz. SB\_PLL\_CORE, SB\_PLL\_PAD, and SB\_PLL\_2\_PAD. A short description of each primitive and its ports/parameters is provided in the following sections.

### SB PLL CORE

The SB\_PLL\_CORE primitive should be used when the source clock of the PLL is driven by FPGA routing i.e. when the PLL source clock originates on the FPGA or is driven by an input pad that is not in the bottom IO bank (IO Bank 2).



### **Ports**

REFERENCECLK: PLL source clock that serves as the input to the SB\_PLL\_CORE primitive.

PLLOUTGLOBAL: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCORE:* Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBAL port.

*LOCK:* Output port, when HIGH, indicates that the signal on PLLOUTGLOBAL/PLLOUTCORE is locked to the PLL source on REFERENCECLK.

*EXTFEEDBACK*: External feedback input to PLL. Enabled when the FEEDBACK\_PATH parameter is set to EXTERNAL.

*DYNAMICDELAY:* 4 bit input bus that enables dynamic control of the delay contributed by the Fine Delay Adjust Block. The Fine Delay Adjust Block is used when there is a need to adjust the phase alignment of PLLOUTGLOBAL/PLLOUTCORE with respect to REFERENCECLK. The DYNAMICDELAY port controls are enabled when the DELAY\_ADJUSTMENT\_MODE parameter is set to DYNAMIC.

*RESET:* Active low input that asynchronously resets the PLL.

*BYPASS*: Input signal, when asserted, connects the signal on REFERENCECLK to PLLOUTCORE/PLLOUTGLOBAL pins.

*LATCHINPUTVALUE:* Active high input, when enabled, forces the PLL into low-power mode. The PLLOUTGLOBAL/PLLOUTCORE pins are held static at their last value. This function is enabled when the parameter ENABLE\_ICEGATE is set to '1'.

SCLK, SDI, SDO: These pins are used only for internal testing purposes, and need not be instantiated by users.

#### **Parameters**

The SB\_PLL\_CORE primitive requires configuration through the specification of the following parameters. It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

| Parameter Name         | Description                                                   | Parameter Value | Description                                                                                                                                                               |
|------------------------|---------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEEDBACK_PATH          | Selects the feedback path to the PLL                          | SIMPLE          | Feedback is internal to the PLL, directly from VCO                                                                                                                        |
|                        | T                                                             | DELAY           | Feedback is internal to the PLL,<br>through the Fine Delay Adjust<br>Block                                                                                                |
|                        |                                                               | PHASE_AND_DELAY | Feedback is internal to the PLL,<br>through the Phase Shifter and the<br>Fine Delay Adjust Block                                                                          |
|                        |                                                               | EXTERNAL        | Feedback path is external to the PLL, and connects to EXTFEEDBACK pin. Also uses the Fine Delay Adjust Block.                                                             |
| DELAY_ADJUSTMENT_MODE  | Selects the mode for<br>the Fine Delay<br>Adjust block.       | FIXED           | Delay of the Fine Delay Adjust Block is fixed, the value is specified by the FIXED_DELAY_ADJUSTMENT parameter setting                                                     |
|                        |                                                               | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[3:0] pins                                                                          |
| FIXED_DELAY_ADJUSTMENT | Sets a constant<br>value for the Fine<br>Delay Adjust Block.  | 0, 1,,15        | The PLLOUTGLOBAL & PLLOUTCORE signals are delay compensated by (n+1)*150 ps, where n = FIXED_DELAY_ADJUSTMENT, only if the setting of the DELAY_ADJUSTMENT_MODE is FIXED. |
| PLL_OUT_PHASE          | Controls the phase alignment of the                           | NONE            | No phase alignment. No duty cycle correction                                                                                                                              |
|                        | PLLOUTCORE &                                                  | 0deg            | 0º phase shift                                                                                                                                                            |
|                        | PLLOUTGLOBAL                                                  | 90deg           | 90º phase shift                                                                                                                                                           |
|                        | signals relative to<br>REFERENCECLK                           | 180deg          | 180° phase shift                                                                                                                                                          |
|                        |                                                               | 270deg          | 270° phase shift                                                                                                                                                          |
| DIVR                   | REFERENCECLK<br>divider                                       | 0,1,2,,15       | These parameters are used to control the output frequency,                                                                                                                |
| DIVF                   | Feedback divider                                              | 0,1,,63         | depending on the                                                                                                                                                          |
| DIVQ                   | VCO Divider                                                   | 0,1,,7          | FEEDBACK_PATH setting.                                                                                                                                                    |
| FILTER_RANGE           | PLL Filter Range                                              | 0,1,,7          |                                                                                                                                                                           |
| EXTERNAL_DIVIDE_FACTOR | Divide-by factor of<br>a divider in external<br>feedback path | User specified  | Specified only when there is a user-<br>implemented divider in the external<br>feedback path.                                                                             |
| ENABLE_ICEGATE         | Enables the PLL                                               | 0               | Power-down control disabled                                                                                                                                               |
|                        | power-down<br>control                                         | 1               | Power-down controlled by LATCHINPUTVALUE input                                                                                                                            |

### SB PLL PAD

The SB\_PLL\_PAD primitive should be used when the source clock of the PLL is driven by an input pad that is located in the bottom IO bank (IO Bank 2), and the source clock is not required inside the FPGA.



### **Ports**

PACKAGEPIN: PLL source clock that serves as the input to the SB\_PLL\_PAD primitive.

PLLOUTGLOBAL: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCORE:* Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBAL port.

LOCK: Output port, when HIGH, indicates that the signal on PLLOUTGLOBAL/PLLOUTCORE is locked to the PLL source on PACKAGEPIN.

*EXTFEEDBACK:* External feedback input to PLL. Enabled when the FEEDBACK\_PATH parameter is set to EXTERNAL.

*DYNAMICDELAY*: 4 bit input bus that enables dynamic control of the delay contributed by the Fine Delay Adjust Block. The Fine Delay Adjust Block is used when there is a need to adjust the phase alignment of PLLOUTGLOBAL/PLLOUTCORE with respect to REFERENCECLK. The DYNAMICDELAY port controls are enabled when the DELAY\_ADJUSTMENT\_MODE parameter is set to DYNAMIC.

RESET: Active low input that asynchronously resets the PLL.

*BYPASS:* Input signal, when asserted, connects the signal on REFERENCECLK to PLLOUTCORE/PLLOUTGLOBAL pins.

*LATCHINPUTVALUE:* Active high input, when enabled, forces the PLL into low-power mode. The PLLOUTGLOBAL/PLLOUTCORE pins are held static at their last value. This function is enabled when the parameter ENABLE\_ICEGATE is set to '1'.

*SCLK, SDI, SDO:* These pins are used only for internal testing purposes, and need not be instantiated by users.

# **Parameters**

The SB\_PLL\_PAD primitive requires configuration through the specification of the following parameters. It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

| Parameter Name         | Description                                                   | Parameter Value | Description                                                                                                                                                               |
|------------------------|---------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEEDBACK_PATH          | Selects the feedback path to the PLL                          | SIMPLE          | Feedback is internal to the PLL, directly from VCO                                                                                                                        |
|                        |                                                               | DELAY           | Feedback is internal to the PLL,<br>through the Fine Delay Adjust<br>Block                                                                                                |
|                        |                                                               | PHASE_AND_DELAY | Feedback is internal to the PLL,<br>through the Phase Shifter and the<br>Fine Delay Adjust Block                                                                          |
|                        |                                                               | EXTERNAL        | Feedback path is external to the PLL, and connects to EXTFEEDBACK pin. Also uses the Fine Delay Adjust Block.                                                             |
| DELAY_ADJUSTMENT_MODE  | Selects the mode for<br>the Fine Delay<br>Adjust block.       | FIXED           | Delay of the Fine Delay Adjust Block is fixed, the value is specified by the FIXED_DELAY_ADJUSTMENT parameter setting                                                     |
|                        |                                                               | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[3:0] pins                                                                          |
| FIXED_DELAY_ADJUSTMENT | Sets a constant value for the Fine Delay Adjust Block.        | 0, 1,,15        | The PLLOUTGLOBAL & PLLOUTCORE signals are delay compensated by (n+1)*150 ps, where n = FIXED_DELAY_ADJUSTMENT, only if the setting of the DELAY_ADJUSTMENT_MODE is FIXED. |
| PLL_OUT_PHASE          | Controls the phase alignment of the                           | NONE            | No phase alignment. No duty cycle correction                                                                                                                              |
|                        | PLLOUTCORE &                                                  | 0deg            | 0° phase shift                                                                                                                                                            |
|                        | PLLOUTGLOBAL                                                  | 90deg           | 90° phase shift                                                                                                                                                           |
|                        | signals relative to<br>REFERENCECLK                           | 180deg          | 180° phase shift                                                                                                                                                          |
|                        | REFERENCECER                                                  | 270deg          | 270° phase shift                                                                                                                                                          |
| DIVR                   | REFERENCECLK<br>divider                                       | 0,1,2,,15       | These parameters are used to control the output frequency,                                                                                                                |
| DIVF                   | Feedback divider                                              | 0,1,,63         | depending on the                                                                                                                                                          |
| DIVQ                   | VCO Divider                                                   | 0,1,,7          | FEEDBACK_PATH setting.                                                                                                                                                    |
| FILTER_RANGE           | PLL Filter Range                                              | 0,1,,7          |                                                                                                                                                                           |
| EXTERNAL_DIVIDE_FACTOR | Divide-by factor of<br>a divider in external<br>feedback path | User specified  | Specified only when there is a user-<br>implemented divider in the external<br>feedback path.                                                                             |
| ENABLE_ICEGATE         | Enables the PLL                                               | 0               | Power-down control disabled                                                                                                                                               |
|                        | power-down<br>control                                         | 1               | Power-down controlled by LATCHINPUTVALUE input                                                                                                                            |

# SB PLL 2 PAD

The SB\_PLL\_2\_PAD primitive should be used when the source clock of the PLL is driven by an input pad that is located in the bottom IO bank (IO Bank 2), and in addition to the PLL output, the source clock is also required inside the FPGA.



#### **Ports**

PACKAGEPIN: PLL source clock that serves as the input to the SB\_PLL\_PAD primitive.

*PLLOUTGLOBALA:* The signal on PACKAGEPIN appears on the FPGA at this pin, and drives a global clock network on the FPGA. Do not use this pin in an external feedback path to the PLL.

*PLLOUTCOREA:* The signal on PACKAGEPIN appears on the FPGA at this pin, which drives regular FPGA routing. Do not use this pin in an external feedback path to the PLL.

PLLOUTGLOBALB: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCOREB*: Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBAL port.

*LOCK:* Output port, when HIGH, indicates that the signal on PLLOUTGLOBALB/PLLOUTCOREB is locked to the PLL source on PACKAGEPIN.

*EXTFEEDBACK:* External feedback input to PLL. Enabled when the FEEDBACK\_PATH parameter is set to EXTERNAL.

*DYNAMICDELAY:* 4 bit input bus that enables dynamic control of the delay contributed by the Fine Delay Adjust Block. The Fine Delay Adjust Block is used when there is a need to adjust the phase alignment of PLLOUTGLOBAL/PLLOUTCORE with respect to REFERENCECLK. The DYNAMICDELAY port controls are enabled when the DELAY\_ADJUSTMENT\_MODE parameter is set to DYNAMIC.

*RESET:* Active low input that asynchronously resets the PLL.

*BYPASS*: Input signal, when asserted, connects the signal on REFERENCECLK to PLLOUTCORE/PLLOUTGLOBAL pins.

LATCHINPUTVALUE: Active high input, when enabled, forces the PLL into low-power mode. The PLLOUTGLOBALA/PLLOUTCOREA pins are held static at their last value only when the parameter ENABLE\_ICEGATE\_PORTA is set to '1', and the LATCHINPUTVALUE signal is asserted. The PLLOUTGLOBALB/PLLOUTCOREB pins are held static at their last value only when the parameter ENABLE\_ICEGATE\_PORTB is set to '1', and the LATCHINPUTVALUE signal is asserted.

SCLK, SDI, SDO: These pins are used only for internal testing purposes, and need not be instantiated by users.

#### **Parameters**

The SB\_PLL\_2\_PAD primitive requires configuration through the specification of the following parameters. It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

| Parameter Name         | Description                                                   | Parameter Value | Description                                                                                                                                                               |
|------------------------|---------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEEDBACK_PATH          | Selects the feedback path to the PLL                          | SIMPLE          | Feedback is internal to the PLL, directly from VCO                                                                                                                        |
|                        | paulto ale 122                                                | DELAY           | Feedback is internal to the PLL,<br>through the Fine Delay Adjust<br>Block                                                                                                |
|                        |                                                               | PHASE_AND_DELAY | Feedback is internal to the PLL,<br>through the Phase Shifter and the<br>Fine Delay Adjust Block                                                                          |
|                        |                                                               | EXTERNAL        | Feedback path is external to the PLL, and connects to EXTFEEDBACK pin. Also uses the Fine Delay Adjust Block.                                                             |
| DELAY_ADJUSTMENT_MODE  | Selects the mode for the Fine Delay Adjust block.             | FIXED           | Delay of the Fine Delay Adjust Block is fixed, the value is specified by the FIXED_DELAY_ADJUSTMENT parameter setting                                                     |
|                        |                                                               | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[3:0] pins                                                                          |
| FIXED_DELAY_ADJUSTMENT | Sets a constant value<br>for the Fine Delay<br>Adjust Block.  | 0, 1,,15        | The PLLOUTGLOBAL & PLLOUTCORE signals are delay compensated by (n+1)*150 ps, where n = FIXED_DELAY_ADJUSTMENT, only if the setting of the DELAY_ADJUSTMENT_MODE is FIXED. |
| PLL_OUT_PHASE          | Controls the phase alignment of the                           | NONE            | No phase alignment. No duty cycle correction                                                                                                                              |
|                        | PLLOUTCORE &                                                  | 0deg            | 0° phase shift                                                                                                                                                            |
|                        | PLLOUTGLOBAL                                                  | 90deg           | 90° phase shift                                                                                                                                                           |
|                        | signals relative to                                           | 180deg          | 180° phase shift                                                                                                                                                          |
|                        | REFERENCECLK                                                  | 270deg          | 270° phase shift                                                                                                                                                          |
| DIVR                   | REFERENCECLK<br>divider                                       | 0,1,2,,15       | These parameters are used to control the output frequency,                                                                                                                |
| DIVF                   | Feedback divider                                              | 0,1,,63         | depending on the                                                                                                                                                          |
| DIVQ                   | VCO Divider                                                   | 0,1,,7          | FEEDBACK_PATH setting.                                                                                                                                                    |
| FILTER_RANGE           | PLL Filter Range                                              | 0,1,,7          | 7                                                                                                                                                                         |
| EXTERNAL_DIVIDE_FACTOR | Divide-by factor of a<br>divider in external<br>feedback path | User specified  | Specified only when there is a user-<br>implemented divider in the external<br>feedback path.                                                                             |
| ENABLE_ICEGATE_PORTA/  | Separate power-                                               | 0               | Power-down control disabled                                                                                                                                               |
| ENABLE_ICEGATE_PORTB   | down controls for<br>Port A and Port B<br>outputs             | 1               | Power-down controlled by LATCHINPUTVALUE input                                                                                                                            |

# iCE40 PLL Primitives

There are 5 primitives that represent the PLL function in the iCEcube2 software viz. SB\_PLL40\_CORE, SB\_PLL40\_PAD, SB\_PLL40\_2\_PAD, SB\_PLL40\_2F\_CORE and SB\_PLL40\_2F\_PAD for the ice40 device family. A short description of each primitive and its ports/parameters is provided in the following sections.

It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

# SB PLL40 CORE

The SB\_PLL40\_CORE primitive should be used when the source clock of the PLL is driven by FPGA routing i.e. when the PLL source clock originates on the FPGA or is driven by an input pad that is not in the bottom IO bank (IO Bank 2).



### **Ports**

REFERENCECLK: PLL source clock that serves as the input to the SB\_PLL40\_CORE primitive.

PLLOUTGLOBAL: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCORE:* Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBAL port.

LOCK: Output port, when HIGH, indicates that the signal on PLLOUTGLOBAL/PLLOUTCORE is locked to the PLL source on REFERENCECLK.

*EXTFEEDBACK:* External feedback input to PLL. Enabled when the FEEDBACK\_PATH parameter is set to EXTERNAL.

*DYNAMICDELAY:* 7 bit input bus that enables dynamic control of the delay contributed by the Fine Delay Adjust Block. The Fine Delay Adjust Block is used when there is a need to adjust the phase alignment of PLLOUTGLOBAL/PLLOUTCORE with respect to REFERENCECLK. The

DYNAMICDELAY port controls are enabled when the DELAY\_ADJUSTMENT\_MODE parameter is set to DYNAMIC.

RESETB: Active low input that asynchronously resets the PLL.

*BYPASS*: Input signal, when asserted, connects the signal on REFERENCECLK to PLLOUTCORE/PLLOUTGLOBAL pins.

*LATCHINPUTVALUE:* Active high input, when enabled, forces the PLL into low-power mode. The PLLOUTGLOBAL/PLLOUTCORE pins are held static at their last value. This function is enabled when the parameter ENABLE\_ICEGATE is set to '1'.

SCLK, SDI, SDO: These pins are used only for internal testing purposes, and need not be instantiated by users.

#### **Parameters**

The SB\_PLL40\_CORE primitive requires configuration through the specification of the following parameters. It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

| Parameter Name                     | Description                                                                      | Parameter Value | Description                                                                                                                                                             |
|------------------------------------|----------------------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEEDBACK_PATH                      | Selects the feedback path to the PLL                                             | SIMPLE          | Feedback is internal to the PLL, directly from VCO                                                                                                                      |
|                                    |                                                                                  | DELAY           | Feedback is internal to the PLL,<br>through the Fine Delay Adjust<br>Block                                                                                              |
|                                    |                                                                                  | PHASE_AND_DELAY | Feedback is internal to the PLL,<br>through the Phase Shifter and the<br>Fine Delay Adjust Block                                                                        |
|                                    |                                                                                  | EXTERNAL        | Feedback path is external to the PLL, and connects to EXTFEEDBACK pin. Also uses the Fine Delay Adjust Block.                                                           |
| DELAY_ADJUSTMENT_M<br>ODE_FEEDBACK | Selects the mode for the<br>Fine Delay Adjust block in<br>the feedback path      | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the FDA_FEEDBACK<br>parameter setting                                                    |
|                                    |                                                                                  | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[3:0] pins                                                                        |
| FDA_FEEDBACK                       | Sets a constant value for<br>the Fine Delay Adjust<br>Block in the feedback path | 0, 1,,15        | The PLLOUTGLOBAL & PLLOUTCORE signals are delay compensated by (n+1)*150 ps, where n = FDA_FEEDBACK only if the setting of the DELAY_ADJUSTMENT_MODE_FEEDBACK is FIXED. |
| DELAY_ADJUSTMENT_M<br>ODE_RELATIVE | Selects the mode for the<br>Fine Delay Adjust block                              | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the FDA_RELATIVE<br>parameter setting                                                    |
|                                    |                                                                                  | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[7:4] pins                                                                        |
| FDA_RELATIVE                       | Sets a constant value for<br>the Fine Delay Adjust<br>Block                      | 0, 1,,15        | The PLLOUTGLOBALA & PLLOUTCOREA signals are additionally delayed by (n+1)*150 ps, where n = FDA_RELATIVE. Used if DELAY_ADJUSTMENT_MODE_ RELATIVE is "FIXED".           |
| SHIFTREG_DIV_MODE                  | Selects shift register configuration                                             | 0,1             | Used when FEEDBACK_PATH is  "PHASE_AND_DELAY".  0→Divide by 4  1→Divide by 7                                                                                            |
| PLLOUT_SELECT                      | Selects the signal to be output at the PLLOUTCORE and                            | SHIFTREG_0deg   | 0° phase shift only if the setting of<br>FEEDBACK_PATH is<br>"PHASE_AND_DELAY"                                                                                          |
|                                    | PLLOUTGLOBAL ports                                                               | SHIFTREG_90deg  | 90° phase shift only if the setting<br>of FEEDBACK_PATH is<br>"PHASE_AND_DELAY" and<br>SHIFTREG_DIV_MODE=0                                                              |
|                                    |                                                                                  | GENCLK          | The internally generated PLL frequency will be output without any phase shift.                                                                                          |

|                            |                                                               | GENCLK_HALF                        | The internally generated PLL frequency will be divided by 2 and then output. No phase shift. |
|----------------------------|---------------------------------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------|
| DIVR                       | REFERENCECLK divider                                          | 0,1,2,,15                          | These parameters are used to                                                                 |
| DIVF                       | Feedback divider                                              | 0,1,,63                            | control the output frequency,                                                                |
| DIVQ                       | VCO Divider                                                   | 0,1,,7                             | depending on the                                                                             |
| FILTER_RANGE               | PLL Filter Range                                              | 0,1,,7                             | FEEDBACK_PATH setting.                                                                       |
| EXTERNAL_DIVIDE_FACT<br>OR | Divide-by factor of a<br>divider in external<br>feedback path | User specified value.<br>Default 1 | Specified only when there is a user-implemented divider in the external feedback path.       |
| ENABLE_ICEGATE             | Enables the PLL power-                                        | 0                                  | Power-down control disabled                                                                  |
|                            | down control                                                  | 1                                  | Power-down controlled by LATCHINPUTVALUE input                                               |

# SB PLL40 PAD

The SB\_PLL40\_PAD primitive should be used when the source clock of the PLL is driven by an input pad that is located in the bottom IO bank (IO Bank 2) or the top IO bank (IO Bank 0), and the source clock is not required inside the FPGA.



#### **Ports**

PACKAGEPIN: PLL source clock that serves as the input to the SB\_PLL40\_PAD primitive.

PLLOUTGLOBAL: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCORE*: Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBAL port.

LOCK: Output port, when HIGH, indicates that the signal on PLLOUTGLOBAL/PLLOUTCORE is locked to the PLL source on REFERENCECLK.

*EXTFEEDBACK:* External feedback input to PLL. Enabled when the FEEDBACK\_PATH parameter is set to EXTERNAL.

*DYNAMICDELAY:* 7 bit input bus that enables dynamic control of the delay contributed by the Fine Delay Adjust Block. The Fine Delay Adjust Block is used when there is a need to adjust the phase alignment of PLLOUTGLOBAL/PLLOUTCORE with respect to REFERENCECLK. The DYNAMICDELAY port controls are enabled when the DELAY\_ADJUSTMENT\_MODE parameter is set to DYNAMIC.

RESETB: Active low input that asynchronously resets the PLL.

*BYPASS*: Input signal, when asserted, connects the signal on REFERENCECLK to PLLOUTCORE/PLLOUTGLOBAL pins.

*LATCHINPUTVALUE:* Active high input, when enabled, forces the PLL into low-power mode. The PLLOUTGLOBAL/PLLOUTCORE pins are held static at their last value. This function is enabled when the parameter ENABLE ICEGATE is set to '1'.

*SCLK, SDI, SDO*: These pins are used only for internal testing purposes, and need not be instantiated by users.

### **Parameters**

The SB\_PLL40\_PAD primitive requires configuration through the specification of the following parameters. It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

| Parameter Name                     | Description                                                                      | Parameter Value | Description                                                                                                                                                             |
|------------------------------------|----------------------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEEDBACK_PATH                      | Selects the feedback path to the PLL                                             | SIMPLE          | Feedback is internal to the PLL, directly from VCO                                                                                                                      |
|                                    |                                                                                  | DELAY           | Feedback is internal to the PLL,<br>through the Fine Delay Adjust<br>Block                                                                                              |
|                                    |                                                                                  | PHASE_AND_DELAY | Feedback is internal to the PLL,<br>through the Phase Shifter and the<br>Fine Delay Adjust Block                                                                        |
|                                    |                                                                                  | EXTERNAL        | Feedback path is external to the PLL, and connects to EXTFEEDBACK pin. Also uses the Fine Delay Adjust Block.                                                           |
| DELAY_ADJUSTMENT_M<br>ODE_FEEDBACK | Selects the mode for the<br>Fine Delay Adjust block in<br>the feedback path      | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the FDA_FEEDBACK<br>parameter setting                                                    |
|                                    |                                                                                  | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[3:0] pins                                                                        |
| FDA_FEEDBACK                       | Sets a constant value for<br>the Fine Delay Adjust<br>Block in the feedback path | 0, 1,,15        | The PLLOUTGLOBAL & PLLOUTCORE signals are delay compensated by (n+1)*150 ps, where n = FDA_FEEDBACK only if the setting of the DELAY_ADJUSTMENT_MODE_FEEDBACK is FIXED. |
| DELAY_ADJUSTMENT_M<br>ODE_RELATIVE | Selects the mode for the<br>Fine Delay Adjust block                              | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the FDA_RELATIVE<br>parameter setting                                                    |
|                                    |                                                                                  | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[7:4] pins                                                                        |
| FDA_RELATIVE                       | Sets a constant value for<br>the Fine Delay Adjust<br>Block                      | 0, 1,,15        | The PLLOUTGLOBALA & PLLOUTCOREA signals are additionally delayed by (n+1)*150 ps, where n = FDA_RELATIVE. Used if DELAY_ADJUSTMENT_MODE_ RELATIVE is "FIXED".           |
| SHIFTREG_DIV_MODE                  | Selects shift register configuration                                             | 0,1             | Used when FEEDBACK_PATH is  "PHASE_AND_DELAY".  0→Divide by 4  1→Divide by 7                                                                                            |
| PLLOUT_SELECT                      | Selects the signal to be output at the PLLOUTCORE and                            | SHIFTREG_0deg   | 0° phase shift only if the setting of<br>FEEDBACK_PATH is<br>"PHASE_AND_DELAY"                                                                                          |
|                                    | PLLOUTGLOBAL ports                                                               | SHIFTREG_90deg  | 90° phase shift only if the setting<br>of FEEDBACK_PATH is<br>"PHASE_AND_DELAY" and<br>SHIFTREG_DIV_MODE=0                                                              |
|                                    |                                                                                  | GENCLK          | The internally generated PLL frequency will be output without any phase shift.                                                                                          |

|                            |                                                               | GENCLK_HALF                        | The internally generated PLL frequency will be divided by 2 and then output. No phase shift. |
|----------------------------|---------------------------------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------|
| DIVR                       | REFERENCECLK divider                                          | 0,1,2,,15                          | These parameters are used to                                                                 |
| DIVF                       | Feedback divider                                              | 0,1,,63                            | control the output frequency,                                                                |
| DIVQ                       | VCO Divider                                                   | 0,1,,7                             | depending on the                                                                             |
| FILTER_RANGE               | PLL Filter Range                                              | 0,1,,7                             | FEEDBACK_PATH setting.                                                                       |
| EXTERNAL_DIVIDE_FACT<br>OR | Divide-by factor of a<br>divider in external<br>feedback path | User specified value.<br>Default 1 | Specified only when there is a user-implemented divider in the external feedback path.       |
| ENABLE_ICEGATE             | Enables the PLL power-                                        | 0                                  | Power-down control disabled                                                                  |
|                            | down control                                                  | 1                                  | Power-down controlled by LATCHINPUTVALUE input                                               |

# SB PLL40 2 PAD

The SB\_PLL40\_2\_PAD primitive should be used when the source clock of the PLL is driven by an input pad that is located in the bottom IO bank (IO Bank 2) or the top IO bank (IO Bank 0), and in addition to the PLL output, the source clock is also required inside the FPGA.



#### **Ports**

PACKAGEPIN: PLL source clock that serves as the input to the SB\_PLL\_PAD primitive.

*PLLOUTGLOBALA*: The signal on PACKAGEPIN appears on the FPGA at this pin, and drives a global clock network on the FPGA. Do not use this pin in an external feedback path to the PLL.

*PLLOUTCOREA*: The signal on PACKAGEPIN appears on the FPGA at this pin, which drives regular FPGA routing. Do not use this pin in an external feedback path to the PLL.

PLLOUTGLOBALB: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCOREB*: Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBAL port.

*LOCK*: Output port, when HIGH, indicates that the signal on PLLOUTGLOBALB/PLLOUTCOREB is locked to the PLL source on PACKAGEPIN.

*EXTFEEDBACK:* External feedback input to PLL. Enabled when the FEEDBACK\_PATH parameter is set to EXTERNAL.

*DYNAMICDELAY:* 4 bit input bus that enables dynamic control of the delay contributed by the Fine Delay Adjust Block. The Fine Delay Adjust Block is used when there is a need to adjust the phase alignment of PLLOUTGLOBAL/PLLOUTCORE with respect to REFERENCECLK. The DYNAMICDELAY port controls are enabled when the DELAY\_ADJUSTMENT\_MODE parameter is set to DYNAMIC.

RESET: Active low input that asynchronously resets the PLL.

*BYPASS*: Input signal, when asserted, connects the signal on REFERENCECLK to PLLOUTCORE/PLLOUTGLOBAL pins.

LATCHINPUTVALUE: Active high input, when enabled, forces the PLL into low-power mode. The PLLOUTGLOBALA/PLLOUTCOREA pins are held static at their last value only when the parameter ENABLE\_ICEGATE\_PORTA is set to '1', and the LATCHINPUTVALUE signal is asserted. The PLLOUTGLOBALB/PLLOUTCOREB pins are held static at their last value only when the parameter ENABLE\_ICEGATE\_PORTB is set to '1', and the LATCHINPUTVALUE signal is asserted.

SCLK, SDI, SDO: These pins are used only for internal testing purposes, and need not be instantiated by users.

#### **Parameters**

The SB\_PLL40\_2\_PAD primitive requires configuration through the specification of the following parameters. It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

| Parameter Name                  | Description                                                                      | Parameter Value | Description                                                                                                                                                                 |
|---------------------------------|----------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEEDBACK_PATH                   | Selects the feedback path to the PLL                                             | SIMPLE          | Feedback is internal to the PLL, directly from VCO                                                                                                                          |
|                                 |                                                                                  | DELAY           | Feedback is internal to the PLL,<br>through the Fine Delay Adjust<br>Block                                                                                                  |
|                                 |                                                                                  | PHASE_AND_DELAY | Feedback is internal to the PLL,<br>through the Phase Shifter and<br>the Fine Delay Adjust Block                                                                            |
|                                 |                                                                                  | EXTERNAL        | Feedback path is external to the PLL, and connects to EXTFEEDBACK pin. Also uses the Fine Delay Adjust Block.                                                               |
| DELAY_ADJUSTMENT_MODE _FEEDBACK | Selects the mode for the<br>Fine Delay Adjust block in<br>the feedback path      | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the<br>FDA_FEEDBACK parameter<br>setting                                                     |
|                                 |                                                                                  | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[3:0] pins                                                                            |
| FDA_FEEDBACK                    | Sets a constant value for<br>the Fine Delay Adjust<br>Block in the feedback path | 0, 1,,15        | The PLLOUTGLOBAL & PLLOUTCORE signals are delay compensated by (n+1)*150 ps, where n = FDA_FEEDBACK only if the setting of the DELAY_ADJUSTMENT_MODE _FEEDBACK is FIXED.    |
| DELAY_ADJUSTMENT_MODE _RELATIVE | Selects the mode for the Fine Delay Adjust block                                 | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the FDA_RELATIVE<br>parameter setting                                                        |
|                                 |                                                                                  | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[7:4] pins                                                                            |
| FDA_RELATIVE                    | Sets a constant value for<br>the Fine Delay Adjust<br>Block                      | 0, 1,,15        | The PLLOUTGLOBALA & PLLOUTCOREA signals are delayed w.r.t. the Port B signals, by (n+1)*150 ps, where n = FDA_RELATIVE. Used if DELAY_ADJUSTMENT_MODE _RELATIVE is "FIXED". |
| SHIFTREG_DIV_MODE               | Selects shift register configuration                                             | 0,1             | Used when FEEDBACK_PATH is "PHASE_AND_DELAY".  0→Divide by 4  1→Divide by 7                                                                                                 |
| PLLOUT_SELECT_PORTB             | Selects the signal to be output at the PLLOUTCOREB and PLLOUTCLOBAL B parts      | SHIFTREG_0deg   | 0° phase shift only if the setting<br>of FEEDBACK_PATH is<br>"PHASE_AND_DELAY"                                                                                              |
|                                 | PLLOUTGLOBALB ports                                                              | SHIFTREG_90deg  | 90° phase shift only if the setting<br>of FEEDBACK_PATH is<br>"PHASE_AND_DELAY" and<br>SHIFTREG_DIV_MODE=0                                                                  |

|                        |                                                               | GENCLK                             | The internally generated PLL frequency will be output to PortB. No phase shift.                       |
|------------------------|---------------------------------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------|
|                        |                                                               | GENCLK_HALF                        | The internally generated PLL frequency will be divided by 2 and then output to PORTB. No phase shift. |
| DIVR                   | REFERENCECLK divider                                          | 0,1,2,,15                          | These parameters are used to                                                                          |
| DIVF                   | Feedback divider                                              | 0,1,,63                            | control the output frequency,                                                                         |
| DIVQ                   | VCO Divider                                                   | 0,1,,7                             | depending on the                                                                                      |
| FILTER_RANGE           | PLL Filter Range                                              | 0,1,,7                             | FEEDBACK_PATH setting.                                                                                |
| EXTERNAL_DIVIDE_FACTOR | Divide-by factor of a<br>divider in external<br>feedback path | User specified value.<br>Default 1 | Specified only when there is a user-implemented divider in the external feedback path.                |
| ENABLE_ICEGATE_PORTA   | Enables the PLL power-                                        | 0                                  | Power-down control disabled                                                                           |
|                        | down control                                                  | 1                                  | Power-down controlled by LATCHINPUTVALUE input                                                        |
| ENABLE_ICEGATE_PORTB   | Enables the PLL power-                                        | 0                                  | Power-down control disabled                                                                           |
|                        | down control                                                  | 1                                  | Power-down controlled by LATCHINPUTVALUE input                                                        |

# SB\_PLL40\_2F\_CORE

The SB\_PLL40\_2F\_CORE primitive should be used when PLL is used to generate 2 different output frequencies, and the source clock of the PLL is driven by FPGA routing i.e. when the PLL source clock originates on the FPGA.



### **Ports**

REFERENCECLK: PLL source clock that serves as the input to the SB\_PLL40\_2F\_CORE primitive.

PLLOUTGLOBALA: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCOREA*: Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBALA port.

PLLOUTGLOBALB: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCOREB:* Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBALB port.

LOCK: Output port, when HIGH, indicates that the signal on PLLOUTGLOBALB/PLLOUTCOREB is locked to the PLL source on PACKAGEPIN.

*EXTFEEDBACK:* External feedback input to PLL. Enabled when the FEEDBACK\_PATH parameter is set to EXTERNAL.

*DYNAMICDELAY:* 4 bit input bus that enables dynamic control of the delay contributed by the Fine Delay Adjust Block. The Fine Delay Adjust Block is used when there is a need to adjust the phase alignment of PLLOUTGLOBAL/PLLOUTCORE with respect to REFERENCECLK. The DYNAMICDELAY port controls are enabled when the DELAY\_ADJUSTMENT\_MODE parameter is set to DYNAMIC.

RESETB: Active low input that asynchronously resets the PLL.

*BYPASS*: Input signal, when asserted, connects the signal on REFERENCECLK to PLLOUTCORE/PLLOUTGLOBAL pins.

LATCHINPUTVALUE: Active high input, when enabled, forces the PLL into low-power mode. The PLLOUTGLOBALA/PLLOUTCOREA pins are held static at their last value only when the parameter ENABLE\_ICEGATE\_PORTA is set to '1', and the LATCHINPUTVALUE signal is asserted. The PLLOUTGLOBALB/PLLOUTCOREB pins are held static at their last value only when the parameter ENABLE\_ICEGATE\_PORTB is set to '1', and the LATCHINPUTVALUE signal is asserted.

SCLK, SDI, SDO: These pins are used only for internal testing purposes, and need not be instantiated by users.

#### **Parameters**

The SB\_PLL40\_2F\_CORE primitive requires configuration through the specification of the following parameters. It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

| Parameter Name                  | Description                                                                      | Parameter Value | Description                                                                                                                                                                 |
|---------------------------------|----------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEEDBACK_PATH                   | Selects the feedback path to the PLL                                             | SIMPLE          | Feedback is internal to the PLL, directly from VCO                                                                                                                          |
|                                 |                                                                                  | DELAY           | Feedback is internal to the PLL,<br>through the Fine Delay Adjust<br>Block                                                                                                  |
|                                 |                                                                                  | PHASE_AND_DELAY | Feedback is internal to the PLL,<br>through the Phase Shifter and<br>the Fine Delay Adjust Block                                                                            |
|                                 |                                                                                  | EXTERNAL        | Feedback path is external to the PLL, and connects to EXTFEEDBACK pin. Also uses the Fine Delay Adjust Block.                                                               |
| DELAY_ADJUSTMENT_MODE _FEEDBACK | Selects the mode for the<br>Fine Delay Adjust block in<br>the feedback path      | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the<br>FDA_FEEDBACK parameter<br>setting                                                     |
|                                 |                                                                                  | DYNAMIC         | Delay of Fine Delay Adjust Block<br>is determined by the signal value<br>at the DYNAMICDELAY[3:0]<br>pins                                                                   |
| FDA_FEEDBACK                    | Sets a constant value for<br>the Fine Delay Adjust<br>Block in the feedback path | 0, 1,,15        | The PLLOUTGLOBALA & PLLOUTCOREA signals are delay compensated by (n+1)*150 ps, where n = FDA_FEEDBACK only if the setting of the DELAY_ADJUSTMENT_MODE _FEEDBACK is FIXED.  |
| DELAY_ADJUSTMENT_MODE _RELATIVE | Selects the mode for the<br>Fine Delay Adjust block                              | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the FDA_RELATIVE<br>parameter setting                                                        |
|                                 |                                                                                  | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[7:4] pins                                                                            |
| FDA_RELATIVE                    | Sets a constant value for<br>the Fine Delay Adjust<br>Block                      | 0, 1,,15        | The PLLOUTGLOBALA & PLLOUTCOREA signals are delayed w.r.t. the Port B signals, by (n+1)*150 ps, where n = FDA_RELATIVE. Used if DELAY_ADJUSTMENT_MODE _RELATIVE is "FIXED". |
| SHIFTREG_DIV_MODE               | Selects shift register configuration                                             | 0,1             | Used when FEEDBACK_PATH is "PHASE_AND_DELAY". 0→Divide by 4 1→Divide by 7                                                                                                   |
| PLLOUT_SELECT_PORTA             | Selects the signal to be output at the PLLOUTCOREA and                           | SHIFTREG_0deg   | 0° phase shift only if the setting<br>of FEEDBACK_PATH is<br>"PHASE_AND_DELAY"                                                                                              |
|                                 | PLLOUTGLOBALA ports                                                              | SHIFTREG_90deg  | 90° phase shift only if the setting of FEEDBACK_PATH is                                                                                                                     |

|                        |                                                                            |                                    | "PHASE_AND_DELAY" and SHIFTREG_DIV_MODE=0                                                                  |
|------------------------|----------------------------------------------------------------------------|------------------------------------|------------------------------------------------------------------------------------------------------------|
|                        |                                                                            | GENCLK                             | The internally generated PLL frequency will be output to PortA. No phase shift.                            |
|                        |                                                                            | GENCLK_HALF                        | The internally generated PLL frequency will be divided by 2 and then output to PORTA. No phase shift.      |
| PLLOUT_SELECT_PORTB    | Selects the signal to be output at the PLLOUTCOREB and PLLOUTGLOBALB ports | SHIFTREG_0deg                      | 0° phase shift only if the setting<br>of FEEDBACK_PATH is<br>"PHASE_AND_DELAY"                             |
|                        |                                                                            | SHIFTREG_90deg                     | 90° phase shift only if the setting<br>of FEEDBACK_PATH is<br>"PHASE_AND_DELAY" and<br>SHIFTREG_DIV_MODE=0 |
|                        |                                                                            | GENCLK                             | The internally generated PLL frequency will be output to PortB. No phase shift.                            |
|                        |                                                                            | GENCLK_HALF                        | The internally generated PLL frequency will be divided by 2 and then output to PORTB. No phase shift.      |
| DIVR                   | REFERENCECLK divider                                                       | 0,1,2,,15                          | These parameters are used to                                                                               |
| DIVF                   | Feedback divider                                                           | 0,1,,63                            | control the output frequency, depending on the FEEDBACK_PATH setting.                                      |
| DIVQ                   | VCO Divider                                                                | 0,1,,7                             |                                                                                                            |
| FILTER_RANGE           | PLL Filter Range                                                           | 0,1,,7                             |                                                                                                            |
| EXTERNAL_DIVIDE_FACTOR | Divide-by factor of a<br>divider in external<br>feedback path              | User specified value.<br>Default 1 | Specified only when there is a user-implemented divider in the external feedback path.                     |
| ENABLE_ICEGATE_PORTA   | Enables the PLL power-                                                     | 0                                  | Power-down control disabled                                                                                |
|                        | down control                                                               | 1                                  | Power-down controlled by LATCHINPUTVALUE input                                                             |
| ENABLE_ICEGATE_PORTB   | Enables the PLL power-                                                     | 0                                  | Power-down control disabled                                                                                |
|                        | down control                                                               | 1                                  | Power-down controlled by LATCHINPUTVALUE input                                                             |

# SB PLL40 2F PAD

The SB\_PLL40\_2F\_PAD primitive should be used when the PLL is used to generated 2 different output frequencies, and the source clock of the PLL is driven by an input pad located in the bottom IO bank (IO Bank 2) or the top IO bank (IO Bank 0).



#### **Ports**

PACKAGEPIN: PLL source clock that serves as the input to the SB\_PLL40\_2F\_PAD primitive.

PLLOUTGLOBALA: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCOREA*: Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBALA port.

PLLOUTGLOBALB: Output clock generated by the PLL, drives a global clock network on the FPGA.

*PLLOUTCOREB*: Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBALB port.

LOCK: Output port, when HIGH, indicates that the signal on PLLOUTGLOBALB/PLLOUTCOREB is locked to the PLL source on PACKAGEPIN.

*EXTFEEDBACK:* External feedback input to PLL. Enabled when the FEEDBACK\_PATH parameter is set to EXTERNAL.

*DYNAMICDELAY:* 4 bit input bus that enables dynamic control of the delay contributed by the Fine Delay Adjust Block. The Fine Delay Adjust Block is used when there is a need to adjust the phase alignment of PLLOUTGLOBAL/PLLOUTCORE with respect to REFERENCECLK. The DYNAMICDELAY port controls are enabled when the DELAY\_ADJUSTMENT\_MODE parameter is set to DYNAMIC.

RESETB: Active low input that asynchronously resets the PLL.

*BYPASS*: Input signal, when asserted, connects the signal on REFERENCECLK to PLLOUTCORE/PLLOUTGLOBAL pins.

LATCHINPUTVALUE: Active high input, when enabled, forces the PLL into low-power mode. The PLLOUTGLOBALA/PLLOUTCOREA pins are held static at their last value only when the parameter ENABLE\_ICEGATE\_PORTA is set to '1', and the LATCHINPUTVALUE signal is asserted. The PLLOUTGLOBALB/PLLOUTCOREB pins are held static at their last value only when the parameter ENABLE\_ICEGATE\_PORTB is set to '1', and the LATCHINPUTVALUE signal is asserted.

SCLK, SDI, SDO: These pins are used only for internal testing purposes, and need not be instantiated by users.

#### **Parameters**

The SB\_PLL40\_2F\_PAD primitive requires configuration through the specification of the following parameters. It is strongly recommended that the configuration of the PLL primitives be accomplished through the use of the PLL Configuration tool that is offered as part of the iCEcube2 software.

| Parameter Name                  | Description                                                                         | Parameter Value | Description                                                                                                                                                                 |
|---------------------------------|-------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEEDBACK_PATH                   | Selects the feedback path to the PLL                                                | SIMPLE          | Feedback is internal to the PLL, directly from VCO                                                                                                                          |
|                                 |                                                                                     | DELAY           | Feedback is internal to the PLL,<br>through the Fine Delay Adjust<br>Block                                                                                                  |
|                                 |                                                                                     | PHASE_AND_DELAY | Feedback is internal to the PLL,<br>through the Phase Shifter and the<br>Fine Delay Adjust Block                                                                            |
|                                 |                                                                                     | EXTERNAL        | Feedback path is external to the PLL, and connects to EXTFEEDBACK pin. Also uses the Fine Delay Adjust Block.                                                               |
| DELAY_ADJUSTMENT_MODE _FEEDBACK | Selects the mode for the<br>Fine Delay Adjust block in<br>the feedback path         | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the FDA_FEEDBACK<br>parameter setting                                                        |
|                                 |                                                                                     | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[3:0] pins                                                                            |
| FDA_FEEDBACK                    | Sets a constant value for<br>the Fine Delay Adjust<br>Block in the feedback path    | 0, 1,,15        | The PLLOUTGLOBALA & PLLOUTCOREA signals are delay compensated by (n+1)*150 ps, where n = FDA_FEEDBACK only if the setting of the DELAY_ADJUSTMENT_MODE_FEEDBACK is FIXED.   |
| DELAY_ADJUSTMENT_MODE _RELATIVE | Selects the mode for the<br>Fine Delay Adjust block                                 | FIXED           | Delay of the Fine Delay Adjust<br>Block is fixed, the value is<br>specified by the FDA_RELATIVE<br>parameter setting                                                        |
|                                 |                                                                                     | DYNAMIC         | Delay of Fine Delay Adjust Block is determined by the signal value at the DYNAMICDELAY[7:4] pins                                                                            |
| FDA_RELATIVE                    | Sets a constant value for<br>the Fine Delay Adjust<br>Block                         | 0, 1,,15        | The PLLOUTGLOBALA & PLLOUTCOREA signals are delayed w.r.t. the Port B signals, by (n+1)*150 ps, where n = FDA_RELATIVE. Used if DELAY_ADJUSTMENT_MODE_ RELATIVE is "FIXED". |
| SHIFTREG_DIV_MODE               | Selects shift register configuration                                                | 0,1             | Used when FEEDBACK_PATH is "PHASE_AND_DELAY".  0→Divide by 4  1→Divide by 7                                                                                                 |
| PLLOUT_SELECT_PORTA             | Selects the signal to be<br>output at the<br>PLLOUTCOREA and<br>PLLOUTGLOBALA ports | SHIFTREG_0deg   | 0° phase shift only if the setting of FEEDBACK_PATH is "PHASE_AND_DELAY"                                                                                                    |
|                                 |                                                                                     | SHIFTREG_90deg  | 90° phase shift only if the setting<br>of FEEDBACK_PATH is<br>"PHASE_AND_DELAY" and<br>SHIFTREG_DIV_MODE=0                                                                  |
|                                 |                                                                                     | GENCLK          | The internally generated PLL frequency will be output to PortA. No phase shift.                                                                                             |

|                        |                                                                            | GENCLK_HALF                        | The internally generated PLL frequency will be divided by 2 and then output to PORTA. No phase shift.      |
|------------------------|----------------------------------------------------------------------------|------------------------------------|------------------------------------------------------------------------------------------------------------|
| PLLOUT_SELECT_PORTB    | Selects the signal to be output at the PLLOUTCOREB and PLLOUTGLOBALB ports | SHIFTREG_0deg                      | 0° phase shift only if the setting of FEEDBACK_PATH is "PHASE_AND_DELAY"                                   |
|                        |                                                                            | SHIFTREG_90deg                     | 90° phase shift only if the setting<br>of FEEDBACK_PATH is<br>"PHASE_AND_DELAY" and<br>SHIFTREG_DIV_MODE=0 |
|                        |                                                                            | GENCLK                             | The internally generated PLL frequency will be output to PortB. No phase shift.                            |
|                        |                                                                            | GENCLK_HALF                        | The internally generated PLL frequency will be divided by 2 and then output to PORTB. No phase shift.      |
| DIVR                   | REFERENCECLK divider                                                       | 0,1,2,,15                          | These parameters are used to control the output frequency, depending on the FEEDBACK_PATH setting.         |
| DIVF                   | Feedback divider                                                           | 0,1,,63                            |                                                                                                            |
| DIVQ                   | VCO Divider                                                                | 0,1,,7                             |                                                                                                            |
| FILTER_RANGE           | PLL Filter Range                                                           | 0,1,,7                             |                                                                                                            |
| EXTERNAL_DIVIDE_FACTOR | Divide-by factor of a<br>divider in external<br>feedback path              | User specified value.<br>Default 1 | Specified only when there is a user-implemented divider in the external feedback path.                     |
| ENABLE_ICEGATE_PORTA   | Enables the PLL power-down control                                         | 0                                  | Power-down control disabled                                                                                |
|                        |                                                                            | 1                                  | Power-down controlled by LATCHINPUTVALUE input                                                             |
| ENABLE_ICEGATE_PORTB   | Enables the PLL power-<br>down control                                     | 0                                  | Power-down control disabled                                                                                |
|                        |                                                                            | 1                                  | Power-down controlled by LATCHINPUTVALUE input                                                             |

# **Device Configuration Primitives**

### SB\_WARMBOOT

iCE FPGA devices permit the user to load a different configuration image during regular operation. Through the use of the Warm Boot Primitive, the user can load one of 4 pre-defined configuration images into the iCE FPGA device.

Note that this Warm Boot mode is different from the Cold Boot operation, which is executed during the initial device boot-up sequence.



The selection of one of these 4 images is accomplished through 2 input signals, S1 and S0. In order to trigger the selection of a new image, an additional signal, BOOT, is provided. It should be noted that this signal is level-triggered, and should be used for every Warm Boot operation i.e. every time the user wishes to load a new image into the device.

The successful instantiation of this primitive also requires the user to specify the address locations of the 4 images. These addresses should be specified in the iCEcube2 software as per the Warm Boot Application Note.

# **Verilog Instantiation**