162016-07-22 00:47:30. QFileInfoクラスを使うと、ファイルのさまざまな情報を取得することがで... ファイル削除 QString str = "C:/Program files/test/" + strFileName; リンク More than 3 years have passed since last update. もし、全てのオペランドが文字列リテラルならば、Verilog の integral 型の連結と同様に振る舞います。 {multiplier{Str1}} 繰り返し。 Str は、string 型 もしくは、文字列リテラルです。 multiplier は、 integral 型で、定数である必要はありません。 If requirement is to just display , as string is already passed into the macro and it can be used directly without needing any conversion in the display. QStringへの変換 http://qiita.com/fumi-san/items/7983d0956b9f0887d10e, you can read useful information later efficiently. 例 2 )シミュレーション時間を短縮するために、長いカウンタ周期を短くする. ファイル名を先にparameterで書いておくとあとが楽。, 文字列を入れる入れ物のサイズは、128(4byte) x 文字数でよかった(はず)。, 読み出した文字列がstr1,str2,str3に格納されているので、ここからデータを取り出す。, あとは要素としては普通のモジュール作成と変わらないはずなので、頑張って作る。 I want to assign register_path= "string" but this not result in the $display displaying "string". Licensed under cc by-sa 3.0 with attribution required. Why not register and get more from Qiita? バック・スラッシュ( \ )で始まる文字列(日本語環境では¥で始まる文字列). 任意の印字可能なascii文字を含むことができる. ホワイト・スペース(スペース,タブ,改行)が識別子の区切りとな … stringは、文字列を扱います。 2つのstring間では、次のような比較が行えます。 ・ Str1 == Str2 ・ Str1 != Str2 ・ Str1 < Str2 ・ Str1 <= Str2 ・ Str1 > Str2 次のようなこともできます。 ・ {Str1, Str2, ..., Strn} : 文字列を連結します …, ファイルやディレクトリにアクセス権を設定する際に、対象とするオブジェクトをどのように指定するかをまとめたものです。 ACE継承フラグ 値フラグ概要 0x1OBJECT_INHERIT_ACEコンテナで …, ファイルからの読み込み 環境:QT5.5 インクルードファイル 1 2 #include #include #include < …, システムの標準パス(Temp、Root、Downloadなど)を取得する。 以下のパスが取得できます。(OSにより異なります) QStandardPaths::DesktopLocation QSta …, 会社の資金繰りが悪化して、アラファイで突然転職活動をすることになり、1ヶ月で転職先を決めたときの話, 外資系IT企業、日系シンクタンクで、SEとして働いた後、コーチング専業会社に就業。転職エージェントを経て、IT業界に出戻りしました。, これまで数百名と面接してきた経験と、自分自身の経験をベースにITエンジニア向けの情報を発信しています。少しずつですが情報を更新中。. %o,octal conversion #include ひろみのみ , Also strings can be concatenated directly. 今... システムタスク $clog2 が使えます。2 を底とする対数の天井関数の結果が得られます。 http://doc.qt.io/qt-5/qstring.html#startsWith. 莫比(Phil Moorby)完成了Verilog的主要設計工作。1990年,Gateway設計自動化被Cadence公司收購。[7], 1990年代初,開放Verilog國際(Open Verilog International, OVI)組織(即現在的Accellera)成立,Verilog面向公有領域開放。[8]1992年,該組織尋求將Verilog納入電氣電子工程師學會標準 。最終,Verilog成為了電氣電子工程師學會1364-1995標準,即通常所說的Verilog-95。[9], 設計人員在使用這個版本的Verilog的過程中發現了一些可改進之處。為了解決用戶在使用此版本Verilog過程中反映的問題,Verilog進行了修正和擴充,這部分內容後來再次被提交給電氣電子工程師學會。這個擴充後的版本後來成為了電氣電子工程師學會1364-2001標準,即通常所說的Verilog-2001。Verilog-2001是對Verilog-95的一個重大改進版本,它具備一些新的實用功能,例如敏感列表、多維陣列、生成語句塊、命名埠連接等。[10]目前,Verilog-2001是Verilog的最主流版本,被大多數商業電子設計自動化軟體包支援。, 2005年,Verilog再次進行了更新,即電氣電子工程師學會1364-2005標準。該版本只是對上一版本的細微修正。這個版本還包括了一個相對獨立的新部分,即Verilog-AMS。[11]這個擴充使得傳統的Verilog可以對整合的類比和混合訊號系統進行建模。[12]:255容易與電氣電子工程師學會1364-2005標準混淆的是加強硬體驗證語言特性的SystemVerilog(電氣電子工程師學會1800-2005標準),它是Verilog-2005的一個超集,它是硬體描述語言、硬體驗證語言(針對驗證的需求,特別加強了物件導向特性)的一個整合。[13], 2009年,IEEE 1364-2005和IEEE 1800-2005兩個部分合併為IEEE 1800-2009,成為了一個新的、統一的SystemVerilog硬體描述驗證語言(hardware description and verification language, HDVL)。[14][15], 描述複雜的硬體電路,設計人員總是將複雜的功能劃分為簡單的功能,模組是提供每個簡單功能的基本結構。設計人員可以採取「自頂向下」的思路,將複雜的功能模組劃分為低層次的模組。[16]:58這一步通常是由系統級的總設計師完成,而低層次的模組則由下一級的設計人員完成。自頂向下的設計方式有利於系統級別層次劃分和管理,並提高了效率、降低了成本。[17]「由下而上」方式是「自頂向下」方式的逆過程。, 使用Verilog描述硬體的基本設計單元是模組(module)。[18]構建複雜的電子電路,主要是通過模組的相互連接呼叫來實現的。模組被包含在關鍵字module、endmodule之內。[16]:59實際的電路元件。Verilog中的模組類似C語言中的函式,它能夠提供輸入、輸出埠,可以實例呼叫其他模組,也可以被其他模組實例呼叫。模組中可以包括組合邏輯部分、過程時序部分。[18]例如,四選一的多路選擇器,就可以用模組進行描述。它具有兩個位選輸入訊號、四個資料輸入,一個輸出端,在Verilog中可以表示為:, 設計人員可以使用一個頂層模組,通過實例呼叫上面這個模組的方式來進行測試。這個頂層模組常被稱為「測試平台(Testbench)」。 ... 文字列への変換 文字列から、空白,タブ、改行文字を削除 The number o... SystemVerilog では string 型が使え、文字列操作もできるよ、という話です。 システムタスク $bits を使います。bit 幅 (integer) を返します。 Contact; ホーム. yahooやgoogleで念入りに調べたつもりですが、自分の求めているようなHPは見つからなかったので、こちらの掲示板に記載させて頂きます。すみませんが、誰かVerilog_HDLに詳しい方ご教授願いますでしょうか。(1)「define」と「parameter」 [19]為了最大程度地對電路的邏輯進行功能驗證,測試代碼需要儘可能多地覆蓋系統所涉及的語句、分支、條件、路徑、觸發、狀態機狀態,[20]:141-144驗證人員需要在測試平台里建立足夠多的輸入激勵,[21]:8並連接到被測模組的輸入端,然後檢測其輸出端的表現是否符合預期(諸如SystemVerilog的硬體驗證語言能夠提供針對驗證專門最佳化的資料結構,以隨機測試的方式進行驗證,這對於高度複雜的積體電路設計驗證可以起到關鍵作用)。實例呼叫模組時,需要將埠的連接情況按照這個模組聲明時的順序排列。這個頂層模組由於不需要再被外界呼叫,因此沒有輸入輸出埠:[3]:4, 在這個測試平台模組里,設計人員可以設定仿真時的輸入訊號以及訊號監視程式,然後觀察仿真時的輸出情況是否符合要求,這樣就可以了解設計是否達到了預期。[19], 範例中的對模組進行實例參照時,按照原模組聲明時的順序羅列了輸入變數。除此之外,還可以使用或者採用命名埠連接的方式。使用這種方式,埠的排列順序可以與原模組聲明時不同,甚至可以不連接某些埠:, 上面所述的情況是,測試平台頂層模組的測試變數直接連接了所設計的功能模組。測試平台還可以是另一種形式,即測試平台並不直接連接所設計的功能模組,而是在這個測試平台之下,將激勵模組和功能模組以相同的抽象級別,通過線網相互連接。[22]這兩種形式的測試平台都可以完成對功能模組的測試。大型的電路系統,正是由各個層次不同模組之間的連接、呼叫,來實現複雜的功能的。[3]:11, Verilog的設計初衷是成為一種基本語法與C語言相近的硬體描述語言。[2]:18這是因為在Verilog設計之初,C語言已經在許多領域得到廣泛應用,C語言的許多語言要素已經被許多人習慣。一種與C語言相似的硬體描述語言,可以讓電路設計人員更容易學習和接受。不過,Verilog與C語言還是存在許多差別。另外,作為一種與普通電腦程式語言不同的硬體描述語言,它還具有一些獨特的語言要素,例如向量形式的線網和暫存器、過程中的非阻塞賦值等。總的來說,具備C語言能力的設計人員將能夠很快掌握Verilog硬體描述語言。[23], 空白符是指代碼中的空格(對應的跳脫識別碼為\b)、制表符(\t)和換行(\n)。[16]:17如果這些空白符出現在字串里,那麼它們不可忽略。除此之外,代碼中的其他空白符在編譯的時候都將會被視為分隔識別碼,即使用2個空格或者1個空格並無影響。[24]不過,在代碼中使用合適的空格,可以讓上下行代碼的外觀一致(例如使設定運算子位於同一個豎直列),從而提高代碼的可讀性。, 為了方便代碼的修改或其他人的閱讀,設計人員通常會在代碼中加入注釋。與C語言一樣,有兩種方式書寫注釋。第一種為多行注釋,即注釋從/*開始,直到*/才結束;另一種為單行注釋,注釋從//開始,從這裡到這一行末尾的內容會被系統辨識為注釋。[25], 某些電子設計自動化工具,會辨識出代碼中以特殊格式書寫、含有某些預先約定關鍵詞的注釋,並從這些注釋所提取有用的資訊。這些注釋不是供人閱讀,而是向第三方工具提供有關設計專案的額外資訊。例如,某些邏輯綜合工具可以從注釋中讀取綜合的約束資訊。[26]:24, Verilog是一種大小寫敏感的硬體描述語言。其中,它的所有系統關鍵字都是小寫的。[3]:29[27], Verilog代碼中用來定義語言結構名稱的字元稱為識別碼,包括變數名、埠名、模組名等等。識別碼可以由字母、數位、底線以及美元符($)來表示。但是識別碼的第一個字元只能是字母、數位或者底線,不能為美元符,這是因為以美元符開始的識別碼和系統任務的保留字衝突。[28]:19, 和其他許多程式語言類似,Verilog也有許多保留字(或稱為關鍵字),用戶定義的識別碼不能夠和保留字相同。Verilog的保留字均為小寫。[28]:19變數類型中的wire、reg、integer等、表示過程的initial、always等,以及所有其他的系統任務、編譯指令,都是關鍵字。[29]可以查閱官方文獻以完整的關鍵字的列表。, 跳脫識別碼(又稱跳脫字元),是由\開始,以空白符結束的一種特殊程式語言結構。[29]這種結構可以用來表示那些容易與系統語言結構相同的內容(例如"在系統中被用來表示字串,如果字串本身的內容包含一個與之形式相同的雙引號,那麼就必須使用跳脫識別碼)。下面列出了常用的幾種跳脫識別碼。除此之外,在反斜線之後也可以加上字元的ASCII,這種跳脫識別碼相當於一個字元。常用的跳脫識別碼有\n(換行)、\t(制表位)、\b(空格)、\\(反斜槓)和\"(英文的雙引號)等。, 上面列出了Verilog採用的具有八種訊號強度的四值邏輯(four-valued logic),數位電路中的訊號可以用邏輯值、訊號強度加以描述。當系統遇到訊號之間的競爭時,需要考慮各組訊號的狀態和強度。如果驅動統一線網的訊號強度不同,則輸出結果是訊號強度高的值;如果兩個強度相同的訊號之間連接到同一個線網,將會發生競爭,結果為不確定值x。[28]:20, Verilog所用到的所有變數都屬於兩個基本的類型:線網類型和暫存器類型。[3]:30, 線網與我們實際使用的電線類似,它的數值一般只能通過連續賦值(continuous assignment),由賦值符右側連接的驅動源決定。[30]線網在初始化之前的值為x(trireg類型的線網是一個例外,它相當於能夠儲存電荷的電容器[22]:105)。如果未連接驅動源,則該線網變數的當前數值為z,即高阻態。線網類型的變數有以下幾種:wire、tri、wor、trior、wand、triand、tri0、tri1、supply0、supply1、trireg,其中wire作為一般的電路連線使用最為普遍,[31]而其他幾種用於構建匯流排,即多個驅動源連接到一條線網的情況,[3]:79-80或搭建電源、接地等。當進行模組的埠聲明時,如果沒有明確指出其類型,那麼這個埠會被隱含地聲明為wire類型。因此,在聲明輸出埠時應該注意是否有必要加上reg關鍵字。以下面的代碼片段為例:, 暫存器與之不同,它可以儲存當前的數值,直到另一個數值被賦值給它。在保持當前數值的過程中,不需要驅動源對它進行作用。[30]如果未對暫存器變數賦值,它的初始值則為x。Verilog中所說的暫存器類型變數與真實的硬體暫存器是不同的,它是指一個儲存數值的變數。如果要在一個過程(initial過程或always過程)里對變數賦值,這個變數必須是暫存器類型的。暫存器類型的變數有以下幾種:reg(普通暫存器)、integer(整數)、time(時間)、real(實數),其中reg作為一般的暫存器使用最為普遍。[32]利用暫存器變數的陣列,還可以對ROM進行建模。[30], 關於選擇線網類型還是暫存器類型,需要符合一定的規定。模組的輸入埠可以與外界的線網或暫存器類型的變數連接,但是這個模組輸出埠只能連接到外界的線網。再簡單點,就是在兩個模組的訊號連接點,提供訊號的一方可以是暫存器或者線網,但是接受訊號的一方只能是線網。[28]:35-36此外,在initial、always過程代碼塊中賦值的變數必須是暫存器類型的,[28]:58[3]:30而連續賦值的物件只能是線網類型的變數。[28]:81[3]:81, 在Verilog里,當一個變數的類型確定,即已經知道它是暫存器類型或者是線網類型,當把具體的數值賦值給它時,需要利用下面所述的數位表示方法。數位表示的基本語法結構為<位宽>'<数制的符号><数值>。[3]:31其中,位寬是與資料大小相等的對應二進位數的位數加上占位所用0的位數,這個位數需要使用十進位來表示。位寬是可選項,如果沒有指明位寬,則預設的資料位寬與仿真器有關(最小32位元);數制需要用字母來表示,h對應十六進位,d對應十進位,o對應八進位,b對應二進位。如果沒有指明數制,則預設資料為十進位數。[28]:18例如:, 如果某個數的最高位為x或z,那麼系統會自動使用x或z來填充沒有占據的更高位。如果最高位為其他情況,系統會自動使用0來填充沒有占據的更高位。, 向量形式的資料是Verilog相對C語言較為特殊的一種資料,但是這種資料在硬體描述語言中十分重要。在Verilog中,純量的意思是只具有一個位元的變數,而向量表示具有多個位元的變數。如果沒有特別指明位寬,系統預設它為純量。[28]:21, 在真實的數位電路,例如將兩個四位二進位數相加的進位加法器中,我們可以發現,其中一個數是通過四條電線(每條線表示四位中的某一位)連接到加法器上的。我們可以用一個向量來表示這個多位數,分別用這個向量的各個分量來表示「四條電線」,即四位中的某一位。這樣做的好處是,可以方便地在Verilog代碼的其他地方選擇其中的一位(位選)或多位(域選)。[28]:22當然,如果沒有進行位選或域選,則這個多位數整體被選擇。, 向量的表示需要使用方括號,方括號里的第一個數位為向量第一個分量的序號,第二個數位為向量最後一個分量的序號,中間用冒號隔開。向量分量的序號不像C語言的陣列一樣必須從0開始,不過為了和數位電路里二進位數高低位的表示方法一致,我們常常讓最低位為0(即對於四位二進位數,其最高位為第3位,次高位為第2位,次低位為第1位,最低位為第0位),當然這只是一種習慣。例如,上面提到的四位二進位數用向量表示為:, 上面的向量聲明之後,我們就可以方便地選擇其中的某幾個分量進行操作。請注意用於域選的方括號的位置在向量名稱之後,方括號內的數位為所需的位數。例如我們可以進行以下操作:, 當對向量進行賦值時,如果右邊的數值位寬大於左邊的變數,則多出來的位被丟棄;如果右邊的數值位寬小於左邊的變數,則不夠的位用0填補。, Verilog中的幾種暫存器類型的資料,[3]:32包括reg、integer、time、real,以及由這幾種資料構成的向量,都可以構成陣列。聲明陣列時,方括號位於陣列名的後面,括號內的第一個數位為第一個元素的序號,第二個數位為最後一個元素的序號,中間用冒號隔開。如果陣列是由向量構成的,則陣列的其中某個元素是向量。同樣,出於習慣考慮,我們一般讓陣列第一個元素的序號為0,後面元素的序號依次遞增。此外,和C語言類似,用戶可以聲明多維陣列。例如:, 由於陣列和向量的表示都使用了方括號,因此使用時需要注意這個變數或向量的名稱在最初被聲明為何種類型的資料。上面第三行的例子是65536個8位元向量組成的向量陣列,它可以描述一個64KB的記憶體。, 表示陣列某個元素時,允許使用變數來表示元素的索引(如number [i] = 1234;),但是表示一個向量的一位或者幾位時,只允許使用數位來表示位的索引;此外,使用陣列時一次只能對一個元素進行操作,而不能向向量那樣同時對連續的幾個位進行操作,例如my_input [65535][7:4] = 4'b1010;將一個四位二進位數賦值給第65536個元素的高四位。[26]:86, 可以通過parameter關鍵字聲明參數。參數與常數的意義類似,不能夠通過賦值運算改變它的數值。在模組進行實例化時,可以能夠通過defparam,即參數多載語句塊來改變模組實例的參數。另一種方法是在模組實例化時,使用#()將所需的實例參數覆蓋模組的預設參數。局部參數可以用localparam關鍵字聲明,它不能夠進行參數多載。[28]:25, 在設計中使用參數,可以使得模組代碼在不同條件下被重複利用,例如四位數全加器和十六位數全加器可以通過參數實例化同一個通用全加器模組。[33]:29, Verilog中的字串總體來說與C語言中的字串較為類似,其中每個字元以ASCII表示,占8位元。[34]字串儲存在位寬足夠的向量暫存器中。字串中的空格、換行等特殊內容,以跳脫識別碼(參見前面提到過的跳脫識別碼)的形式表示。, 為了使設計人員方便地使用暫存器傳輸級描述,Verilog提供了多種流程控制結構,包括if、if...else、if...else if...else等形式的條件結構,case分支結構,for、while迴圈結構。這些流程控制結構與C語言有著相似的用法。不同的迴圈結構可能造成不同的邏輯綜合結果。[35]Verilog也提供了一些C語言中沒有的流程控制結構以適應硬體描述語言的需要,例如casex、casez兩種選擇結構,前者可以條件數值中的x、z均作為無關值,後者僅將z作為無關值;[22]:53[3]:87-88此外還提供了forever、repeat兩種迴圈結構,分別用於無限迴圈和指定次數迴圈。[2]:56-65[16]:109-126數位電路的邏輯功能描述常常使用到這些流程控制結構,例如,case結構可以清晰地描述一個數據多工器。, Verilog的許多運算子和C語言類似,但是有一部分運算子是特有的,例如拼接運算子、縮減運算子、帶有無關位的相等運算子等。, 系統任務可以被用來執行一些系統設計所需的輸入、輸出、時序檢查、仿真控制操作。[3]:51-53所有的系統任務名稱前都帶有美元符號$使之與用戶定義的任務和函式相區分。[36]例如,$display用於顯示指定的字串,然後自動換行(用法類似C語言中的printf函式);$monitor用於監視變數,一旦被監視的變數發生變化,會顯示指定的字串;而$time可以提取當前的仿真時間。完整的列表請查閱參考工具、Verilog手冊或標準文件。[37], Verilog具有一些編譯指令,它們的基本格式為`,注意第一個符號不是單引號,而是鍵盤上數位1左邊那個鍵對應的撇號。常用的編譯指令有文字宏預定義`define、`include,它們的功能與C語言中類似,分別提供文字替換、檔案包含的功能。Verilog還提供了`ifdef、`ifndef等一系列條件編譯指令,設計人員可以使得代碼在滿足一定條件的情況下才進行編譯。此外,`timescale指令可以對時間單位進行定義。[28]:132詳細的編譯指令清單請參閱相關參考書籍。, 在Verilog中,可以聲明兩種不同的過程:always過程和initial過程。過程可以是包含時序的過程描述,而不包含時序的過程還可以表達組合邏輯。[22]:170always過程從關鍵字always開始,可以連續多次執行,當過程的最後一行代碼執行完成後,再次從第一行代碼開始執行。如果沒有使用系統任務$finish,always過程將不斷迴圈執行。initial過程從關鍵字initial開始,它只能執行一次。[38]:140-145, 一個模組中可以包含多個過程,各個過程相互之間是並行執行的。不過,過程不能夠巢狀使用。如果過程中有多個語句,則需要使用關鍵字begin、end或fork、join將它們組成一個代碼塊。這兩種關鍵字組合代表著順序代碼塊和並列代碼塊,後面的部分會講述這兩種結構。, 例如,利用always過程迴圈執行的特點,可以為模組提供一個時間脈衝(注意第一個initial過程為時鐘的初始化,這個過程只需要進行一次):, 雖然,always代碼塊和while語句、forever語句都能提供迴圈功能,但是always代碼塊的迴圈更側重過程的迴圈執行,而後二者更側重代碼的迴圈執行。因此,為了使代碼更具條理,過程的迴圈應當用always語句描述。當然,在實際使用過程中,強制使用其中的某一種在功能實現上都是可行的。, 在Verilog中,有兩種賦值運算,一種叫做阻塞賦值(blocking assignment),其運算子為=;另一種叫做非阻塞賦值(non-blocking assignment),其運算子為<=。在順序代碼塊中使用阻塞賦值語句,如果這一句沒有執行完成,那麼後面的語句不會執行;如果在順序代碼塊中使用非阻塞賦值,則執行這一句的同時,並不會阻礙下一句代碼的執行。[3]:47而且,如果後一個語句涉及前面一個非阻塞賦值語句中的變數,由於這兩個語句「同時」執行,因此後一個語句所用到的是前面一個語句執行前變數的數值。非阻塞賦值是Verilog作為硬體描述語言與普通程式語言的一個重大區別。, 上面的例子如果沒有使用非阻塞賦值,而使用阻塞賦值,那麼flop1和flop2的數值就不能被交換。flop1和flop2在執行完畢後的數值都與之前flop2的數值相同。在傳統的程式語言中,可能需要一個臨時的變數,或者使用指標,才能夠達到交換兩個變數的目的。這裡使用了非阻塞賦值,相當於引入了一個隱含的臨時變數。第二個非阻塞賦值右邊的a是第一句賦值之前的數值,變數交換的目的得以實現。[28]:84訊號邊緣敏感的過程語句塊內常使用非阻塞賦值,使語句塊的諸賦值語句同時進行,雖然功能上似乎可以用阻塞賦值實現,但是仿真時會產生不正常的結果。[22]:180, 通常的過程賦值語句往往只有在觸發或迴圈等情況,即賦值語句被執行到時候,才會使左邊的暫存器變數改變一次;而線網變數的連續賦值則一直「監視」右邊表達式的變化,一旦其結果發生變化,立即會左邊的線網變數更新為此結果。[22]如果需要對暫存器變數進行過程連續賦值,則可以使用Verilog提供的assign或force關鍵字「強制地」將設定運算子右邊表達式的結果連續不斷地施加在左邊的暫存器變數上。, 對線網類型變數的連續賦值是數位電路資料流建模的重要步驟,數位系統不含時序的組合邏輯部分可以使用線網的連續賦值描述。線網不能夠像暫存器那樣儲存當前數值,它需要驅動源提供訊號,這種驅動是連續不斷的,因此線網變數的賦值稱為連續賦值,這與暫存器變數在過程中的單次賦值不同,而且所用的運算子也有區別。在Verilog里,線網連續賦值的關鍵字為assign,下面為一個例子:, 在這個例子中,線網變數out在系統執行過程中總為兩個輸入線網變數in1和in2邏輯與的結果。, 線網的連續賦值可以在關鍵字assgin附加延遲資訊,[3]:43例如上面的代碼可以改為:, Verilog能夠描述過程中的時序特性,這也是硬體描述語言與普通電腦程式語言的重要差別之一。過程的時序控制可以通過三種方式實現:延遲時序控制、事件時序控制以及電平敏感時序控制。, 過程中的時序控制可以控制代碼的執行時間。在Verilog中,除了過程中的時序控制,還可以定義元件、路徑的延遲。這些延遲請參見本條目後面有關邏輯閘級延遲的部分。, 在代碼中使用關鍵字#和延遲的時間,就可以通過延遲來進行時序控制。延遲的時間可以是數位、變數或者表達式。延遲時序控制又分為兩種:常規延遲和內嵌延遲。[16]:89, 常規延遲在賦值語句的左邊,系統執行到這一行代碼時,系統先進行延遲,延遲完成後,再計算表達式,並將結果賦值給左邊的變數;而內嵌延遲在賦值語句的右邊,系統執行到這一行代碼時,系統先立即計算表達式,再進行延遲,最後把表達式的結果賦值給左邊的變數。在上述兩種延遲方式中,設計人員需要注意表達式的自變數在延遲過程中可能發生變化。常規延遲是先延遲再計算表達式,這時表達式的自變數可能已經發生了變化;而內嵌延遲在延遲前就已經進行了計算,表達式的自變數在延遲過程中發生的變化,對已經計算的表達式結果沒有影響,延遲只是指這個結果需要等待一段時間再賦值給左邊的變數。[16]:89-93, 在順序語句塊(begin...end)中,由於語句是從上到下、一行一行地執行,而所有常規延遲時間都是實際執行時間相對於這一句本來應該開始執行的時間(也是上一句執行完成之時)的延遲值。因此,在上面的代碼範例中,對變數y的賦值時間相對於上一句結束延遲了8個系統周期,而上一句相對系統零時刻已經延遲了5個系統周期,因此對y的賦值發生在第13個系統周期。不過,如果順序語句塊中存在非阻塞賦值,由於這個結構有著類似並列語句塊的特點,因此需要特別考慮。, 在並列語句塊(fork...join)中,由於所有語句都是並行執行的,而所有常規延遲時間都是實際執行時間相對於這一句本來應該開始執行的時間(也是系統零時刻)的延遲值,因此各個常規延遲所指的時間都是相對於系統零時刻。, 事件時序控制的意思是,如果指定的事件發生,則代碼被觸發執行。它的關鍵字為@,後面可以加變數或者事件名稱。參見下面的例子:, 上面@後面括號里的是常規事件。Verilog允許設計人員通過關鍵字event和觸發符號->定義自己所需要的命名事件觸發:, 一種經典的用法結構如下,可以理解為「在整個仿真過程中,一旦某變數發生變化,就執行某操作」:, 另一種用法稱為OR事件時序控制,其代碼結構為@(a or b)或@(a, b),即當a或b其中任意一個變數發生變化時,代碼或代碼塊才被觸發執行。監視的變數如果有3個,則其代碼結構變為@(a or b or c)或@(a, b, c),以此類推。如果需要監視的變數很多,則可以使用@*或@(*),它表示對之後代碼塊中的所有輸入變數敏感。此外,敏感列表中除了變數,還可以是前面所提到過的常規事件、命名事件。[28]:87-89, Verilog中還有一種電平敏感時序控制方式,即使用wait(a),當變數a為真,則執行後面的代碼塊。[28]:69, begin、end組合代表了這個代碼塊的各行代碼是順序執行的,這種代碼塊稱為順序代碼塊;[16]:66-67後面的fork、join代表了這個代碼塊的各行代碼是並行執行的,這種代碼塊稱為並列代碼塊。[16]:68-69與模組、過程不同,兩種代碼塊是可以巢狀,即順序代碼塊中可以包含並列代碼塊。[16]:69-72下面的例子展示了這兩種代碼塊巢狀使用的效果:, 由於這個initial過程使用了關鍵字fork、join,其中x、y、z的賦值同時於系統零時刻發生,而z和w由於位於一個順序代碼塊中,因此w的賦值在z的賦值後才進行。, 在使用並列代碼塊的時候,有可能引起代碼的競爭,例如兩個語句對一個變數同時進行賦值。雖然理論上兩個語句同時執行,但是具體的情況是必然有一句先執行,但這與順序語句塊的「先後」有本質區別。實際的先後順序取決於所用的仿真系統。[28]:95這並不是Verilog硬體描述語言本身的缺陷,並列語句塊是一種人為設定的功能,這可以讓設計人員更容易地描述某些過程,當然他們必須認真考慮競爭帶來的潛在問題。, 任務通過關鍵字task來聲明。任務可以有零個或者多個輸入變數,但是沒有輸出返回值。呼叫任務時,將按照任務內指定的方式處理這些變數。由於它相當於一個子過程,因此任務中賦值的變數只能是暫存器類型的,而且只能使用過程賦值語句。任務可以具有時序結構,例如延遲、非阻塞賦值等。任務中可以呼叫任務和函式。[2]:79與模組的聲明不同,任務的聲明沒有類似模組埠列表的輸入變數列表。儘管如此,呼叫任務的時候,還是需要在括號里按照任務聲明時的順序羅列輸入變數。[22]:57在某種程度上,任務和C語言中沒有返回值的函式有些類似。, 函式通過關鍵字function來聲明。函式不僅有輸入變數,還有一個返回值作為輸出變數,這個返回值的名稱與函式的名稱相同。函式與任務不同,它是一個只有邏輯功能的部分,不能包含時序結構。函式中只能呼叫函式。[2]:79Verilog中的函式與C語言中有返回值的函式有些類似。通常將函式放在設定運算子的右邊,它的返回值被賦值給左邊的變數。[39], 如果任務或函式同時在多個地方被呼叫,則需要使用automatic關鍵字聲明,這樣系統可以為不同地方的呼叫分配獨立的記憶體空間。[28]:118[28]:121-122, 邏輯閘級描述的抽象級別較低,僅次於電晶體級。實際的硬體電路往往都是以邏輯閘級網表作為基礎構建的,而設計人員常常會在進行更高抽象級別的設計。儘管如此,邏輯閘級的設計還是更接近真實電路形式。Verilog提供了一系列邏輯閘原語(Primitive)供用戶使用。例如,非(not)、及閘(and)、或閘(or)、反及閘(nand)、或非(nor)、互斥或(xor)、同或(xnor)。邏輯閘原語和模組類似,可以通過實例參照的方式使用。[16]:156, Verilog能夠在低抽象級別對電路進行描述,是它的一個重要特點。Verilog中提供了多種電晶體級(也稱開關級)元件類型,包括N型金屬氧化物半導體場效電晶體(關鍵字為nmos)、P型金屬氧化物半導體場效電晶體(關鍵字為pmos)、互補式金屬氧化物半導體(關鍵字為cmos)、帶阻抗的互補式金屬氧化物半導體(關鍵字為rcmos)、電源單元(關鍵字為supply1)、接地單元(關鍵字為supply0)等。所有的電晶體都可以設定延遲屬性。[3]:9設計人員可以利用這些低抽象級元件構建所需要的邏輯閘或直接構成其他進階組件。[28]:158-167, 真實的硬體電路不可避免地都存在延遲現象。在Verilog中,可以對邏輯閘、電晶體這些元件的延遲資訊進行描述。可以為元件的延遲指定一個時間,則上升、下降、關斷的延遲都使用這個時間;也可以按照先後順序分別指定上升延遲、下降延遲,而關斷延遲取二者較小值;當然也可以為上升、下降、關斷各指定一個時間。[28]:50-51例如,下面的代碼為及閘實例添加了三個延遲時間,分別對應上升、下降、關斷:, 邏輯閘和電晶體的延遲屬於「慣性延遲」。它的意思是,邏輯閘和電晶體獲得外部輸入之後,延遲指定的時間後,才會將結果呈現在輸出端上。在延遲期間,如果輸入改變,但是這個訊號的持續時間小於指定延遲的時間,則不會影響邏輯閘和電晶體的輸出;如果這個訊號的持續時間大於指定延遲的時間,則之前的結果將不會呈現在輸出端,改變輸入訊號後的結果將經過延遲後將呈現在輸出端[22]:143-144, Verilog還允許設計人員為每個延遲時間設定最大值、典型值、最小值,在編譯階段可以通過編譯代碼選擇其中一個。[28]:51-52, 在聲明線網或對線網進行連續賦值的時候,可以為線網添加延遲資訊。這樣,所有連續賦值給線網的表達式都會立即計算出結果,但是這個結果在延遲時間後才會賦值給線網。[3]:43如果在這段延遲時間內,右側表達式的結果發生變化,則用於賦值的表達式結果取變化後的。另外,如果如果輸入變數變化的脈衝寬度小於延遲的時間,其變化不會對輸出造成影響。這種延遲被稱為「慣性延遲」,[28]:59邏輯閘和電晶體的延遲也是這種情況。, 過程延遲在前面的延遲時序控制一部分講述過。過程賦值語句中的延遲主要分為常規延遲(又稱為外部延遲)和內嵌延遲(又稱為內部延遲)兩種,其中前者先延遲,再計算表達式、賦值給左邊的變數;而後者先立即計算表達式,經過延遲後再將結果賦值給左邊的變數。[16]:89-93, 設計人員可以在模組中關鍵字specify、endspecify之間對路徑延遲進行描述。與元件的延遲不同,路徑延遲是指訊號在某兩個暫存器類型或線網類型變數之間傳遞所需的延遲時間。在specify代碼塊中可以使用條件結構來根據情況選擇所需的延遲時間值。與元件延遲相同的是,延遲的時間值可以指定上升、下降、關斷的情況,同時也可以包含最大值、典型值、最小值。[28]:148-153, 設計人員編寫的Verilog代碼通常是在較高抽象級別的,例如暫存器傳輸級。這一抽象級別包含了對電路訊號在暫存器之間傳輸情況的描述。但是邏輯閘級的網表,即邏輯閘的相互連接形式,才最接近真實的硬體電路。這一形式與暫存器傳輸級的描述,在功能上是等效的。為了給後續硬體製造人員提供這種低抽象級別的描述,需要將高抽象級別的Verilog代碼轉換為低抽象級別的邏輯閘級網表。這一過程稱為邏輯綜合(Logic Synthesis)。[3]:5[12]:253, 在自動化邏輯綜合工具出現之前,儘管人們可以用硬體描述語言進行設計,但是還是需要人工進行邏輯綜合。例如,如果電路模組只有少數幾個輸入端,我們可以使用類似卡諾圖的方法來對邏輯函式進行化簡。隨著電路規模不斷增加,人工邏輯綜合的容易出錯、耗費大量時間的缺點逐漸凸顯。同時,在某種特殊器件製程下最佳化的綜合結果不一定在另一種製程下還合適,如果需要採用另外的製程,設計人員需要花費很長時間重新進行邏輯綜合。隨著自動化邏輯綜合工具的出現,硬體描述語言、所需器件製程資訊(製程庫)可以直接被邏輯綜合工具讀取,通過其內部的自動綜合演算法,輸出符合設計約束(通常包括時序、功耗、面積的約束)的邏輯閘級網表。藉助自動綜合工具,設計人員可以將更多的精力放在高抽象級別的硬體描述語言設計。[28]:203-204, 邏輯綜合工具不能接受所有的Verilog代碼。設計人員需要確保硬體描述語言代碼是周期到周期的暫存器傳輸級描述。諸如while的迴圈結構必須通過訊號邊緣的形式(如@(posedge clock))提供終止條件;initial結構可能也不能被轉換。如果不指明數位的位寬,那麼系統可能預設它為一個較大的值(如32位元),這就可能產生規模非常龐大的邏輯閘級網表,其中一部分是不必要的,這將造成資源的浪費。與未知邏輯x、高阻態z有關的運算子不能被轉換,例如===、!==。此外,條件結構如果只有if而沒有對else的情況進行設計,或者選擇結構缺少預設情況default,很可能產生預期之外的閂鎖。[3]:93由於需要使用與製程相關的邏輯閘,因此用戶自訂的原語很可能不能被轉換。[3]:91設計人員需要採取良好的代碼風格,以獲得更最佳化的邏輯綜合結果。[28]:204-219為了適應符合可重用設計思想的系統晶片、矽智財設計,設計人員還應該遵循更嚴格的編碼規範。[40], 除了系統提供的26種邏輯閘、電晶體原語,[22]:103-104Verilog也提供用戶自訂原語(User Defined Primitive, UDP)。原語與模組的階層類似,但是原語的輸入輸出關係是完全通過查表實現的。組合邏輯的用戶自訂原語的核心是真值表,序向邏輯的用戶自訂原語的核心是激發表。設計人員需要在狀態表中羅列可能出現的輸入和輸出情況。如果在實際使用過程中,遇到狀態表中沒有定義的情況,則輸出不確定值x。[3]:62使用自訂原語很直觀,但是如果輸入變數較多,狀態表就會變得很複雜。在很多情況中,用戶自訂原語並不能被邏輯綜合工具轉換。[3]:91[22]:200, 程式語言介面(Program Language Interface, PLI)提供了通過C語言函式對Verilog資料結構進行儲存、讀取操作的途徑。[3]:9, Verilog程式語言介面的發展先後經過了三代,其中第一代為任務或函式子程式,它可以在C程式和Verilog設計之間傳遞資料;第二代為存取子程式,它可以在用戶自訂C程式和Verilog的內部資料表示的介面上被使用;第三代為Verilog過程介面,它進一步擴充了前兩代程式語言介面的功能。[28]:199-200, 通過使用程式語言介面,設計人員可以自訂介面的功能,然後通過類似呼叫系統任務的方式呼叫這些自訂功能。這樣,設計人員可以很大程度地擴充他們能使用的功能,例如監視、激勵、除錯功能,或者用它來提取設計資訊、顯示輸出等。[28]:184-186, Verilog作為業界使用最廣泛的硬體描述語言之一,有大量的電子設計自動化工具對它予以支援。通過使用整合式開發環境,設計人員可以在常見的Windows或其他圖形化系統中進行設計、仿真、驗證,例如Cadence和Synopsys等公司提供的積體電路電腦輔助設計系統。[42], Verilog硬體描述語言(Verilog Hardware Description Language)的英語縮寫Verilog HDL和另一種類似的硬體描述語言VHDL在名稱上容易混淆,實際上二者是兩種不同的硬體描述語言。[43]一些進階的電子設計自動化工具支援用戶在專案內同時使用Verilog和VHDL來進行硬體設計。[44]:18, VHDL是由美國國防部主持研發的硬體描述語言,成為了第一個成為電氣電子工程師學會標準的硬體描述語言,美國政府相關的專案都是基於VHDL;而Verilog由民間商業公司的私有產品發展為IEEE標準的,因此在商用領域的市場占有量更大,設計人員和支援資源比VHDL更廣。在美國大約有10萬設計人員、200所大學教授採用Verilog硬體描述語言。[45], Verilog和VHDL作為業界廣泛認可、同為電氣電子工程師學會標準的硬體描述語言,有著各自的特點。VHDL的設計之初就更加針對標準化進行設計,Verilog則具有簡明、高效的代碼風格。[16]:4兩種語言都能夠在多個抽象層次對數位電路建模,並且可以與驗證、仿真、綜合工具協同工作。其中,Verilog的邏輯閘級、電晶體級級電路描述能力更強,VHDL不具備這樣低階的描述能力,但是另一方面,VHDL的系統級抽象描述能力則比Verilog強。[12]:255另外,由於Verilog與C語言在語法上有相似之處,因此具有C語言基礎的設計人員更容易掌握它,[38]:11而VHDL設計人員需要具有Ada語言編程基礎,並且學習周期比Verilog更長。相關學術文獻顯示,在美國的進階數位系統設計領域,Verilog和VHDL的使用比率大約分別為80%和20%,這項比率在日本和台灣和美國相似。[45]隨著Verilog-A被合併到Verilog標準之中,而該部分後來成為了Verilog-AMS的一部分,該語言增加了對類比電子系統的描述能力,因此它在混合訊號積體電路中有著更廣泛的應用。[5], //使用内嵌延迟:先用当前时刻的x、y数值计算(x+y),再等待10个系统周期后对z赋值, Provider Backbone Bridge Traffic Engineering, Universal Power Adapter for Mobile Devices, IEEE P1364-2005: IEEE Standard Verilog Hardware Description Language, Little Bit of History: Gateway was acquired by Cadence, 1364-1995 - IEEE Standard Hardware Description Language Based on the Verilog(R) Hardware Description Language, 1364-2005 - IEEE Standard for Verilog Hardware Description Language, IEEE approves SystemVerilog, revision of Verilog, 1800-2009 - IEEE Standard for SystemVerilog--Unified Hardware Design, Specification, and Verification Language, Verilog HDL Syntax And Semantics Part-I: White Space, Verilog HDL Syntax And Semantics Part-III: Types of Nets, Verilog HDL Syntax And Semantics Part-III: Register Data Types, Cornell ECE576 Course illustrating synthesis constructs, https://zh.wikipedia.org/w/index.php?title=Verilog&oldid=62497383.

ű崎賢人 ĸ演男優賞 Áぜ 18, Âイフェイス ɀ明 Ťし方 16, Ãニラバー Žたり 2020 4, Ps4 Ãディアプレイヤー Vr ņ生 Áきない 13, Android Ãック画面 Âラーム 7, Ƅ知県 Ź稚園 Âロナウイルス 14, Z会 Ņ会 Âャンペーン 5,

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.