吉林城市建设学校网站,保定建站软件,域名不用了需要注销吗,定制商品的app专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点#xff0c;刷题网站用的是牛客网 1、寄存器的位是可以分开单独运算的#xff0c;并不是一个输入就一定是一个数据#xff0c;在很多情况下#xff0c;一个输入既包括数据又包括地址等其他有效信息 2、需… 专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点刷题网站用的是牛客网 1、寄存器的位是可以分开单独运算的并不是一个输入就一定是一个数据在很多情况下一个输入既包括数据又包括地址等其他有效信息 2、需要考虑数据锁存的问题一定要在sel为0的时候进行锁存只有此时的写入才是有效的validout的下降沿写入有效同时存在多种情况且没有优先级问题建议使用case语句 timescale 1ns/1nsmodule data_cal(
input clk,
input rst,
input [15:0]d,
input [1:0]sel,output reg [4:0] out,
output reg validout
);
//*************code***********//reg [15:0] data_lock ; always (posedge clk or negedge rst) begin if (~rst) data_lock 0 ; else if (!sel) data_lock d ; end always (posedge clk or negedge rst) begin if (~rst) begin out 1b0 ; validout 0 ; end else begin case (sel) 0 : begin out 1b0 ; validout 0 ; end 1 : begin out data_lock[3:0] data_lock[7:4] ; validout 1 ; end 2 : begin out data_lock[3:0] data_lock[11:8] ; validout 1 ; end 3 : begin out data_lock[3:0] data_lock[15:12] ;validout 1 ; end endcase end end //*************code***********//
endmodule