串并转换需要用到移位寄存器,窜到并可以使用大括号进行移位保存。并到窜使用输出引出线引出其中一位。
16位转8位需要计数器,计数值为0时输出高8位,计数值为1时输出低八位
窜并转换的原理本质上是移位寄存器。并串转换的原理是:先将四位数据暂存于一个多位寄存器器中,然后左移输出到一位输出端口,这里通过一个“移位”指令就可以了。串并转换的原理是:新输入的位值成为原来数据的最低位,将原来数据的最高位舍去,这里可以通过一个简单的“连接符”就能做到。
module pal_serial_4( //四位并串转换程序
clk,rst,load,
din,dout
);
input clk,rst,load;
input[3:0] din;
output dout;
reg[3:0] databuff;
always @ (posedge clk or negedge rstor posedge load)
begin
if(!rst) databuff<=4'b0;
else if(load) databuff<=din;
else //databuff<={databuff[2:0],1'b0};
databuff<=databuff<<1; //将寄存器内的值左移,依次读出
end
assign dout=databuff[3];输出高位
endmodule
module serial_pal_4( //四位串并转换程序
clk,en,rst,
cin,cout
);
input cin,clk,en,rst;
output[3:0] cout;
reg[3:0] cout;
always @ (posedge clk or negedge rst)
begin
if(!rst) cout<=4'b0;
else if(en)
cout<={cout[2:0],cin};//窜并转换
else cout<=cout;
end
endmodule