北邮22信通一枚~
跟随课程进度更新北邮信通院数字系统设计的笔记、代码和文章
持续关注作者 迎接数电实验学习~
获取更多文章,请访问专栏:
北邮22级信通院数电实验_青山如墨雨如画的博客-CSDN博客
目录
shift_register.v
- module shift_register
- (
- input sclr_n,si,sck,rck,g_n,
- output qa,qb,qc,qd,qe,qf,qg,qh,qh_out
- );
-
- reg [7:0] shift_dffs;
-
- always@(posedge sck or negedge sclr_n)
- begin
- if(~sclr_n)
- shift_dffs[7:0]<=8'h00;
- else
- shift_dffs[7:0]<={shift_dffs[6:0],si};
- end
-
- reg [7:0] storge_dffs;
-
- always @ (posedge rck)
- begin
- storge_dffs [7:0] <=shift_dffs[7:0];
- end
- assign qh_out=shift_dffs[7];
- assign {qh,qg,qf,qe,qd,qc,qb,qa} = g_n ? 8'bzzzz_zzzz : storge_dffs [7:0];
- endmodule