module top(out, clk, in);
    output [7:0] out;
    input signed clk, in;
    reg signed [7:0] out;

`ifndef NO_INIT
    initial begin
        out = 0;
    end
`endif

    always @(posedge clk)
	begin
		out    <= out >> 1;
		out[7] <= in;
	end    
endmodule