

# *The Open-Source Bluespec bsc Compiler and Reusable Example Designs*

Julie Schwartz, Niraj N.Sharma, Darius Rad, Ken Takusagawa,  
Joe Stoy & Rishiyur S. Nikhil

WOSET 2021: Workshop on Open-Source EDA Tools  
November 4, 2021

# Overview



# BSV/BH compared with others: semantics (behavioral model)

| HLS/OpenCL                                                                                                                                                                                                                                                                              | BSV/BH                                                                                                                                                                                                                                                                                                                                                                                           | Chisel,<br>Verilog, SystemVerilog, VHDL                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
| <p>Semantics: C</p> <p>C-“ish”</p> <p>Compiler, not source code, determines microarchitecture (can be guided with hints)</p> <p>Not universal (limits on automatic parallelization in C compilers).</p> <p>Sweet spot: dense matrix-and-loop codes, very simple control structures.</p> | <p>Semantics:</p> <ul style="list-style-type: none"><li>- Concurrent Atomic Transactions</li><li>- a.k.a. Guarded Atomic Actions</li></ul> <p>Enables <i>scalable</i> informal and formal reasoning about correctness of HW (massive concurrency, fine-grain).</p> <p>Popular in formal verification of fine-grain concurrent systems such as cache-coherence. cf. TLA+, UNITY, Event-B, ...</p> | <p>Semantics: traditional clocked digital circuits</p> |

# BSV/BH compared with others:

## modern Programming Language features

|            |                                                                                                                                                                                                                                                           |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | <p>BSV/BH</p> <p>Full power of Haskell 98<br/>(higher-order functions, polymorphic types,<br/>typeclasses, monads, packages, ...)<br/>+ bitwidth-arithmetic and checking<br/>+ static clock-domain checking<br/>(but is not an embedding in Haskell).</p> |
| C-“ish”    | <p>Chisel</p> <p>Full power of Scala available for<br/>parameterization, generators, etc.<br/>(Chisel is embedded in Scala).</p>                                                                                                                          |
|            | <p>Verilog, SystemVerilog, VHDL</p>                                                                                                                                                                                                                       |
| HLS/OpenCL | <p>HDLs (hardware-design languages)<br/>and HLHDLs (high-level HDLs)</p>                                                                                                                                                                                  |

# An example fragment of BSV, for flavor

*Concurrent bubblesort of an array of registers*



Instantiate vector of registers

- strongly-typed polymorphic size '*n\_t*',
- strongly-typed register contents 'Maybe #(t)',  
(polymorphic type 't' but  
tagged with Valid/Invalid bits ('Maybe'))
- using standard vector higher-order function 'replicateM'  
on standard register module instantiator 'mkReg'  
with reset value 'Invalid'

```
Vector #(n_t,
      Reg #(Maybe #(t))) xs <- replicateM (mkReg(tagged Invalid));

for (Integer i = 0; i < valueOf(n_t)-1; i = i+1)
  rule rl_swap_i (xs [i] > xs [i+1]);
    xs [i]   <= xs [i+1];
    xs [i+1] <= xs [i];
  endrule
```

Implicitly generative loops  
(can also be written in Haskell style  
maps, lists, recursion, ...  
since rules are first-class values).

Though values are polymorphic (type 't'),  
comparison '>' is strongly-typed  
(using Haskell *typeclasses*).

Adjacent rules (updating common registers) arbitrated automatically due to atomic transaction semantics

Full example (including simpler lead-up examples without parameterization and generators):

<https://github.com/BSVLang/Main.git>

Tutorials/BSV\_Training/Example\_Programs/Eg03e\_Bubblesort/src\_BSV/Bubblesort.bsv

The true power of *rules* is revealed as we scale atomicity across parameterized module boundaries.

The true power of Haskell features is revealed as we scale to large, parameterized designs.

# BSV/BH libraries: a sampling

## Basic data types

- Bit vectors
- structs, tagged unions, enums (w. automatic \$display)
- Vectors (of arbitrary types, including modules, interfaces) and higher-order functions map, fold, scan, zip, ...
- One-hot

## Primitive modules

- Registers
- Concurrent Registers

## FIFOs

- Simple FIFOs
- BRAMFIFO
- LevelFIFO
- SyncFIFO (clock-domain crossing)
- GearBox (width-change)
- MIMO (multiple-in/out)
- Reorder Buffer

## Display

- Format objects
- FShow typeclass

## Storage Structures

- Default-value Register
- Register File
- BRAM
- Memory Interface

## Math

- Floating Point
- FixedPoint
- Complex
- IFFT
- Random Numbers (LFSRs)

## Counters

- Arbiter
- Up/down counters
- Gray counters
- BufIndex
- WrapNumber

## Composable, Controllable FSMs

- FSM interface
- Smts (abstracted FSM components)
- FSM builders (general, one-shot, stall control)

## Connectivity

- Connectable typeclass
- GetPut interfaces
- Credit-based GetPut
- ClientServer interfaces
- AXI4, AXI4-Lite interfaces, crossbars

## Clock and Reset Domains

- Statically checked Clock and Reset types
- Clock Generators and Transformers
- Clock Division
- Clock Gating and Clock selection
- Synchronizers: Bit, Pulse, Word, FIFO, RAM

## Crypto/signature

- CRC
- AES
- SHA256 (planned)

## FPGA-specific

- BRAM
- BRAMFIFO
- Xilinx IP wrappers

## Advanced

- Monadic plumbing
- Configuration bus

*Most of this is written in BSV*

# bsc tools and flows

(Tools shown in light blue )

## BSV/BH and *bsc* timeline and maturity



## Significant example designs (open source)

The paper briefly describes and provides links for a number of significant, open-source designs (by no means an exhaustive list). All of them run on FPGAs

- Complete Linux-capable RISC-V system running on Xilinx VCU118 boards and Amazon AWS (“AWS-Steria\_RISCV\_Virtio”). [ **Demo** and next slides. ]
- Several RISC-V CPUs from Bluespec, Inc. and MIT (Piccolo, Flute, Toooba/RISCV-OOO). Piccolo and Flute are highly parameterized on the RISC-V ISA options, generating a range of CPUs from small, embedded to powerful, Linux-capable.
- These Bluespec CPU repositories also include several variants of cache systems, Debug Modules, Interrupt Controllers, Timer interruptors, AXI4 and AXI4-Lite interfaces, fabrics and components, etc.
- Security-enhanced CPU designs (MIPS and RISC-V) from U. Cambridge.
- “Shakti” RISC-V CPU family from IIT Madras.
- “CONNECT” NoC (network-on-chip) generator from Carnegie Mellon University.
- “BlueCheck” automatic hardware checker modelled on Haskell QuickCheck from U.Cambridge.

*Please see paper for open-source repository links for all the above.*

# Hardware setup for demo

Intel NUC mini-server  
running Debian Linux  
("host side")

Thunderbolt cable  
carrying PCIe



Xilinx VCU118  
inside a Node Pro PCIe cage  
with PCIe connected via  
Thunderbolt cable to NUC  
("hardware/FPGA side")

# A significant open-source example design (live demo)

- Runs in simulation and on Xilinx VCU118 and Amazon AWS; boots FreeBSD (also Linux capable). Virtio support provides networking and block-storage to FreeBSD/Linux on RISC-V.
- RISC-V CPU on FPGA-side is controllable from GDB on host-side.



Entire hardware-side, and much of AWSteria\_Infra is written in BSV. Host-side code is in C.

Flute CPU, RISC-V components (Debug Module, PLIC, Timer, SW intr), AXI: <https://github.com/bluespec/Flute>

AWSteria\_RISCV\_Virtio: [https://github.com/GaloisInc/BESSPIN-CloudGFE/tree/rsn3/AWSteria\\_RISCV\\_Virtio](https://github.com/GaloisInc/BESSPIN-CloudGFE/tree/rsn3/AWSteria_RISCV_Virtio) (rsn3 branch; will move to main branch)

AWSteria\_Infra: [https://github.com/bluespec/AWSteria\\_Infra](https://github.com/bluespec/AWSteria_Infra)

## Conclusion

We invite the community to join us in using BSV/BH, and in continued development of the *bsc* compiler and tools.

Key links:

- *bsc* compiler source code (written in Haskell), including libraries: <https://github.com/B-Lang-org/bsc>
- Additional contributed libraries: <https://github.com/B-Lang-org/bsc-contrib>
- Bluespec Development Workstation (GUI): <https://github.com/B-Lang-org/bdw>
- Tutorial materials. Comprehensive textbook(s) are in progress. Meanwhile, the following links are useful:
  - Bluespec, Inc.'s training materials <https://github.com/BSVLang/Main>: working examples, slides, and a PDF copy of the “BSV by Example” book.
  - ICFP 2020 tutorial: [https://github.com/rsnikhil/ICFP2020\\_Bluespec\\_Tutorial](https://github.com/rsnikhil/ICFP2020_Bluespec_Tutorial)
  - Video recording of ICFP 2020 tutorial: <https://www.youtube.com/watch?v=JCxE3JQAXY0>

*Please see paper for open-source repository links for the rest of the mentioned artefacts.*

*Thank you!*