找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2531|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

兩儀性與多義性的問題

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:105323 發(fā)表于 2016-2-23 17:41 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
              
?圖1



?圖2


如圖2所示,s_module.v 和o_module.v 的Pin_Out輸出是共享著蜂鳴器資源,但是有一個事實我們必須了解,就是“一個時期僅有一個輸出”這個道理。為了有效協(xié)調(diào)Pin_Out的輸出,就添加“選擇器”來控制輸出。
module sos_module
(
CLK,RSTn,Start_Sig,Done_Sig,Pin_Out
);
input CLK;
input RSTn;
input Start_Sig;
output Done_Sig;
output Pin_Out;
wire S_Done_Sig;
wire S_Start_Sig;
wire S_Pin_Out;
s_module U1
(
.CLK(CLK),
.RSTn(RSTn),
.Start_Sig(S_Start_Sig),
.Done_Sig(S_Done_Sig),
.Pin_Out(S_Pin_Out)
);
wire O_Done_Sig;
wire O_Start_Sig;
wire O_Pin_Out;
o_module U2
(
.CLK(CLK),
.RSTn(RSTn),
.Start_Sig(O_Start_Sig),
.Done_Sig(O_Done_Sig),
.Pin_Out(O_Pin_Out)
);
sos_control_module U3
(
.CLK(CLK),
.RSTn(RSTn),
.Start_Sig(Start_Sig),
.Done_Sig(Done_Sig),
.S_Start_Sig(S_Start_Sig),
.O_Start_Sig(O_Start_Sig),
.S_Done_Sig(S_Done_Sig),
.O_Done_Sig(O_Done_Sig)
);
reg Pin_Out;
always@(*)
if(S_Start_Sig) Pin_Out=S_Pin_Out;
else if(O_Start_Sig)Pin_Out=O_Pin_Out;
else Pin_Out=1'bx;
endmodule
在62~72 行是“選擇器”Pin_Out 寄存器是用來驅(qū)動Pin_Out 輸出(65 行)。在67 行
表示“任何時候都會變化”。然而S_Start_Sig 和O_Start_Sig信號,作為選擇器的辨別信號。當(dāng)S_Start_Sig 拉高時,是S_Pin_Out 驅(qū)動著Pin_Out輸出,當(dāng)O_Start_Sig 拉高的時候,是O_Pin_Out 驅(qū)動著Pin_Out 輸出。
但是有一點必須注意,就是第70 行,每一個選擇器都需要一個“默認狀態(tài)”,如果沒
有添加這一行,會出現(xiàn)很多編譯警告。
[/url]

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表