|
module ww (in1,r1,reset,clk,out);
% q. C' N T, v6 p7 F D, n' Xinput in1,clk,reset;
0 L" l8 _: [) c, k xoutput reg [3:0]out;5 {& `0 ^9 b" D0 N# o& n
output reg r1;
, v: T# m4 W+ O. g1 areg [2:0]zxc; V. @# c" I8 J3 A; Q* u
/ B* J1 }0 a; a1 `always @ (posedge clk)
# ^' U: p/ Z% L$ K" Kbegin
8 a8 R5 E7 Y& y; mif(!zxc[2]&&zxc[1])+ b, J3 Z/ |5 T* V' a+ v) h
r1 <=~r1;
2 }9 ?2 `5 @4 H' M5 N, [zxc <={zxc[1:0],in1};5 o" k9 A1 t% O3 S
9 M- m# J; G& z# P! ^
if(!reset)( o% n( d2 a" V0 v) l3 r
out <=4'b0000;6 B# n9 t F/ D6 {9 d
else) m7 ^9 e; k4 x* h& y+ U/ v
) B; d! a4 n: L/ u
begin# Y* a: p9 J7 n3 ]& p7 ]8 F. {
if(in1==1) out<=out+1;
% E. q; `: X! H- ?( u2 e4 cif(out==4'b1111) out<=4'b0000;
, S* S6 ^2 Z$ d# ^+ U end, H7 B+ V, J% D$ T1 d8 d
end
; }/ y( T" @" A" I/ aendmodule
6 K `) ]) ]0 V, D; P* B; l8 W+ ]# X1 I( l1 j8 ^% }7 k* T/ {5 z
要做一個有reset 和每按一次就亮一顆 例如按一次 亮第一顆 按第二次 第一顆不熄滅 亮第二顆......有四顆 全亮時再按一次 熄滅 就這樣迴圈下去
$ r' Y3 ^& l" K! R. ?& b( X! @' m有做成這樣 有加上除去彈跳 之後就不知道怎打 也不知道這樣語法到底正不正確 |
|