verilog語法-淺談case casez casex
來源:
責編:
時間:2023-09-04 10:17:00
311觀看
導讀1、語法說明在rtl仿真中,有四種狀態,分別是0、1、x(unknown values)和z(high-impedance values)。 case 結構體中:0,1,X與Z是四種不同的狀態,case條件比較時會檢測比較雙方每個bit是否完全相等。casez 結構體中:把Z當做don’
在rtl仿真中,有四種狀態,分別是0、1、x(unknown values)和z(high-impedance values)。case 結構體中:0,1,X與Z是四種不同的狀態,case條件比較時會檢測比較雙方每個bit是否完全相等。casez 結構體中:把Z當做don’t care conditions,case條件比較時,比較雙方存在Z值的bit位不參與比較 ,其他比特位相等則視為條件命中casex 結構體中:把Z和X當做don’t care conditions,case條件比較時,比較雙方存在Z或者X的bit位不參與比較,其他比特位相等則視為條件命中- 在casex、casez中推薦使用 ?來替換Z和X
- case、casex、casez語句中,如果命中多個case條件,則執行命中的第一個case
LmZ28資訊網——每日最新資訊28at.com
2、案例解析
LmZ28資訊網——每日最新資訊28at.com
always@(*)
begin
case(sel[1:0])
2'b00: data1 = 3'd0 ;
2'b01: data1 = 3'd1 ;
2'b10: data1 = 3'd2 ;
2'b11: data1 = 3'd3 ;
2'b1z: data1 = 3'd4 ;
2'b1x: data1 = 3'd5 ;
default: data1 = 3'd7 ;
endcase
end
always@(*)
begin
casez(sel[1:0])
2'b00: data2 = 3'd0 ;
2'b01: data2 = 3'd1 ;
2'b10: data2 = 3'd2 ;
2'b11: data2 = 3'd3 ;
2'b1z: data2 = 3'd4 ;
2'b1x: data2 = 3'd5 ;
default: data2 = 3'd7 ;
endcase
end
always@(*)
begin
casex(sel[1:0])
2'b00: data3 = 3'd0 ;
2'b01: data3 = 3'd1 ;
2'b10: data3 = 3'd2 ;
2'b11: data3 = 3'd3 ;
2'b1z: data3 = 3'd4 ;
2'b1x: data3 = 3'd5 ;
default: data3 = 3'd7 ;
endcase
end
always@(*)
begin
casez(sel[1:0])
2'b00: data4 = 3'd0 ;
2'b01: data4 = 3'd1 ;
2'b10: data4 = 3'd2 ;
2'b11: data4 = 3'd3 ;
2'b1?: data4 = 3'd4 ;
2'b1x: data4 = 3'd5 ;
default: data4 = 3'd7 ;
endcase
end
always@(*)
begin
casex(sel[1:0])
2'b00: data5 = 3'd0 ;
2'b01: data5 = 3'd1 ;
2'b10: data5 = 3'd2 ;
2'b11: data5 = 3'd3 ;
2'b1?: data5 = 3'd4 ;
2'b1x: data5 = 3'd5 ;
default: data5 = 3'd7 ;
endcase
end
- sel[1:0]為1’b1z時,命中了[2'b1z: data2 = 3'd4 ;],data1被賦值3’d4
- sel[1:0]為1’b1x時,命中了[2'b1x: data2 = 3'd5 ;],data1被賦值3’d5
casez語句中Z狀態會被忽略,不做比較,X依舊進行比較- sel[1:0]為1’b1z時,實際僅比較sel[1],命中了[2'b10: data2 = 3'd2 ;]和[2'b1z: data2 = 3'd4; ],根據優先級原則, data2被賦值3’d2
- sel[1:0]為1’b1x時,依舊比較sel[1:0],命中了[2'b1x: data2 = 3'd5 ;], data2被賦值3’d5
- sel[1:0]為1’b1z時,實際僅比較sel[1],命中了[2'b10: data2 = 3'd2 ;], data3被賦值3’d2
- sel[1:0]為1’b1x時,實際僅比較sel[1],命中了[2'b10: data2 = 3'd2 ;], data3被賦值3’d2
- sel[1:0]為1’b1z時,實際僅比較sel[1],命中了[2'b10: data2 = 3'd2 ;], data4被賦值3’d2
- sel[1:0]為1’b1x時,同時命中了[2'b1?: data4 = 3'd4 ;]和[2'b1x: data4 = 3'd5 ;],根據優先級原則,data4被賦值3’d4
- sel[1:0]為1’b1z時,實際僅比較sel[1],命中了[2'b10: data2 = 3'd2 ;]、[2'b1?: data5 = 3'd4 ;]、[2'b1x: data5 = 3'd5 ;],根據優先級原則,data5被賦值3’d2
- sel[1:0]為1’b1x時,實際僅比較sel[1],命中了[2'b10: data2 = 3'd2 ;]、[2'b1?: data5 = 3'd4 ;]、[2'b1x: data5 = 3'd5 ;],根據優先級原則,data5被賦值3’d2
LmZ28資訊網——每日最新資訊28at.com
3、Do-not-care values 參考說明
LmZ28資訊網——每日最新資訊28at.com
LmZ28資訊網——每日最新資訊28at.com
SystemVerilog(IEEE Std 1800-2017)和verilog(IEEE P1364-2005)標準關于casez、casex的描述是一致的:截圖如下: LmZ28資訊網——每日最新資訊28at.com
EndLmZ28資訊網——每日最新資訊28at.com
LmZ28資訊網——每日最新資訊28at.com
LmZ28資訊網——每日最新資訊28at.com
標簽:
-
前言:三年的疫情因為要上網課的原因激活了平板市場,如今網課的時代已經過去,大家的生活都恢復到了正軌,這也就意味著,真正考驗平板電腦生存的環境來了。也就是面對著這種殘酷的
-
8月5日消息,Redmi K60至尊版將于8月發布,在此前舉行的戰略發布會上,官方該機將搭載搭載天璣9200+處理器,安兔兔V10跑分超177萬分,是目前安卓陣營最高的分數
-
線程通信是指多個線程之間通過某種機制進行協調和交互,例如,線程等待和通知機制就是線程通訊的主要手段之一。 在 Java 中,線程等待和通知的實現手段有以下幾種方式:Object 類下
-
按鈕是為任何網絡應用程序提供交互性的最常見方式。但我們經常傾向于使用其他HTML元素,如 div span 等作為 clickable 元素。但通過這樣做,我們錯過了許多內置瀏覽器的功能。
-
來源:運營研究社作者 | 張知白編輯 | 楊佩汶設計 | 晏談夢潔這個暑期,旅游賽道徹底火了:有的「地方」火了——貴州村超旅游收入 1 個月超過 12 億;有的「博主」火了&m
-
7月17日消息,據外媒報道,去年下半年開始的半導體需求下滑,影響到了三星電子、SK海力士、英特爾等諸多廠商,營收明顯下滑,部分廠商甚至出現了虧損。作為
-
-
滴滴違法違規被罰80.26億 存在16項違法事實開始于2121年7月,歷經一年時間,網絡安全審查辦公室對“滴滴出行”網絡安全審查終于有了一個暫時的結束。據“網信
-
近日,微軟發布了Windows 11新版,而Build 22563更新主要引入了幾周前曝光的平板模式任務欄等,系統更流暢了。更新中,Windows 11加入了專門針對平板優化的任務欄