

# **SBI BFM** – Quick Reference

For general information see UVVM Essential Mechanisms located in uvvm vvc framework/doc.

# sbi\_write (addr\_value, data\_value, msg, clk, sbi\_if, [scope, [msg\_id\_panel, [config]]])

**Example**: sbi write(x"1000", x"40", "Set baud rate to 9600", clk, sbi if);

Suggested usage: sbi\_write(C\_ADDR\_UART\_TX, C\_BAUD\_9600, "Set baud rate to 9600"); -- Suggested usage requires local overload (see section 5)

## sbi read (addr value, data value, msg, clk, sbi if, [scope, [msg id panel, [config, [proc name]]]])

**Example**: sbi\_read(x"1000", v\_data\_out, "Read UART baud rate", clk, sbi\_if);

Suggested usage: sbi\_read(C\_ADDR\_UART\_BAUD, v\_data\_out, "Read UART baud rate"); - Suggested usage requires local overload (see section 5)

# Sbi\_check (addr\_value, data\_exp, msg, clk, sbi\_if, [alert\_level, [scope, [msg\_id\_panel, [config]]]])

**Example**: sbi\_check(x"1155", x"3B", "Check data from UART RX", clk, sbi\_if);

Suggested usage: sbi check(C ADDR UART RX, x"3B", "Check data from UART RX"); -- Suggested usage requires local overload (see section 5)

# sbi\_poll\_until (addr\_value, data\_exp, max\_polls, timeout, msg, clk, sbi\_if, terminate\_loop, [alert\_level, [scope, [msg\_id\_panel, [config]]]])

Example: sbi poll until(x"1155", x"0D", 10, 100 ns, "Read UART until CR is found", clk, sbi if, terminate loop);

Suggested usage: sbi\_poll\_until(C\_ADDR\_UART\_RX, x"0D", "Read UART until CR is found"); -- Suggested usage requires local overload (see section 5)

# init sbi if signals (addr width, data width)

**Example**: sbi if <= init sbi if signals(addr width, data width);

#### BFM Configuration record 't sbi bfm config'

| Record element             | Туре          | C_SBI_BFM_CONFIG_DEFAULT |
|----------------------------|---------------|--------------------------|
| max_wait_cycles            | integer       | 10                       |
| max_wait_cycles_severity   | t_alert_level | FAILURE                  |
| use_fixed_wait_cycles_read | boolean       | false                    |
| fixed_wait_cycles_read     | natural       | 0                        |
| clock_period               | time          | 10 ns                    |
| clock_period_margin        | time          | 0 ns                     |
| clock_margin_severity      | t_alert_level | TB_ERROR                 |
| setup_time                 | time          | 2.5 ns                   |
| hold_time                  | time          | 2.5 ns                   |
| id_for_bfm                 | t_msg_id      | ID_BFM                   |
| id_for_bfm_wait            | t_msg_id      | ID_BFM_WAIT              |
| id_for_bfm_poll            | t_msg_id      | ID_BFM_POLL              |
| use_ready_signal           | boolean       | true                     |
| setup_time                 | time          | 0 ns                     |
| hold_time                  | time          | 0 ns                     |

#### Signal record 't sbi if'

| 3         |       |                  |  |
|-----------|-------|------------------|--|
| Record el | ement | Type             |  |
| cs        |       | std_logic        |  |
| addr      |       | unsigned         |  |
| wena      |       | std_logic        |  |
| rena      |       | std_logic        |  |
| wdata     |       | std_logic_vector |  |
| ready     |       | std_logic        |  |
| rdata     |       | std_logic_vector |  |

Note: BFM calls can also be made with listing of single signals rather than t sbi if.



sbi\_bfm\_pkq.vhd



Copyright © 2017 by Bitvis AS. All rights reserved.



# BFM non-signal parameters

| Name         | Туре             | Example(s)               | Description                                                                                                  |
|--------------|------------------|--------------------------|--------------------------------------------------------------------------------------------------------------|
| addr_value   | unsigned         | x"5A"                    | The address of a software accessible register.                                                               |
| data_value   | std_logic_vector | x"D3"                    | The data value to be written to the addressed register                                                       |
| data_exp     | std_logic_vector | x"0D"                    | The data value to expect when reading the addressed register. A mismatch results in an alert with severity   |
|              |                  |                          | ʻalert_level'                                                                                                |
| max_polls    | integer          | 1                        | The maximum number of polls (reads) before the expected data must be found. Exceeding this limit results in  |
|              |                  |                          | an alert with severity 'alert_level'.                                                                        |
| timeout      | time             | 100 ns                   | The maximum time to pass before the expected data must be found. Exceeding this limit results in an alert    |
|              |                  |                          | with severity 'alert_level'.                                                                                 |
| alert_level  | t_alert_level    | ERROR or TB_WARNING      | Set the severity for the alert that may be asserted by the BFM procedure.                                    |
| msg          | string           | "Write to Peripheral 1"  | A custom message to be appended in the log/alert.                                                            |
| scope        | string           | "SBI BFM"                | A string describing the scope from which the log/alert originates.                                           |
|              |                  |                          | In a simple single sequencer typically "SBI BFM". In a verification component typically "SBI_VVC ".          |
| msg_id_panel | t_msg_id_panel   | shared_msg_id_panel      | Optional msg_id_panel, controlling verbosity within a specified scope. Defaults to a common ID panel defined |
|              |                  |                          | in the adaptations package.                                                                                  |
| config       | t_sbi_bfm_config | C_SBI_BFM_CONFIG_DEFAULT | Configuration of BFM behaviour and restrictions. See section 2 for details.                                  |

# BFM signal parameters

| Name           | Туре      | Description                                                           |
|----------------|-----------|-----------------------------------------------------------------------|
| clk            | std_logic | The clock signal used to read and write data in/out of SBI BFM.       |
| sbi_if         | t_sbi_if  | See table "Signal record 't_sbi_if"                                   |
| terminate_loop | std_logic | External control of loop termination to e.g. stop polling prematurely |

Note 1: All signals are active high.

Note 2: Record sbi\_if can be replaced with the signals listed in said record.



# BFM details

# 1 BFM procedure details and examples

# Procedure sbi\_write()

### Description

#### sbi\_write(addr\_value, data\_value, msg, clk, sbi\_if, [scope, [msg\_id\_panel, [config]]])

The sbi write() procedure writes the given data to the given address on the DUT, using the SBI protocol:

- 1. At 'config.clock period'/4 before the first rising clock edge the bus lines are set:
  - a. cs and wena are set to '1'
  - b. rena is set to '0'
  - c. addr is set to addr value
  - d. wdata is set to data\_value
- 2. With ready-signalling:
  - a. on the first rising edge the DUT ready signal is evaluated:
    - If ready is '1', cs and wena are set to '0' again 'config.clock\_period'/4 after the last rising edge and the write procedure was successful
    - If ready is '0', the procedure will wait one clock cycle and evaluate the ready signal again. This will repeat until ready is set to '1', or invoke an error if the process has repeated 'config.max wait cycles' times. A log message with ID config.id for bfm wait is logged at the first wait.
- 2. Without ready-signalling:
  - a. cs and wena are set to '0' again 'config.clock period'/4 after the first rising edge
- The default value of scope is C SCOPE ("SBI BFM")
- The default value of msg id panel is shared msg id panel, defined in UVVM Util.
- The default value of config is C\_SBI\_BFM\_CONFIG\_DEFAULT, see table on the first page.
- A log message is written if message ID 'config.id for bfm' is enabled for the specified message ID panel.

#### The procedure reports an alert if:

- ready signal is not set to '1' within 'config.max\_wait\_cycles' after cs and wena are set to '1' (alert\_level: 'config.max\_wait\_cycles\_severity').

#### Examples

```
sbi_write(x"1000", x"55", "Write data to Peripheral 1", clk, sbi_if);
sbi_write(x"1000", x"55", "Write data to Peripheral 1", clk, sbi_if, C_SCOPE, shared_msg_id_panel, C_SBI_BFM_CONFIG_DEFAULT);
```

#### Suggested usage (requires local overload, see section 5):

```
sbi_write(C_ADDR_UART_TX, x"40", "Set baud rate to 9600");
```

Note: Record sbi if can be replaced with the signals cs, addr, rena, wena, ready, wdata.

## sbi\_read()

#### sbi\_read(addr\_value, data\_value, msg, clk, sbi\_if, [scope, [msg\_id\_panel, [config, [proc\_name]]]])

The sbi\_read() procedure reads data from the DUT at the given address, using the SBI protocol:

- 1. At 'config.clock period'/4 before the first rising clock edge the bus lines are set:
  - a. cs and rena are set to '1'
  - b. wena is set to '0'
  - c. addr is set to addr value



- With ready-signalling:
  - a. On the first rising edge the DUT ready signal is evaluated:
    - If ready is '1', the data on the rdata line is returned to the reader in 'data value'.
    - If ready is '0', the procedure will wait one clock cycle and evaluate the ready signal again. This will repeat until ready is set to '1', or invoke an error if the process has repeated 'config.max wait cycles' times. A log message with ID config.id for bfm wait is logged at the first wait.
- Without ready-signalling:
  - a. On the first rising edge the data on the rdata line is returned to the reader in 'data\_value'.
- 3. After 'config.clock period'/4 cs and rena are set to '0' again
- The default value of scope is C SCOPE ("SBI BFM")
- The default value of msg\_id\_panel is shared\_msg\_id\_panel, defined in UVVM\_Util.
- The default value of config is C\_SBI\_BFM\_CONFIG\_DEFAULT, see table on the first page.
- The default value of proc\_name is "sbi\_read". This argument is intended to be used internally, when procedure is called by sbi\_check() or sbi\_poll\_until().
- A log message is written if 'config.id\_for\_bfm' ID is enabled for the specified message ID panel. This will only occur if the argument proc\_name is left unchanged.

The procedure reports an alert if:

- ready signal is not set to '1' within 'config.max wait cycles' after cs and wena are set to '1' (alert level: 'config.max wait cycles severity')

#### Examples:

```
sbi_read(x"1000", v_data_out, "Read from Peripheral 1", clk, sbi_if);
sbi_read(x"1000", v_data_out, "Read from Peripheral 1", clk, sbi_if,, C_SCOPE, shared_msg_id_panel, C_SBI_BFM_CONFIG_DEFAULT);
```

#### Suggested usage (requires local overload, see section 5):

```
sbi_read(C_ADDR_UART_BAUD, v_data_out, "Read UART baud rate");
```

Note: Record sbi if can be replaced with the signals cs, addr, rena, wena, ready, rdata.

#### sbi\_check()

#### sbi\_check(addr\_value, data\_exp, msg, clk, sbi\_if, [alert\_level, [scope, [msg\_id\_panel, [config]]]])

The sbi\_check() procedure reads data from the DUT at the given address, using the SBI protocol described under sbi\_read(). After reading data from the SBI bus, the read data is compared with the expected data, 'data\_exp'.

- The default value of alert level is ERROR
- The default value of scope is C\_SCOPE ("SBI BFM")
- The default value of msg id panel is shared msg id panel, defined in UVVM Util.
- The default value of config is C SBI BFM CONFIG DEFAULT, see table on the first page.
- If the check was successful, and the read data matches the expected data, a log message is written with ID 'config.id for bfm' (if this ID has been enabled).
- If the read data did not match the expected data, an alert with severity 'alert level' will be reported.

The procedure will also report alerts for the same conditions as the sbi read() procedure.

#### Examples:

#### Suggested usage (requires local overload, see section 5):

```
sbi_check(C_ADDR_UART_RX, x"3B", "Check data from UART RX buffer");
```

Note: Record sbi\_if can be replaced with the signals cs, addr, rena, wena, ready, rdata.



## sbi\_poll\_until()

#### sbi\_poll\_until(addr\_value, data\_exp, max\_polls, timeout, msg, clk, sbi\_if, terminate\_loop, [alert\_level, [scope, [msg\_id\_panel, [config]]]])

The sbi\_poll\_until() procedure reads data from the DUT at the given address, using the SBI protocol described under sbi\_read(). After reading data from the DUT, the read data is compared with the expected data, 'data exp'. If the read data does not match the expected data, the process is repeated until one or more of the following occurs:

- 1. The read data matches the expected data, 'data\_exp'
- 2. The number of read retries is equal to 'max polls'
- 3. The time between start of sbi poll until procedure and now is greater than 'timeout'
- 4. 'terminate\_loop' signal is set to '1'

If the procedure exits because of 2. or 3. an alert with severity 'alert\_level' is issued. If either 'max\_polls' or 'timeout' is set to 0 (ns), this constraint will be ignored and interpreted as no limit.

- The default value of alert level is ERROR
- The default value of scope is C\_SCOPE ("SBI BFM")
- The default value of msg\_id\_panel is shared\_msg\_id\_panel, defined in UVVM\_Util.
- The default value of config is C SBI BFM CONFIG DEFAULT, see table on the first page.
- If the check was successful, and the read data matches the expected data, a log message is written with ID 'config.id for bfm' (if this ID has been enabled).
- If the procedure is terminated using 'terminate loop' a log message with ID ID TERMINATE CMD will be issued.
- If the read data did not match the expected data, an alert with severity 'alert\_level' will be reported.

The procedure will also report alerts for the same conditions as the sbi\_read() procedure.

#### Examples:

```
sbi_poll_until(x"1155", x"0D", 10, 100 ns, "Poll for data from Peripheral 1", clk, sbi_if, terminate_loop);
sbi_poll_until(x"1155", x"0D", 10, 100 ns, "Poll for data from Peripheral 1", clk, sbi_if, terminate_loop, ERROR, C_SCOPE,
shared msg id panel, C_SBI_BFM_CONFIG_DEFAULT);
```

#### Suggested usage (requires local overload, see section 5):

```
sbi_poll_until(C_ADDR_UART_RX, x"0D", "Poll UART RX buffer until CR is found");
sbi poll until(C ADDR UART RX, x"0D", C MAX POLLS, C TIMEOUT, "Poll UART RX buffer until CR is found");
```

Note: Record sbi if can be replaced with the signals cs, addr, rena, wena, ready, rdata.

### init\_sbi\_if\_signals()

#### init sbi if signals(addr width, data width)

This function initializes the SBI interface. All the BFM outputs are set to zeros ('0'), and BFM inputs are set to 'Z'. Example:

```
sbi if <= init sbi if signals(addr width, data width)</pre>
```



# 2 BFM Configuration record

Type name: t\_sbi\_bfm\_config

| Record element             | Туре          | C_SBI_BFM_CONFIG_DEFAULT | Description                                                                          |
|----------------------------|---------------|--------------------------|--------------------------------------------------------------------------------------|
| max wait cycles            | integer       | 10                       | The maximum number of clock cycles to wait for the DUT ready signal before           |
| max_wait_cycles            |               |                          | reporting a timeout alert.                                                           |
| max_wait_cycles_severity   | t_alert_level | failure                  | The above timeout will have this severity                                            |
| use fixed wait cycles read | boolean       | false                    | When true, wait 'fixed_wait_cycles_read' after asserting 'rena' signal, before       |
| use_lixed_wait_cycles_read |               |                          | sampling 'rdata from DUT'                                                            |
| fixed_wait_cycles_read     | natural       | 0                        | Number of clock cycles to wait after asserting 'rena' signal, before sampling        |
|                            |               |                          | 'rdata' from DUT.                                                                    |
| clock_period               | time          | 10 ns                    | Period of the clock signal.                                                          |
| clock_period_margin        | time          | 0 ns                     | Input clock period margin to specified clock_period.                                 |
| clock_period_margin        |               |                          | Will check T/2 if input clock is low when BFM is called and T if input clock is high |
| clock_margin_severity      | t_alert_level | TB_ERROR                 | The above margin will have this severity                                             |
| setup time                 | time          | 2.5 ns                   | Generated signals setup time. Suggested value is clock_period/4.                     |
| Setup_time                 | ume           | 2.0 113                  | An alert is reported if setup_time exceed clock_period/2.                            |
| hold_time                  | time          | 2.5 ns                   | Generated signals hold time. Suggested value is clock_period/4.                      |
|                            |               |                          | An alert is reported if hold_time exceed clock_period/2.                             |
| id_for_bfm                 | t_msg_id      | ID_BFM                   | The message ID used as a general message ID in the SBI BFM                           |
| id_for_bfm_wait            | t_msg_id      | ID_BFM_WAIT              | The message ID used for logging waits in the SBI BFM                                 |
| id_for_bfm_poll            | t_msg_id      | ID_BFM_POLL              | The message ID used for logging polling in the SBI BFM                               |
| use_ready_signal           | boolean       | true                     | Whether or not to use the interface 'ready' signal                                   |



## 3 Additional Documentation

The SBI BFM is used in the IRQC example provided with the UVVM Utility Library. Thus, you can find info under:

- 'Making a simple, structured and efficient VHDL testbench - Step-by-step' (PPT)

There is also a webinar available on 'Making a simple, structured and efficient VHDL testbench - Step-by-step' (via Aldec1.)

# 3.1 SBI protocol

SBI is our name for the simplest bus interface possible, one that has been used for decades in the electronics industry. Some think of it as a simple SRAM interface, but that is not a standard, and is probably understood and used in many different ways. Thus, we have defined a name and an exact behaviour, with some flexibility.

SBI is a single cycle bus with an optional ready-signalling. The protocol for SBI with and without ready-signalling is given below. Data is sampled on rising edge a and b.



As can be seen from the figure all required signals including data input must be ready on the rising edge of the clock. This also applies for a read access, but the actual data output is provided combinatorial as soon as the combinational logic allows

Note that an active 'cs', a valid 'addr' and an active 'wena' or 'rena' is needed on the same active clock edge to be registered as a valid read or write. (Being active on two consecutive rising clocks will result in two consecutive accesses - with or without side-effects depending on the module's internal functional logic.) 'rdata' will just ripple out for the right combination of 'cs', 'addr' and 'rena'.

With this simple version, the designer has the option to provide input and/or output registers externally to allow a higher frequency (with added latency).

SBI has optional ready-signalling. When 'ready' is used it applies to both read and write accesses. For both read and write accesses all input signals must be held until 'ready' is active. For a read access, the output data may not be used (sampled) until 'ready' is active, but must do so on the first rising edge of the clock after 'ready' active.



# 4 Compilation

The SBI BFM may only be compiled with VHDL 2008. It is dependent on the UVVM Utility Library (UVVM-Util), which is only compatible with VHDL 2008. See the separate UVVM-Util documentation for more info. After UVVM-Util has been compiled, the sbi\_bfm\_pkg.vhd BFM can be compiled into any desired library. See UVVM Essential Mechanisms located in uvvm vvc framework/doc for information about compile scripts.

# 4.1 Simulator compatibility and setup

This BFM has been compiled and tested with Modelsim version 10.3d and Riviera-PRO version 2015.10.85.

For required simulator setup see UVVM-Util Quick reference.

\*1 https://www.aldec.com/en/support/resources/multimedia/webinars/1673



## 5 Local BFM overloads

A good approach for better readability and maintainability is to make simple, local overloads for the BFM procedures in the TB process. This allows calling the BFM procedures with the key parameters only e.g.

#### By defining the local overload as e.g.:

Using a local overload like this also allows the following – if wanted:

- Have address value as natural and convert in the overload
- Set up defaults for constants. May be different for two overloads of the same BFM
- Apply dedicated message ID panel to allow dedicated verbosity control

#### **IMPORTANT**

This is a simplified Bus Functional Model (BFM) for SBI.

The given BFM complies with the basic SBI protocol and thus allows a normal access towards a SBI interface. This BFM is not a SBI protocol checker. For a more advanced BFM please contact Bitvis AS at <a href="mailto:support@bitvis.no">support@bitvis.no</a>



Disclaimer: This IP and any part thereof are provided "as is", without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with this IP.