大家在構(gòu)建測試激勵時,經(jīng)常會遇到需要使某個信號強制變成某個值,此時我們經(jīng)常會用到Verilog和SystemVerilog中的force實現(xiàn)這樣的功能。但是有時候在對多位寬的信號進行force時有時會出現(xiàn)編譯錯誤,這是為什么呢?本文將對此類情況進行示例說明。
【示例】
【仿真結(jié)果】
示例中,通過三種方式對sig中的部分位選進行了force。通過force將sig中的第0位force為了1,從顯示信息可以看到sig[0]已經(jīng)被修改;通過force將sig中的第0位和第1位force為了00,從顯示信息可以看到sig[1:0]已經(jīng)被修改;通過force將sig整體force為了0111,從顯示信息可以看到sig[1:0]已經(jīng)被修改;
可以看到,我們可以通過force對于變量、變量中的某一位或者某一個片段進行改變,那么可能有些人覺得這么一位一位的進行force太麻煩了,是否可以使用for循環(huán)對sig中所有位遍歷進行force呢?請看下例。
【示例】
【仿真結(jié)果】
編譯錯誤!這是為什么呢?對比該示例和上一示例,可以發(fā)現(xiàn)當信號的索引為常值時,可以進行force,但是當索引為變量時,此時編譯不通過。
也就是說在對信號進行force的時候,如果要對其中的某一位或者一個片段進行force時,其中的索引只能是常數(shù)不能是變量,否則將會導致便以失敗。
那么如果想實現(xiàn)通過變量實現(xiàn)對于多位寬信號中每一位進行force還有什么辦法嗎?下面我們通過示例介紹幾種。
【示例】使用generate結(jié)構(gòu)
【仿真結(jié)果】
示例中,使用generate結(jié)構(gòu)實現(xiàn)了對于sig中每一位的遍歷。這其實借助了generate是在仿真前的析構(gòu)(elaboration)階段完成的特性,即在仿真開始之前,相當于已經(jīng)將sig被force的每一位的initial結(jié)構(gòu)都已經(jīng)生成好了,這樣在仿真開始執(zhí)行時(生成好的initial塊開始被執(zhí)行時),其中“force sig[i]”中的i都已經(jīng)是確定的值了,因此就可以避免force信號中某一位時,索引為變量的情況。
除了這種在析構(gòu)(elaboration)階段就生成好語句結(jié)構(gòu)的方式外,還可以想如下方式操作。
【示例】
【仿真結(jié)果】
示例中,實際上是將要force的信號每一位都單獨寫了出來,即保證了被force信號的索引都是常量,缺點是,如果這個信號比較寬,那么寫起來比較枯燥,沒有上一種使用generate結(jié)構(gòu)方便。但是實際上兩者之所有都沒有問題,其實都是保證了被force信號的索引是個常值。
所以,如果在實際使用時,需要對多位寬信號的每一位或者某一個片段進行force,那么需要保證被force的那一位或者那一個片段的索引值在仿真運行開始時是常值。
審核編輯:劉清
-
仿真器
+關注
關注
14文章
1014瀏覽量
83591 -
Verilog語言
+關注
關注
0文章
113瀏覽量
8206
原文標題:如何遍歷force多位寬信號的每一比特
文章出處:【微信號:處芯積律,微信公眾號:處芯積律】歡迎添加關注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關推薦
評論