## wat: hardware edition

Emil J / widlarizer

## TCL



```
1 emil@blahaj ~> tclsh
2 % set x 1
3 1
4 % set x $x+1
```

```
1 emil@blahaj ~> tclsh
2 % set x 1
3 1
4 % set x $x+1
5 1+1
```

```
1 emil@blahaj ~> tclsh
2 % set x 1
3 1
4 % incr x
5 2
```

TCL

... there is no syntax, or it's so simple you have to do everything outside the syntax.

#### - Guido van Rossum, 1999

It was designed to be a "scripting language", on the assumption that a "scripting language" need not try to be a real programming language. ... It lacks arrays; ... It fakes having numbers, which works, but has to be slow.

#### - GNU Jesus, 1994

There are people at the office who have been dealing with this crap for 20 years and still can't tell me off the top of their head the order of parameters to basic functionality functions.

- some guy on orange site

\_1\_ and \_2\_ compute different values. Credit: @whitequark

```
1 module top(a, b, c);
2 input a;
3 input [2:0] b;
4 input [3:0] c;
5 wire [3:0] _0_;
6 wire [3:0] _1_;
7 wire [3:0] _2_;
8 assign _0_ = + $signed(b);
9 assign _1_ = a ? _0_ : c;
10 assign _2_ = a ? (+ $signed(b)) : c;
11 endmodule
```

+m Unary plus m (same as m)

#### IEEE 1364 Verilog HDL

For the arithmetic operators, if any operand bit value is the unknown value x or the high-impedance value z, then the entire result value shall be x.



#### Table 17-5—Mnemonics for strength levels

| Mnemonic | Strength name    | Strength level |
|----------|------------------|----------------|
| Su       | Supply drive     | 7              |
| St       | Strong drive     | 6              |
| Pu       | Pull drive       | 5              |
| La       | Large capacitor  | 4              |
| We       | Weak drive       | 3              |
| Me       | Medium capacitor | 2              |
| Sm       | Small capacitor  | 1              |
|          |                  |                |



#### wire vs reg

???

- one (1) good parser
- others so bad they literally crash your GUI
- "safe subset"
- IR?!
- every sufficiently complex HW design contains a verilog codegen
- non-synthesizable Verilog



Figure 3: Xilinx Vivado, 3k USD



Dadibom 09/12/2021 wtf why doesnt undo work in modelsim i press ctrl+z to undo something and it deletes the entire contents of the file and i cant redo

Figure 4: Modelsim





Figure 5: warnings

set\_property src\_info {type:SCOPED\_XDC file:87 line:13 export:INPL set\_property src\_info {type:SCOPED\_XDC file:87 line:14 export:INPU set\_property src\_info {type:SCOPED\_XDC file:87 line:15 export:INPU set\_property src\_info {type:SCOPED\_XDC file:87 line:16 export:INPL set\_property src\_info {type:SCOPED\_XDC file:87 line:17 export:INPL set\_property src\_info {type:SCOPED\_XDC file:87 line:18 export:INPU set\_property src\_info {type:SCOPED\_XDC file:87 line:19 export:INPL set\_property src\_info {type:SCOPED\_XDC file:87 line:20 export:INPL set\_property src\_info {type:SCOPED\_XDC file:87 line:21 export:INPL set\_property src\_info {type:SCOPED\_XDC file:87 line:22 export:INPU set property src info {type:SCOPED XDC file:87 line:23 export:INP

Figure 6: codegen wat

### Hardware

#### You want to see side effects? I'll show you side effects



#### Figure 8: AWS F1



### Hardware

## Hardware



Figure 9: Ring oscillator

### Hardware

When the response to a test vector is captured by state elements in scan based tests, the switching activity of the circuit may be large resulting in abnormal power dissipation and supply current demand.

- 10.1109/TEST.2006.297694



## Hardware bugs

#### Always read the errata.

I2C: In master receive mode, data remains latched in data register until new data is received.

Workaround: When slave is configured to transmit data on an irregular basis, it should not sent 2 consecutive bytes with the same data

 STM SPC582Bz automotive qualified certified microcontroller errata

...how do I submit a pull request against a piece of melted sand?

## Hardware bugs



### What now?

- better languages! Clash, Chisel, Amaranth
- tooling? Yosys, simulators, place-and-route, ASIC fab stuff, formal verification
- industry-standard isn't all there is
- hardware can be fun
- small world with tough problems