



## Hardware Description Languages — Executive-Level Summary

 "Hardware description languages" can be used to represent the circuit designs discussed in Appendix B. Useful as description/specification and also as input to tools that can generate logic blocks.

Slide 3

- Two commonly-used ones are Verilog and VHDL; textbook uses Verilog. Discussion and examples in section B.4.
- Syntactically, Verilog looks more or less like C, but there's (at least) one significant difference: It needs to represent not only sequences of assignments (where each one completes before the next one starts) but also blocks of assignments that execute in parallel. (Think in terms of values flowing through the pictures we've been drawing fast but not infinitely so, so where possible we want to do things simultaneously rather than in sequence.)









## 32-Bit ALU from 1-Bit ALUs, Continued

- Figures B.5.10 and B.5.11 and accompanying text show how to extend the design to implement slt and also an overflow detector. Executive-level summary: Calculate a b and use high-order bit of result of that operation to set low-order bit of result.
- Result is something we can use to do pretty much all of the arithmetic and logic operations of the MIPS ISA. Exceptions are shifts (but those don't seem like they'd be too hard) and multiplication/division (which do, so skip for now).

```
Slide 8
```











## Register Files, Continued Inputs: Two (multi-bit) register numbers saying which registers we want to "read" (use as input to some operation). One (multi-bit) register number saying which register we (might) want to "write" (change the value of). One (32-bit) value to (maybe) save in a register. A "yes do a write" bit. Outputs: Two (32-bit) values representing the contents of the two registers selected by the "read register" numbers used as input.









