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

Subversion Repositories openarty

[/] [openarty/] [trunk/] [rtl/] [enetpackets.v] - Diff between revs 30 and 33

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

Rev 30 Rev 33
Line 209... Line 209...
`ifdef  TX_SYNCHRONOUS_WITH_WB_CLK
`ifdef  TX_SYNCHRONOUS_WITH_WB_CLK
        wire    tx_busy, tx_complete;
        wire    tx_busy, tx_complete;
`else
`else
        reg     tx_busy, tx_complete;
        reg     tx_busy, tx_complete;
`endif
`endif
        reg     config_hw_crc, config_hw_mac;
        reg     config_hw_crc, config_hw_mac, config_hw_ip_check;
        reg     rx_crcerr, rx_err, rx_miss, rx_clear;
        reg     rx_crcerr, rx_err, rx_miss, rx_clear;
`ifdef  RX_SYNCHRONOUS_WITH_WB_CLK
`ifdef  RX_SYNCHRONOUS_WITH_WB_CLK
        wire    rx_valid, rx_busy;
        wire    rx_valid, rx_busy;
`else
`else
        reg     rx_valid, rx_busy;
        reg     rx_valid, rx_busy;
Line 227... Line 227...
        reg             p_rx_clear;
        reg             p_rx_clear;
        reg     [7:0]    clear_pipe;
        reg     [7:0]    clear_pipe;
 
 
        initial config_hw_crc = 0;
        initial config_hw_crc = 0;
        initial config_hw_mac = 0;
        initial config_hw_mac = 0;
 
        initial config_hw_ip_check = 0;
        initial o_net_reset_n = 1'b0;
        initial o_net_reset_n = 1'b0;
        initial tx_cmd    = 1'b0;
        initial tx_cmd    = 1'b0;
        initial tx_cancel = 1'b0;
        initial tx_cancel = 1'b0;
        initial rx_crcerr = 1'b0;
        initial rx_crcerr = 1'b0;
        initial rx_err    = 1'b0;
        initial rx_err    = 1'b0;
Line 272... Line 273...
                pre_cmd <= 1'b0;
                pre_cmd <= 1'b0;
                if ((wr_ctrl)&&(wr_addr==3'b001))
                if ((wr_ctrl)&&(wr_addr==3'b001))
                begin // TX command register
                begin // TX command register
 
 
                        // Reset bit must be held down to be valid
                        // Reset bit must be held down to be valid
 
                        config_hw_ip_check <= (!wr_data[18]);
                        o_net_reset_n <= (!wr_data[17]);
                        o_net_reset_n <= (!wr_data[17]);
                        config_hw_mac <= (!wr_data[16]);
                        config_hw_mac <= (!wr_data[16]);
                        config_hw_crc <= (!wr_data[15]);
                        config_hw_crc <= (!wr_data[15]);
                        pre_cmd <= (wr_data[14]);
                        pre_cmd <= (wr_data[14]);
                        tx_cancel <= (tx_busy)&&(!wr_data[14]);
                        tx_cancel <= (tx_busy)&&(!wr_data[14]);
Line 303... Line 305...
        assign  w_maw = MAW+2; // Number of bits in the packet length field
        assign  w_maw = MAW+2; // Number of bits in the packet length field
        assign  w_rx_ctrl = { 4'h0, w_maw, {(24-19){1'b0}}, rx_crcerr, rx_err,
        assign  w_rx_ctrl = { 4'h0, w_maw, {(24-19){1'b0}}, rx_crcerr, rx_err,
                        rx_miss, rx_busy, (rx_valid)&&(!rx_clear),
                        rx_miss, rx_busy, (rx_valid)&&(!rx_clear),
                        {(14-MAW-2){1'b0}}, rx_len };
                        {(14-MAW-2){1'b0}}, rx_len };
 
 
        assign  w_tx_ctrl = { 4'h0, w_maw, {(24-18){1'b0}},
        assign  w_tx_ctrl = { 4'h0, w_maw, {(24-19){1'b0}},
 
                        !config_hw_ip_check,
                        !o_net_reset_n,!config_hw_mac,
                        !o_net_reset_n,!config_hw_mac,
                        !config_hw_crc, tx_busy,
                        !config_hw_crc, tx_busy,
                                {(14-MAW-2){1'b0}}, tx_len };
                                {(14-MAW-2){1'b0}}, tx_len };
 
 
        reg     [31:0]   counter_rx_miss, counter_rx_err, counter_rx_crc;
        reg     [31:0]   counter_rx_miss, counter_rx_err, counter_rx_crc;
Line 543... Line 546...
`endif
`endif
 
 
 
 
`ifdef  RX_SYNCHRONOUS_WITH_WB_CLK
`ifdef  RX_SYNCHRONOUS_WITH_WB_CLK
        wire    n_rx_clear;
        wire    n_rx_clear;
        reg     n_rx_config_hw_mac, n_rx_config_hw_crc;
        reg     n_rx_config_hw_mac, n_rx_config_hw_crc, n_rx_config_ip_check;
        assign  n_rx_clear = rx_clear;
        assign  n_rx_clear = rx_clear;
`else
`else
        (* ASYNC_REG = "TRUE" *) reg n_rx_config_hw_mac, n_rx_config_hw_crc;
        (* ASYNC_REG = "TRUE" *) reg n_rx_config_hw_mac, n_rx_config_hw_crc,
 
                        n_rx_config_ip_check;
        (* ASYNC_REG = "TRUE" *) reg r_rx_clear;
        (* ASYNC_REG = "TRUE" *) reg r_rx_clear;
        reg     n_rx_clear;
        reg     n_rx_clear;
        always @(posedge `RXCLK)
        always @(posedge `RXCLK)
        begin
        begin
                r_rx_clear <= (p_rx_clear)||(!o_net_reset_n);
                r_rx_clear <= (p_rx_clear)||(!o_net_reset_n);
Line 558... Line 562...
        end
        end
`endif
`endif
 
 
 
 
        reg             n_rx_net_err;
        reg             n_rx_net_err;
        wire            w_npre,  w_rxmin,  w_rxcrc,  w_rxmac,  w_rxip;
        wire            w_npre,  w_rxmin,  w_rxcrc,  w_rxmac;
        wire    [3:0]    w_npred, w_rxmind, w_rxcrcd, w_rxmacd, w_rxipd;
        wire    [3:0]    w_npred, w_rxmind, w_rxcrcd, w_rxmacd;
        wire            w_minerr, w_rxcrcerr, w_macerr, w_broadcast, w_iperr;
        wire            w_minerr, w_rxcrcerr, w_macerr, w_broadcast, w_iperr;
`ifndef RX_BYPASS_HW_PREAMBLE
`ifndef RX_BYPASS_HW_PREAMBLE
        rxepreambl rxprei(`RXCLK, rx_clk_stb, 1'b1, (n_rx_net_err),
        rxepreambl rxprei(`RXCLK, rx_clk_stb, 1'b1, (n_rx_net_err),
                        i_net_dv, i_net_rxd, w_npre, w_npred);
                        i_net_dv, i_net_rxd, w_npre, w_npred);
`else
`else
        assign  w_npre  = i_net_dv;
        assign  w_npre  = i_net_dv;
        assign  w_npred = i_net_rxerr;
        assign  w_npred = i_net_rxerr;
`endif
`endif
 
 
`ifdef  RX_HW_MINLENGTH
`ifdef  RX_BYPASS_HW_MINLENGTH
        // Insist on a minimum of 64-byte packets
        // Insist on a minimum of 64-byte packets
        rxeminlen       rxmini(`RXCLK, rx_clk_stb, 1'b1, (n_rx_net_err),
        rxemin  rxmini(`RXCLK, rx_clk_stb, 1'b1, (n_rx_net_err),
                        w_npre, w_npred, w_rxmin, w_rxmind, w_minerr);
                        w_npre, w_npred, w_minerr);
`else
`else
        assign  w_rxmin = w_npre;
 
        assign  w_rxmind= w_npred;
 
        assign  w_minerr= 1'b0;
        assign  w_minerr= 1'b0;
`endif
`endif
 
        assign  w_rxmin = w_npre;
 
        assign  w_rxmind= w_npred;
 
 
`ifndef RX_BYPASS_HW_CRC
`ifndef RX_BYPASS_HW_CRC
        rxecrc  rxcrci(`RXCLK, rx_clk_stb, n_rx_config_hw_crc, (n_rx_net_err),
        rxecrc  rxcrci(`RXCLK, rx_clk_stb, n_rx_config_hw_crc, (n_rx_net_err),
                        w_rxmin, w_rxmind, w_rxcrc, w_rxcrcd, w_rxcrcerr);
                        w_rxmin, w_rxmind, w_rxcrc, w_rxcrcd, w_rxcrcerr);
`else
`else
Line 598... Line 602...
`else
`else
        assign  w_rxmac  = w_rxcrc;
        assign  w_rxmac  = w_rxcrc;
        assign  w_rxmacd = w_rxcrcd;
        assign  w_rxmacd = w_rxcrcd;
`endif
`endif
 
 
 
`define RX_HW_IPCHECK
`ifdef  RX_HW_IPCHECK
`ifdef  RX_HW_IPCHECK
        // Check: if this packet is an IP packet, is the IP header checksum
        // Check: if this packet is an IP packet, is the IP header checksum
        // valid?
        // valid?
 
        rxeipchk rxipci(`RXCLK, rx_clk_stb, n_rx_config_ip_check,(n_rx_net_err),
 
                        w_rxcrc, w_rxcrcd, w_iperr);
`else
`else
        assign  w_rxip  = w_rxmac;
 
        assign  w_rxipd = w_rxmacd;
 
        assign  w_iperr = 1'b0;
        assign  w_iperr = 1'b0;
`endif
`endif
 
 
        wire                    w_rxwr;
        wire                    w_rxwr;
        wire    [(MAW-1):0]      w_rxaddr;
        wire    [(MAW-1):0]      w_rxaddr;
        wire    [31:0]           w_rxdata;
        wire    [31:0]           w_rxdata;
        wire    [(MAW+1):0]      w_rxlen;
        wire    [(MAW+1):0]      w_rxlen;
 
 
        rxewrite #(MAW) rxememi(`RXCLK, 1'b1, (n_rx_net_err), w_rxip, w_rxipd,
        rxewrite #(MAW) rxememi(`RXCLK, 1'b1, (n_rx_net_err), w_rxmac, w_rxmacd,
                        w_rxwr, w_rxaddr, w_rxdata, w_rxlen);
                        w_rxwr, w_rxaddr, w_rxdata, w_rxlen);
 
 
        reg     last_rxwr, n_rx_valid, n_rxmiss, n_eop, n_rx_busy, n_rx_crcerr,
        reg     last_rxwr, n_rx_valid, n_rxmiss, n_eop, n_rx_busy, n_rx_crcerr,
                n_rx_err, n_rx_broadcast, n_rx_miss;
                n_rx_err, n_rx_broadcast, n_rx_miss;
        reg     [(MAW+1):0]      n_rx_len;
        reg     [(MAW+1):0]      n_rx_len;
Line 631... Line 636...
 
 
                // n_rx_net_err goes true as soon as an error is detected,
                // n_rx_net_err goes true as soon as an error is detected,
                // and stays true as long as valid data is coming in
                // and stays true as long as valid data is coming in
                n_rx_net_err <= (i_net_dv)&&((i_net_rxerr)||(i_net_col)
                n_rx_net_err <= (i_net_dv)&&((i_net_rxerr)||(i_net_col)
                                ||(w_minerr)||(w_macerr)||(w_rxcrcerr)
                                ||(w_minerr)||(w_macerr)||(w_rxcrcerr)
 
                                ||(w_iperr)
                                ||(n_rx_net_err)
                                ||(n_rx_net_err)
                                ||((w_rxwr)&&(n_rx_valid)));
                                ||((w_rxwr)&&(n_rx_valid)));
 
 
                last_rxwr <= w_rxwr;
                last_rxwr <= w_rxwr;
                n_eop <= (!w_rxwr)&&(last_rxwr)&&(!n_rx_net_err);
                n_eop <= (!w_rxwr)&&(last_rxwr)&&(!n_rx_net_err);
 
 
                n_rx_busy <= (!n_rx_net_err)&&((i_net_dv)||(w_npre)||(w_rxmin)
                n_rx_busy <= (!n_rx_net_err)&&((i_net_dv)||(w_npre)||(w_rxmin)
                        ||(w_rxcrc)||(w_rxmac)||(w_rxip)||(w_rxwr));
                        ||(w_rxcrc)||(w_rxmac)||(w_rxwr));
 
 
                // Oops ... we missed a packet
                // Oops ... we missed a packet
                n_rx_miss <= (n_rx_valid)&&(w_rxwr)||
                n_rx_miss <= (n_rx_valid)&&(w_rxwr)||
                        ((n_rx_miss)&&(!n_rx_clear));
                        ((n_rx_miss)&&(!n_rx_clear));
 
 
Line 667... Line 673...
 
 
                if ((!i_net_dv)||(n_rx_clear))
                if ((!i_net_dv)||(n_rx_clear))
                begin
                begin
                        n_rx_config_hw_mac <= config_hw_mac;
                        n_rx_config_hw_mac <= config_hw_mac;
                        n_rx_config_hw_crc <= config_hw_crc;
                        n_rx_config_hw_crc <= config_hw_crc;
 
                        n_rx_config_ip_check <= config_hw_ip_check;
                end
                end
        end
        end
 
 
`ifdef  RX_SYNCHRONOUS_WITH_WB_CLK
`ifdef  RX_SYNCHRONOUS_WITH_WB_CLK
        assign  rx_busy  = n_rx_busy;
        assign  rx_busy  = n_rx_busy;

powered by: WebSVN 2.1.0

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