module shift (clk, si, so); input clk,si; output so; reg [7:0] tmp; always @(posedge clk) begin tmp <= tmp << 1; tmp[0] <= si; end assign so = tmp[7]; endmodule
module shift (clk, ce, si, so); input clk, si, ce; output so; reg [7:0] tmp; always @(negedge clk) begin if (ce) begin tmp <= tmp << 1; tmp[0] <= si; end end assign so = tmp[7]; endmoduleVerilog code for an 8-bit shift-left register with a positive-edge clock, asynchronous clear, serial in and serial out.
module shift (clk, clr, si, so); input clk, si, clr; output so; reg [7:0] tmp; always @(posedge clk or posedge clr) begin if (clr) tmp <= 8’b00000000; else tmp <= {tmp[6:0], si}; end assign so = tmp[7]; endmoduleVerilog code for an 8-bit shift-left register with a positive-edge clock, a synchronous set, a serial in and a serial out.
module shift (clk, s, si, so); input clk, si, s; output so; reg [7:0] tmp; always @(posedge clk) begin if (s) tmp <= 8’b11111111; else tmp <= {tmp[6:0], si}; end assign so = tmp[7]; endmodule
module shift (clk, si, po); input clk, si; output [7:0] po; reg [7:0] tmp; always @(posedge clk) begin tmp <= {tmp[6:0], si}; end assign po = tmp; endmodule
module shift (clk, load, si, d, so); input clk, si, load; input [7:0] d; output so; reg [7:0] tmp; always @(posedge clk or posedge load) begin if (load) tmp <= d; else tmp <= {tmp[6:0], si}; end assign so = tmp[7]; endmodule
module shift (clk, sload, si, d, so); input clk, si, sload; input [7:0] d; output so; reg [7:0] tmp; always @(posedge clk) begin if (sload) tmp <= d; else tmp <= {tmp[6:0], si}; end assign so = tmp[7]; endmodule
module shift (clk, si, left_right, po); input clk, si, left_right; output po; reg [7:0] tmp; always @(posedge clk) begin if (left_right == 1’b0) tmp <= {tmp[6:0], si}; else tmp <= {si, tmp[7:1]}; end assign po = tmp; endmodule
Can't assign 1-bit po to 8-bit tmp. Also, serial out "so" should be assigned either to tmp[0] or tmp[7] depending on left_right.
ReplyDeletehello? ?
ReplyDeletehttp://www.csit-sun.pub.ro/courses/Masterat/Xilinx%20Synthesis%20Technology/toolbox.xilinx.com/docsan/xilinx4/data/docs/xst/hdlcode8.html
ReplyDeleteNICE :)
add a work bench
ReplyDeleteI suggest you have to add mux
ReplyDeleteassign po = left_right ? tmp[0]:temp[7];