

# Modular Design in Bluespec Using Asim/AWB

Joel Emer<sup>‡†</sup>, Michael Adler<sup>‡</sup>, Michael Pellauer<sup>‡†</sup>

<sup>‡</sup>VSSAD Group Intel †CSG - CSAIL MIT

## Why modularity?

- Speed of development
- Shared components between products
- Reuse across generations
- Improved fidelity
- Incremental refinement
- Facilitates area/speed trade-offs
- Architectural experimentation
- Factorial development and evaluations
- Sharing



## **ASIM Module Hierarchy**





#### **ASIM Module Selection**





## **Module Selection**





## **Module Replacement**





#### **Module Instantiation**





## Factorial Coding/Experiments





### Module Description (.awb file)

%name SMIPS R10K Superscalar Decode Stage

%desc SMIPS R10K Superscalar Decode Stage

%attributes s10k smips hasim

%provides hasim\_pipe\_decode

%requires hasim\_rob hasim\_branch\_pred

%public Decode.bsv



## (H) ASIM Module Hierarchy





## (H) ASIM Module Hierarchy





### (H) ASIM Module Hierarchy





#### Module Interfaces

Plumbing Modules

Algorithm Modules

Message Modules

Library Modules



## **AWB Operation**



Repositories

Workspace



#### **Build Features**

- Model level parameter specification
- Automatic Makefile creation from templates (L2)
- Bluespec module dependence analysis
- Easy to specify synthesis boundaries (L3a)
- Support for parallel builds (L3b)
- Allows BDPI and Verilog modules (L7)
- Support for hybrid hardware/software modules
- Targets bitfile, iverilog, Bluesim



## Communication: A modularity speedbump





## Soft Connections: Flattening the speedbumps





#### **Soft Connections**

Use "ModuleCollect" to collect connection names:

```
let my_con <- mkConnection_Send("dec_to_exe");</pre>
```

Use static elaboration to find/join ends. Pseudo-code:



#### Connections





## Connections Across Synthesis Boundaries (L3)

4. Use the previous scheme to connect as normal





### Acknowledgments

- David Goodwin
- Artur Klauser
- Martha Mercaldi
- Toni Juan
- Srilatha Manne
- Nate Binkert

- Shubu Mukherjee
- Angshu Parashar
- Ramon Matas
- Arvind
- Saila Parthasarathy
- Krishna Rangan
- Brian Slechta



Soon...

http://asim.csail.mit.edu





## Backup

