eolas/Computer_Architecture/Hardware_Description_Language.md

53 lines
2.2 KiB
Markdown
Raw Normal View History

2022-12-28 13:00:05 +00:00
---
categories:
- Computer Architecture
- Hardware
tags: [HDL, nand-to-tetris]
---
# Hardware Description Language
2022-12-29 12:30:05 +00:00
An HDL is a declarative programming language used to describe the behaviour or structure of [digital circuits](/Electronics_and_Hardware/Digital_circuits/Integrated_circuits.md). They are used to simulate the circuit and check its response.
The hardware designer specifies a chip's logic by writing an HDL program which is then rigorously tested. At this stage, a [hardware simulator](/Computer_Architecture/Hardware_simulation.md) takes the HDL program as input and creates a software representation of the chip logic. The designer can instruct the simulator to test the virtual chip on various sets of inputs. This is done to check the chip's functionality but also to benchmark a variety of other parameters such as speed of computation and energy consumption.
2022-12-28 13:00:05 +00:00
There are many HDLs but the most popular are VHDL ("very high speed integrated-circuit description language") and Verilog.
2022-12-29 12:30:05 +00:00
## Usage in _NAND to Tetris_
2022-12-29 13:00:07 +00:00
We won't use an actual HDL language, instead we will use a simplified toy language called HDL that is simple enough that when it is used with a simulator, we can learn the main facets of chip design. Its syntax is very similar to VHDL.
2022-12-29 12:30:05 +00:00
## Demonstration
We will create an HDL program for an XOR gate that is implemented through the following arrangement of NOT, AND, and OR gates:
2022-12-29 13:00:07 +00:00
![](/img/xor-hdl.png)
Here is our HDL file:
```vhdl
/* Xor gate
If a!=b out=1 else out=0
*/
CHIP Xor {
IN a, b;
OUT out;
PARTS:
Not (in=a, out=nota);
Not (in=b, out=notb);
And (a=a, b=notb, out=w1);
And (a=nota, b=b, out=w2);
Or (a=w1, b=w2, out=out)
}
```
### Key points of note
#### Interface (`CHIP, IN, OUT`)
At the top level of the HDL program, the `CHIP` name and `IN`/`OUT` declaration is the _interface_ of the chip. Here we specify our naming convention for the `IN` and `OUT` values which we will refer to in the implementation declaration in `PARTS`.
#### Implementation (`PARTS`)
Everything under the `PARTS` section is the chip _implementation_. We can draw on composite gates in the `PARTS` declaration (e.g. `Not`, `And`, `Or`). The convention is to work from left to right when transcribing from a digital circuit diagram