7.4 行为建模具体实例
以上面的频率计数器为例,其中的 HEX2LED 和 CNT_4b 模块采用行为建模。
2004-08-16 第37页,共41页
版权所有,侵权必究
绝密
Verilog HDL 入门教程请输入文档编号
CNT_4b 模块对应的文件 CNT_4b.v 的内容如下:
module CNT_4b (CLK, ENABLE, RESET, FULL, Q);
input CLK;
input ENABLE;
input RESET;
output FULL;
output [3:0] Q;
wire CLK;
wire ENABLE;
wire RESET;
wire FULL;
wire [3:0] Q;
// add your declarations here
reg [3:0] Qint;
always @(posedge RESET or posedge CLK)
begin
if (RESET)
Qint = 4'b0000;
else if (ENABLE)
begin
if (Qint == 9)
Qint = 4'b0000;
else
Qint = Qint + 4'b1;
end
end
assign Q = Qint;
assign FULL = (Qint == 9) ? 1'b1 : 1'b0;
endmodule
该模块实现一个模10 的计数器。
HEX2LED 模块对应的文件HEX2LED.v 的内容为:
module HEX2LED (HEX, LED);
2004-08-16 第38页,共41页
版权所有,侵权必究
绝密
Verilog HDL 入门教程请输入文档编号
input [3:0] HEX;
output [6:0] LED;
wire [3:0] HEX;
reg [6:0] LED;
// add your declarations here
always @(HEX)
begin
case (HEX)
4'b0001 : LED = 7'b1111001; // 1
4'b0010 : LED = 7'b0100100; // 2
4'b0011 : LED = 7'b0110000; // 3
4'b0100 : LED = 7'b0011001; // 4
4'b0101 : LED = 7'b0010010; // 5
4'b0110 : LED = 7'b0000010; // 6
4'b0111 : LED = 7'b1111000; // 7
4'b1000 : LED = 7'b0000000; // 8
4'b1001 : LED = 7'b0010000; // 9
4'b1010 : LED = 7'b0001000; // A
4'b1011 : LED = 7'b0000011; // B
4'b1100 : LED = 7'b1000110; // C
4'b1101 : LED = 7'b0100001; // D
4'b1110 : LED = 7'b0000110; // E
4'b1111 : LED = 7'b0001110; // F
default :LED = 7'b1000000; // 0
endcase
end
endmodule
该模块实现模10 计数器的值到 7段码的译码。
至此,整个频率计数器的系统设计由4个模块(4个文件)我们已设计完毕。这就是HDL 的自
顶向下的设计方式和HDL的多种建模方式的应用。
免责声明: 凡注明来源本网的所有作品,均为本网合法拥有版权或有权使用的作品,欢迎转载,注明出处。非本网作品均来自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。