

Text editor

openxxr

micro

VScode

Sublime text

Tool

Vivado

Quartus

FPGA

IEEE 1800:

VHDL 93

TH-181  $\Rightarrow$  bit sliceable ALU

ADD, SUB, XOR, AND





MATRIX  
DECODE → LE  
Matrix → LC



43      LE → Logic Element



$\frac{xc7}{\downarrow}$        $\frac{35t}{635 \text{ kcells}}$       CGP      238  
 - extension cell within      ↳ package tow  
 32 kLUT      SMD - 238 pin  
 Matrix 7      speed programming.

→ 100 MHz

Carry look ahead adder.

$\frac{n(n+1)}{2}$  AND, n OR gate

ALU - 1 bit

$a_{in} = \begin{bmatrix} + \\ - \end{bmatrix}$

$b_{in} = 1 \text{ or } 0$

carry-in

result-out

carry-out

1  
2  
3  
4

$a_{in} = 1011$

$b_{in} = 1101$

$c_{in} = 000$



Advantage

→ Less time

Disadvantage

→ Increase complexity

→ adds more gates to design

→ n-bits

$$\frac{n(n+1)}{2} \text{ AND}$$

n - OR

1 + 2 + 3 -

## Run Xstler

- ↳ avoid multidriver.
- ↳ no-connected nets
- ↳ latch after



↳ Run synthesis.

Constraint wizard

↳ before finish

view timing constraint

Create timing summary report

Timing constraint file

↳ Add source clk.xdc

write constraint file.

generates.

↳ Clock wizard.

clk

→ 200 MHz

→ select signals

→ initial condition.

Finish.

⇒ generate report ⇒ Timing report

use of race  $\Rightarrow$  optimize for ALU



LFFR - Linear feed forward register.

8.84



5A5A5A  
6x4



0101    1010     $\times 3$   
1-  
0-

~~x d<sub>2</sub> d<sub>2</sub> d<sub>2</sub>~~  
0 → 1



$I_b = 0$   
BJT  $\Rightarrow$  oscillate

$I_g = 0$   
MOSFET  $\Rightarrow$  stick to a state

(a) transitional rate  $\frac{Q_1 Q_2}{0 \rightarrow 1}$   
 $\Rightarrow$  floating NO internal PULLUP  
 PULL-DOWN } register gate  
 in FPGAs

MOSFET  $\Rightarrow$  can be used to implement  
 but, generates impulse response.  $\Rightarrow$

VHDL  $\Rightarrow$  state variable.  
 Verilog  $\Rightarrow$  4 state variable  $\Rightarrow$  that cannot account for  
 floating state in a BJT  
 $\hookrightarrow$  commercial design they use MOSFET so does not  
 have to account for.

Motability avoided by reguring o/p

BCD  $\Rightarrow$  7 segment

$$\begin{matrix} A \\ F \mid \frac{a}{D} \mid B \\ E \mid \frac{c}{D} \mid C \end{matrix}$$

|   | B <sub>3</sub> | B <sub>2</sub> | B <sub>1</sub> | B <sub>0</sub> | A | B | C | D | E | F | G |
|---|----------------|----------------|----------------|----------------|---|---|---|---|---|---|---|
| 0 | 0              | 0              | 0              | 0              | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 1 | 0              | 0              | 0              | 1              | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| 2 | 0              | 0              | 1              | 0              | 0 | 0 | 1 | 0 | 0 | 1 | 0 |
| 3 | 0              | 0              | 1              | 1              | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 4 | 0              | 1              | 0              | 0              | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 5 | 0              | 1              | 0              | 1              | 0 | 1 | 0 | 0 | 1 | 0 | 0 |
| 6 | 0              | 1              | 1              | 0              | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 7 | 0              | 1              | 1              | 1              | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 8 | 1              | 0              | 0              | 0              | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 9 | 1              | 0              | 0              | 1              | 0 | 0 | 0 | 1 | 1 | 0 | 0 |

Automata Theory -

- Non-probabilistic problem
- Probabilistic problem
- ↳ finite step.



$\frac{101}{\downarrow}$  RESET  $\rightarrow 1 \text{ DET\_1}$   
 $10 \text{ RESET}$



$\text{DET\_1} \rightarrow 0 \text{ DET\_10}$   
 $| \quad | \text{ DET\_1}$

$\text{DET\_10} \rightarrow 1 \text{ DONE}$   
 $10 \text{ RESET}$

-----  
 $\text{DONE} \rightarrow 1 \text{ DET\_1}$   
 $10 \text{ DET\_10}$

$d_{in} = 10110110111\dots$   
 $\downarrow \downarrow \downarrow \downarrow \downarrow$   
 $q_1 = 1101101$

$\begin{matrix} 0 & 0 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 & 0 \end{matrix}$   
 $10$



$d - 0 \xrightarrow{1} 1 \circ$   
 $q - \underline{011} \xrightarrow{0} \underline{10}$

$\begin{matrix} 00 \\ 01 \\ 10 \\ 11 \end{matrix}$

if ( $d_{in}$ )

$$q_{in} \sim q_{out}$$

else

$$q_{in} = q_{out}$$



$\text{RESET} \rightarrow 1 \text{ DONE } 1$   
 $10 \text{ RESET } 0$   
 $\text{DONE} \rightarrow 1 \text{ DONE } 0$   
 $10 \text{ RESET } 1$

odd is a even 'o's



Det-1 → 0      Det-0      0

| |      Det-11      0

Det-0 → |      Det-01      |

| 0      Det-00      |

RESET → |      DONE      ,      |  
           | 0      E1-00      ,      0

E1-00 → |      01-00      ,      0

| 0      RESET      ,      0

01-00 → |      E1-00      ,      0

| 0      DONE      ,      1

DONE → |      RESET      ,      0

| 0      odd1\_odd0      ,      0

|  
   ↓  
   0|

100  
 010  
 001



→ Odd & Even.

⇒ detect odd, even SV



TB ✓

→ ROM to store & release seq.

⇒ input.rom.SV



→ counter & display.

⇒ ~~test~~ counter.display.SV



06-11-2024  
Design Patterns in System Verilog HDL

- S. clean SRAM

- reset

aktion 7

↳ done by a RESET-synchronous  
of time period 100ms

↓  
Test Bench reset



2. clear SRAM

- reset

Section 7

↳ done by a RESET synchronous  
of time period 100ms



## Sequence detector odd 1's and even 01 toggles



seq - 010100110100001011100101110101  
 exp - 00000000001111001010000000  
 o/p - 00000000001111001010000000

Mute → Toggle

16ms

20ms

62.5 kHz

Volume UP → press & hold

$\frac{1}{20} \times 10^{-3}$

50Hz

Phy



↑ ↓ × MUTE

↑ + - ↓

MUTE



PS/2 → OS/2  
PS/2 → DB/2

accept info from synchronous system & display over 7-segment digit.

→ Vcc and  
5 - clk 1 - data

↓

shift - register & latch

Data-width → 11 bits.



gratizing frequ-





To 7-seg display.



→ store sequence in ROM

→ on run, fetch the sequence & detect segment.

```
for (i=0; i <= 3; i++)  
    rom mem[i] <- 0;
```



[15:0] ~~mem~~ ROM [3:0]  
~~[0:3]~~  
~~[0:3]~~

ptr = 0

→ load seq  
 -> n[0] ptr < B4  
 ROM [0] <-  
 ptr = +1  
 +1[0]

ARM → Bus ~ 1.  
Memory ~ 2.  
UVM ~ 3.  
→ Master, Slave, ...  
AXI, AXB, ...

Out of order  
done above coding  
UVM based  
coverage from  
bsm



```
if (sig[i]) begin
    mem[i] <= in-data;
end
```

mem[0]   
mem[i] 



### Read Master



13-11-2024

### Single clk pipeline



2

- ✓ works without metastability
- ✓ wider frequency range

## AMBA - AXI - A Lite

READY, VALID  $\Rightarrow$  Common for different modes.



High  $\rightarrow$  channel should have valid data

Handshake



- Variable width verification RAM, with AXI 4 subordinate



address Channel in AXI<sub>4</sub>

READ

WRITE  
Master  $\rightarrow$



Address Handshake

Data Handshake



$\rightarrow$  Implementation of overclocking. AMD alternatively

$\rightarrow$  single clk pipeline

$\rightarrow$  higher throughput at same clock frequency



~~IDLE~~

MUTE → mute MUTE  
↓ ~mute IDLE

| up VOL-UP MUTE → ~mute & mute clr IDLE  
| down MUTE

VOL-UP → ~up IDLE

| up VOL-UP

| up & Max IDLE



B



2Hz



\* Reporting (Vivado) :- Vivado generates report at every stage except Linting & Elaboration.



6 types of reporting. & 3 more:-  
 1) utilization - No. of reg, buf, nets and all other used components.  
 2) DRC :- If there exists any violations in designs.  
 3) Methodology :- parameters or how design was generated.

Floorplanning & IO planning.

TOP right ~~right~~ <sup>right</sup> SRAM.

X0Y1 ~~X0YD~~ <sup>right</sup> Y1 regions

\*\*\*\*\*

very good!!!

bitstream = from SRAM file to FPGA SRAM (Raw bin to Flash mem)

Mstream MCS = more reliable than raw bin.  
 memory calibration system.

## Low Power VLSI design

DFT, xv.log, xsim.

### Design constraint.

Timing analyser, FPGA analyser, simulator.

Method

① → out of control synthesis.

② → Block design.

### Design for testability

Scan flop



A B C D.

0 1 0 0

1 0 0 0

0 1 0 1

1 0 0 1

0 1 1 0

1 0 1 0

### Block Designer.

AKT BRAM controller

Block mem generator

Altera  
Lookahead

LE vs LUT

Xilinx

LUT → config time

memory

Bulk memory vs

Throughput vs

Latency

distributed vs area

DRAM, between region

high density

iCE40

small form  
small power

Jasper

ECP5

Small form  
High perf

Advantages

Pipelining

- Long Combinational
- Multi-cycle
- Failed / Trailing.



VGA → Sync  
Sync → Hsync



### Implementation in Barje 3

→ AXI4S to video out  
video timing controller

IDLE  $\text{txn\_ack} \Leftarrow 0$

TPGS → R, G, B

START  $\text{txn\_ack} \Leftarrow 1$  | →

if (data\_valid == 1)  
mem [addr] ← data

1 sec

$100 \times 10^6 \text{ Hz} \rightarrow 99.999.999$

4563

1011010011

0.0 sec

→ x30

12'b 1111 1111 1111

99.999.9999

d 4095 | 30 Sec  
↑ ↑  
0 0

6x4  
24

Sec

136.5

136.5  $\frac{+12}{\longrightarrow}$   
0  $\longleftarrow$  0

$$f(\Sigma, Q_1)$$



$$S_0 = f(IDLE, \text{ ask-order})$$

~~$$S_1 = f(ASK, GET-ORDER, \text{ in-token})$$~~

$$S_1 = f(GET-ORDER, \text{ in-token})$$

$$S_2 = f(ASK-TOKEN, \text{ dispense})$$

$$S_3 = f(MORE-TOKEN, \text{ dispense})$$

$$S_4 = f(DISPENSE, \text{ ack-order})$$



wait

parallel & full call.

disable

def param, # operators

full & parallel connection

race condition

deterministic non deterministic

PLI, VCD

ASMD chart.

switch level modeling

execute\_data (iteration T)

do write

do - read

exit - addr.



do\_write  
(TW. size)

WORD:



ERROR; detection

x AMBA

x I<sub>2</sub>C

Ethernet ✓

PCIe ✓

USB ✓

136KB/s

1Mb/s

I<sub>2</sub>C

J<sub>3</sub>C

SCK .

SDA -

Multi

754, →



I<sub>1</sub>

✓  
✗  
✗  
✓



## VGA - Video Graphic Array.

- Resolution  $\rightarrow$   $1080 \times 1920$  (Full HD)

- Frame Rate  $\rightarrow$  60 Hz

- Synchronization  $\rightarrow$  hsync



### □ Xilinx AXI4-Stream Video Out

- valid, ready, data

- start, ready, lstart

↓  
EOL

↓  
SOF

End of line

start of frame

### □ Video Timing Control

- hsync, vsync

## Clocking Wizard

- clk\_out1  $\rightarrow$  148.5

(remove rest, locked for simplicity)

## □ Video Timing Controller

### Detection / generation

- Cncheck AXI4-lite interface for test pattern
- Cncheck enable detection)

### Default / constant

- video mode 1080P

-- Connecting all blocks --

## □ Slice

Din width - 24

from - } depending on colour  
down to - }

Dout width - 4

## □ Video test pattern generator.

clk

reset\_n

data ready

data valid

[7:0] datax

sot

eot

