### Tahmini Ders İçeriği (Tentative Couse Schedule – Syllabus)



- 1. Hafta: Sayısal Sinyaller/Sistemler, İkilik Tabanda Sayılar, Taban Aritmetiği, İşaretli/Eksi Sayıların Gösterimi, Sayısal Tasarım Tarihçesi
- **2. Hafta:** İkili Mantık Aritmetiği ve Kapıları, Bool Cebiri Teorisi ve Tanımları, Bool Fonksiyonları, Kapı-Seviyesinde Yalınlaştırma, Karnough Haritası, Önemsenmeyen Durumlar, NAND, NOR, XOR
- 3-4. Hafta: FPGA, Birleşik (Combinational) Devreler, Aritmetik Modüller, Decoder, Encoder, Mux, Verilog HDL
- **5. Hafta:** Ardışık (Sequential) Devreler, Mandal (Latch), Flip-Flop, Yazmaçlar (Registers)

Lab Sınavı (265/264L)

- 6. Hafta: Durum Makinaları, Örnek Tasarımlar, Sayaçlar (Counters)
- 7. Hafta: FSM Örnekleri
- 8. Hafta: RTL (Register Transfer Level) ASMD (Algorithmic State Machine and Datapath) Tasarımları
- 9. Hafta: (7-11 Kasım) Durağan Zaman Analizi (Static Timing Analysis)

Ara Sınav (265/264) (15 Kasım)

- 10. Hafta: (14-18 Kasım) Bellekler, FPGA'da Block RAM, OpenRAM
- 11-12. Hafta: (21-25 Kasım, 28 Kasım 2 Aralık) Boru hattı, FPGA ve ASIC Tasarım Akışları

Final (Aralık) – Proje Teslimleri (18 Aralık)

# DURAĞAN ZAMAN ANALİZİ (STATIC TIMING ANALYSIS - STA)



**Durağan**: Devre sentezlendikten sonra, donanım üzerinde çalışmadan, durağanken, dinamik ya da elektronlar hareketli değilken yapılan bir analizdir

Zaman: Devrenin, istenilen saat frekansında doğru çalışıp çalışamayacağını inceler

Analiz: Bir analiz işlemidir, yani var olan bir netlist (sentez sonucu) içerisinde bulunan mantık hücrelerinin ve aralarındaki bağlantı yollarının gecikmelerini ve yine saat sinyali ile ilgili belirsizlikleri hesaba katan bir bilgisayar yazılımıdır

### **TANIMLAR**





FF1: Kaynak (Source) Flip-Flop

FF2: Hedef (Destination) Flip-Flop

**Combinational Delay**: Sinyalin birleşik (combinational) devre elemanlarında ilerlerken meydana gelen gecikme

Wire Delay (Routing Delay): Sinyalin bağlantı kablosu, yolu üzerinde ilerlerken meydana gelen gecikme

## BIR SINYALIN YOLCULUĞU











**Setup Time (Tsetup)**: Flip-Flop çıkış sinyalinin tutarlı olması için, Flip-Flop giriş sinyalinin (D1) saat sinyalinin yükselen kenarından <u>önce</u> beklemesi gereken süre.

**Hold Time (Thold)**: Flip-Flop çıkış sinyalinin tutarlı olması için, Flip-Flop giriş sinyalinin (D1) saat sinyalinin yükselen kenarından <u>sonra</u> beklemesi gereken süre.





## SETUP TIME ANALİZİ - MAX FREKANS FORMÜLÜ





Tperiod – Tsetup > Tcq + Tcomb

Tperiod > Tcq + Tcomb + Tsetup

Period (min) = Tcq + Tcomb + Tsetup

Frequency (max) = 1 / (Tcq + Tcomb + Tsetup)

Slack = Tperiod – (Tcq + Tcomb + Tsetup)

**Positive Slack** 

Negative Slack





### **HOLD TIME ANALIZI**



Tcq + Tcomb > Thold
if (Tcomb == 0) "Back to back 2 FF durumu"
Tcq > Thold

Slack = Tcq + Tcomb - Thold

Positive Slack

Negative Slack



### **METASTABILITY**





Signal transition occurs after clock edge and minimum t<sub>H</sub>: Ball lands on the old data side. Signal transition meets register t<sub>SU</sub> and t<sub>H</sub>: Ball lands on the new data side. Signal violates register t<sub>SU</sub> or t<sub>H</sub>:
Ball balances at top of hill or takes too long to reach the bottom. Output is metastable and violates t<sub>CO</sub>.



### **VIVADO PERIYOT KISITI**

Tperiod – Tsetup > Tcq + Tcomb

Tperiod > Tcq + Tcomb + Tsetup

Period (min) = Tcq + Tcomb + Tsetup

Frequency (max) = 1 / (Tcq + Tcomb + Tsetup)

Slack = Tperiod – (Tcq + Tcomb + Tsetup)

Positive Slack



create\_clock -name devclk -period 10 [get\_ports clk]











#### create\_clock -period 10.000 -waveform {0.000 5.000} [get\_ports clk]



| tup                          |          | Hold                         |          | Pulse Width                              |          |
|------------------------------|----------|------------------------------|----------|------------------------------------------|----------|
| Worst Negative Slack (WNS):  | 3.075 ns | Worst Hold Slack (WHS):      | 0.146 ns | Worst Pulse Width Slack (WPWS):          | 4.500 ns |
| Total Negative Slack (TNS):  | 0.000 ns | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |
| Number of Failing Endpoints: | 0        | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |
| Total Number of Endpoints:   | 50       | Total Number of Endpoints:   | 50       | Total Number of Endpoints:               | 48       |





| Summary         |                                                                                                                       |
|-----------------|-----------------------------------------------------------------------------------------------------------------------|
| Name            | → Path 1                                                                                                              |
| Slack           | <u>3.075ns</u>                                                                                                        |
| Source          | olcum_buffer_reg[1][2]/C (rising edge-triggered cell FDCE clocked by clk {rise@0.000ns fall@5.000ns period=10.000ns}) |
| Destination     | ▶ fren_reg/D (rising edge-triggered cell FDCE clocked by clk {rise@0.000ns fall@5.000ns period=10.000ns})             |
| Path Group      | clk                                                                                                                   |
| Path Type       | Setup (Max at Slow Process Corner)                                                                                    |
| Requirement     | 10.000ns (clk rise@10.000ns - clk rise@0.000ns)                                                                       |
| Data Path Delay | 6.774ns (logic 2.974ns (43.903%) route 3.800ns (56.097%))                                                             |
| Logic Levels    | 9 (CARRY4=3 LUT3=1 LUT4=3 LUT5=1 LUT6=1)                                                                              |
| Clock Path Skew | <u>-0.145ns</u>                                                                                                       |
| Clock Utainty   | <u>0.035ns</u>                                                                                                        |

| Source Clock Path     |           |           |        |       |                                       |               |                           |           |       | TODD ETT                                    |
|-----------------------|-----------|-----------|--------|-------|---------------------------------------|---------------|---------------------------|-----------|-------|---------------------------------------------|
| Delay Type            | Incr (ns) | Path (ns) | Locati | ion N | etlist Resource(s)                    |               |                           |           |       | TOBB ETU  Ekonomi ve Teknoloji Üniversitesi |
| (clock clk rise edge) | (r) 0.000 | 0.000     |        |       |                                       |               |                           |           |       | Elenent is remotel, universities            |
|                       | (r) 0.000 | 0.000     |        |       | clk                                   |               |                           |           |       |                                             |
| net (fo=0)            | 0.000     | 0.000     |        | 1     | ¹ clk                                 |               |                           |           |       |                                             |
|                       |           |           |        |       | clk_IBUF_inst/I                       |               |                           |           |       |                                             |
| IBUF (Prop ibuf I O)  | (r) 0.923 | 0.923     |        | -     | clk_IBUF_inst/O                       | CARE          | XY4 (Prop c4 S[0] CO[3])  | (r) 0.532 | 6.089 | <pre>olcum_buffer_reg[0][5]_i_1/CO[3]</pre> |
| net (fo=1, unplaced)  | 0.800     | 1.722     |        | 7     | ' clk_IBUF                            | net (f        | o=1, unplaced)            | 0.000     | 6.089 | → olcum_buffer_reg[0][5]_i_1_n_0            |
|                       |           |           |        |       | clk_IBUF_BUFG_inst/I                  |               |                           |           |       | olcum_buffer_reg[0][7]_i_1/Cl               |
| BUFG (Prop bufg I O)  | (r) 0.096 | 1.818     |        |       | clk_IBUF_BUFG_inst/O                  | CARE          | XY4 (Prop carry4 Cl O[0]) | (f) 0.235 | 6.324 | <pre>olcum_buffer_reg[0][7]_i_1/O[0]</pre>  |
| net (fo=47, unplaced) | 0.584     |           |        |       | clk_IBUF_BUFG                         | net (f        | o=3, unplaced)            | 0.488     | 6.812 | → gaz3[8]                                   |
| FDCE                  | 0.501     | 2.102     |        |       | olcum_buffer_reg[1][2]/C              |               |                           |           |       | gaz_i_6/l1                                  |
| Data Path             |           |           |        |       | olcum_buner_reg[1][2]/C               | – <u>LUT4</u> | (Prop lut4 I1 O)          | (r) 0.320 | 7.132 | gaz_i_6/O                                   |
| Delay Type            |           | Incr (ns) | Path   | Loca  | Netlist Resource(s)                   | net (f        | o=1, unplaced)            | 0.000     | 7.132 | → gaz_i_6_n_0                               |
| FDCE (Prop fdce C Q)  |           | (r) 0.456 | 2.858  |       | ■ olcum_buffer_reg[1][2]/Q            |               |                           |           |       | gaz_reg_i_3/DI[3]                           |
| net (fo=3, unplaced)  |           | 0.824     | 3.682  |       | ✓ olcum_buffer_reg[1][2]              | CARE          | XY4 (Prop c4 DI[3] CO[3]) | (r) 0.411 | 7.543 | <pre>gaz_reg_i_3/CO[3]</pre>                |
| net (10=5, unplaced)  |           | 0.024     | 3.002  |       | _                                     | net (f        | o=3, unplaced)            | 0.936     | 8.479 | → gaz1                                      |
| 11175 (9 1 15 10 0)   |           | () 0 222  | 4.005  |       | olcum_buffer[0][5]_i_17/l0            |               |                           |           |       | ▶ fren_i_2/l3                               |
| LUT5 (Prop lut5 I0 O) |           | (r) 0.323 | 4.005  |       | d olcum_buffer[0][5]_i_17/O           | LUT6          | (Prop lut6 I3 O)          | (r) 0.124 | 8.603 | fren_i_2/O                                  |
| net (fo=2, unplaced)  |           | 0.460     | 4.465  |       | → olcum_buffer[0][5]_i_17_n_0         | net (f        | o=1, unplaced)            | 0.449     | 9.052 | → fren_i_2_n_0                              |
|                       |           |           |        |       |                                       |               |                           |           |       | ▶ fren_i_1/l1                               |
| LUT3 (Prop lut3 I2 O) |           | (r) 0.117 | 4.582  |       | <pre>d olcum_buffer[0][5]_i_5/O</pre> | LUT4          | (Prop lut4 I1 O)          | (r) 0.124 | 9.176 | fren_i_1/O                                  |
| net (fo=2, unplaced)  |           | 0.643     | 5.225  |       | → olcum_buffer[0][5]_i_5_n_0          | net (f        | o=1, unplaced)            | 0.000     | 9.176 | → fren1_out                                 |
|                       |           |           |        |       | olcum_buffer[0][5]_i_9/l3             | FDCE          |                           |           |       | fren_reg/D                                  |
| LUT4 (Prop lut4 I3 O) |           | (r) 0.332 | 5.557  |       | d olcum_buffer[0][5]_i_9/O            | Arriv         | ral Time                  |           | 9.176 |                                             |
| net (fo=1, unplaced)  |           | 0.000     | 5.557  |       | → olcum_buffer[0][5]_i_9_n_0          |               |                           |           |       |                                             |
|                       |           |           |        |       | olcum_buffer_reg[0][5]_i_1/S          | [0]           |                           |           |       |                                             |



| Destination Clock Path |            |        |      |                      |
|------------------------|------------|--------|------|----------------------|
| Delay Type             | Incr (ns)  | Path ( | Loca | Netlist Resource(s)  |
| (clock clk rise edge)  | (r) 10.000 | 10.000 |      |                      |
|                        | (r) 0.000  | 10.000 |      |                      |
| net (fo=0)             | 0.000      | 10.000 |      | ∠ clk                |
|                        |            |        |      | clk_IBUF_inst/I      |
| IBUF (Prop ibuf I O)   | (r) 0.789  | 10.789 |      | clk_IBUF_inst/O      |
| net (fo=1, unplaced)   | 0.760      | 11.549 |      | ∠ clk_IBUF           |
|                        |            |        |      | clk_IBUF_BUFG_inst/I |
| BUFG (Prop bufg I O)   | (r) 0.091  | 11.640 |      | clk_IBUF_BUFG_inst/O |
| net (fo=47, unplaced)  | 0.439      | 12.079 |      | ∠ clk_IBUF_BUFG      |
| FDCE                   |            |        |      |                      |
| clock pessimism        | 0.178      | 12.257 |      |                      |
| clock uncertainty      | -0.035     | 12.222 |      |                      |
| FDCE (Setup fdce C D)  | 0.029      | 12.251 |      | fren_reg             |
| Required Time          |            | 12.251 |      |                      |

#### create\_clock -period 5.000 -waveform {0.000 2.500} [get\_ports clk]



#### **Design Timing Summary**

| Setup                          | H        | lold                         |          | Pulse Width                                    |    |
|--------------------------------|----------|------------------------------|----------|------------------------------------------------|----|
| Worst Negative Slack (WNS): -  | 1.569 ns | Worst Hold Slack (WHS):      | 0.146 ns | Worst Pulse Width Slack (WPWS): 2.000          | ns |
| Total Negative Slack (TNS): -  | 3.562 ns | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): 0.000 | ns |
| Number of Failing Endpoints: 3 | 3        | Number of Failing Endpoints: | 0        | Number of Failing Endpoints: 0                 |    |
| Total Number of Endpoints: 5   | 50       | Total Number of Endpoints:   | 50       | Total Number of Endpoints: 48                  |    |

Timing constraints are not met.





| Summary         |                                                                                                                      |
|-----------------|----------------------------------------------------------------------------------------------------------------------|
| Name            | ₽ Path 1                                                                                                             |
| Slack           | <u>-1.569ns</u>                                                                                                      |
| Source          | olcum_buffer_reg[1][3]/C (rising edge-triggered cell FDCE clocked by clk {rise@0.000ns fall@2.500ns period=5.000ns}) |
| Destination     | ▶ fren_reg/D (rising edge-triggered cell FDCE clocked by clk {rise@0.000ns fall@2.500ns period=5.000ns})             |
| Path Group      | clk                                                                                                                  |
| Path Type       | Setup (Max at Slow Process Corner)                                                                                   |
| Requirement     | 5.000ns (clk rise@5.000ns - clk rise@0.000ns)                                                                        |
| Data Path Delay | 6.418ns (logic 2.467ns (38.439%) route 3.951ns (61.561%))                                                            |
| Logic Levels    | 7 (CARRY4=2 LUT3=1 LUT4=2 LUT5=1 LUT6=1)                                                                             |
| Clock Path Skew | <u>-0.145ns</u>                                                                                                      |
| Clock Utainty   | <u>0.035ns</u>                                                                                                       |

| ~ | Source Clock Path     |             |           |         |          |                            |         |                              |           |       | TODD PALL                         |
|---|-----------------------|-------------|-----------|---------|----------|----------------------------|---------|------------------------------|-----------|-------|-----------------------------------|
| Ц | Delay Type            | Incr (ns)   | Path (ns) | Locatio | n Ne     | tlist Resource(s)          |         |                              |           |       | TOBB ETÜ                          |
|   | (clock clk rise edge) | (r) 0.000   | 0.000     |         |          |                            |         |                              |           |       | Ekonomi ve Teknoloji Üniversitesi |
|   |                       | (r) 0.000   | 0.000     |         | ₽        | clk                        |         |                              |           |       |                                   |
|   | net (fo=0)            | 0.000       | 0.000     |         | 7        | clk                        |         |                              |           |       |                                   |
|   |                       |             |           |         | <b></b>  | clk_IBUF_inst/I            |         | LITA (Prop. lut4 12 O)       | (r) 0.303 | 6.760 | <b>■</b> goz i 7/0                |
|   | IBUF (Prop ibuf I O)  | (r) 0.923   | 0.923     |         |          | clk_IBUF_inst/O            |         | LUT4 (Prop lut4 I2 O)        |           |       | ■ gaz_i_7/O                       |
|   | net (fo=1, unplaced)  | 0.800       | 1.722     |         | 7        | clk_IBUF                   |         | net (fo=1, unplaced)         | 0.000     | 6.760 | ✓ gaz_i_7_n_0                     |
|   |                       |             |           |         | <b>D</b> | clk_IBUF_BUFG_inst/I       |         | CARRYA (R A RICO) CO(O)      | (1) 0 427 | 7.407 | gaz_reg_i_3/DI[2]                 |
|   | BUFG (Prop bufg I O)  | (r) 0.096   | 1.818     |         |          | clk_IBUF_BUFG_inst/O       |         | CARRY4 (Prop c4 DI[2] CO[3]) | (r) 0.427 | 7.187 | gaz_reg_i_3/CO[3]                 |
|   | net (fo=47, unplaced) | 0.584       | 2.402     |         | 7        | clk_IBUF_BUFG              |         | net (fo=3, unplaced)         | 0.936     | 8.123 | ∕ gaz1                            |
|   | FDCE                  |             |           |         | <b>D</b> | olcum_buffer_reg[1][3]/C   |         |                              |           |       | ▶ fren_i_2/I3                     |
| V | Data Path             |             |           |         |          |                            |         | LUT6 (Prop lut6 I3 O)        | (r) 0.124 | 8.247 | fren_i_2/O                        |
| Ц | Delay Type            |             | Incr (ns) | Path    | Loca     | Netlist Resource(s)        |         | net (fo=1, unplaced)         | 0.449     | 8.696 | → fren_i_2_n_0                    |
|   | FDCE (Prop fdce C Q)  |             | (r) 0.456 | 2.858   |          | d olcum_buffer_reg[1][3]/0 | Q       |                              |           |       | fren_i_1/l1                       |
|   | net (fo=3, unplaced)  |             | 0.824     | 3.682   |          | → olcum_buffer_reg[1][3]   |         | LUT4 (Prop lut4 I1 O)        | (r) 0.124 | 8.820 | fren_i_1/O                        |
|   |                       |             |           |         |          | olcum_buffer[0][5]_i_15/   | 10      | net (fo=1, unplaced)         | 0.000     | 8.820 | → fren1_out                       |
|   | LUT5 (Prop lut5 I0 O) |             | (r) 0.295 | 3.977   |          | d olcum_buffer[0][5]_i_15/ | O       | FDCE                         |           |       | fren_reg/D                        |
|   | net (fo=3, unplaced)  |             | 0.467     | 4.444   |          | → olcum_buffer[0][5]_i_15_ | n_0     | Arrival Time                 |           | 8.820 |                                   |
|   |                       |             |           |         |          |                            | 2       |                              |           |       |                                   |
|   | LUT3 (Prop lut3 I2 O) |             | (r) 0.124 | 4.568   |          | d olcum_buffer[0][5]_i_4/0 | )       |                              |           |       |                                   |
|   | net (fo=1, unplaced)  |             | 0.639     | 5.207   |          | → olcum_buffer[0][5]_i_4_n | _0      |                              |           |       |                                   |
|   |                       |             |           |         |          | olcum_buffer_reg[0][5]_i   | _1/DI[1 | ]                            |           |       |                                   |
|   | CARRY4 (Prop carry4 D | DI[1] O[3]) | (f) 0.614 | 5.821   |          | d olcum_buffer_reg[0][5]_i | _1/0[3] |                              |           |       |                                   |
|   | net (fo=3, unplaced)  |             | 0.636     | 6.457   |          | ∠ gaz3[7]                  |         |                              |           |       |                                   |
|   |                       |             |           |         |          | gaz_i_7/I2                 |         |                              |           |       |                                   |



| <b>Destination Clock Path</b> |           |       |      | ,                    |
|-------------------------------|-----------|-------|------|----------------------|
| Delay Type                    | Incr (ns) | Path  | Loca | Netlist Resource(s)  |
| (clock clk rise edge)         | (r) 5.000 | 5.000 |      |                      |
|                               | (r) 0.000 | 5.000 |      |                      |
| net (fo=0)                    | 0.000     | 5.000 |      | ∠ clk                |
|                               |           |       |      | clk_IBUF_inst/I      |
| IBUF (Prop ibuf I O)          | (r) 0.789 | 5.789 |      | clk_IBUF_inst/O      |
| net (fo=1, unplaced)          | 0.760     | 6.549 |      | ∠ clk_IBUF           |
|                               |           |       |      | clk_IBUF_BUFG_inst/I |
| BUFG (Prop bufg I O)          | (r) 0.091 | 6.640 |      | clk_IBUF_BUFG_inst/O |
| net (fo=47, unplaced)         | 0.439     | 7.079 |      | ∠ clk_IBUF_BUFG      |
| FDCE                          |           |       |      | fren_reg/C           |
| clock pessimism               | 0.178     | 7.257 |      |                      |
| clock uncertainty             | -0.035    | 7.222 |      |                      |
| FDCE (Setup fdce C D)         | 0.029     | 7.251 |      | fren_reg             |
| Required Time                 |           | 7.251 |      |                      |