

## تمرین سری ۲

درس معماری کامپیوتر نیم سال دوم ۰۰-۹۹

۱. قطعه کد زیر را در نظر بگیرید:

```
module FSM(input logic clk, rst ,
         input logic a,b ,
         output logic y);
always ff@(posedge clk , posedge rst)
  if(rst) state <= S2;</pre>
  else
         state <= nextstate;
always comb
  case(state)
    S0: if (a \& b) next state = S1;
        else nextstate = S2;
    S1: if (a) next state = S0;
        else nextstate = S3;
    S2: if (a \mid b) nextstate = S1;
        else nextstate = S3;
    S3: if (b) next state = S0;
        else nextstate = S2;
assign y = (state == S0) | (state == S3);
```

endmodule

- أ. با ذكر دليل بگوييد كه ماشين حالت توصيف شده يک ماشين حالت moore است يا mealy؟ ب. دياگرام حالت ماشين فوق را رسم كنيد.
- ج. ماشین حالت کشیده شده را با کمترین تغییرات از پاسخ قسمت أ به دیگری (mealy/moore) تبدیل کنید.
- ۲. هدف از این تمرین مرور نحوه مدلسازی با زبان SystemVerilog است. خروجی نهایی این تمرین توصیف یک ضرب کننده بدون علامت ۸-بیتی است است که شبیه سازی و سنتز می شود. ضرب کننده مد نظر حالتی بین ضرب کننده ترتیبی و ضرب کننده سریع معرفی شده در درس است. بدین ترتیب که با فرض وجود بلوکهای ضرب کننده سریع ۴-بیت، در چهار سیکل نیمه پایین و نیمه بالای عدد اول و دوم را در هم ضرب کرده و در مرتبه مناسب آنها را با هم جمع می کند. مراحل زیر به ترتیب روند پیاده سازی را مشخص می کنند.
  - أ. یک ماژول ضرب کننده سریع  $^*$ -بیت را به صورت رفتاری مدل سازی کنید و آن را شبیه سازی و تست کنید. ب. یک بلوک جمع کننده یارامتری  $^*$ -بیت توصیف کنید و آن را شبیه سازی و توصیف کنید.

- ج. با استفاده از ماژولهای مرحله ی قبل، یک ماژول ضرب کننده ۸-بیت را به صورت ساختاری مدل سازی کنید (در صورت استفاده از ماژولهای کمکی دیگر، همه ی آنها را به صورت ساختاری پیاده سازی کنید). ممکن است علاوه بر ماژولهای مرحله قبل نیاز به پیاده سازی یک واحد کنترل و یک شیفت رجیستر (با امکان شیفت ۴-بیت در یک سیکل) هم داشته باشید.
  - د. در مرحله ی پایانی، با طراحی یک testbench مناسب مدل را شبیه سازی و صحت سنجی کنید.

|                                                                                                                               | <b>y</b> 7             | <b>y</b> 6             | <b>y</b> 5             | <b>y</b> 4             | <b>y</b> 3            | <b>y</b> 2             | <b>y</b> 1             | <b>y</b> 0            |
|-------------------------------------------------------------------------------------------------------------------------------|------------------------|------------------------|------------------------|------------------------|-----------------------|------------------------|------------------------|-----------------------|
|                                                                                                                               | <b>X</b> 7             | <b>X</b> 6             | <b>X</b> 5             | <b>X</b> 4             | <b>X</b> 3            | <b>X</b> 2             | <b>X</b> <sub>1</sub>  | $\mathbf{x}_0$        |
|                                                                                                                               | <b>p</b> <sub>70</sub> | p <sub>60</sub>        | p <sub>50</sub>        | p <sub>40</sub>        | p <sub>30</sub>       | <b>p</b> <sub>20</sub> | $p_{10}$               | p <sub>00</sub>       |
| p <sub>71</sub>                                                                                                               | $p_{61}$               | $p_{51}$               | p <sub>41</sub>        | <b>p</b> <sub>31</sub> | $p_{21} \\$           | $p_{11} \\$            | <b>p</b> <sub>01</sub> |                       |
| p <sub>72</sub> p <sub>62</sub>                                                                                               | p <sub>52</sub>        | p <sub>42</sub>        | <b>p</b> <sub>32</sub> | $p_{22}$               | $p_{12}$              | p <sub>02</sub>        |                        |                       |
| $p_{73}$ $p_{63}$ $p_{53}$                                                                                                    | p <sub>43</sub>        | <b>p</b> <sub>33</sub> | $p_{23}$               | $p_{13}$               | p <sub>03</sub>       |                        |                        |                       |
| p <sub>74</sub> p <sub>64</sub> p <sub>54</sub> p <sub>44</sub>                                                               | p <sub>34</sub>        | p <sub>24</sub>        | $p_{14}$               | p <sub>04</sub>        | 7                     |                        |                        |                       |
| $p_{75}$ $p_{65}$ $p_{55}$ $p_{45}$ $p_{35}$                                                                                  | p <sub>25</sub>        | $p_{15}$               | p <sub>05</sub>        |                        |                       |                        |                        |                       |
| p <sub>76</sub> p <sub>66</sub> p <sub>56</sub> p <sub>46</sub> p <sub>36</sub> p <sub>26</sub>                               | $p_{16}$               | p <sub>06</sub>        |                        |                        |                       |                        |                        |                       |
| p <sub>77</sub> p <sub>67</sub> p <sub>57</sub> p <sub>47</sub> p <sub>37</sub> p <sub>27</sub> p <sub>17</sub>               | <b>p</b> <sub>07</sub> |                        |                        |                        |                       |                        |                        |                       |
| S <sub>15</sub> S <sub>14</sub> S <sub>13</sub> S <sub>12</sub> S <sub>11</sub> S <sub>10</sub> S <sub>9</sub> S <sub>8</sub> | <b>S</b> <sub>7</sub>  | <b>S</b> <sub>6</sub>  | <b>S</b> <sub>5</sub>  | <b>S</b> <sub>4</sub>  | <b>S</b> <sub>3</sub> | <b>S</b> <sub>2</sub>  | S <sub>1</sub>         | <b>s</b> <sub>0</sub> |

گزارش نهایی آپلود شده، علاوه بر پاسخ سوالات تحلیلی، باید شامل موارد زیر از سوال دوم باشد.

- فایل سورس SystemVerilog (.sv.) بلوک طراحی شده.
- خروجی شبیهسازی که ورودی/خروجیها را با radix مناسب نشان دهد.
- یک screenshot از خروجی RTL viewer که ارتباط آن با کد خود را به هنگام تحویل توضیح می دهید.
- یک فایل متنی شامل گزارش مساحت استفاده شده از تراشه FPGA و نیز تاخیر مدار با شرایط 1200mv .slow 85C

## توجه:

- تمرین های درس معماری به صورت گروههای دو نفره انجام داده شده و تحویل می گردند.
- نکته مهم این است تمامی افراد گروه باید به همه جوانب و جزئیات تمرینها مسلط باشند که این نکته توسط دستیاران آموزشی موقع تحویل به دقت بررسی خواهد شد.
  - هر گروه باید به صورت مجزا تمرین را انجام داده و از کیی تمرینهای گروههای دیگر خودداری کند.
- به منظور ایجاد شرایط یکسان برای تمامی گروهها و فاصله داشتن زمان آپلود و تحویل، به هنگام تحویل، اعضای گروه، در همان زمان تمرین خود را از درسافزار دانلود کرده و روی سیستم خود تحویل میدهند.

موفق باشيد