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

Subversion Repositories wb2axi4

[/] [wb2axi4/] [trunk/] [rtl/] [wb_egress.sv] - Diff between revs 2 and 3

Show entire file | Details | Blame | View Log

Rev 2 Rev 3
Line 12... Line 12...
fifo_adr_rdata,
fifo_adr_rdata,
fifo_adr_rd,
fifo_adr_rd,
fifo_adr_empty,
fifo_adr_empty,
fifo_dat_rdata,
fifo_dat_rdata,
fifo_dat_rd,
fifo_dat_rd,
fifo_dat_empty,
fifo_dat_empty
);
);
 
 
parameter  WB_ADR_W      = 32;
parameter  WB_ADR_W      = 32;
parameter  WB_DAT_W      = 32;
parameter  WB_DAT_W      = 32;
parameter  WB_TGA_W      = 8;
parameter  WB_TGA_W      = 8;
Line 32... Line 32...
parameter  AXI_BURST_W   = 2;
parameter  AXI_BURST_W   = 2;
parameter  AXI_LOCK_W    = 2;
parameter  AXI_LOCK_W    = 2;
parameter  AXI_CACHE_W   = 4;
parameter  AXI_CACHE_W   = 4;
parameter  AXI_PROT_W    = 3;
parameter  AXI_PROT_W    = 3;
parameter  AXI_DATA_W    = 32;
parameter  AXI_DATA_W    = 32;
parameter  AXI_STRB_W    = 4;
parameter  AXI_STB_W     = 4;
parameter  FIFO_ADR_W    = AXI_ID_W + AXI_ADDR_W + AXI_LEN_W + AXI_SIZE_W + AXI_BURST_W + AXI_LOCK_W + AXI_CACHE_W + AXI_PROT_W +1 ;
parameter  FIFO_ADR_W    = AXI_ID_W + AXI_ADDR_W + AXI_LEN_W + AXI_SIZE_W + AXI_BURST_W + AXI_LOCK_W + AXI_CACHE_W + AXI_PROT_W +1 ;
parameter  FIFO_DAT_W    = AXI_ID_W + AXI_DATA_W + AXI_STRB_W + 2;
parameter  FIFO_DAT_W    = AXI_ID_W + AXI_DATA_W + AXI_STB_W + 2;
parameter  ST_W          = 2 ;
parameter  ST_W          = 2 ;
parameter  ST_IDLE       = 2'b00,
parameter  ST_IDLE       = 2'b00,
           ST_READ_ADDR  = 2'b01,
           ST_READ_ADDR  = 2'b01,
           ST_WAIT_DATA  = 2'b10,
           ST_WAIT_DATA  = 2'b10,
           ST_READ_DATA  = 2'b11;
           ST_READ_DATA  = 2'b11;
parameter  WB_W          = 2;
parameter  WB_W          = 2;
parameter  WB_IDLE       = 2'b00,
parameter  WB_IDLE       = 2'b00,
           WB_FIRST_DATA = 2'b01,
           WB_FIRST_DATA = 2'b01,
           WB_NEXT_DATA  = 2'b10;
           WB_NEXT_DATA  = 2'b10;
 
 
 
 
input  wire                          wb_clk;
input  wire                          wb_clk;
input  wire                          wb_resetn;
input  wire                          wb_resetn;
input  wire                          ENABLE;
input  wire                          ENABLE;
wb_if.master                         WB_TX_IF;
wishbone_if.master                   WB_TX_IF;
input  wire [FIFO_ADR_W-1:0]         fifo_adr_rdata;
input  wire [FIFO_ADR_W-1:0]         fifo_adr_rdata;
output wire                          fifo_adr_rd;
output wire                          fifo_adr_rd;
input  wire                          fifo_adr_empty;
input  wire                          fifo_adr_empty;
input  wire [FIFO_DAT_W-1:0]         fifo_dat_rdata;
input  wire [FIFO_DAT_W-1:0]         fifo_dat_rdata;
output wire                          fifo_dat_rd;
output wire                          fifo_dat_rd;
Line 62... Line 63...
reg  [ST_W-1:0]        state;
reg  [ST_W-1:0]        state;
reg  [ST_W-1:0]        next_state;
reg  [ST_W-1:0]        next_state;
reg                    inc_dat_ptr;
reg                    inc_dat_ptr;
reg  [4:0]             data_count;
reg  [4:0]             data_count;
wire                   allow_adr_rd;
wire                   allow_adr_rd;
wire                   fifo_adr_rd;
 
wire                   fifo_adr_rd_q;
wire                   fifo_adr_rd_q;
wire                   fifo_dat_rd;
 
reg  [AXI_ID_W   -1:0] axi_id    ;
reg  [AXI_ID_W   -1:0] axi_id    ;
reg  [AXI_ADDR_W -1:0] axi_addr  ;
reg  [AXI_ADDR_W -1:0] axi_addr  ;
reg  [AXI_LEN_W  -1:0] axi_len   ;
reg  [AXI_LEN_W  -1:0] axi_len   ;
reg  [AXI_SIZE_W -1:0] axi_size  ;
reg  [AXI_SIZE_W -1:0] axi_size  ;
reg  [AXI_BURST_W-1:0] axi_burst ;
reg  [AXI_BURST_W-1:0] axi_burst ;
Line 76... Line 75...
reg  [AXI_CACHE_W-1:0] axi_cache ;
reg  [AXI_CACHE_W-1:0] axi_cache ;
reg  [AXI_PROT_W -1:0] axi_prot  ;
reg  [AXI_PROT_W -1:0] axi_prot  ;
reg                    wr_req    ;
reg                    wr_req    ;
reg  [AXI_ID_W   -1:0] axi_wid   ;
reg  [AXI_ID_W   -1:0] axi_wid   ;
reg  [AXI_DATA_W -1:0] axi_wdata ;
reg  [AXI_DATA_W -1:0] axi_wdata ;
reg  [AXI_STRB_W -1:0] axi_wstrb ;
reg  [AXI_STB_W  -1:0] axi_wstrb ;
reg                    axi_wlast ;
reg                    axi_wlast ;
reg                    axi_wvalid;
reg                    axi_wvalid;
reg                    wb_we_o ;
reg                    wb_we_o ;
reg  [WB_ADR_W-1:0]    wb_adr_o;
reg  [WB_ADR_W-1:0]    wb_adr_o;
reg  [WB_TGA_W-1:0]    wb_tga_o;
reg  [WB_TGA_W-1:0]    wb_tga_o;
reg  [WB_ADR_W-1:0]    wb_adr_tmp;
reg  [WB_ADR_W-1:0]    wb_adr_tmp;
 
reg  [AXI_LEN_W-1:0]   wb_len_tmp;
reg  [WB_BTE_W-1:0]    wb_bte_o;
reg  [WB_BTE_W-1:0]    wb_bte_o;
reg                    wb_cyc_o;
reg                    wb_cyc_o;
reg  [WB_TGC_W-1:0]    wb_tgc_o;
reg  [WB_TGC_W-1:0]    wb_tgc_o;
reg  [WB_CTI_W-1:0]    wb_cti_o;
reg  [WB_CTI_W-1:0]    wb_cti_o;
reg  [WB_STB_W-1:0]    wb_stb_o;
reg                    wb_stb_o;
reg  [WB_DAT_W-1:0]    wb_dat_o;
reg  [WB_DAT_W-1:0]    wb_dat_o;
reg  [WB_TGD_W-1:0]    wb_tgd_o;
reg  [WB_TGD_W-1:0]    wb_tgd_o;
reg  [WB_SEL_W-1:0]    wb_sel_o;
reg  [WB_SEL_W-1:0]    wb_sel_o;
 
 
 
reg  [WB_W-1:0]  wb_cs;
 
reg  [WB_W-1:0]  wb_ns;
 
 
 
 
 
 
assign allow_adr_rd = wb_cs == WB_IDLE;
assign allow_adr_rd = wb_cs == WB_IDLE;
always_comb begin
always_comb begin
  next_state = state;
  next_state = state;
  inc_dat_ptr  = 0; //int- internal
  inc_dat_ptr  = 0; //int- internal
Line 109... Line 113...
    end
    end
    ST_READ_ADDR : begin
    ST_READ_ADDR : begin
      next_state = ST_WAIT_DATA;
      next_state = ST_WAIT_DATA;
    end
    end
    ST_WAIT_DATA : begin
    ST_WAIT_DATA : begin
      if (WB_TX_IF.ACK_I & !fifo_dat_empty) begin
      if (WB_TX_IF.ACK & !fifo_dat_empty) begin
        next_state = ST_READ_DATA;
        next_state = ST_READ_DATA;
      end else begin
      end else begin
        next_state = ST_WAIT_DATA;
        next_state = ST_WAIT_DATA;
      end
      end
    end
    end
    ST_READ_DATA : begin
    ST_READ_DATA : begin
      if (data_count>0 & WB_TX_IF.ACK_I) begin
      if (data_count>0 & WB_TX_IF.ACK) begin
        next_state = ST_READ_DATA;
        next_state = ST_READ_DATA;
        inc_dat_ptr = 1;
        inc_dat_ptr = 1;
      end else if (data_count>0) begin
      end else if (data_count>0) begin
        next_state = ST_WAIT_DATA;
        next_state = ST_WAIT_DATA;
        inc_dat_ptr = 0;
        inc_dat_ptr = 0;
      end
      end else begin
        next_state = ST_IDLE;
        next_state = ST_IDLE;
        inc_dat_ptr = 0;
        inc_dat_ptr = 0;
      end
      end
    end
    end
  endcase
  endcase
Line 138... Line 142...
sync_single_ff #(.DATA_W(1)) adr_rd_ff (
sync_single_ff #(.DATA_W(1)) adr_rd_ff (
  .DIN    ( fifo_adr_rd   ),
  .DIN    ( fifo_adr_rd   ),
  .DOUT   ( fifo_adr_rd_q ),
  .DOUT   ( fifo_adr_rd_q ),
  .CLK    ( wb_clk        ),
  .CLK    ( wb_clk        ),
  .RESET_N( wb_resetn     )
  .RESET_N( wb_resetn     )
)
);
 
 
always @(posedge wb_clk or negedge wb_resetn)
always @(posedge wb_clk or negedge wb_resetn)
  if (~wb_resetn) begin
  if (~wb_resetn) begin
    state <= ST_IDLE;
    state <= ST_IDLE;
    data_count <= 0 ;
    data_count <= 0 ;
  end else begin
  end else begin
Line 187... Line 192...
///Wishbone master output
///Wishbone master output
always @(*) begin
always @(*) begin
  wb_ns = wb_cs;
  wb_ns = wb_cs;
  case (wb_cs)
  case (wb_cs)
    WB_IDLE : begin
    WB_IDLE : begin
      if (fifo_data_rd) begin
      if (fifo_dat_rd) begin
        wb_ns = WB_FIRST_DATA;
        wb_ns = WB_FIRST_DATA;
      end  else begin
      end  else begin
        wb_ns = WB_IDLE;
        wb_ns = WB_IDLE;
      end
      end
    end
    end
    WB_FIRST_DATA : begin
    WB_FIRST_DATA : begin
      if (axi_wlast & WB_TX_IF.ACK_I)
      if (axi_wlast & WB_TX_IF.ACK)
        wb_ns = WB_IDLE;
        wb_ns = WB_IDLE;
      else if (~axi_wlast & WB_TX_IF.ACK_I)
      else if (~axi_wlast & WB_TX_IF.ACK)
        wb_ns = WB_NEXT_DATA;
        wb_ns = WB_NEXT_DATA;
      else
      else
        wb_ns = WB_FIRST_DATA;
        wb_ns = WB_FIRST_DATA;
    end
    end
 
 
    WB_NEXT_DATA : begin
    WB_NEXT_DATA : begin
      if (axi_wlast & WB_TX_IF.ACK_I)
      if (axi_wlast & WB_TX_IF.ACK)
        wb_ns = WB_IDLE;
        wb_ns = WB_IDLE;
      else
      else
        wb_ns = WB_NEXT_DATA;
        wb_ns = WB_NEXT_DATA;
    end
    end
  endcase
  endcase
Line 283... Line 288...
      end
      end
    endcase
    endcase
  end
  end
end
end
 
 
assign WB_TX_IF.ADR_O = wb_adr_o;
assign WB_TX_IF.ADR   = wb_adr_o;
assign WB_TX_IF.WE_O  = wb_we_o;
assign WB_TX_IF.WE    = wb_we_o;
assign WB_TX_IF.TGA_O = wb_tga_o;
assign WB_TX_IF.TGA   = wb_tga_o;
assign WB_TX_IF.BTE_O = wb_bte_o;
assign WB_TX_IF.BTE   = wb_bte_o;
assign WB_TX_IF.CYC_O = wb_cyc_o;
assign WB_TX_IF.CYC   = wb_cyc_o;
assign WB_TX_IF.TGC_O = wb_tgc_o;
assign WB_TX_IF.TGC   = wb_tgc_o;
assign WB_TX_IF.CTI_O = wb_cti_o;
assign WB_TX_IF.CTI   = wb_cti_o;
assign WB_TX_IF.STB_O = wb_stb_o;
assign WB_TX_IF.STB   = wb_stb_o;
assign WB_TX_IF.DAT_O = wb_dat_o;
assign WB_TX_IF.DAT_O = wb_dat_o;
assign WB_TX_IF.TGD_O = wb_tgd_o;
assign WB_TX_IF.TGD_O = wb_tgd_o;
assign WB_TX_IF.SEL_O = wb_sel_o;
assign WB_TX_IF.SEL   = wb_sel_o;
 
 
endmodule
endmodule

powered by: WebSVN 2.1.0

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