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

# دستور کار آزمایشگاه مدارهای منطقی

تهیه و تنظیم: گروه مدرسین آزمایشگاه

پاییز ۱۳۹۶

### آزمایش ۷

#### هدف: پیادهسازی مدار جمع کننده-تفریق کننده ۴-بیتی بهصورت ساختاری

۱. در گام نخست این آزمایش، هدف پیادهسازی مدار شکل ۱ است. این مدار دو بیت A و B را دریافت و بر اساس اینکه مقدار Cin صفر یا یک باشد، به صورت متناظر دو بیت را با یکدیگر جمع یا از یکدیگر تفریق می کند.

از دانشجویان انتظار می رود تا این مدار را با زبان Verilog به صورت ساختاری توصیف کنند. توصیف مدار تمام Or و Or مع کننده ی این شکل نیز باید به صورت ساختاری انجام پذیرد (فرض کنید تاخیر گیتهای And و Or هر کدام ۵ نانوثانیه، گیت ۱۰ XOR نانوثانیه و گیت ۲ not نانوثانیه است. تاخیرهای ذکرشده در تمامی مراحل این آزمایش برقرار هستند).



شكل ١ مدار جمع كننده-تفريق كننده تك بيتي [1]

۲. در گام دوم این آزمایش لازم است تا دانشجویان مطابق شکل ۲ مدار جمع کننده-تفریق کننده ۴-بیتی را
 با استفاده از مدار بخش اول توصیف کنند.

اکنون دانشجویان باید برای این مدار یک برنامه آزمون نوشته و مدار را به ازای حداقل  $\pi$  حالت تفریق و  $\pi$  حالت جمع تست کنند. پس از اعمال ورودی تا زمانی که خروجی ثابت بشود، خروجی چه گذارهایی دارد؟ آنها را یادداشت کنید. علت این تغییرات چیست؟



شکل ۲ مدار جمع کننده-تفریق کننده چهار بیتی

۳. در گام آخر این آزمایش لازم است دانشجویان مطابق مراحل ذکر شده در پیوست ۳، کدهای بخش اول و دوم خود را سنتز کرده و آن را بر روی بورد FPGA بارگذاری کنند. ورودیهای بخش ۲ را با کمک کلیدهای موجود بر روی بورد اعمال کنید و نتایج را مشاهده کنید.

۲

<sup>\</sup> Testbench

## پیوست ۳

#### مراحل سنتز و بارگذاری کد توصیف سختافزاری روی FPGA

فاز اول: برنامه ریزی FPGA



شکل ۱ صفحه شروع کار با ابزار ISE



شکل ۲ ایجاد یک پروژه جدید



شکل ۳ تعیین ویژگی های FPGA



شکل ۴ ایجاد یک فایل برای entity



شکل ۵ تعیین نوع و نام فایل



شکل ۶ تعیین پورتهای ورودی و خروجی



شکل ۷ خلاصه از ویژگیهای فایل ایجاد شده



شکل ۸ لیست فایلهای ایجاد شده



شکل ۹ افزودن فایلهایی که از قبل وجود دارند



شکل ۱۰ خلاصه ای از ویژگیهای پروژه ایجاد شده

```
🌌 ISE Project Navigator - E:\projects\SampleRam\SampleRam.xise - [ram_8_4.vhd]
E Edit View Project Source Process Tools Window Help
 --use UNISIM.VComponents.all;
                                                                         28
    Sources for: Implementation
                                                                         29
                                                                E
N S
                                                                               entity ram 8_4 is

Port ( clk : in STD_LOGIC;
    write_enable : in STD_LOGIC;
    address : in STD_LOGIC VECTOR (2 downto 0);
    data_in : in STD_LOGIC_VECTOR (3 downto 0);
    data_out : out STD_LOGIC_VECTOR (3 downto 0));
end ram 8_4.
                                                                         30
         Hierarchy
     a
          5ampleRam
 xc3s400-5pq208
 ram_8_1 an 8_4 - Behavioral (ram_8_4.vhd)
    1
                                                                         32
                                                                         33
34
35
    00
1
     36
37
38
                                                                              end ram 8 4;
     architecture Behavioral of ram 8_4 is
type ram is array (0 to 7) of std_logic_vector(3 downto 0);
signal mem_1 : ram;
                                                                 %
                                                                         39
40
41
                                                                 %
                                                                 34
                                                                         42
43
44
45
46
47
48
                                                                                    process (clk)
                                                                                       gin
if(rising_edge(clk)) then
if (write_enable = '1') then
    mem_1 (conv_integer(address)) <= data_in;
    data_out <= "ZZZZ";</pre>
     Processes: ram_8_4 - Behavioral
          Design Summary/F
Design Utilities
User Constraints
Synthesize - XST
Implement Design
Generate Program
                     Design Summary/Reports
     熨
                                                                         49
50
51
     PC.
                                                                                             else
                                                                                                  data_out<= mem_1 (conv_integer(address));
                                                                                             end if ;
                    Implement Design
Generate Programming File
                                                                         52
53
54
                                                                                        end if :
                                                                                    end process;
                     Configure Target Device
                    Undate Bitstream with Processor Data
                                                                         55
                                                                               end Behavioral;
                     Analyze Design Using Chipscope
                                                                         57
                                                                 ram_8_4.vhd
                                                                                                                   Design Summary (out of date)
    Console
                                                                                                                                                                                      ↔ □ ♂ ×
                                                 HDL Compilation
        Compiling vhdl file "E:/projects/SampleRam/ram_8_4.vhd" in Library work.
     Console Errors Warnings
                                                                                                                                                                              Ln 48 Col 21 VHDL
```

شکل ۱۱ نوشتن کد طراحی



شکل ۱۲ منوی سنتز



شکل ۱۳ نتیجه سنتز



شكل ۱۴ منوى ايجاد فايل محدوديت (تعيين پورتهاي FPGA)



شكل ۱۵ تعيين نام فايل محدوديت



شکل ۱۶ ویژگیهای فایل محدودیت ایجاد شده



شکل ۱۷ فایل محدودیت در منوی Hirearchy



شکل ۱۸ ویرایش فایل محدودیت به صورت متنی



شکل ۱۹ تعیین port های طرح بر روی FPGA



شکل ۲۰ ایجاد فایل برنامهریزی



شکل ۲۱ اجرای نرم افزار IMPACT برای برنامه ریزی



شکل ۲۲ ابزارهای شناخته شده



شکل ۲۳ تعیین فایل برنامه ریزی RAM موجود در روی بورد. (فعلا این مرحله را bypass می کنیم.)



شکل ۲۴ انتخاب فایل برنامه ریزی تولید شده در مرحله قبل



شکل ۲۵ نمایش ویژگیهای برنامه ریزی ابزار



شکل ۲۶ برنامه ریزی FPGA



شکل ۲۷ تائید نهایی



شکل ۲۸ وضعیت برنامه ریزی

## فاز دوم: برنامه ریزی RAM روی بورد



شكل ۲۹ منوى ايجاد فايل برنامه ريزي RAM



شکل ۳۰ هشدار مبنی بر ایجاد پروژه iMPACT جدید



شکل ۳۱ منوی ایجاد فایل برنامه ریزی در پنجره iMPACT



شکل ۳۲ گام اول ایجاد فایل برنامه ریزی



شکل ۳۳ گام دوم ایجاد فایل برنامه ریزی



شکل ۳۴ گام سوم ایجاد فایل برنامه ریزی



شکل ۳۵ جستجوی RAM های روی بورد توسط iMPACT



شکل ۳۶ انتخاب فایل برنامه ریزی FPGA برای برنامه ریزی شکل ۳۶



شکل ۳۷ هشدار مبنی بر افزودن فایل جدید



شكل ٣٨ نتيجه انتخاب فايل



شكل ٣٩ ايجاد موفقيت آميز فايل برنامه ريزي RAM



شکل ۴۰ تعیین فایل برنامه ریزی RAM



شکل ۴۱ انتخاب فایل برنامه ریزی RAM



شكل ۴۲ انتخاب فايل برنامه ريزي FPGA



شکل ۴۳ ویژگیهای برنامه ریزی دو ابزار



شکل ۴۴ برنامه ریزی RAM



شکل ۴۵ نتیجه موفقیت آمیز برنامه ریزی RAM