?? timer.v
字號:
/*--------小時、分鐘和秒計時子模塊 --------*/
//采用異步時鐘計時
module timer(clk,reset,start,sec,min,hour,day);
input clk,reset,start;
output[7:0] sec,min,hour;
output day;
reg[7:0] sec,min,hour;
reg min_clk,h_clk,day;
reg started; // 中間變量,用于將脈沖信號轉變為電平信號
always @(posedge clk or posedge reset or posedge start) // ------(1)秒計時
begin
if(reset) // 異步復位
begin
sec<=0;started<=0; // 復位后,則秒計數器清零,且started為低電平,
//使秒計數器維持0,則不會產生分時鐘和小時時鐘,故保證所有計數器為0。
end
else if(start) started<=1; // 按下start,則started為高電平
if(started) // 若已開始計數
begin
if(sec==8'h59) // 若計到59s
begin
sec[7:0]<=0;
min_clk<=1; // 則分時鐘為1
end
else
begin
if(sec[3:0]==9)
begin
sec[3:0]<=0;
sec[7:4]<=sec[7:4]+1;
end
else sec[3:0]<=sec[3:0]+1;
min_clk<=0; // 否則分時鐘為0
end
end
end
always @(posedge min_clk or posedge reset) // ------(2)分計時
begin
if(reset) // 異步復位
min<=0;
else if(min==8'h59) // 若計到59分
begin
min<=0;
h_clk<=1; // 則小時時鐘為1
end
else
begin
if(min[3:0]==9 )
begin
min[3:0]<=0;
min[7:4]<=min[7:4]+1;
end
else min[3:0]<=min[3:0]+1;
h_clk<=0; // 否則小時時鐘為0
end
end
always @(posedge h_clk or posedge reset) // ------(3)小時計時
begin
if(reset) // 異步復位
hour<=0;
else if(hour==8'h23) // 若計到23小時
begin
hour<=0;
day<=1; // 則向一日進位
end
else
begin
if(hour[3:0]==9 )
begin
hour[3:0]<=0;
hour[7:4]<=hour[7:4]+1;
end
else hour[3:0]<=hour[3:0]+1;
day<=0; // 否則日時鐘為0
end
end
endmodule
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -