日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

两段式状态机不可能完成的任务

發布時間:2024/4/17 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 两段式状态机不可能完成的任务 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

兩段式狀態機不可能完成的任務(特權)

???????? 最近折騰狀態機,發現一個小任務對于兩段式狀態機寫法是不可能完成的。這個小任務很簡單,先看用一段式狀態機實現的代碼:

module test(

??????????? clk,rst_n,

??????????? din,dout

??????? );

?

input clk;

input rst_n;???

input din;

output[3:0] dout;??

?

parameter IDLE? = 3'd0;

parameter STA1? = 3'd1;

?

//一段式寫法

reg[2:0] cstate;

reg[3:0] cnt;

?

always @(posedge clk or negedge rst_n)

??? if(!rst_n) cstate <= IDLE;

??? else begin

??????? case(cstate)

??????????? IDLE: begin

??????????????????? cnt <= 4'd0;

??????????????????? if(din) cstate <= STA1;

??????????????????? else cstate <= IDLE;???????

??????????????? end

??????????? STA1: begin

??????????????????? cnt <= cnt+1'b1;

??????????????????? if(cnt == 4'd10) cstate <= IDLE;

??????????????????? else cstate <= STA1;

??????????????? end

??????????? default: cstate <= IDLE;

??????? endcase

??? end

?

assign dout = cnt;

?

endmodule

???????? 同樣的,用三段式狀態機也能夠實現這個功能:

//三段式寫法

reg[2:0] cstate,nstate;

reg[3:0] cnt;

?

always @(posedge clk or negedge rst_n)

??? if(!rst_n) cstate <= IDLE;

??? else cstate <= nstate;

?

always @(cstate or din or cnt) begin

??? case(cstate)

??????? IDLE: ? if(din) nstate = STA1;

??????????????? else nstate = IDLE;????

??????? STA1: ? if(cnt == 4'd10) nstate = IDLE;

??????????????? else nstate = STA1;

??????? default: nstate = IDLE;

??? endcase

end

?

always @(posedge clk or negedge rst_n)

??? if(!rst_n) cnt <= 4'd0;

??? else begin

??????? case(nstate)

??????????? IDLE: ? cnt <= 4'd0;

??????????? STA1: ? cnt <= cnt+1'b1;

??????????? default: ;

??????? endcase

??? end

???????? 嚴格來看,上面的三段式狀態機相比于一段式會滯后一個時鐘周期。但是我們的重點不在這里,大家大可以不必鉆這個牛角尖。另外,這個實例實現的功能本身也沒 有什么意義,當然也是可以用別的更簡單(不需要狀態機)的方式實現,但是你可以想象成這是實際應用中狀態機各種復雜輸出的一部分。

???????? 而如果大家希望用兩段式狀態機實現這個功能,或許會這么寫:

//兩段式寫法

reg[2:0] cstate,nstate;

reg[3:0] cnt;

?

always @(posedge clk or negedge rst_n)

??? if(!rst_n) cstate <= IDLE;

??? else cstate <= nstate;

?

always @(cstate or din or cnt) begin

??? case(cstate)

??????? IDLE: begin

??????????????? cnt = 4'd0;

??????????????? if(din) nstate = STA1;

??????????????? else nstate = IDLE;????

??????????? end

??????? STA1: begin

??????????????? cnt = cnt+1'b1;

??????????????? if(cnt == 4'd10) nstate = IDLE;

??????????????? else nstate = STA1;

??????? ??? end

??????? default: nstate = IDLE;

??? endcase

end

???????? 如果大家有興趣對三中代碼方式都做一下仿真,會發現一些有意思的問題,尤其兩段式狀態機最終根本無法退出STA1,計數器cnt也會死在那里。究其根本原因,可大有學問。在編譯工程后,出現了數條類似下面的warning:

Warning: Found combinational loop of 2 nodes

??? Warning: Node "Add0~2"

??? Warning: Node "cnt~9"

??????? 何為combinational loop?讓handbook來解釋吧,看不懂英文的可別怪我~_~

Combinational loops are among the most common causes of instability and unreliability in digital designs. They should be avoided whenever possible. In a synchronous design, feedback loops should include registers. Combinational loops generally violate synchronous design principles by establishing a direct feedback loop that contains no registers. For example, a combinational loop occurs when the left-hand side of an arithmetic expression also appears on the right-hand side in HDL code. A combinational loop also occurs when you feed back the output of a register to an asynchronous pin of the same register through combinational logic, as shown in Figure 5–1.

? ? ? ? 沒有寄存器打一拍的這種combinational loop(組合環)是一種不推薦的設計方式,就如兩段式狀態機所實現的效果,甚至最終無法實現功能要求。同樣的功能,一段式和三段式狀態機之所以能夠解決 這個問題,就是避免了在純組合邏輯中涉及這個反饋邏輯。在初學verilog時,我們常提的latch(鎖存器),其實也是combinational loop的一個特例。

轉載于:https://www.cnblogs.com/lueguo/p/3582250.html

總結

以上是生活随笔為你收集整理的两段式状态机不可能完成的任务的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 一级视频黄色 | 性视频免费 | 久久综合狠狠 | 中文视频一区 | www.爱爱.com| 青青视频二区 | 亚洲黄色在线观看视频 | 国内自拍在线观看 | 精品在线免费播放 | 国产探花一区二区 | 国产一区二区三区www | 动漫大乳美女 | 欧美精品一区二区三区久久 | 国产xxxxx视频 | av制服丝袜 | 日韩福利在线视频 | 调教丰满的已婚少妇在线观看 | 亚洲成人精品在线 | 日韩欧美二区 | 色哟哟一区二区三区四区 | 精品人妻无码一区二区三区换脸 | 国产少妇在线 | 欧美s码亚洲码精品m码 | 亚洲成人免费在线 | 欧美三级自拍 | 杨幂一区二区三区免费看视频 | 日本韩国欧美一区二区三区 | 91免费看. | 精品一区二区三区蜜臀 | 五月婷婷免费视频 | 精品久久人妻av中文字幕 | 久久av影院 | 欧美 日韩 国产 激情 | 男人的天堂av网站 | 一区在线免费观看 | 亚洲精品久久久中文字幕 | 欧美精品自拍偷拍 | 日韩综合色| 亚洲破处视频 | 伊人影院99| 欧美性猛交xxxx黑人 | 波多野结衣中文字幕一区二区三区 | 喷潮在线观看 | 特级西西444www大精品视频免费看 | 国产第20页 | 国产精品自拍99 | 国产高清在线观看 | 中日韩精品视频在线观看 | 成人高潮片免费 | 国产伦精品一区二区三区视频痴汉 | av免费观看网址 | 美国一级大黄一片免费中文 | 亚洲三级一区 | 搞黄视频在线观看 | 亚洲欧美精品suv | 亚洲精品网站在线 | 精品99久久久 | 激情综合网站 | 欧美一区视频 | 无码一区二区三区免费视频 | 人人艹在线观看 | 免费在线观看高清影视网站 | 中文字幕永久在线播放 | 久久久噜噜噜久久久 | 一区二区三区国产av | 亚洲女人的天堂 | 热久久国产精品 | 国产精品污www一区二区三区 | 天天操天天射天天 | 女性毛片 | 亚洲精品在线观看av | 91视频 - 88av | av在线播放网站 | 久久精品99久久久久久久久 | 国产精品男人的天堂 | 在线中文av| av合集 | 中文字幕制服丝袜 | 午夜视频 | 800av免费在线观看 | 欧美日韩在线视频 | 亚洲一品道 | 9久久9毛片又大又硬又粗 | 在线免费观看黄视频 | 影音先锋男人站 | 九九av在线 | 女女h百合无遮羞羞漫画软件 | 最新av在线网址 | 欧美熟妇精品久久久久久 | 欧洲女同同性吃奶 | 欧美劲爆第一页 | 国产精品高潮呻吟久久久久久 | 波多野吉衣在线观看视频 | 一本久道综合色婷婷五月 | 国产xxxx18| www在线看片 | 国产精品中文在线 | 国产免费无码XXXXX视频 | 午夜在线观看视频18 |