# طراحی سیستمهای قابل بازپیکربندی دکتر صاحبالزمانی



دانشگاه صنعتی امیر کبیر ( پلی تکنیک تهران ) دانشکده مهندسی کامپیوتر

رضا آدینه پور ۴۰۲۱۳۱۰۵۵

تمرین سری اول

۲۹ مهر ۱۴۰۳

# طراحی سیستمهای قابل بازپیکربندی



تمرین سری اول

رضا آدینه پور ۴۰۲۱۳۱۰۵۵

## \_\_\_\_\_ mell leb

با ذكر دليل بيان كنيد جملات زير صحيح هستند يا خير.

۱. در یک پروژه با زمان محدود بهترین راه جهت پیادهسازی الگوریتم پردازشی استفاده از تراشههای قابل بازپیکربندی است.

## پاسخ

### نادرست.

زیراً در زمان محدود بهترین راه برای پیادهسازی یک الگوریتم پردازشی استفاده از پردازندههای مرسوم موجود در بازار مانند CPU است. چون معمولا زمان طراحی و برنامهریزی برای تراشههای قابلبازپیکربندی مانند FPGA بشتر از CPU های مرسوم است.

۲. طراحیهای مبتنی بر پردازندههای همه منظوره و تراشههای خاص منظوره، دو انتهای بردار کارآیی و انعطافپذیری هستند.

## پاسخ

درست

٣. معماري قابل بازييكربندي جهت حل مشكل دسترسي حافظه در كامپيوتر فون نيومن ارائه شده است.

### پاسخ

درست.

۴. در کاربردهای فضایی و محیطهای دارای تشعشعات زیاد، تراشههای مبتنی بر FLASH بهترین گزینه انتخابی هستند.

## پاسخ

#### نادرست

تراشههای مبتنی بر FLASH در برابر تشعشعات آسیبپذیر هستند و ممکن است دچار BitFlip بشوند. معمولا در این محیطها، از تراشههایی با تکنولوژیهایی مانند SRAM استفاده می شود.ناشی از تشعشعات دارند.

۵. از تراشههای مبتنی بر آنتیفیوز به دلیل مقاومت مناسب در برابر دمای بالا در کاربردهای صنعتی استفاده میشود.

پاسخ

صفحه ۱ از ۸

| : LAFPCA         | 4          | <1         |                | والمدام خام | CGRA یا دارایودن   | و تاشیخام  |
|------------------|------------|------------|----------------|-------------|--------------------|------------|
| A ۲۲۲۲ ها داريد. | ى ئىسىت بە | ه آن حمت ع | منظوره بنشت، د | واحدهای حاص | ט בורושבני (הושבני | 7. داشههای |

پاسخ

۷. استفاده از FPGAها در مقایسه با تولید یک تراشه خاص باعث کاهش هزینه تولید محصول خواهد شد.

پاسخ

۸. یک ASIC همواره سریعتر از یک FPGA دستورات پردازشی سطح بالا را انجام خواهد داد.

پاسخ

٩. افزایش تعداد ورودی یک LUT همواره باعث افزایش سرعت مدار پیادهسازی شده با استفاده از آن خواهد شد.

پاسخ

۱۰. بلوکهای UltraRAM در کنار بلوکهای DSP برای پیادهسازی الگوریتمهای هوش مصنوعی به کمک FPGA خانواده Zynq بسیار مناسب هستند.

پاسخ

صفحه ۲ از ۸

## ---- سوال دوم

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

پاسخ

صفحه ۳ از ۸

# **——** سوال سوم

میخواهیم مدار زیر را یک بار با LUTهای ۳ ورودی و بار دیگر با LUTهای ۴ ورودی پیادهسازی کنیم به طوری که در هر حالت تعداد LUTهای مورد استفاده کمینه باشد.



شكل ١: مدار مورد نظر

پاسخ

صفحه ۴ از ۸

# سوال چهارم

معماری سوئیچهای Wilton و Disjoint را توضیح داده و میزان  $F_s$  را در هر یک گزارش نمایید. آیا معماری دیگری برای اتصال سوئیچها می شناسید؟

پاسخ

صفحه ۵ از ۸

## ---- melb پنجم

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

- Link (I)
- Link (II)

پروژه مشابه موارد یاد شده در دو ویدئو نیز بایستی به همراه پاسخ تمرینها بارگذاری شود. جهت دانلود نرمافزار ویوادو از این لینک استفاده نمایید. نسخه پیشنهادی ۲.۲۰۲۰ به بعد میباشد. به دلیل مشکل احتمالی در فعالساز بهتر است از نسخه ۲۰۲۴ استفاده نشود.

همانطور که در ویدئو نیز بیان شد، هدف در این قسمت، طراحی Co-Design است. بدین منظور، برای طراحی یک گیت NOT ساده، گیت AND را با استفاده از Logic Block های FPGA طراحی میکنیم و ماژول NOT را در هسته پردازشی یعنی CPU طراحی کرده و اتصالات بین این دو طراحی را برقرار میکنیم.

ذکر این نکته الزامی است که در این تمرین ما از بورد EBAZ4205 که تراشه موجود بر روی آن Zynq 7000 است استفاده نمودیم. این آیسی در نرمافزار Vivado با پارتنامبر xc7z010c1g400-3 شناخته می شود. تصویر این برد در «شکل ۲» آورده شده است:



شکل ۲: بورد مورد استفاده در این تمرین

همچنین فایل Constrain مربوط به این بورد را میتوان از اینجا دانلود کرد.

در ابتدا پس از نصب نرمافزار و انتخاب آیسی، طراحی سمت PL را انجام میدهیم. در این قسمت صرفا یک گیت AND را طراحی میکنیم. کد نوشته شده برای ماژول AND بهصورت زیر است:

صفحه ۶ از ۸

```
Listing 1: AND Module for PL
1 library IEEE;
2 use IEEE.STD_LOGIC_1164.ALL;
5 entity NAND_gate is
      Port ( a, b: in std_logic;
              y: out std_logic );
8 end NAND_gate;
10 architecture Behavioral of NAND_gate is
12 begin
13
      y \le a and b;
16 end Behavioral;
```

پس اط طراحی ماژول AND میبایست نحوه Interconnection سمت PS و PS را در درون تراشه برقرار کنیم. بدین منظور از قسمت طراحی دیاگرامی Vivado پردازنده ZYNQ را انتخاب میکنیم و همچنین از ماژول AND خودمان نيزيک بلوک ميسازيم.

با استفاده از بلوک های AXI GPIO میتوانیم ارتباطات بین PL و PS را برقرار کنیم. درنهایت سیستم طراحی شده بهصورت «شکل ۳» میشود.



شكل ٣: طراحي PL و PS انجام شده

پس از تکمیل شدن طراحی، میبایست گیت NOT را نیز بهصورت نرمافزاری (به زبان c) طراحی کنیم و سپس طراحی را

سنتز نهایی کنیم. برای انجام این کار، نرم افزار Vitis Clasic را اجرا میکنیم و یک Application Project جدید میسازیم و فایل xsa.

پس از ایجاد پروژه کد گیت NOT را بهصورت زیر مینویسیم:

```
Listing 2: AND Module for PL
#include <stdio.h>
2 // #include "platform.h"
3 #include "xgpio.h"
4 #include "xparameters.h"
5 #include "xil_printf.h"
```

دكتر صاحب الزماني صفحه ۷ از ۸

```
7 int main()
8 {
       init_platform();
9
10
      XGpio input, output;
11
      int a;
12
13
      int y;
14
      XGpio_Initialize(&input, XPAR_AXI_GPIO_O_DEVICE_ID);
15
      XGpio_Initialize(&output, XPAR_AXI_GPIO_1_DEVICE_ID);
16
17
      XGpio_SetDataDirection(&input, 1, 1);
18
      XGpio_SetDataDirection(&output, 1, 0);
19
20
      /* print("debug the code"); */
21
      while(1)
23
24
           a = XGpio_DiscreteRead(&input, 1);
25
26
           if(a == 1)
27
28
               y = 0;
29
           }
30
           else
31
           {
               y = 1;
33
34
35
           XGpio_DiscreteWrite(&output, 1, y);
36
37
38
39
      cleanup_platform();
40
      return 0;
41 }
```

سپس بعد از سنتر کد، با قرار دادن فایل Bitstream ایجاد شده در مرحله PL به عنوان فایل پروگرام، طراحی Bitstream شده را بر روی بردمان پروگرم میکنیم.

صفحه ۸ از ۸