OpenCores
URL https://opencores.org/ocsvn/openarty/openarty/trunk

Subversion Repositories openarty

[/] [openarty/] [trunk/] [rtl/] [wboled.v] - Diff between revs 3 and 21

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 3 Rev 21
Line 56... Line 56...
        wire            dev_busy;
        wire            dev_busy;
        lloled  #(CBITS)
        lloled  #(CBITS)
                lwlvl(i_clk, dev_wr, dev_dbit, dev_word, dev_len, dev_busy,
                lwlvl(i_clk, dev_wr, dev_dbit, dev_word, dev_len, dev_busy,
                        o_sck, o_cs_n, o_mosi, o_dbit);
                        o_sck, o_cs_n, o_mosi, o_dbit);
 
 
 
`define EXTRA_WB_DELAY
 
`ifdef  EXTRA_WB_DELAY
 
        reg             r_wb_stb, r_wb_we;
 
        reg     [31:0]   r_wb_data;
 
        reg     [1:0]    r_wb_addr;
 
        always @(posedge i_clk)
 
                r_wb_stb <= i_stb;
 
        always @(posedge i_clk)
 
                r_wb_we <= i_we;
 
        always @(posedge i_clk)
 
                r_wb_data <= i_data;
 
        always @(posedge i_clk)
 
                r_wb_addr <= i_addr;
 
`else
 
        wire            r_wb_stb, r_wb_we;
 
        wire            r_wb_data;
 
        wire    [1:0]    r_wb_addr;
 
 
 
        assign  r_wb_stb  = i_stb;
 
        assign  r_wb_we   = i_we;
 
        assign  r_wb_data = i_data;
 
        assign  r_wb_addr = i_addr;
 
`endif
 
 
 
 
 
 
        reg             r_busy;
        reg             r_busy;
        reg     [3:0]    r_len;
        reg     [3:0]    r_len;
        reg     [31:0]   r_a, r_b;
        reg     [31:0]   r_a, r_b;
        always @(posedge i_clk)
        always @(posedge i_clk)
                if ((i_stb)&&(i_we))
                if ((r_wb_stb)&&(r_wb_we))
                begin
                begin
                        if (i_addr[1:0]==2'b01)
                        if (r_wb_addr[1:0]==2'b01)
                                r_a <= i_data;
                                r_a <= r_wb_data;
                        if (i_addr[1:0]==2'b10)
                        if (r_wb_addr[1:0]==2'b10)
                                r_b <= i_data;
                                r_b <= r_wb_data;
                end else if (r_cstb)
                end else if (r_cstb)
                begin
                begin
                        r_a <= 32'h00;
                        r_a <= 32'h00;
                        r_b <= 32'h00;
                        r_b <= 32'h00;
                end
                end
 
 
        always @(posedge i_clk)
        always @(posedge i_clk)
        begin
        begin
                case (i_addr)
                case (r_wb_addr)
                2'b00: o_data <= { 13'h00, o_pwr, 8'h00, r_len, 3'h0, r_busy };
                2'b00: o_data <= { 13'h00, o_pwr, 8'h00, r_len, 3'h0, r_busy };
                2'b01: o_data <= r_a;
                2'b01: o_data <= r_a;
                2'b10: o_data <= r_b;
                2'b10: o_data <= r_b;
                2'b11: o_data <= { 13'h00, o_pwr, 8'h00, r_len, 3'h0, r_busy };
                2'b11: o_data <= { 13'h00, o_pwr, 8'h00, r_len, 3'h0, r_busy };
                endcase
                endcase
        end
        end
 
 
        initial o_ack = 1'b0;
        initial o_ack = 1'b0;
        always @(posedge i_clk)
        always @(posedge i_clk)
                o_ack <= i_stb;
                o_ack <= r_wb_stb;
        assign  o_stall = 1'b0;
        assign  o_stall = 1'b0;
 
 
        reg     r_cstb, r_dstb, r_pstb;
        reg     r_cstb, r_dstb, r_pstb;
        reg     [23:0]   r_data;
        reg     [23:0]   r_data;
        initial r_cstb = 1'b0;
        initial r_cstb = 1'b0;
        initial r_dstb = 1'b0;
        initial r_dstb = 1'b0;
        initial r_pstb = 1'b0;
        initial r_pstb = 1'b0;
        always @(posedge i_clk)
        always @(posedge i_clk)
                r_cstb <= (i_stb)&&(i_addr[1:0]==2'b00);
                r_cstb <= (r_wb_stb)&&(r_wb_addr[1:0]==2'b00);
        always @(posedge i_clk)
        always @(posedge i_clk)
                r_dstb <= (i_stb)&&(i_addr[1:0]==2'b11)&&(i_data[22:20]==3'h0);
                r_dstb <= (r_wb_stb)&&(r_wb_addr[1:0]==2'b11)&&(r_wb_data[22:20]==3'h0);
        always @(posedge i_clk)
        always @(posedge i_clk)
                r_pstb <= (i_stb)&&(i_addr[1:0]==2'b11)&&(i_data[22:20]!=3'h0);
                r_pstb <= (r_wb_stb)&&(r_wb_addr[1:0]==2'b11)&&(r_wb_data[22:20]!=3'h0);
        always @(posedge i_clk)
        always @(posedge i_clk)
                r_data <= i_data[23:0];
                r_data <= r_wb_data[23:0];
 
 
        initial o_pwr = 3'h0;
        initial o_pwr = 3'h0;
        always @(posedge i_clk)
        always @(posedge i_clk)
                if (r_pstb)
                if (r_pstb)
                        o_pwr <= ((o_pwr)&(~r_data[22:20]))
                        o_pwr <= ((o_pwr)&(~r_data[22:20]))
                                        |((i_data[18:16])&(r_data[22:20]));
                                        |((r_wb_data[18:16])&(r_data[22:20]));
 
 
        reg     [3:0]    b_len;
        reg     [3:0]    b_len;
        always @(posedge i_clk)
        always @(posedge i_clk)
                casez(i_data[31:28])
                casez(r_wb_data[31:28])
                4'b000?: b_len <= (i_data[16])? 4'h1:4'h2;
                4'b000?: b_len <= (r_wb_data[16])? 4'h1:4'h2;
                4'b0010: b_len <= 4'h3;
                4'b0010: b_len <= 4'h3;
                4'b0011: b_len <= 4'h4;
                4'b0011: b_len <= 4'h4;
                4'b0100: b_len <= 4'h5;
                4'b0100: b_len <= 4'h5;
                4'b0101: b_len <= 4'h6;
                4'b0101: b_len <= 4'h6;
                4'b0110: b_len <= 4'h7;
                4'b0110: b_len <= 4'h7;

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.