## EmbHardw Exercises

Generated by Doxygen 1.8.13

# **Contents**

Index

| 1   | Desi | gn Unit Index                      | 1  |
|-----|------|------------------------------------|----|
|     | 1.1  | Design Unit Hierarchy              | 1  |
| 2   | Desi | gn Unit Index                      | 3  |
|     | 2.1  | Design Unit List                   | 3  |
| 3   | File | Index                              | 5  |
|     | 3.1  | File List                          | 5  |
| 4   | Clas | s Documentation                    | 7  |
|     | 4.1  | behavioural Architecture Reference | 7  |
|     | 4.2  | behavioural Architecture Reference | 8  |
|     | 4.3  | behavioural Architecture Reference | 8  |
|     | 4.4  | behavioural Architecture Reference | 9  |
|     | 4.5  | behavioural Architecture Reference | 9  |
|     | 4.6  | FIFO Entity Reference              | 10 |
|     | 4.7  | LCD Architecture Reference         | 11 |
|     | 4.8  | LcdDriver Entity Reference         | 12 |
|     | 4.9  | reader Entity Reference            | 13 |
|     | 4.10 | testbenchFifo Entity Reference     | 13 |
|     | 4.11 | testbenchLcd Entity Reference      | 14 |
|     | 4.12 | writer Entity Reference            | 14 |
| 5   | File | Documentation                      | 17 |
|     | 5.1  | IcdDriver.vhdl File Reference      | 17 |
|     |      | 5.1.1 Detailed Description         | 17 |
| Ind | dex  |                                    | 19 |

# **Design Unit Index**

## 1.1 Design Unit Hierarchy

This inheritance list is sorted roughly, but not completely, alphabetically:

| reader        | <br> |  |  |  |  |  |      |  |  |  | <br> |  |  |  |  |      |  |  |  |  | •     | 13 |
|---------------|------|--|--|--|--|--|------|--|--|--|------|--|--|--|--|------|--|--|--|--|-------|----|
| testbenchFifo | <br> |  |  |  |  |  |      |  |  |  |      |  |  |  |  |      |  |  |  |  | •     | 13 |
| FIFO          |      |  |  |  |  |  | <br> |  |  |  |      |  |  |  |  |      |  |  |  |  | <br>• | 10 |
| testbenchLcd  | <br> |  |  |  |  |  |      |  |  |  |      |  |  |  |  |      |  |  |  |  |       | 14 |
| LcdDriver     |      |  |  |  |  |  | <br> |  |  |  |      |  |  |  |  |      |  |  |  |  |       | 12 |
| FIFO .        |      |  |  |  |  |  |      |  |  |  |      |  |  |  |  | <br> |  |  |  |  |       | 10 |
| writer        | <br> |  |  |  |  |  |      |  |  |  | <br> |  |  |  |  |      |  |  |  |  |       | 14 |

2 Design Unit Index

# **Design Unit Index**

## 2.1 Design Unit List

Here is a list of all design unit members with links to the Entities they belong to:

| architecture behavioural |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     | . 7  |
|--------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|------|
| architecture behavioural |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | . , | . 8  |
| architecture behavioural |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     | . 8  |
| architecture behavioural |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |      |
| architecture behavioural |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |      |
| entity FIFO              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     | . 10 |
| architecture LCD         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |      |
| entity LcdDriver         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |      |
| entity reader            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |      |
| entity testbenchFifo     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |      |
| entity testbenchLcd      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     | . 14 |
| entity writer            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     | . 14 |

Design Unit Index

# File Index

| 0 4   |     | le l |      |     |
|-------|-----|------|------|-----|
| 3.1   | H-1 |      | 1 1  | Ct  |
| . 7 . |     | V -  | _ 13 | . T |

Here is a list of all documented files with brief descriptions:

| lcdDriver.vhdl |                                                              |    |
|----------------|--------------------------------------------------------------|----|
| LCD driver     | Translates avalon bus data and commands to the LCD interface | 17 |

6 File Index

## **Class Documentation**

## 4.1 behavioural Architecture Reference

#### **Processes**

- edgeDetect( Reset\_NRI , Clk\_CI )
- nextState( Clk\_Cl , Reset\_NRI )
- logic( Clk\_Cl , Push\_Edge\_D , Pop\_Edge\_D , numEl\_D )

## **Types**

- state\_T(stateReset,stateEmpty,stateFilling,stateFull)
- memory\_T(SIZE- 1 downto 0 )std\_logic\_vector( 15 downto 0 )

## **Signals**

- stateNext\_D state\_T
- statePres\_D state\_T
- data\_D memory\_T
- numEl\_D natural
- head\_D natural
- tail\_D natural
- Push\_Edge\_D std\_logic
- Push\_Last\_D std\_logic
- Pop\_Edge\_D std\_logic
- Pop\_Last\_D std\_logic

The documentation for this class was generated from the following file:

• fifo.vhdl

## 4.2 behavioural Architecture Reference

#### **Processes**

- clk process()
- stim\_proc()

## Components

• FIFO

## **Constants**

```
• TimeMax_C time:= 1000 ns
```

```
• Clk_period_C time:= 20 ns
```

## **Signals**

- Clk\_S std\_logic
- Reset\_NR std\_logic
- Push\_S std\_logic
- Pop\_S std\_logic
- DataPush\_D std\_logic\_vector( 15 downto 0 )
- DataPop\_D std\_logic\_vector( 15 downto 0 )
- Full\_S std\_logic
- Empty\_S std\_logic
- Time\_S time:= 0 ns

#### Instantiations

dut FIFO

The documentation for this class was generated from the following file:

· testbenchFifo.vhdl

## 4.3 behavioural Architecture Reference

#### **Processes**

- clk\_process()
- stim\_proc()

## Components

• LcdDriver

#### **Constants**

- TimeMax\_C time:= 1000 ns
- Clk\_period\_C time:= 20 ns

#### **Signals**

- Clk S std logic
- Reset\_NR std\_logic
- Address\_D std\_logic\_vector( 1 downto 0 )
- Write\_S std\_logic
- WriteData\_D std\_logic\_vector( 15 downto 0 )
- Read\_S std\_logic
- ByteEnable\_D std\_logic
- BeginBurstTransfer D std logic
- BurstCount\_D std\_logic\_vector(7 downto 0)
- WaitReq\_S std\_logic
- ReadData\_D std\_logic\_vector( 15 downto 0 )
- DB\_D std\_logic\_vector( 15 downto 0 )
- Rd\_NS std\_logic
- Wr\_NS std\_logic
- Cs\_NS std\_logic
- DC\_NS std\_logic
- LcdReset\_NR std\_logic
- IM0\_S std\_logic
- Time\_S time:= 0 ns

#### Instantiations

lcd LcdDriver

The documentation for this class was generated from the following file:

· testbenchLcd.vhdl

#### 4.4 behavioural Architecture Reference

The documentation for this class was generated from the following file:

· reader.vhdl

## 4.5 behavioural Architecture Reference

#### **Processes**

pRegWrite( Clk\_Cl )

The documentation for this class was generated from the following file:

· writer.vhdl

## 4.6 FIFO Entity Reference

Inheritance diagram for FIFO:



## **Entities**

• behavioural architecture

#### Libraries

• ieee

## **Use Clauses**

- std\_logic\_1164
- numeric\_std
- std\_logic\_unsigned

## Generics

• SIZE natural:= 256

#### **Ports**

- Clk\_Cl in std\_logic
- Reset\_NRI in std\_logic
- Push\_SI in std\_logic
- Pop\_SI in std\_logic
- Data\_DI in std\_logic\_vector( 15 downto 0)
- Data\_DO out std\_logic\_vector( 15 downto 0 )
- Full\_SO out std\_logic
- Empty\_SO out std\_logic

The documentation for this class was generated from the following file:

• fifo.vhdl

#### 4.7 LCD Architecture Reference

#### **Processes**

- edgeDetect( Reset\_NRI , Clk\_CI )
- nextStateRx( Clk\_Cl , Reset\_NRI )
- logicRx( Clk\_Cl , RxStatePres\_D , FifoFull\_D , Write\_Edge\_D , RxData\_D )
- nextStateTx( Clk Cl , Reset NRI )
- logicTx( Clk\_Cl , TxStatePres\_D , FifoEmpty\_D )

#### Components

FIFO

#### **Types**

- TxState\_T(TxStateReset,TxStateDispReset,TxStateIdle,TxStatePreTx,TxStateTx,TxStatePostTx)

## **Signals**

- RxStateNext\_D RxState\_T:=RxStateReset
- TxStateNext\_D TxState\_T:=TxSTateReset
- RxStatePres D RxState\_T:=RxStateReset
- TxStatePres\_D TxState\_T:=TxSTateReset
- Pop\_S std\_logic
- Push\_S std\_logic
- RxData\_D std\_logic\_vector( 15 downto 0 )
- TxData\_D std\_logic\_vector( 15 downto 0 )
- FifoFull\_D std\_logic
- FifoEmpty\_D std\_logic
- IsData\_D std\_logic
- BitEnable\_D std\_logic\_vector( 15 downto 0 )
- Write\_Edge\_D std\_logic
- Write\_Last\_D std\_logic
- Read\_Edge\_D std\_logic
- Read\_Last\_D std\_logic

#### **Instantiations**

· databuffer FIFO

The documentation for this class was generated from the following file:

IcdDriver.vhdl

## 4.8 LcdDriver Entity Reference

Inheritance diagram for LcdDriver:



#### **Entities**

• LCD architecture

#### Libraries

ieee

#### **Use Clauses**

- std\_logic\_1164
- numeric\_std

### **Ports**

- · Clk\_Cl in std\_logic
- Reset\_NRI in std\_logic
- Address\_DI in std\_logic\_vector( 1 downto 0 )
- Write\_SI in std\_logic
- WriteData\_DI in std\_logic\_vector( 15 downto 0 )
- · Read\_SI in std\_logic
- ByteEnable DI in std\_logic\_vector( 1 downto 0)
- BeginBurstTransfer\_DI in std\_logic
- BurstCount\_DI in std\_logic\_vector( 7 downto 0 )
- WaitReq\_SO out std\_logic
- ReadData\_DO out std\_logic\_vector( 15 downto 0 )
- ReadDataValid\_SO out std\_logic
- DB\_DIO inout std\_logic\_vector( 15 downto 0 )
- Rd\_NSO out std\_logic
- Wr\_NSO out std\_logic
- Cs\_NSO out std\_logic
- DC\_NSO out std\_logic
- · LcdReset NRO out std\_logic
- IM0\_SO out std\_logic

The documentation for this class was generated from the following file:

· IcdDriver.vhdl

## 4.9 reader Entity Reference

#### **Entities**

· behavioural architecture

#### Libraries

• ieee

#### **Use Clauses**

• std\_logic\_1164

#### **Ports**

- · Clk\_Cl in std\_logic
- Address\_DI in std\_logic\_vector( 2 downto 0)
- · Read SI in std\_logic
- RegDir\_DI in std\_logic\_vector( 7 downto 0)
- RegPort\_DI in std\_logic\_vector( 7 downto 0 )
- RegPin\_DI in std\_logic\_vector( 7 downto 0 )
- ReadData\_DO out std\_logic\_vector(7 downto 0)

The documentation for this class was generated from the following file:

· reader.vhdl

## 4.10 testbenchFifo Entity Reference

Inheritance diagram for testbenchFifo:



## **Entities**

• behavioural architecture

#### Libraries

• ieee

## **Use Clauses**

• std\_logic\_1164

The documentation for this class was generated from the following file:

testbenchFifo.vhdl

## 4.11 testbenchLcd Entity Reference

Inheritance diagram for testbenchLcd:



#### **Entities**

· behavioural architecture

## Libraries

• ieee

## **Use Clauses**

• std\_logic\_1164

The documentation for this class was generated from the following file:

· testbenchLcd.vhdl

## 4.12 writer Entity Reference

#### **Entities**

• behavioural architecture

## Libraries

• ieee

## **Use Clauses**

• std\_logic\_1164

#### **Ports**

- Clk\_Cl in std\_logic
- Address\_DI in std\_logic\_vector( 2 downto 0)
- Write\_SI in std\_logic
- WriteData\_DI in std\_logic\_vector( 7 downto 0 )
- RegDir\_DO out std\_logic\_vector( 7 downto 0)
- RegPort\_DIO inout std\_logic\_vector( 7 downto 0 )
- IRQCtrl\_SO out std\_logic
- IRQState\_SO out std\_logic

The documentation for this class was generated from the following file:

· writer.vhdl

## **File Documentation**

## 5.1 IcdDriver.vhdl File Reference

LCD driver. Translates avalon bus data and commands to the LCD interface.

## **Entities**

- LcdDriver entity
- LCD architecture

## 5.1.1 Detailed Description

LCD driver. Translates avalon bus data and commands to the LCD interface.

Author

David Wright

18 File Documentation

# Index

```
behavioural, 7–9
FIFO, 10
LCD, 11
LcdDriver, 12
lcdDriver.vhdl, 17
reader, 13
testbenchFifo, 13
testbenchLcd, 14
writer, 14
```