在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 從VHDL代碼到真實硬件:設計一個8位算術邏輯單元

            從VHDL代碼到真實硬件:設計一個8位算術邏輯單元

            作者: 時間:2024-09-03 來源:EEPW編譯 收藏

            在這個項目中,我們使用VHDL語言創(chuàng)建了一個(ALU),并在連接到帶有輸入開關和LED顯示器的自定義PCB的Altera CPLD開發(fā)板上運行它。

            本文引用地址:http://www.biyoush.com/article/202409/462593.htm

            使用基于硬件的方法開發(fā)電子系統(tǒng)并不總是需要將各種晶體管和邏輯門物理連接到面包板或PCB上。可以使用離散邏輯構建算術邏輯單元(ALU),但隨著邏輯復雜性的增加,還有更好的選擇。通過可編程邏輯設備和硬件描述語言(HDL),可以在單個芯片中實現(xiàn)從簡單電路到高度專業(yè)化的處理單元的任何內(nèi)容。

            ALU項目概述

            在這個項目中,我將介紹(ALU)電路的創(chuàng)建過程,該電路具有輸入DIP開關和輸出LED,如圖1所示。我使用VHDL語言對ALU進行編碼,并在復雜可編程邏輯器件(CPLD)開發(fā)板上運行。我的目標是介紹可編程邏輯,并為使用真實硬件而不是圖表和計算機模擬打開大門。

            定制PCB開關和LED顯示ALU操作

            1.png

            圖1. 項目運行過程。圖片由Kristijan Nelkovski友情提供

            對于這個項目,我構建了一個帶有All About Circuits品牌的定制印刷電路板(PCB),如圖2所示。與更知名的現(xiàn)場可編程門陣列(FPGA)相比,CPLD是一種更實惠但功能較弱的可編程邏輯器件。這兩種設備都可以用于創(chuàng)建具有專用輸入和輸出的定制電子設計。

            已完成的ALU項目包括一個定制的PCB

            2.png

            圖2:已完成的ALU項目包括一個定制的PCB。圖片由Kristijan Nelkovski提供

            從內(nèi)部來看,這些CPLD和FPGA組件包含可重構邏輯塊陣列,并作為獨立的IC封裝,以便嵌入到您自己的設計中。制造商提供開發(fā)板,用于學習、測試和實驗使用他們的技術和軟件環(huán)境。我使用CPLD的開發(fā)板。

            什么是ALU?

            每個處理器的核心都是一個組合邏輯電路,該電路對稱為算術邏輯單元的整數(shù)二進制數(shù)執(zhí)行算術和位操作。我們將在本項目中構建的電路是一個8位算術邏輯單元,它包含兩個8位操作數(shù)(輸入),一個8位結(jié)果(輸出)和一個4位操作碼(輸入),該操作碼定義了將要執(zhí)行的操作(圖3)

            ALU的符號表示

            3.png 

            圖3. ALU的符號表示。圖片由Jim Lamberson提供,維基共享資源

            ALU 通常包含狀態(tài)位(既是輸入也是輸出),這些狀態(tài)位向處理器提供有關最后執(zhí)行的操作的重要信息。這些狀態(tài)信息可以包括結(jié)果是否為零,或者結(jié)果是否溢出到最高有效位(MSB)之外。但是,我們的電路不需要它們,因此不會包含任何狀態(tài)位。

            ALU為學習VHDL編碼和CPLD編程操作提供了極好的起點。一旦你完成這個項目,你就可以輕松地擴展到更困難的應用。

            項目詳情和參考

            在這個項目中,我們將使用VHDL語言創(chuàng)建一個8位算術邏輯單元(ALU),并使用英特爾的Quartus Prime Lite Edition軟件(Altera現(xiàn)在是英特爾的一部分)在Altera Max II EPM240 CPLD開發(fā)板上運行它。該電路的代碼基于加州大學河濱分校發(fā)布的實驗室練習設計。

            對于這個項目,你需要對編程和離散邏輯有基本的理解。查看AAC的VHDL和4位離散邏輯ALU項目介紹也會有所幫助。

            注意:雖然我為這個項目創(chuàng)建了一個“屏蔽”類型的板子,但這里介紹的所有內(nèi)容都是完全適合面包板和穿孔板的。

            使用Quartus Prime為Altera MAX II開發(fā)板設置新項目

            為了開始我們的項目,我們需要下載并安裝Quartus Prime Lite Edition,并創(chuàng)建一個文件夾來存儲我們所有的項目。我從英特爾的網(wǎng)站下載了該軟件,并在“Windows Documents”目錄中創(chuàng)建了一個名為“quartus”的文件夾。

            當我們運行Quartus時,我們需要做的第一件事就是通過“新建項目向?qū)А痹O置一個新項目,該向?qū)Э梢栽凇拔募?>新建項目向?qū)А毕抡业?。然后,我們需要在名為“介紹”的第一個屏幕上點擊“下一步”。

            如圖4所示,在名為“Directory, Name, Top-Level Entity”的第二個屏幕上,我們需要選擇之前創(chuàng)建的文件夾作為工作目錄,并為當前項目提供一個合適的名稱。我將此項目命名為“ALU”。

            Quartus“目錄、名稱、頂層實體”屏幕

             4.png

            圖4. Quartus“目錄、名稱、頂層實體”屏幕。圖片由Kristijan Nelkovski提供

            對于“項目類型”屏幕,我們需要選擇“空項目”,并將下一個名為“添加文件”的屏幕留空(圖5)。

            Quartus“項目類型”屏幕

             5.png

            圖5. Quartus“項目類型”屏幕。圖片由Kristijan Nelkovski提供

            在“Family, Device & Board Settings”屏幕上,我們需要從“Device family”部分的下拉菜單中選擇“MAX II”(圖6)。然后,從“Available devices”部分選擇“EPM240T100C5”,因為這是Altera MAX II EPM240上的芯片。

            Quartus 填滿族群屏幕

             6.png

            圖6. Quartus填充的“系列、設備和板設置”屏幕。圖片由Kristijan Nelkovski提供

            接下來,我們需要在“EDA工具設置”屏幕上將“Verilog HDL”更改為“VHDL”,點擊下一步,并在“摘要”(圖7)中檢查是否一切正常。在此之后,我們可以點擊“完成”按鈕,然后我們的新項目將被創(chuàng)建。

            Quartus EDA工具設置屏幕

             7.png

            圖7. Quartus“EDA工具設置”屏幕。圖片由Kristijan Nelkovski提供

            一旦此項目打開,我們需要在“項目導航器:層次結(jié)構”窗口中單擊我們實體的名稱,然后通過按“CTRL+N”并選擇“VHDL文件”來創(chuàng)建一個新的VHDL文件

            打開此文件后,我們必須通過“文件 -> 另存為”將其保存為實體的VHDL文件。完成所有這些后,我們可以開始為ALU編寫代碼。

            聲明VHDL庫

            因此,與所有編程語言一樣,我們需要在的頂部首先聲明將在項目中使用的庫。

             8.png

            創(chuàng)建 ALU 電路實體

            接下來,我們將創(chuàng)建一個ALU實體,定義其所有輸入和輸出端口。在這里,我們定義端口A和B為“IN STD_LOGIC_VECTOR(7 DOWNTO 0)”,這意味著每個輸入實際上都是一個8位總線,其位編號從7到0,其中第七位是MSB。同樣,SEL端口被定義為4位輸入,RES端口被定義為8位輸出。

             9.png

            創(chuàng)建算術邏輯單元電路的VHDL行為架構

            現(xiàn)在我們需要設計電路的結(jié)構或行為。我們將使用三個輸入或端口A、B和Sel創(chuàng)建一個過程。

            在此過程中,我們可以調(diào)用“case-when”語句(類似于其他編程語言中的“switch-case”),其中我們檢查端口SEL的狀態(tài)。SEL值是ALU的操作碼,它決定了需要在端口A和B上接收的兩個8位數(shù)字之間執(zhí)行的操作。

            這是在語句的“當XXXX =>”部分完成的,其中XXXX表示SEL的二進制狀態(tài)(介于0000和1111之間的位置)。每個狀態(tài)都分配給一個相應的ALU操作,該操作使用端口A和B上接收到的值執(zhí)行。輸出在端口RES上寫出。

            在此之后,我們可以結(jié)束“case”語句、流程和行為架構,并以此結(jié)束我們項目的代碼部分。

            10.png

            在上面的代碼中,我包含了一些最常見的算術和邏輯操作,以及一些隨機的操作,并注釋了每個操作的作用。在這里,你可以替換和包含任何你想要的任意算術或邏輯操作!

            引腳映射

            代碼完成后,我們需要做的第一件事就是編譯它。這可以通過進入“處理 -> 開始編譯”來完成。如果一切編譯正確,我們不應該收到任何錯誤消息,盡管我們可能會收到一些可以忽略的警告。

            接下來,我們需要將之前為實體定義的端口連接到Altera開發(fā)板上的物理引腳。我們將通過Quartus的Pin Planner工具來完成此操作,該工具可通過“Assignments -> Pin Planner”訪問

            引腳規(guī)劃工具包含:

            使用中的芯片(本例中為EPM240)的視覺表示。

            描述每種引腳類型的引腳圖例。

            一個包含我們實體端口中每個單獨節(jié)點的表格。在這個表格中,我們可以通過在“位置”列的相應行中寫出每個節(jié)點,將其連接到專用引腳。

            表1包含我生成的引腳分配表。

            11.png

            表1. ALU的Quartus引腳映射表

            將代碼上傳到Altera開發(fā)板

            一旦我們將每個輸入和輸出分配給一個引腳,就需要再次編譯代碼。如果沒有彈出錯誤消息,我們就可以繼續(xù)將其上傳到Altera MAX II。

            為此,我們首先必須通過板上的桶形插孔將板子本身連接到5 V電源。接下來,我們必須通過JTAG端口將其連接到USB Blaster,然后使用迷你USB插孔將USB Blaster連接到我們的計算機(圖8)。

            Altera板和USB Blaster連接。

             12.png

            ?圖8。更改板和USB噴砂機連接。圖片由KristijanNelkovski提供

            然后,我們可以通過進入“工具->編程器”并檢查“編程/配置”來運行編程器,如圖9所示。然后我們需要打開“硬件設置”,選擇“USB Blaster”作為我們的“可用硬件項”(我們的程序員),然后點擊“開始”,我們的代碼將被上傳到Altera MAX II。

            Quartus編程器屏幕

            13.png

            ?圖9。Quartus編程器屏幕。圖片由KristijanNelkovski提供

            印刷電路板電路圖

            圖10所示為我們的電路圖。每個LED都通過一個限流電阻連接到一個輸出針腳。連接到輸入引腳的DIP開關的每個觸點也通過電阻網(wǎng)絡被下拉到地(在定制PCB上,這些電阻網(wǎng)絡隱藏在DIP開關的下面)。

            帶開關輸入和LED輸出的定制PCB電路圖

            14.png

            ?圖10。帶開關輸入和LED輸出的定制PCB電路圖。圖片由KristijanNelkovski提供

            在把所有的東西都接好并用5V給Altera板供電之后,我們可以通過在我們的操作端口上輸入數(shù)字并將操作模式切換到我們喜歡的任何操作來看到ALU的動作。發(fā)光二極管顯示結(jié)果,如圖1所示。

            ALU項目物料清單

            表2為本工程的材料清單。

            15.png

            ?表2。材料清單

            輪到你了!

            在這個項目中,我們用VHDL語言創(chuàng)建了一個8位ALU電路,并在CPLD開發(fā)板上運行。這里,我的目標是介紹可編程邏輯,并為使用真正的硬件組件而不是圖表和計算機模擬的FPGA組件打開大門。

            如果重復此項目,則可以很容易地向ALU的VHDL操作中添加額外的操作碼。還可以修改電路設計以輸出和顯示狀態(tài)代碼。在以下評論中分享您的想法或項目!




            評論


            技術專區(qū)

            關閉