# Comparing functional Embedded Domain-Specific Languages for hardware description

João Paulo Pizani Flor

Department of Information and Computing Sciences, Utrecht University

February 13th, 2014

#### Introduction

Hardware design Domain-Specific Languages Hardware EDSLs

#### Analyzed EDS

Choice criteria Chosen EDSLs Evaluation criteria

#### Modeled Circuits

Choice ALU Memory bank CPU

# Analysis of the EDSLs

ForSyDe Coquet

# Conclusions

Results Future work



```
Table of Contents
 Introduction
    Hardware design
    Domain-Specific Languages
    Hardware FDSIs
 Analyzed EDSLs
    Choice criteria
    Chosen EDSLs
    Evaluation criteria
 Modeled Circuits
    Choice
    AI U
    Memory bank
    CPU
 Analysis of the EDSLs
```

### Introduction

Hardware design Domain-Specific Languages Hardware EDSLs

#### nalyzed EDS

Choice criteria Chosen EDSLs Evaluation criteria

#### Modeled Circuits

Choice ALU Memory bank CPU

#### Analysis of the EDSLs

ForSyDe Coquet

Coquet

### Conclusio

Results Future work



Universiteit Utrecht

Conclusions

Lava ForSyDe Coquet

# Section 1

# Introduction

### Introduction

Domain-Specific Languages Hardware EDSLs

#### Analyzed ED

Choice criteria Chosen EDSLs

#### Modeled Circuits

Choice ALU Memory bank

# Analysis of the

Lava ForSyDe

# Conclusio

Results



# Hardware design

#### Introduction

### Hardware design

Domain-Specific Languages Hardware EDSL

#### Analyzed ED

Choice criteria
Chosen EDSLs
Evaluation criteria

#### Modeled Circuit

Choice ALU Memory bank

# Analysis of the EDSLs

Lava ForSyDe Coquet

### Camalua

Results



# Domain-Specific Languages

A computer language (turing-complete or *not*) targeting a specific application domain.

### **Example DSLs:**

- SQL (database queries)
- CSS (document formatting)
- MATLAB (Matrix programming)
- VHDL (Hardware description)

Domain-Specific Languages

ALU.

Coquet



# Domain-Specific Languages

A computer language (turing-complete or *not*) targeting a specific application domain.

### **Example DSLs:**

- SQL (database queries)
- CSS (document formatting)
- MATLAB (Matrix programming)
- VHDL (Hardware description)

A DSL can also be *embedded* in a general-purpose language.

### Example EDSLs:

- ▶ Boost.Proto (C++ / parser combinators)
- Diagrams (Haskell / programmatic drawing)
- Parsec (Haskell / parser combinators)

Hardware design
Domain-Specific
Languages
Hardware FDSIs

Applymed EDSI

Choice criteria Chosen EDSLs

Modeled Circuit

Choice ALU Memory bank CPU

Analysis of the EDSLs

ForSyDe Coquet

Results



# Example of an EDSL: Parsec

A simple parser for a "Game of Life"-like input format:

```
dead, alive :: Parser Bool
dead = fmap (const False) (char '.')
alive = fmap (const True) (char '*')
line :: Parser [Bool]
line = many1 (dead <|> alive)
board :: Parser [[Bool]]
board = line 'endBy1' newline
parseBoardFromFile :: FilePath -> IO [[Bool]]
parseBoardFromFile filename = do
    result <- parseFromFile board filename
    return $ either (error . show) id result
```

Hardware design Domain-Specific Languages

Choice criteria Chosen EDSLs

Modeled Circuit

Choice ALU Memory bank CPU

Analysis of the EDSLs

ForSyDe Coquet

Conclusions
Results
Future work

### Hardware EDSLs

An EDSL used for hardware design-related tasks. Can encompass:

- Modelling / description
- Simulation (validation)
- Formal verification
- Synthesis to other (lower-level) languages

Hardware EDSLs

ALU.

Coquet



# Example of a hardware EDSL

Some Lava code...

#### Introduction

Hardware design Domain-Specific Languages

### Hardware EDSLs

### Analyzed ED

Choice criteria
Chosen EDSLs
Evaluation criteria

#### Modeled Circuits

Choice ALU Memory bank

# Analysis of the

Lava ForSyDe

### Conclusio

Results Future work



# Section 2

# Analyzed EDSLs

Introduction

Domain-Specific Languages Hardware EDSLs

### Analyzed EDSLs

Choice criteria Chosen EDSLs

Modeled Circuits

Choice ALU Memory bank

Analysis of the

Lava ForSyDe Coquet

Coquet

Conclusion

Future work



# Choice criteria

#### Introduction

Hardware design Domain-Specific Languages Hardware EDSI

#### Analyzed EF

# Choice criteria

Evaluation criteri

#### Modeled Circuit

Choice ALU Memory bank

# Analysis of the EDSLs

Lava ForSyDe Coquet

### Conclus

Results



# Chosen EDSLs

The language we chose to evaluate, with the respective host language, were:

- Lava (Haskell chalmers-lava dialect)
- ForSyDe (Haskell)
- Coquet (Coq)

Chosen EDSLs

ALU.

Coquet



### Evaluation criteria

- Simulation
- Verification
- Genericity
- Depth of embedding
- Tool integration
- Extensibility

Introduction

Domain-Specific Languages Hardware EDSLs

Analyzed ED

Choice criteria
Chosen EDSLs
Evaluation criteria

M 11 161 1

Modeled Circuits

Choice ALU Memory bank

Analysis of the

ForSyDe Coquet

Conclusio

Results
Future work



# Section 3

# **Modeled Circuits**

#### Introduction

Domain-Specific Languages Hardware EDSLs

#### Analyzed ED

Chosen EDSLs

### Modeled Circuits

Choice ALU Memory bank

# Analysis of the

Lava ForSyDe Coquet

Conclusio

#### Conclusions Results

Future wor



# Choice criteria

- Not too simple, not too complex
- Familiar to any hardware designer
  - No signal processing, etc.
- Well-defined, pre-specification
  - · Results to verify the models against

### Choice

ALU.

Coquet



# Chosen circuits

We cherry-picked circuits from the book "Elements of Computing Systems", as they satisfied all of our demands.



Figure: "Elements of Computing Systems" - Nisan, Schocken, available at http://www.nand2tetris.org.

#### Introduction

Hardware design Domain-Specific Languages Hardware EDSLs

#### Analyzed EDS

Choice criteria Chosen EDSLs Evaluation criteria

#### Modeled Circuits

### Choice

ALU Memory ban CPU

# Analysis of the EDSLs

ForSyD Coquet

# Conclusi

Results Future work



# Chosen circuits

Circuit 1 A 2-input, 16-bit-wide, simple ALU

Circuit 2 A 64-word long, 16-bit wide memory block

Circuit 3 An extremely reduced instruction set CPU, the Hack CPU.

Let's take a quick look at each of these circuit's specification...

Introduction

Domain-Specific Languages Hardware EDSLs

Analyzed ED

Choice criteria Chosen EDSLs

Modeled Circuits

Choice

ALU Memory bank CPU

Analysis of the EDSLs

ForSyDe Coquet

Conclusions
Results
Future work

# Circuit 1: ALU

# Some of the circuit's key characteristics:

- ▶ 2 operand inputs and 1 operand output, each 16-bit wide
- ▶ 1 output flag
- ▶ Can execute 18 different *functions*, among which:
  - · Addition, subtraction
  - Bitwise AND / OR
  - Constant outputs
  - · Addition of constants to an operand
  - Sign inversion

Introduction

Domain-Specific Languages Hardware EDSLs

Analyzed ED

Choice criteria Chosen EDSLs

Modeled Circuit

Choice ALU

Memory bank CPU

Analysis of the

EDSLs Lava

ForSyDe Coquet

Conclusions
Results
Future work



# Circuit 1: block diagram



Figure: Input/Output ports of circuit 1, the ALU.

#### Introduction

Hardware design Domain-Specific Languages Hardware EDSLs

#### Analyzed ED

Choice criteria Chosen EDSLs Evaluation criteria

#### Modeled Circuits

Choice ALU Memory bank

# Analysis of the

Lava ForSyDe

# Conclusi

Conclusions Results Future work



# Circuit 1: specification

The behaviour of the ALU is specified by the values of the *control bits* and *flags*:

Operations such as bitwise OR, subtraction, etc. can be done by setting the control bits appropriately.

Introduction
Hardware design
Domain-Specific
Languages

Analyzed EDSI

Choice criteria Chosen EDSLs

Modeled Circuits

Choice ALU Memory bank CPU

Analysis of the EDSLs

Lava ForSyDe Coquet

Conclusions
Results
Future work



# Circuit 2: RAM64

# Some of the circuit's key characteristics:

- Sequential circuit, with clock input
- 64 memory words stored, each 16-bit wide
- ► Address port has width log<sub>2</sub> 64 = 16 bit

ALU. Memory bank

Coquet



# Circuit 2: block diagram



Figure: Input/Output ports of *circuit 2*, the RAM64 block.

#### Introduction

Domain-Specific Languages Hardware EDSLs

#### Analyzed ED

Choice criteria Chosen EDSLs Evaluation criteria

#### Modeled Circuits

ALU Memory bank

# CPU

Analysis of the EDSLs

ForSyDe Coquet

# Conclusion

Results Future work



# Circuit 2: specification

The output "out" holds the value at the memory line indicated by "address".

- ► Iff "load" = 1, then the value at input "in" will be loaded into memory line "address".
- ► The loaded value will be emitted on "out" at the *next* clock cycle.

Introduction

Hardware design Domain-Specific Languages Hardware EDSLs

Analyzed EDSLs

Choice criteria
Chosen EDSLs

Modeled Circuits

Choice ALU Memory bank

Memory bank CPU

Analysis of the EDSLs

ForSyDe Coquet

Conclusions
Results
Future work



# Circuit 3: Hack CPU

- A very reduced instruction set CPU
  - Only 2 instructions: "C" and "A"
- ▶ Follows the Harvard architecture
  - Separate address spaces for data and instruction memory.
- Instructions are 16-bits wide
  - · As well as the memory input and output
- ► Two internal registers: "D" and "A"

Introduction

Domain-Specific Languages Hardware EDSLs

Analyzed EDS

Choice criteria Chosen EDSLs

Modeled Circuits

Choice ALU Memory bank CPU

Analysis of the

Lava ForSyDe Coquet

Conclusion

Results
Future work



# Circuit 3: block diagram



Figure: Input/Output ports of circuit 3, the Hack CPU.

ALU. CPU

Coquet

# Results



# Circuit 3: specification

Circuit 3 runs "A" and "C" instructions, according to the Hack assembly specification.

▶ The "A" instruction: sets the "A" register.



- The value in "A" can be used:
  - As operand for a subsequent computation
  - As address for jumps

ALU. CPU

Coquet



# Circuit 3: specification

Circuit 3 runs "A" and "C" instructions, according to the *Hack* assembly specification.

► The "C" instruction: sets the "C" register, performs computation or jumps.

| comp                | •        | dest  | jump     |
|---------------------|----------|-------|----------|
|                     |          |       |          |
| 1 x x a c1 c2 c3 c4 | c5 c6 d1 | d2 d3 | j1 j2 j3 |
| LInstruction code   | -        |       |          |

- Some peculiarities:
  - Bits "c1" to "c6" control the ALU
  - · conditional or unconditional jumps
  - destination of the computation result: "A", "D", "M"

Introduction

Hardware design Domain-Specific Languages Hardware EDSLs

Analyzed EDSI

Choice criteria Chosen EDSLs

Modeled Circuits

Choice ALU Memory bank CPU

Analysis of the EDSLs

ForSyDe Coquet

Conclusio

Results Future work



# Circuit 3: specification (parts)



Figure: Parts used to build the *Hack* CPU, and their interconnection.

Introduction

Domain-Specific Languages Hardware EDSLs

inalyzed EDS

Choice criteria Chosen EDSLs Evaluation criteria

Modeled Circuits

Choice ALU Memory bank CPU

Analysis of the EDSLs
Lava

ForSyDe Coquet

Conclusio

Results Future work



# Section 4

# Analysis of the EDSLs

#### Introduction

Domain-Specific Languages Hardware EDSLs

#### Analyzed El

Choice criteria Chosen EDSLs

Modeled Circuits

Choice ALU Memory bank

# Analysis of the EDSLs

Lava ForSyDe

Coquet

Conclusion

Results



### Lava

```
type SB = Signal Bool
halfAdder :: (SB, SB) -> (SB, SB)
halfAdder inputs = (xor2 inputs, and2 inputs)
fullAdder :: (SB, (SB, SB)) -> (SB, SB)
fullAdder (cin, (a, b)) = (s, cout)
    where
      (ab, c1) = halfAdder (a, b)
      (s, c2) = halfAdder (ab, cin)
      cout
               = or2 (c1, c2)
rippleCarryAdder :: [(SB, SB)] -> [SB]
rippleCarryAdder ab = s
    where (s, _) = row fullAdder (low, ab)
```

ALU.

Lava ForSvDe Coquet

# ForSyDe

Introduction

Domain-Specific Languages

#### Analyzed ED

Choice criteria
Chosen EDSLs
Evaluation criteria

#### Modeled Circuit

Choice ALU Memory bank

# Analysis of the EDSLs

Lava ForSyDe

Coque

6

Results

Results Future work



# Coquet

Introduction

Domain-Specific Languages Hardware EDSL:

#### Analyzed ED

Choice criteria Chosen EDSLs Evaluation criteria

#### Modeled Circuit

Choice ALU Memory bank CPU

#### Analysis of the FDSIs

Lava ForSvDe

### Coquet

Conclus

### Conclusio

Results



# Section 5

# Conclusions

#### Introduction

Domain-Specific Languages Hardware EDSLs

#### Analyzed ED

Choice criteria Chosen EDSLs

#### Modeled Circuits

Choice ALU Memory bank CPU

# Analysis of the EDSLs

Lava ForSyDe Coquet

### Conclusions

Results



# Results

#### Introduction

Domain-Specific Languages Hardware FDSI

#### Analyzed ED

Choice criteria
Chosen EDSLs
Evaluation criteria

#### Modeled Circuit

Choice ALU Memory bank

# Analysis of the EDSLs

Lava ForSyDe Coquet

Coquet

#### Conclusio

Results



# Future work

Languages

Choice criteria

ALU Memory bank

Lava

### Results

Future work



Thank you!

Questions?

