1) [15 PUAN] Aşağıdaki boşlukları uygun şekilde doldurun.

3'lük tabanda işlem yaparken 0,1,2,3 rakamları kullanılabilir.

2'lik tabanda verilen 1010001110101010111110001 sayısı 8'lik tabanda 50725361 olarak ifade edilir.

2'lik tabanda verilen 1010001110101010111110001 sayısı 16'lık tabanda A3AFF1 olarak ifade edilir.

6'lık tabanda verilen 135.13 sayısı 10'luk tabanda \_\_\_\_\_\_ olarak ifade edilir.

İşaretli 2'ye tümleyen (2's complement) metodunda 1100101011 sayısı 10'luk tabanda -203 olarak ifade edilir.

2) [20 PUAN] Aşağıda C dilinde verilen kodu RISC-V assembly dilinde yazınız.

```
int a,b,c,d,e;
a = 7; b = 4; c = 6; d = 3;
if ((a-b) == (c-d))
    e = (a-b) + (c-d);
else
    e = (a+b) - (c+d);
CEVAP:

addi a0, zero, 7 #a
    addi a1, zero, 4 #b
    addi a2, zero, 6 #c
    addi a3, zero, 3 #d
    addi a4, zero, 0 #e

sub t0, a0, a1 # t0 = a0 - a1
    sub t1, a2, a3 # t1 = a2 - a3

bne t0, t1, _else # if t0 != t1 then _else
```

add a4, t0, t1 # a4 = t0 + t1

j exit # jump to exit:

```
sub a4, t0, t1 # a4 = t0 - t1

_exit:

_stop:
j _stop # jump to _stop
```

NOT: a,b,c,d,e değişkenleri sırasıyla a0,a1,a2,a3,a4 registerlarında tutulacaktır. RISCV instructionları yazarken registerları a0 ya da karşılığı olan x10 şeklinde istediğiniz gibi yazabilirsiniz. RISCV register tablosu ve RV32I instruction listesi aşağıda verilmiştir:

| 31 | 0            |                                 |                                                                                                                                                                                                                                      |                                                               |
|----|--------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
|    | x0 / zero    | Hardwired zero                  |                                                                                                                                                                                                                                      |                                                               |
|    | x1 / ra      | Return address                  |                                                                                                                                                                                                                                      |                                                               |
|    | x2 / sp      | Stack pointer                   | RV32                                                                                                                                                                                                                                 | I                                                             |
|    | x3 / gp      | Global pointer                  | Integer Computation                                                                                                                                                                                                                  | Loads and Stores                                              |
|    | x4 / tp      | Thread pointer                  |                                                                                                                                                                                                                                      |                                                               |
|    | x5 / t0      | Temporary                       | <u>add</u> {immediate}                                                                                                                                                                                                               | Load (byte                                                    |
|    | x6 / t1      | Temporary                       | subtract                                                                                                                                                                                                                             | 1 gad halfword word                                           |
|    | x7 / t2      | Temporary                       | <u>sub</u> tract                                                                                                                                                                                                                     | <u>word</u>                                                   |
| ,  | x8 / s0 / fp | Saved register, frame pointer   | (and                                                                                                                                                                                                                                 |                                                               |
|    | x9 / s1      | Saved register                  | or - immediate                                                                                                                                                                                                                       | 1oad {byte \hat{\munsigned} unsigned                          |
|    | x10 / a0     | Function argument, return value | $ \begin{cases} \underline{\underline{and}} \\ \underline{\underline{or}} \\ \underline{\underline{ex}} \text{clusive } \underline{\underline{or}} \end{cases} \begin{cases} \underline{\underline{i}} \text{mmediate} \end{cases} $ | <u>h</u> alfword                                              |
|    | x11 / a1     | Function argument, return value | (- —)                                                                                                                                                                                                                                |                                                               |
|    | x12 / a2     | Function argument               | shift 1eft 1ogical                                                                                                                                                                                                                   | Miscellaneous instructions                                    |
|    | x13 / a3     | Function argument               | shift right arithmetic immediate                                                                                                                                                                                                     | fence loads & stores                                          |
|    | x14 / a4     | Function argument               | shift right logical                                                                                                                                                                                                                  | fence.instruction & data                                      |
|    | x15 / a5     | Function argument               | load upper immediate                                                                                                                                                                                                                 |                                                               |
|    | x16 / a6     | Function argument               | add upper immediate to pc                                                                                                                                                                                                            | environment $\left\{\frac{\text{break}}{\text{call}}\right\}$ |
|    | x17 / a7     | Function argument               |                                                                                                                                                                                                                                      | _ ( <u>call</u> )                                             |
|    | x18 / s2     | Saved register                  | <u>set less than</u> { _immediate } { _unsign                                                                                                                                                                                        | ( <u>read &amp; clear bit</u> )                               |
|    | x19 / s3     | Saved register                  | (immediate) (unsign                                                                                                                                                                                                                  | ned control status register read & set bit immediate          |
|    | x20 / s4     | Saved register                  | Control transfer                                                                                                                                                                                                                     | read & write                                                  |
|    | x21 / s5     | Saved register                  | <u>b</u> ranch { <u>eq</u> ual }<br><u>n</u> ot <u>e</u> qual }                                                                                                                                                                      |                                                               |
|    | x22 / s6     | Saved register                  |                                                                                                                                                                                                                                      |                                                               |
|    | x23 / s7     | Saved register                  | <u>branch</u> {greater than or <u>equal</u> {_unsi                                                                                                                                                                                   | }                                                             |
|    | x24 / s8     | Saved register                  | less than unsi                                                                                                                                                                                                                       | gned∫                                                         |
|    | x25 / s9     | Saved register                  |                                                                                                                                                                                                                                      |                                                               |
|    | x26 / s10    | Saved register                  | $\underline{\mathbf{j}}$ ump $\underline{\mathbf{a}}$ nd $\underline{\mathbf{l}}$ ink $\left\{ \underline{\mathbf{r}}$ egister $\right\}$                                                                                            |                                                               |
|    | x27 / s11    | Saved register                  | (20910101)                                                                                                                                                                                                                           |                                                               |
|    | x28 / t3     | Temporary                       |                                                                                                                                                                                                                                      |                                                               |
|    | x29 / t4     | Temporary                       |                                                                                                                                                                                                                                      |                                                               |
|    | x30 / t5     | Temporary                       |                                                                                                                                                                                                                                      |                                                               |
|    | x31 / t6     | Temporary                       |                                                                                                                                                                                                                                      |                                                               |
|    | 22           |                                 |                                                                                                                                                                                                                                      |                                                               |

| 31                                               | 25 24     | 20  | 19  | 15 | 14  | 12 | 11      | 7       | 6         | 0        |
|--------------------------------------------------|-----------|-----|-----|----|-----|----|---------|---------|-----------|----------|
| imm[31:12]                                       |           |     |     |    |     | rd |         | 011011  |           |          |
| imm[31:12]                                       |           |     |     |    | rd  |    | 001011  | 1 U aui |           |          |
| imm[20 10:1 11 19:12]                            |           |     |     |    | rd  |    | 110111  | 1 J jal |           |          |
| im                                               | imm[11:0] |     | rs1 |    | 000 | rd |         | 1100111 | 1 I jalr  |          |
| imm[12 10:                                       | :5]       | rs2 | rsl | l  | 00  | 0  | imm[4:1 | [11]    | 110001    | 1 B beq  |
| imm[12 10:                                       | :5]       | rs2 | rs1 | L  | 00  | 1  | imm[4:1 | [11]    | 110001    | 1 B bne  |
| imm[12 10:                                       |           | rs2 | rsl | l  | 10  | 0  | imm[4:1 |         | 110001    | 1 B blt  |
| imm[12 10:                                       | :5]       | rs2 | rsl | l  | 10  | 1  | imm[4:1 | [11]    | 110001    | 1 B bge  |
| imm[12 10:                                       | :5]       | rs2 | rsl | l  | 11  | 0  | imm[4:1 | [11]    | 110001    | 1 B bltu |
| imm[12 10:                                       | :5]       | rs2 | rsl | l  | 11  | 1  | imm[4:1 | [11]    | 110001    | 1 B bge  |
| imm[11:0]<br>imm[11:0]<br>imm[11:0]<br>imm[11:0] |           | rsl |     | 00 | 0   | rd |         | 000001  | 1 I lb    |          |
|                                                  |           | rsl | l   | 00 | 1   | rd |         | 000001  | 1 I lh    |          |
|                                                  |           | rsl | l   | 01 | 0   | rd |         | 000001  | 1 I lw    |          |
|                                                  |           | rsl | l   | 10 | 0   | rd |         | 000001  | 1 I lbu   |          |
| im                                               | m[11:0]   |     | rsl | l  | 10  | 1  | rd      |         | 000001    | 1 I lhu  |
| imm[11:5                                         | ]         | rs2 | rsl | l  | 00  | 0  | imm[4   | :0]     | 010001    | 1 S sb   |
| imm[11:5                                         | ]         | rs2 | rs1 | l  | 00  | 1  | imm[4   | :0]     | 010001    | 1 S sh   |
| imm[11:5                                         | ]         | rs2 | rsl |    | 01  | 0  | imm[4   | :0]     | 010001    | 1 S sw   |
| imm[11:0]<br>imm[11:0]                           |           | rsl | l   | 00 | 0   | rd |         | 001001  | 1 I addi  |          |
|                                                  |           | rsl | l   | 01 | 0   | rd |         | 001001  | 1 I slti  |          |
| imm[11:0]                                        |           | rsl | l   | 01 | 1   | rd |         | 001001  | 1 I sltiu |          |
| imm[11:0]<br>imm[11:0]                           |           | rsl | l   | 10 | 0   | rd |         | 001001  | 1 I xori  |          |
|                                                  |           |     | rsl | l  | 11  | 0  | rd      |         | 001001    | 1 I ori  |
| imm[11:0]                                        |           |     | rs1 | l  | 11  | 1  | rd      |         | 001001    | 1 I andi |

| 0000000 shamt                                                                                                                                                                                    |             | rs1   | 001                                                          | rd                                                   | 0010011                                               | I slli                                                                    |                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------|--------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| 0000000 shamt                                                                                                                                                                                    |             | shamt | rsl                                                          | 101                                                  | rd                                                    | 0010011                                                                   | I srli                                                                                 |
| 0100000                                                                                                                                                                                          |             | shamt | rs1                                                          | 101                                                  | rd                                                    | 0010011                                                                   | I srai                                                                                 |
| 0000000                                                                                                                                                                                          |             | rs2   | rs1                                                          | 000                                                  | rd                                                    | 0110011                                                                   | R add                                                                                  |
| 010000                                                                                                                                                                                           | 0100000 rs2 |       | rs1                                                          | 000                                                  | rd                                                    | 0110011                                                                   | R sub                                                                                  |
| 000000                                                                                                                                                                                           | 0000000     |       | rs1                                                          | 001                                                  | rd                                                    | 0110011                                                                   | R sll                                                                                  |
| 000000                                                                                                                                                                                           | 0000000 r   |       | rs1                                                          | 010                                                  | rd                                                    | 0110011                                                                   | R slt                                                                                  |
| 0000000                                                                                                                                                                                          |             | rs2   | rs1                                                          | 011                                                  | rd                                                    | 0110011                                                                   | R sltu                                                                                 |
| 0000000                                                                                                                                                                                          |             | rs2   | rs1                                                          | 100                                                  | rd                                                    | 0110011                                                                   | R xor                                                                                  |
| 0000000                                                                                                                                                                                          |             | rs2   | rs1                                                          | 101                                                  | rd                                                    | 0110011                                                                   | R srl                                                                                  |
| 010000                                                                                                                                                                                           | 0100000 rs2 |       | rs1                                                          | 101                                                  | rd                                                    | 0110011                                                                   | R sra                                                                                  |
| 000000                                                                                                                                                                                           | 0000000 rs2 |       | rs1                                                          | 110                                                  | rd                                                    | 0110011                                                                   | R or                                                                                   |
| 000000                                                                                                                                                                                           | 0000000 rs2 |       | rs1                                                          | 111                                                  | rd                                                    | 0110011                                                                   | R and                                                                                  |
| 0000                                                                                                                                                                                             | pred        | succ  | 00000                                                        | 000                                                  | 00000                                                 | 0001111                                                                   | I fence                                                                                |
| 0000                                                                                                                                                                                             | 0000        | 0000  | 00000                                                        | 001                                                  | 00000                                                 | 0001111                                                                   | I fence.i                                                                              |
| 00000000000                                                                                                                                                                                      |             |       | 00000                                                        | 000                                                  | 00000                                                 | 1110011                                                                   | I ecall                                                                                |
| 00000000001                                                                                                                                                                                      |             |       | 00000                                                        | 000                                                  | 00000                                                 | 1110011                                                                   | I ebreak                                                                               |
|                                                                                                                                                                                                  | csr         |       | rs1                                                          | 001                                                  | rd                                                    | 1110011                                                                   | I csrrw                                                                                |
|                                                                                                                                                                                                  | csr         |       | rs1                                                          | 010                                                  | rd                                                    | 1110011                                                                   | I csrrs                                                                                |
|                                                                                                                                                                                                  | csr         |       | rs1                                                          | 011                                                  | rd                                                    | 1110011                                                                   | I csrrc                                                                                |
|                                                                                                                                                                                                  | csr         |       | zimm                                                         | 101                                                  | rd                                                    | 1110011                                                                   | I csrrwi                                                                               |
|                                                                                                                                                                                                  | csr         |       | zimm                                                         | 110                                                  | rd                                                    | 1110011                                                                   | I csrrsi                                                                               |
|                                                                                                                                                                                                  | csr         |       | zimm                                                         | 111                                                  | rd                                                    | 1110011                                                                   | I csrrci                                                                               |
| 0000         pred         succ           0000         0000         0000           000000000000         00000000000           csr         csr           csr         csr           csr         csr |             |       | 00000<br>00000<br>00000<br>rs1<br>rs1<br>rs1<br>zimm<br>zimm | 001<br>000<br>000<br>001<br>010<br>011<br>101<br>110 | 00000<br>00000<br>00000<br>rd<br>rd<br>rd<br>rd<br>rd | 0001111<br>1110011<br>1110011<br>1110011<br>1110011<br>1110011<br>1110011 | I fend<br>I ecal<br>I ebre<br>I csrr<br>I csrr<br>I csrr<br>I csrr<br>I csrr<br>I csrr |

Tarih: 12.05.2023 09:30 - 11:30

- 3) [20 PUAN] Aşağıdaki sorulara cevap veriniz:
- a) Bilgisayarda stack bellekte nasıl bir yerdedir? Stack'in işlevi nedir? Stack overflow hatası hangi durum ya da durumlarda meydana gelebilir?
- a) CEVAP:

LİFO şeklinde çalışır yani son gelen ilk işlenir. Stack owerflow stacke ayırdığımız alandan daha fazla kullanım olması ile veri kaybı oluşumuna denir.

b) RISC ve CISC nedir? Aralarındaki farklar nelerdir?

## c)CEVAP:

Risc her saat vuruşunda bir instrucktion tamamlaren cisc deki instrucktionlar çok fazla aksiyon barındırdığı çin bir instrucktionun tamamlanması için pek çok saat vuruşuna ihtiyaç duyar

c) Aşağıda verilen devredeki en uzun yol gecikmesi (critical path delay) nedir? Kapı gecikmeleri NOT 1 ns, AND ve OR 2 ns, XOR 4 ns. Kablo gecikmesi, bir kapının çıkışından diğer kapının girişine, giriş ve çıkış sinyalleri için de 1 ns. Devrenin giriş ve çıkışındaki kablo gecikmeleri hesaba katmayı unutmayın.

## c) CEVAP:

En uzun yol a-d dir 9ns



d) c şıkkında verilen devrede çıkış sinyallerini giriş sinyalleri cinsinden bool fonksiyonu şeklinde yazınız.

d) CEVAP:

$$D = (a' | c') ^ c$$

$$E = (b' \& c')'$$

## 4) [15 PUAN]

Aynı instruction set architecture için iki farklı işlemci tasarımı düşünün. ISA'da bulunan instructionlar, CPI (cycle per instruction) değerlerine göre A, B, C ve D sınıfları olmak üzere dört sınıfa ayrılabilir.

P1 işlemcisi 2,5 GHz saat hızına sahiptir ve A,B,C,D instructionları için CPI değerleri sırasıyla 1, 2, 3 ve 3'tür. P2 işlemcisi 3 GHz saat hızına sahiptir ve A,B,C,D instructionları için CPI değerleri sırasıyla 2, 2, 2 ve 2'dir. Toplam instruction sayısı 1 milyon olan bir program incelendiğinde instruction tipleri şu şekilde dağılım göstermiştir: %10 A sınıfı, %20 B sınıfı, %50 C sınıfı ve %20 D sınıfı. Bu program için:

- a) Hangi işlemci daha hızlıdır ve yavaş olana göre hızlı olma oranı kaçtır? Yaptığınız işlemleri, hesapları göstererek söyleyiniz.
- b) İki işlemci tasarımı için ortalama CPI değerlerini hesaplayınız. Yaptığınız işlemleri, hesapları göstererek söyleyiniz.
- c) İki işlemci için de toplam gereken saat vuruşu sayısı nedir hesaplayınız. Yaptığınız işlemleri, hesapları göstererek söyleyiniz.

#### Tarih: 12.05.2023 09:30 - 11:30

# 5) [30 PUAN]

3 adet sayıdan en büyüğünü bulan algoritmayı risc-v assembly dilinde yazınız. Gereksinimler:

- 3 adet sayı, bir array içerisinde bulunmaktadır (Örneğin my\_array[0], my\_array[1], my\_array[2]). Arrayın 3 elemanı da 32-bit genişliğindedir ve bellekte bulunmaktadır. Arrayin ilk elemanının (my\_array[0]) adresinin x10 registerinda bulunduğu bilinmektedir.
- İşlem sonucunda bulunan en büyük sayı belleğe kaydedilecektir ve bellekte yazılacağı adres x11 registerındadır.

## 5) CEVAP:

```
addi a0, a0, 0x100
addi a1, zero, 0 #Sonuç
addi t0, zero, 5 #Arraydeki il sayımız
sw t0, 0(a0)
addi t0, zero, 10 #Arraydeki ikincisayımız
sw t0, 8(a0)
addi t0, zero, 1 #Arraydeki son sayımız
sw t0, 16(a0)
lw a1, 0(a0)
lw t1, 8(a0)
slt t2,a1,t1
addi t3, zero, 1
bne t2, t3, _digerini_kontrol_et
lw a1, 8(a0)
_digerini_kontrol_et:
lw a1, 8(a0)
lw t1, 16(a0)
slt t2,a1,t1
bne t2, t3,_islemi_bitir
lw a1, 16(a0)
```

```
_stop:
j _stop # jump to _stop
```

NOT: Vize çözümlerinizi pdf formatında beni (mbaykenar) collaborator olarak eklediğiniz private github repo üzerinde paylaşacaksınız. Piazza üzerinden yüklenen bu word formatındaki vize dosyası üzerinde cevaplarınızı yazıp "isim\_soyisim\_bz403\_vize.pdf" olarak github reponuzda oluşturacağınız "vize" adındaki klasörün içine upload edeceksiniz.