

# Gisselquist Technology, LLC

### Building Generic Bus Properties

Daniel E. Gisselquist, Ph.D. March, 2023







#### > AXIN Protocol

Signals

**ABORT** 

**ABORT** 

**ABORT** 

**ABORT** 

**BYTES** 

## **AXIN Protocol**



## Signals



#### **AXIN Protocol**

Signals
 ABORT

ABORT

**ABORT** 

**ABORT** 

**BYTES** 

| Global  | AXI    | AXIN  |
|---------|--------|-------|
| Signals | Stream |       |
| ACLK    | TVALID | VALID |
| ARESETN | TREADY | READY |
|         | TDATA  | DATA  |
|         | TSTRB  | BYTES |
|         | TKEEP  |       |
|         | TLAST  | LAST  |
|         |        | ABORT |
|         | TUSER  |       |



## **Signals**



| AXIN | Protocol |
|------|----------|
|------|----------|

Signals
 ABORT

ABORT

**ABORT** 

**ABORT** 

BYTES

| Global  | AXI    | AXIN  |
|---------|--------|-------|
| Signals | Stream |       |
| ACLK    | TVALID | VALID |
| ARESETN | TREADY | READY |
|         | TDATA  | DATA  |
|         | TSTRB  | BYTES |
|         | TKEEP  |       |
|         | TLAST  | LAST  |
|         |        | ABORT |
|         | TUSER  |       |

These signals arean't really needed



# Signals



| AX | IN | Protocol |
|----|----|----------|
|    |    |          |

➢ Signals

**ABORT** 

**ABORT** 

**ABORT** 

**ABORT** 

**BYTES** 

| Global  | AXI    | AXIN  |
|---------|--------|-------|
| Signals | Stream |       |
| ACLK    | TVALID | VALID |
| ARESETN | TREADY | READY |
|         | TDATA  | DATA  |
|         | TSTRB  | BYTES |
|         | TKEEP  |       |
|         | TLAST  | LAST  |
|         |        | ABORT |
|         | TUSER  |       |

We'll add these two new ones





**AXIN Protocol** 

ABORT

ABORT

**ABORT** 

**BYTES** 

1. ABORT may be raised at any time



It may be raised while VALID && !READY.





**AXIN Protocol** 

Signals
ABORT

→ ABORT

ABORT

ABORT

**BYTES** 

1. ABORT may be raised at any time



It may be raised even without raising VALID.





#### **AXIN Protocol**

Signals
ABORT
ABORT

→ ABORT
ABORT
BYTES

- 1. ABORT may be raised at any time
- 2. ABORT may be only be released if not stalled

```
ACLK STATISTICATION
VALID
READY
DATA
ABORT
```





**AXIN Protocol** 

Signals
ABORT
ABORT
ABORT

→ ABORT
BYTES

- 1. ABORT may be raised at any time
- 2. ABORT may be only be released if not stalled
- 3. While legal, it doesn't make sense to raise ABORT if VALID && LAST.
- 4.



If VALID && LAST are both true, the packet has successfully, entered the downstream registers. Raising ABORT at this point makes little sense.





**AXIN Protocol** 

Signals
ABORT
ABORT
ABORT

→ ABORT

**BYTES** 

- 1. ABORT may be raised at any time
- 2. ABORT may be only be released if not stalled
- 3. While legal, it doesn't make sense to raise ABORT if VALID && LAST.
- 4. Nor does it make sense to raise ABORT if a packet hasn't started.



If VALID && LAST are both true, the packet has successfully, entered the downstream registers. Raising ABORT at this point makes little sense.



### **BYTES**



#### **AXIN Protocol**

Signals ABORT ABORT ABORT

ABORT 

→ BYTES

- 1. All beats are packed
- 2. The BYTES field contains clog2(DW/8) bits. If ever BYTES == 0, then there are DW/8 valid bytes implied.
- 3. Only the last beat can contain fewer than DW/8 bytes
- 4. The last beat cannot be empty. It must have at least one byte.
- 5. Ordering can be big endian





### **BYTES**



#### **AXIN Protocol**

Signals **ABORT ABORT ABORT** 

**ABORT** ➢ BYTES

- All beats are packed
- The BYTES field contains \$clog2(DW/8) bits. If ever BYTES == 0, then there are DW/8 valid bytes implied.
- Only the last beat can contain fewer than DW/8 bytes
- The last beat cannot be empty. It must have at least one byte.
- 5. Ordering can be big or little endian

