Component Data Sheet ANGRYVIPER Team

## Summary - Si5351

| Name              | $\mathrm{si}5351$                               |
|-------------------|-------------------------------------------------|
| Worker Type       | Device                                          |
| Version           | v1.5                                            |
| Release Date      | 4/2019                                          |
| Component Library | ocpi.assets.devices                             |
| Workers           | si5351.hdl                                      |
| Tested Platforms  | ZedBoard(PL)/Zipper, ALST4/Zipper, ML605/Zipper |

## **Functionality**

The Si5351 device worker exposes the register set of the Si5351C I<sup>2</sup>C clock generator IC[1] and directly interfaces with the IC's INTR and EOB pins. Each register is exposed as a uchar (8-bits wide) property. The worker drives the EOB pin to ground and the INTR pin's signal is currently unused. The Si5351C SDA/SCL pins are not controlled directly by this worker, but instead by a subdevice of this worker which arbitrates I2C bus access.

## **Block Diagrams**

### Top level

| </th <th></th> <th>&gt;</th>                                                        |                                                     | > |
|-------------------------------------------------------------------------------------|-----------------------------------------------------|---|
| </td <td>  FPGA  </td> <td>&gt;</td>                                                | FPGA                                                | > |
| </td <td>  (represented by /\</td> <td>&gt;</td>                                    | (represented by /\                                  | > |
| </td <td>  OpenCPI platform)   control plane interface exposes  </td> <td>&gt;</td> | OpenCPI platform)   control plane interface exposes | > |
| </td <td>  each Si5351C register as a</td> <td>&gt;</td>                            | each Si5351C register as a                          | > |
| </td <td>uchar property</td> <td>&gt;</td>                                          | uchar property                                      | > |
| </td <td>   </td> <td>&gt;</td>                                                     |                                                     | > |
| </td <td>   si5351.hdl</td> <td>&gt;</td>                                           | si5351.hdl                                          | > |
| </td <td>    workers on</td> <td>&gt;</td>                                          | workers on                                          | > |
| </td <td>  /\intr  oeb   </td> <td>&gt;</td>                                        | /\intr  oeb                                         | > |
| </td <td>        /   /  </td> <td>&gt;</td>                                         | /   /                                               | > |
| </td <td> </td> <td>&gt;</td>                                                       |                                                     | > |
| </td <td> </td> <td>&gt;</td>                                                       |                                                     | > |
| </td <td> </td> <td>&gt;</td>                                                       |                                                     | > |
| </td <td>                                       </td> <td>&gt;</td>                 |                                                     | > |
| </td <td> </td> <td>&gt;</td>                                                       |                                                     | > |
| </td <td> </td> <td>&gt;</td>                                                       |                                                     | > |
| </td <td> </td> <td>&gt;</td>                                                       |                                                     | > |
| </td <td> </td> <td>&gt;</td>                                                       |                                                     | > |
| </td <td>                                       </td> <td>&gt;</td>                 |                                                     | > |
| </td <td></td> <td>&gt;</td>                                                        |                                                     | > |
| </td <td> </td> <td>&gt;</td>                                                       |                                                     | > |
| </td <td> _ VV </td> <td>&gt;</td>                                                  | _ VV                                                | > |
| </td <td>         (other</td> <td>&gt;</td>                                         | (other                                              | > |
| </td <td> </td> <td>&gt;</td>                                                       |                                                     | > |
| </td <td>_  </td> <td>&gt;</td>                                                     | _                                                   | > |
| </td <td> INTR OEB SDA SCL  </td> <td>&gt;</td>                                     | INTR OEB SDA SCL                                    | > |
| </td <td>  Si5351C IC  </td> <td>&gt;</td>                                          | Si5351C IC                                          | > |
| </td <td>  </td> <td>&gt;</td>                                                      |                                                     | > |

Component Data Sheet ANGRYVIPER Team

### Worker Implementation Details

#### si5351.hdl - Property Set

Information about the static Si5351C hardware configuration is conveyed via the clkin\_present, clkin\_freq, xtal\_present, xtal\_freq, vc\_present, outputs\_present, oeb\_mode, and intr\_connected properties. Because these properties are designed to convey static information that is determined at build-time, their parameter attribute is set to true. Each of these properties also has its readable attribute set to true. Normally it is not recommended to set both the parameter and the readable attributes to true because readable implies unnecessary control plane infrastructure for property read accesses. Setting the parameter attribute alone to true exposes an optimized property read access mechanism for applications. This mechanism is not currently implemented, however, for device proxy slave interfaces. Because the aforementioned parameter properties are intended to be accessed via a device proxy slave interface, their readable attributes are set to true.

Each non-parameter property's value represents that of a Si5351C register. Each non-parameter property is a raw property.

#### si5351.hdl - Control Plane Timeout Value Selection

Because  $I^2C$  transactions require additional clock cycles to complete property accesses, the control plane timeout default value (of 16) is overriden to be 131072. The intended  $I^2C$  SCL clock frequency is 250 kHz, and the  $I^2C$  read operation duration is approximated to be 32 SCL clock cycles. This results in a read access being approximately 32/(250,000 Hz) = 0.000128 sec. This corresponds to (control plane clock cycles/sec)\*(0.000128 sec) clock cycles per read access. By setting the timeout to 131072, control plane clocks of up to approximately 131072/0.00128 Hz = 1.024 GHz would be supported, which is far higher than any currently possible control plane clock frequency.

#### Source Dependencies

#### si5351.hdl

• assets/hdl/devices/si5351.hdl/si5351.vhd

# Component Spec Properties

| Name | Type | SequenceLength | ArrayDimensions | Accessibility | Valid Range | Default | Usage |
|------|------|----------------|-----------------|---------------|-------------|---------|-------|
| -    | -    | -              | -               | -             | -           | -       | -     |

# Worker Properties

### si5351.hdl

| Scope    | Name            | Type  | ArrayDimensions | Accessibility          | Padding | Valid Range        | Default | Usage                                                                                                                               |
|----------|-----------------|-------|-----------------|------------------------|---------|--------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------|
| Property | clkin_present   | Bool  |                 | Parameter,<br>Readable |         | -                  | 0       | Does this chip have an external clock as input?                                                                                     |
| Property | clkin_freq      | Float |                 | Parameter,<br>Readable |         |                    | 0       |                                                                                                                                     |
| Property | xtal_present    | Bool  |                 | Parameter,<br>Readable |         |                    | 0       | Does this chip have a crystal oscillator as input?                                                                                  |
| Property | xtal_freq       | Float |                 | Parameter,<br>Readable |         |                    | 0       |                                                                                                                                     |
| Property | vc_present      | Bool  |                 | Parameter,<br>Readable |         |                    | 0       | Does this chip have a VCXO as input?                                                                                                |
| Property | outputs_present | Bool  | 8               | Parameter,<br>Readable |         |                    | 0       |                                                                                                                                     |
| Property | oeb_mode        | Enum  |                 | Parameter,<br>Readable |         | low,high,connected | low     |                                                                                                                                     |
| Property | intr_connected  | Bool  |                 | Parameter,<br>Readable |         |                    | 0       |                                                                                                                                     |
| Property | dev_status      | UChar |                 | Readable               |         |                    |         | Hardware registers: 0: Device Status                                                                                                |
| Property | int_sts_stcky   | UChar |                 | Volatile,<br>Writable  |         |                    |         | Hardware registers: 1: Interrupt Status Sticky                                                                                      |
| Property | int_sts_mask    | UChar |                 | Readable,<br>Writable  |         |                    |         | Hardware registers: 2: Interrupt Status Mask                                                                                        |
| Property | out_en_ctl      | UChar |                 | Readable,<br>Writable  |         |                    |         | Hardware registers: 3: Output enable control                                                                                        |
| Property | reserved00      | UChar | 5               |                        | true    |                    |         | Hardware registers: 4-8: Reserved                                                                                                   |
| Property | oeb_pin_en      | UChar |                 | Volatile,<br>Writable  |         |                    |         | Hardware registers: 9: OEB pin enable control mask                                                                                  |
| Property | reserved01      | UChar | 5               |                        | true    |                    |         | Hardware registers: 10-14: Reserved                                                                                                 |
| Property | pll_in_src      | UChar |                 | Readable,<br>Writable  |         |                    |         | Hardware registers: 15: PLL Input Source                                                                                            |
| Property | clk_ctl         | UChar | 8               | Readable,<br>Writable  |         |                    |         | Hardware registers: 16 - 23: Clock Control                                                                                          |
| Property | clk30_dis_st    | UChar |                 | Volatile,<br>Writable  |         |                    |         | Hardware registers: 24: Clock Disable State                                                                                         |
| Property | clk74_dis_st    | UChar |                 | Volatile,<br>Writable  |         |                    |         | Hardware registers: 25                                                                                                              |
| Property | ms_div_params   | UChar | 2x8             | Readable,<br>Writable  |         |                    |         | Hardware registers: 26 - 41: Feedback Multi-<br>synth Divider Parameters (doc section 3.2) - one<br>set per PLL (NOT per MS output) |
| Property | ms_0_5_params   | UChar | 6x8             | Readable,<br>Writable  |         |                    |         | Hardware registers: 42 - 89: Output Multisynth<br>Parameters (doc section 4.1) - one set of 8 regs<br>per MS output for the first 6 |
| Property | ms_6_7_params   | UChar | 2               | Readable,<br>Writable  |         |                    |         | Hardware registers: 90 - 91: Output Multisynth<br>Parameters (doc section 4.1) - one register per<br>MS output for the last 2       |
| Property | clk67_div       | UChar |                 | Readable,<br>Writable  |         |                    |         | Hardware registers: 92: Clock 6-7 Output divider                                                                                    |
| Property | pad0            | UChar | 56              |                        | true    |                    |         | Hardware registers: 93 - 148: Padding                                                                                               |

| AN                     |
|------------------------|
| Ω                      |
| 刀                      |
| ٢                      |
| $\sim$                 |
| $^{\prime}\mathrm{IP}$ |
| ER                     |
| Tea                    |
| 18                     |

| Property | ss_params    | UChar | 13 | Readable, |      | Hardware registers: 149 - 161: Spread Spectrum    |
|----------|--------------|-------|----|-----------|------|---------------------------------------------------|
|          |              |       |    | Writable  |      | Parameters                                        |
| Property | vcx          | UChar | 3  | Readable, |      | Hardware registers: 162 - 164: VCXO Parame-       |
|          |              |       |    | Writable  |      | ters                                              |
| Property | clk_phs_offs | UChar | 6  | Readable, |      | Hardware registers: 165 - 170: Initial Phase Off- |
|          |              |       |    | Writable  |      | sets                                              |
| Property | reserved02   | UChar | 6  |           | true | Hardware registers: 171 - 176: Reserved           |
| Property | pll_reset    | UChar |    | Readable, |      | Hardware registers: 177: PLL Reset                |
|          |              |       |    | Writable  |      |                                                   |
| Property | reserved16   | UChar | 5  |           | true | Hardware registers: 178-182: Reserved             |
| Property | xtal_cl      | UChar |    | Readable, |      | Hardware registers: 183: Crystal Internal Load    |
|          |              |       |    | Writable  |      | Capacitance                                       |
| Property | reserved03   | UChar | 3  |           | true | Hardware registers: 184-186: Reserved             |
| Property | fanout_en    | UChar |    | Readable, |      | Hardware registers: 187: Fanout enable            |
|          |              |       |    | Writable  |      |                                                   |
| Property | reserved04   | UChar | 68 |           | true | Hardware registers: 188-255: Reserved             |

# Component Ports

# Worker Interfaces

## ${ m si5351.hdl}$

| Type             | Name   | DataWidth | Advanced       | Usage                                                                                                                                               |
|------------------|--------|-----------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| RawProp          | rprops | -         | Master=true    | Raw properties connection for slave I2C device worker                                                                                               |
| ControlInterface | -      | -         | Timeout=131072 | Control clock cycles required to complete property read/write. I2C transactions require additional clock cycles to complete than the default of 16. |

Component Data Sheet ANGRYVIPER Team

## Control Timing and Signals

#### si5351.hdl

The Si5351 HDL device worker uses the clock from the Control Plane and standard Control Plane signals. There are no ports and therefore no latency or pipeline delay concerns to consider.

### Performance and Resource Utilization

si5351.hdl

#### References

[1] SI5351 A/B/C-B I2C-PROGRAMMABLE ANY-FREQUENCY CMOS CLOCK GENERATOR + VCXO https://www.silabs.com/documents/public/data-sheets/Si5351-B.pdf