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語言的更多信息 。 shell
這些步驟很是枯燥乏味。 windows
文件名: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
文件名: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
文件名:testbench.v ide
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
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後生成的波形文件ui
7. 在控制檯輸入gtkwave dff.vcd觀察波形。若是發現沒有波形,不要驚慌,在窗口右側上選擇某一個module,而後在右下選擇某一個變量,再點擊insert就能夠看到輸出的波 形了spa
到這裏,咱們已經完成了這個簡易的IDE的後端的操做 插件
前端的搭建徹底依靠Sublime Text 3豐富的插件。
個人大部分文章首發在知乎專欄:關於計算機的一些事,歡迎你們關注。