

# Gisselquist Technology, LLC

## Building Generic Bus Properties

Daniel E. Gisselquist, Ph.D. December, 2019







#### ➢ Bus Properties

Four Properties

- 1. Reset
- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

**AXI** Properties

# **Bus Properties**



## Four Properties



#### **Bus Properties**

- ➢ Four Properties
- 1. Reset
- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

#### **AXI** Properties

- 1. Everything gets cleared following a reset
- 2. Whenever the bus is stalled, the request doesn't change
- 3. There should be no acknowledgments without a prior request
- 4. All requests should (eventually) get a response





#### **Bus Properties**

Four Properties

▶ 1. Reset

- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

**AXI** Properties

1. Everything gets cleared following a reset



```
assert property (@(posedge i_clk)
  i_reset |=> !o_ack);
```





#### **Bus Properties**

Four Properties

▶ 1. Reset

- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

**AXI** Properties

1. Everything gets cleared following a reset

```
i_clk
i_reset
i_request
o_ack
f_outstanding
```

```
assert property (@(posedge i_clk)
  i_reset |=> !o_ack);
```

```
assume property (@(posedge i_clk)
  i_reset |=> !i_request);
```





#### **Bus Properties**

Four Properties

▶ 1. Reset

- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

**AXI** Properties

1. Everything gets cleared following a reset

```
i_clk
i_reset
i_request
o_ack
f_outstanding
```

```
assert property (@(posedge i_clk)
  i_reset |=> !o_ack);
```

```
assume property (@(posedge i_clk)
  i_reset |=> !i_request);
```

```
assert property (@(posedge i_clk)
  i_reset |=> (f_outstanding == 0));
```



## 2. Stalls

**Bus Properties** 

Four Properties

- 1. Reset
- 3. Extra Acks
- 4. No Lockups

**AXI** Properties

2. Whenever the bus is stalled, the request doesn't change



```
assert property (@(posedge i_clk)
   i_request && o_stall && (!i_reset)
   |=> i_request && $stable(request_details));
```



## 3. Extra Acks

#### **Bus Properties**

Four Properties

- 1. Reset
- 2. Stalls
- > 3. Extra Acks
- 4. No Lockups

**AXI** Properties

3. There should be no acknowledgments without a prior request





## 4. No Lockups



#### **Bus Properties**

Four Properties

- 1. Reset
- 2. Stalls
- 3. Extra Acks
- > 4. No Lockups

#### **AXI** Properties

4. All requests should (eventually) get a response







#### **Bus Properties**

> AXI Properties

**AXI Signals** 

- 1. Reset
- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

# **AXI** Properties



# **AXI Signals**

**Bus Properties** 

**AXI** Properties

> AXI Signals

- 1. Reset
- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

|         |         |        |        |         | <b>V//</b> V |
|---------|---------|--------|--------|---------|--------------|
| Global  | Write   | Write  | Write  | Read    | Read         |
| Signals | Address | Data   | Return | Address | Return       |
| ACLK    | AWVALID | WVALID | BVALID | ARVALID | RVALID       |
| ARESETN | AWREADY | WREADY | BREADY | ARREADY | RREADY       |
|         | AWADDR  | WDATA  | BRESP  | ARADDR  | RRESP        |
|         | AWPROT  | WSTRB  |        | ARPROT  | RDATA        |
|         | AWID    |        | BID    | ARID    | RID          |
|         | AWLEN   | WLAST  |        | ARLEN   | RLAST        |
|         | AWSIZE  |        |        | ARSIZE  |              |
|         | AWBURST |        |        | ARBURST |              |
|         | AWLOCK  |        |        | ARLOCK  |              |
|         | AWCACHE |        |        | ARCACHE |              |
|         | AWQOS   |        |        | ARQOS   |              |
|         | AWUSER  | WUSER  | BUSER  | ARUSER  | RUSER        |



# AXI Signals

| Bus | Prope | erties |
|-----|-------|--------|
|-----|-------|--------|

**AXI** Properties

> AXI Signals

- 1. Reset
- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

|          |         |        |        |         | <b></b> √//└ |
|----------|---------|--------|--------|---------|--------------|
| Global   | Write   | Write  | Write  | Read    | Read         |
| Signals  | Address | Data   | Return | Address | Return       |
| ACLK     | AWVALID | WVALID | BVALID | ARVALID | RVALID       |
| ARESETN  | AWREADY | WREADY | BREADY | ARREADY | RREADY       |
|          | AWADDR  | WDATA  | BRESP  | ARADDR  | RRESP        |
|          | AWPROT  | WSTRB  |        | ARPROT  | RDATA        |
|          | RID     |        |        |         |              |
| AXI-lite | RLAST   |        |        |         |              |
|          | AWSIZE  |        |        | AKSIZE  |              |
|          | AWBURST |        |        | ARBURST |              |
|          | AWLOCK  |        |        | ARLOCK  |              |
|          | AWCACHE |        |        | ARCACHE |              |
|          | AWQOS   |        |        | ARQOS   |              |
|          | AWUSER  | WUSER  | BUSER  | ARUSER  | RUSER        |



# (a) AXI Signals

**Bus Properties** 

**AXI** Properties

> AXI Signals

- 1. Reset
- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

|                               |         |        |        |         | ^\\\\  |
|-------------------------------|---------|--------|--------|---------|--------|
| Global                        | Write   | Write  | Write  | Read    | Read   |
| Signals                       | Address | Data   | Return | Address | Return |
| ACLK                          | AWVALID | WVALID | BVALID | ARVALID | RVALID |
| ARESETN                       | AWREADY | WREADY | BREADY | ARREADY | RREADY |
|                               | AWADDR  | WDATA  | BRESP  | ARADDR  | RRESP  |
|                               | AWPROT  | WSTRB  |        | ARPROT  | RDATA  |
|                               | AWID    |        | BID    | ARID    | RID    |
|                               | AWLEN   | WLAST  |        | ARLEN   | RLAST  |
|                               |         |        |        | ARSIZE  |        |
| We'll focus on the read chan- |         |        |        | ARBURST |        |
| nels for today's presentation |         |        | ARLOCK |         |        |
|                               | AWCACHE |        |        | ARCACHE |        |
|                               | AWQOS   |        |        | ARQOS   |        |
|                               | AWUSER  | WUSER  | BUSER  | ARUSER  | RUSER  |





**Bus Properties** 

**AXI** Properties

**AXI Signals** 

▶ 1. Reset

- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

1. Everything gets cleared following a reset

S\_AXI\_ACLK S\_AXI\_ARESETN S\_AXI\_ARVALID

S\_AXI\_RVALID f\_outstanding



How might you write the properties to describe this?





**Bus Properties** 

**AXI** Properties

**AXI Signals** 

▶ 1. Reset

- 2. Stalls
- 3. Extra Acks
- 4. No Lockups

1. Everything gets cleared following a reset

```
S_AXI_ACLK
S_AXI_ARESETN
S_AXI_ARVALID
S_AXI_RVALID
```





How might you write the properties to describe this?

```
// The slave assume master signals
assume property (@(posedge i_clk)
   !S_AXI_ARESETN |=> !S_AXI_ARVALID);

// Asserts its own outputs
assert property (@(posedge i_clk)
   !S_AXI_ARESETN |=> !S_AXI_RVALID);
```



### 2. Stalls

**Bus Properties** 

**AXI** Properties

**AXI Signals** 

1. Reset

- 3. Extra Acks
- 4. No Lockups

2. Whenever the bus is stalled, the request doesn't change

S\_AXI\_ACLK S\_AXI\_ARESETN S\_AXI\_ARVALID

S\_AXI\_ARREADY





### 2. Stalls

**Bus Properties** 

**AXI** Properties

**AXI Signals** 

1. Reset

→ 2. Stalls

- 3. Extra Acks
- 4. No Lockups

2. Whenever the bus is stalled, the request doesn't change

```
S_AXI_ACLK
S_AXI_ARESETN
S_AXI_ARVALID
```

S\_AXI\_ARREADY



```
assume property (@(posedge i_clk)
    (S_AXI_ARESETN)
    && S_AXI_ARVALID && !S_AXI_ARREADY
    |=> S_AXI_ARVALID && $stable(S_AXI_ARADDR));

assert property (@(posedge i_clk)
    (S_AXI_ARESETN)
    && S_AXI_RVALID && !S_AXI_RREADY
    |=> S_AXI_RVALID && $stable(S_AXI_RDATA));
```



## 3. Extra Acks

**Bus Properties** 

**AXI** Properties

**AXI Signals** 

- 1. Reset
- 2. Stalls

→ 3. Extra Acks

4. No Lockups

3. There should be no acknowledgments without a prior request

S\_AXI\_ACLK
S\_AXI\_ARESETN
S\_AXI\_ARVALID
S\_AXI\_ARREADY
S\_AXI\_RVALID
S\_AXI\_RVALID

f\_outstanding





## 3. Extra Acks

**Bus Properties** 

**AXI** Properties

**AXI Signals** 

- 1. Reset
- 2. Stalls

> 3. Extra Acks

4. No Lockups

3. There should be no acknowledgments without a prior request

```
S_AXI_ACLK
S_AXI_ARESETN
S_AXI_ARVALID
S_AXI_ARREADY
```

S\_AXI\_RVALID

S\_AXI\_RREADY

f\_outstanding



```
assert property (@(posedge i_clk)
    (f_outstanding == 0)
    |-> !S_AXI_RVALID);
```



## 4. No Lockups



#### **Bus Properties**

#### **AXI** Properties

**AXI Signals** 

- 1. Reset
- 2. Stalls
- 3. Extra Acks
- > 4. No Lockups

4. All requests should (eventually) get a response

S\_AXI\_ACLK S\_AXI\_ARESETN S\_AXI\_ARVALID

S\_AXI\_ARREADY S\_AXI\_RVALID S\_AXI\_RREADY

> f\_outstanding f\_ack\_delay





## 4. No Lockups



**Bus Properties** 

**AXI** Properties

**AXI Signals** 

- 1. Reset
- 2. Stalls
- 3. Extra Acks
- > 4. No Lockups

4. All requests should (eventually) get a response

S\_AXI\_ACLK
S\_AXI\_ARESETN
S\_AXI\_ARVALID
S\_AXI\_ARREADY
S\_AXI\_RVALID

**S\_AXI\_RREADY** 

f\_outstanding f\_ack\_delay

