用Sublime Text搭建簡易IDE編寫Verilog代碼

来源:http://www.cnblogs.com/hf-z/archive/2016/05/17/5503000.html
-Advertisement-
Play Games

前言 Verilog是一種硬體描述語言(HDL),該語言在Windows上有集成開發環境可以使用,如ModelSim,但ModelSim的編輯器不太好用因此筆者萌生了用Sublime Text3來編寫Verilog的想法。下麵我們將圍繞著Sublime Text3搭建起一個簡易的IDE, 我將儘量把 ...


前言

Verilog是一種硬體描述語言(HDL),該語言在Windows上有集成開發環境可以使用,如ModelSim,但ModelSim的編輯器不太好用因此筆者萌生了用Sublime Text3來編寫Verilog的想法。下麵我們將圍繞著Sublime Text3搭建起一個簡易的IDE, 我將儘量把步驟寫的細緻一點,這將會使整個過程看起來很繁瑣,但這是值得的。

原材料

說明:Sublime Text是一款功能強大的編輯器,可擴展性非常強;而icarus-verilog是一款Verilog的編譯器,在這裡我們使用的版本是iverilog-0.9.7_setup.exe (latest stable release),在Icarus Verilog這個網站上有關於該編譯器和Verilog語言的更多信息 。


開始搭建

後端

這些步驟非常枯燥乏味。

  1. 安裝icarus-verilog-on-windows。請記下安裝目錄,例如我的安裝目錄為F:\iverilog\,(下麵我也將以此目錄為例)。註意安裝過程中會有可選擇的項,請勾選上所有項,尤其 是和gtkwave相關的項
  2. 打開控制台,輸入命令iverilog,若顯示’iverilog: no source files.’字樣,則執行第4步;否則執行第3
  3. 配置系統變數。將F:\iverilog\bin\這一路徑加到系統的Path變數中,執行第三步,觀察輸出是否為’iverilog: no source files.’
  4. 當iverilog命令輸出正常後,我們就可以用它來編譯運行verilog源文件了,編寫如下三個文件

  文件名:dff.v 

 1 //dff modules represents a D type flip-flop
 2 module dff(d,clk,q,qn);
 3 input d,clk;
 4 output q,qn;
 5 reg q,qn;
 6 //Initialize flip-flop outputs
 7 initial begin q=0; qn=1; end
 8 //Change output on positive clock edge
 9 always @(posedge clk)
10 begin
11 q <= d;
12 qn <= !d;
13 end
14 endmodule
dff.v 

  文件名:tester.v

 1 module tester(q,qn,clk,d);
 2 input q,qn;
 3 output clk,d;
 4 reg clk,d;
 5 //Run the test once
 6 initial
 7 begin
 8 clk=0;
 9 //Dump results of the simulation to ff.cvd,important!
10 $dumpfile(“dff.vcd”);
11 $dumpvars;
12 //Generate input signal d
13 d=0; #9 d=1; #1 d=0; #1 d=1; #2 d=0; #1 d=1; #12 d=0;
14 #1 d=1; #2 d=0; #1 d=1; #1 d=0; #1 d=1; #1 d=0; # 7 d=1;
15 #8 $finish;
16 end
17 //Generate periodic clock signal
18 always
19 begin
20 #4 clk=!clk;
21 end
22 endmodule
tester.v

  文件名:testbench.v  

1 `include "tester.v"
2 `include "dff.v"
3 //Test bench connects the flip-flop to the tester module
4 module testbench;
5     wire clk,d,q,qn;
6     dff ff1(d,clk,q,qn);
7     tester tst1(q,qn,clk,d);
8 
9 endmodule
testbench.v

  5. 將上述三個文件放在同一個文件夾下,打開控制台,進入該目錄,輸入iverilog testbench.v,此時應當沒有任何輸出,再次進入該文件夾,發現多出了一個名為a.out的文 件,這個文件就是我們編譯testbench.v得到的目標文件

  6. 在控制台輸入vvp a.out,輸出’VCD info: dumpfile dff.vcd opened for output.’字樣,此命令是執行我們剛剛編譯生成的a.out再次進入該文件夾,發現多出來了一個名為    dff.vcd的文件,這個文件是我們執行a.out後生成的波形文件

  7. 在控制台輸入gtkwave dff.vcd觀察波形。如果發現沒有波形,不要驚慌,在視窗右側上選擇某一個module,然後在右下選擇某一個變數,再點擊insert就可以看到輸出的波 形了

到這裡,我們已經完成了這個簡易的IDE的後端的操作

前端

前端的搭建完全依靠Sublime Text 3豐富的插件。

  1. 安裝Sublime Text 3。後面我將其簡稱為ST,就像安裝QQ一樣,一路點next就好了
  2. 安裝關鍵詞高亮插件。用ST打開一個verilog文件(尾碼名為.v)中,發現是沒有高亮顯示的,按ctrl+shift+p,調出ST的包管理視窗,輸入install package,再輸入verilog後找到對應的項,回車,等待安裝完成,重啟ST,再次打開一個verilog文件,發現已經可以高亮顯示了
  3. 綁定快捷鍵編譯。打開ST,Preference—>Browse Packages—>找到User文件夾,將這個文件( 訪問密碼 7f77)放到該文件夾下
  4. 再次重啟ST,隨便打開一個verilog文件,按ctrl+b,就可以編譯該文件了,編譯正確輸出ST會有”[Finished in 0.6s]”類似的輸出,如果出現其他情況,作如下設置Tools—>Build System->Verilog,其效果和在控制台輸入iverilog xxx.v是一樣的,都會在文件目錄下生成編譯後的a.out文件
  5. 其實,到這一步就可以了,我們可以在ST中編寫編譯好verilog文件後,再打開控制台運行、查看波形,但是這樣仍然不夠方便,那麼可不可以直接在ST中運行、查看波形呢?其實,我們只需要在ST中可以運行控制台命令就可以了,幸運的是,ST為我們提供了這樣的插件。
  6. 安裝SublimeREPL插件。同安裝關鍵詞高亮插件一樣,按ctrl+shift+p,調出ST的包管理視窗,輸入install package,再輸入verilog後找到對應的項,回車,等待安裝完成,重啟ST,然後ctrl+shift+p,輸入sublimeREPLshell(sublimeREPLPowerShell也可以),在新打開的ST標簽頁中就可以運行cmd命令了(把這個標簽頁放在下麵是個不錯的選擇,可以參考一下下麵的圖片)。
  7. 至此,所有步驟已經結束。下麵是我的簡易IDE截圖


結語

Sublime Text好強大…,Verilog好強大… 第一次用博客園,還用不熟哈Embarrassed smile


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Scrapy是一個為了爬取網站數據,提取結構性數據而編寫的應用框架。 其可以應用在數據挖掘,信息處理或存儲歷史數據等一系列的程式中。其最初是為了頁面抓取 (更確切來說, 網路抓取 )所設計的, 也可以應用在獲取API所返回的數據(例如 Amazon Associates Web Services ) ...
  • 代碼結構: 1、ThymeleafController 1 package com.xxx.firstboot.web; 2 3 import org.springframework.stereotype.Controller; 4 import org.springframework.ui.Mod ...
  • Implement strStr(). Returns the index of the first occurrence of needle in haystack, or -1 if needle is not part of haystack. 暴力 KMP 以後寫。。 ...
  • 對於三目運算符(ternary operator),python可以用conditional expressions來替代 如對於x<5?1:0可以用下麵的方式來實現 1if x<5else 0 註: conditional expressions是在python 2.5之前引入的,所以以上代碼僅適 ...
  • 思維導圖 點擊下圖,可以看具體內容! 介紹 正則表達式,大家在開發中應該是經常用到,現在很多開發語言都有正則表達式的應用,比如javascript,java,.net,php等等,我今天就把我對正則表達式的理解跟大家嘮嘮,不當之處,請多多指教! 需要知道的術語——下麵的術語你知道多少? 需要知道的術 ...
  • 程式計數器 程式計數器是一塊較小的記憶體,它是線程私有的,可以看作是當前線程執行位元組碼的計數器。在虛擬機的概念模型中,位元組碼解釋器就是通過這個計數器來找到下一個將要執行的指令。java中分支語句,迴圈,異常處理以及線程恢復都是通過程式計數器來實現的。 由於JVM在執行線程的時候是通過CPU輪流執行各個 ...
  • 0. XXXX "is not a class or namespace"錯誤 最詭異的錯誤,提示意思很明顯,說你寫的名字既不是一個類也不是一個命名空間,雖然我C++水平不是很高,但再愚笨也不至於連類的格式class MyClass{....};也寫不明白吧,報此錯誤原因顯然跟它沒關係,那又是怎麼回 ...
  • 對於每個Java程式員來說,HelloWorld是一個再熟悉不過的程式。它很簡單,但是這段簡單的代碼能指引我們去深入理解一些複雜的概念。這篇文章,我將探索我們能從這段簡單的代碼中學到什麼。如果你對HelloWorld有獨到的理解,請留下你的評論。 HelloWorld.java 為什麼所有東西都是從 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...