//时计时器---十位(0~2) always @(posedge clk or negedge rst_n) begin if (!rst_n) begin cnt_h_ten<=1; end else if(set_time_TO_idel) begin cnt_h_ten<=set_cnt_h_ten; end else if (add_cnt_h_ten) begin if (end_cnt_h_ten) begin cnt_h_ten<=0; end else cnt_h_ten<=cnt_h_ten+1; end end assign add_cnt_h_ten=end_cnt_h_bit; assign end_cnt_h_ten=add_cnt_h_ten&&cnt_h_ten==2&&cnt_h_bit==cnt_flag1;
时间: 2024-03-08 08:45:33 浏览: 188
Spartan6 FPGA 3-8译码器实验VERILOG源码 Xilinx ISE14.6 工程文件.zip
这段代码实现了一个时钟计时器,用来计算时钟的十位数。其中:
- always @(posedge clk or negedge rst_n) 表示在时钟的上升沿或复位信号的下降沿触发计时器操作;
- if (!rst_n) begin cnt_h_ten<=1; end 表示当复位信号为低电平时,时钟的十位数被置为 1;
- else if(set_time_TO_idel) begin cnt_h_ten<=set_cnt_h_ten; end 表示当设置时间并且将其置为闲置状态时,时钟的十位数被设置为预设的值 set_cnt_h_ten;
- else if (add_cnt_h_ten) begin...end 表示当增加时钟的十位数时,如果当前的十位数达到了最大值 2(end_cnt_h_ten=1)时,时钟的十位数被置为 0;否则时钟的十位数加 1;
- assign add_cnt_h_ten=end_cnt_h_bit; 表示 add_cnt_h_ten 信号的值等于 end_cnt_h_bit 信号的值;
- assign end_cnt_h_ten=add_cnt_h_ten&&cnt_h_ten==2&&cnt_h_bit==cnt_flag1; 表示 end_cnt_h_ten 信号的值等于 add_cnt_h_ten 信号为高电平并且当前的十位数为 2 且位数 cnt_h_bit 等于标志位 cnt_flag1 时的值为高电平。
综上所述,这段代码实现了一个可设置、可增加、可复位和可归零的时钟计时器,用来计算时钟的十位数。
阅读全文