/***********************license start*************** * Copyright (c) 2003-2012 Cavium Inc. (support@cavium.com). All rights * reserved. * * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials provided * with the distribution. * * Neither the name of Cavium Inc. nor the names of * its contributors may be used to endorse or promote products * derived from this software without specific prior written * permission. * This Software, including technical data, may be subject to U.S. export control * laws, including the U.S. Export Administration Act and its associated * regulations, and may be subject to export or import regulations in other * countries. * TO THE MAXIMUM EXTENT PERMITTED BY LAW, THE SOFTWARE IS PROVIDED "AS IS" * AND WITH ALL FAULTS AND CAVIUM INC. MAKES NO PROMISES, REPRESENTATIONS OR * WARRANTIES, EITHER EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE, WITH RESPECT TO * THE SOFTWARE, INCLUDING ITS CONDITION, ITS CONFORMITY TO ANY REPRESENTATION OR * DESCRIPTION, OR THE EXISTENCE OF ANY LATENT OR PATENT DEFECTS, AND CAVIUM * SPECIFICALLY DISCLAIMS ALL IMPLIED (IF ANY) WARRANTIES OF TITLE, * MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR A PARTICULAR PURPOSE, LACK OF * VIRUSES, ACCURACY OR COMPLETENESS, QUIET ENJOYMENT, QUIET POSSESSION OR * CORRESPONDENCE TO DESCRIPTION. THE ENTIRE RISK ARISING OUT OF USE OR * PERFORMANCE OF THE SOFTWARE LIES WITH YOU. ***********************license end**************************************/ /** * @file * * Automatically generated error messages for cn38xxp2. * * This file is auto generated. Do not edit. * *
$Revision$
* *

Error tree for CN38XXP2

* @dot * digraph cn38xxp2 * { * rankdir=LR; * node [shape=record, width=.1, height=.1, fontsize=8, font=helvitica]; * edge [fontsize=7, font=helvitica]; * cvmx_root [label="ROOT|root"]; * cvmx_ciu_int0_sum0 [label="CIU_INTX_SUM0(0)"]; * cvmx_root:root:e -> cvmx_ciu_int0_sum0 [label="root"]; * cvmx_ciu_int_sum1 [label="CIU_INT_SUM1"]; * cvmx_root:root:e -> cvmx_ciu_int_sum1 [label="root"]; * cvmx_npi_rsl_int_blocks [label="NPI_RSL_INT_BLOCKS|l2c|npi|gmx0|gmx1|ipd|spx0|pow|spx1|asx0|asx1|pko|tim|key|mio|pip|fpa|lmc|dfa|iob|zip"]; * cvmx_l2d_err [label="L2D_ERR|sec_err|ded_err"]; * cvmx_npi_rsl_int_blocks:l2c:e -> cvmx_l2d_err [label="l2c"]; * cvmx_l2t_err [label="L2T_ERR|sec_err|ded_err|lckerr|lckerr2"]; * cvmx_npi_rsl_int_blocks:l2c:e -> cvmx_l2t_err [label="l2c"]; * cvmx_npi_int_sum [label="NPI_INT_SUM|rml_rto|rml_wto|po0_2sml|po1_2sml|po2_2sml|po3_2sml|i0_rtout|i1_rtout|i2_rtout|i3_rtout|i0_overf|i1_overf|i2_overf|i3_overf|p0_rtout|p1_rtout|p2_rtout|p3_rtout|p0_perr|p1_perr|p2_perr|p3_perr|g0_rtout|g1_rtout|g2_rtout|g3_rtout|p0_pperr|p1_pperr|p2_pperr|p3_pperr|p0_ptout|p1_ptout|p2_ptout|p3_ptout|i0_pperr|i1_pperr|i2_pperr|i3_pperr|win_rto|p_dperr|iobdma|pci_rsl"]; * cvmx_pci_int_sum2 [label="NPI_PCI_INT_SUM2|tr_wabt|mr_wabt|mr_wtto|tr_abt|mr_abt|mr_tto|msi_per|msi_tabt|msi_mabt|msc_msg|tsr_abt|serr|aperr|dperr|ill_rwr|ill_rrd|win_wr|ill_wr|ill_rd"]; * cvmx_npi_int_sum:pci_rsl:e -> cvmx_pci_int_sum2 [label="pci_rsl"]; * cvmx_npi_rsl_int_blocks:npi:e -> cvmx_npi_int_sum [label="npi"]; * cvmx_gmx0_bad_reg [label="GMXX_BAD_REG(0)|out_col|ncb_ovr|out_ovr|loststat|statovr|inb_nxa"]; * cvmx_npi_rsl_int_blocks:gmx0:e -> cvmx_gmx0_bad_reg [label="gmx0"]; * cvmx_gmx0_rx0_int_reg [label="GMXX_RXX_INT_REG(0,0)|carext|maxerr|alnerr|lenerr|skperr|niberr|ovrerr"]; * cvmx_npi_rsl_int_blocks:gmx0:e -> cvmx_gmx0_rx0_int_reg [label="gmx0"]; * cvmx_gmx0_rx1_int_reg [label="GMXX_RXX_INT_REG(1,0)|carext|maxerr|alnerr|lenerr|skperr|niberr|ovrerr"]; * cvmx_npi_rsl_int_blocks:gmx0:e -> cvmx_gmx0_rx1_int_reg [label="gmx0"]; * cvmx_gmx0_rx2_int_reg [label="GMXX_RXX_INT_REG(2,0)|carext|maxerr|alnerr|lenerr|skperr|niberr|ovrerr"]; * cvmx_npi_rsl_int_blocks:gmx0:e -> cvmx_gmx0_rx2_int_reg [label="gmx0"]; * cvmx_gmx0_rx3_int_reg [label="GMXX_RXX_INT_REG(3,0)|carext|maxerr|alnerr|lenerr|skperr|niberr|ovrerr"]; * cvmx_npi_rsl_int_blocks:gmx0:e -> cvmx_gmx0_rx3_int_reg [label="gmx0"]; * cvmx_gmx0_tx_int_reg [label="GMXX_TX_INT_REG(0)|pko_nxa|ncb_nxa|undflw"]; * cvmx_npi_rsl_int_blocks:gmx0:e -> cvmx_gmx0_tx_int_reg [label="gmx0"]; * cvmx_gmx1_bad_reg [label="GMXX_BAD_REG(1)|out_col|ncb_ovr|out_ovr|loststat|statovr|inb_nxa"]; * cvmx_npi_rsl_int_blocks:gmx1:e -> cvmx_gmx1_bad_reg [label="gmx1"]; * cvmx_gmx1_rx0_int_reg [label="GMXX_RXX_INT_REG(0,1)|carext|maxerr|alnerr|lenerr|skperr|niberr|ovrerr"]; * cvmx_npi_rsl_int_blocks:gmx1:e -> cvmx_gmx1_rx0_int_reg [label="gmx1"]; * cvmx_gmx1_rx1_int_reg [label="GMXX_RXX_INT_REG(1,1)|carext|maxerr|alnerr|lenerr|skperr|niberr|ovrerr"]; * cvmx_npi_rsl_int_blocks:gmx1:e -> cvmx_gmx1_rx1_int_reg [label="gmx1"]; * cvmx_gmx1_rx2_int_reg [label="GMXX_RXX_INT_REG(2,1)|carext|maxerr|alnerr|lenerr|skperr|niberr|ovrerr"]; * cvmx_npi_rsl_int_blocks:gmx1:e -> cvmx_gmx1_rx2_int_reg [label="gmx1"]; * cvmx_gmx1_rx3_int_reg [label="GMXX_RXX_INT_REG(3,1)|carext|maxerr|alnerr|lenerr|skperr|niberr|ovrerr"]; * cvmx_npi_rsl_int_blocks:gmx1:e -> cvmx_gmx1_rx3_int_reg [label="gmx1"]; * cvmx_gmx1_tx_int_reg [label="GMXX_TX_INT_REG(1)|pko_nxa|ncb_nxa|undflw"]; * cvmx_npi_rsl_int_blocks:gmx1:e -> cvmx_gmx1_tx_int_reg [label="gmx1"]; * cvmx_ipd_int_sum [label="IPD_INT_SUM|prc_par0|prc_par1|prc_par2|prc_par3|bp_sub"]; * cvmx_npi_rsl_int_blocks:ipd:e -> cvmx_ipd_int_sum [label="ipd"]; * cvmx_spx0_int_reg [label="SPXX_INT_REG(0)|prtnxa|abnorm|spiovr|clserr|drwnng|rsverr|tpaovr|diperr|syncerr|calerr"]; * cvmx_npi_rsl_int_blocks:spx0:e -> cvmx_spx0_int_reg [label="spx0"]; * cvmx_stx0_int_reg [label="STXX_INT_REG(0)|calpar0|calpar1|ovrbst|datovr|diperr|nosync|unxfrm|frmerr"]; * cvmx_npi_rsl_int_blocks:spx0:e -> cvmx_stx0_int_reg [label="spx0"]; * cvmx_pow_ecc_err [label="POW_ECC_ERR|sbe|dbe|rpe"]; * cvmx_npi_rsl_int_blocks:pow:e -> cvmx_pow_ecc_err [label="pow"]; * cvmx_spx1_int_reg [label="SPXX_INT_REG(1)|prtnxa|abnorm|spiovr|clserr|drwnng|rsverr|tpaovr|diperr|syncerr|calerr"]; * cvmx_npi_rsl_int_blocks:spx1:e -> cvmx_spx1_int_reg [label="spx1"]; * cvmx_stx1_int_reg [label="STXX_INT_REG(1)|calpar0|calpar1|ovrbst|datovr|diperr|nosync|unxfrm|frmerr"]; * cvmx_npi_rsl_int_blocks:spx1:e -> cvmx_stx1_int_reg [label="spx1"]; * cvmx_asx0_int_reg [label="ASXX_INT_REG(0)|txpsh|txpop|ovrflw"]; * cvmx_npi_rsl_int_blocks:asx0:e -> cvmx_asx0_int_reg [label="asx0"]; * cvmx_asx1_int_reg [label="ASXX_INT_REG(1)|txpsh|txpop|ovrflw"]; * cvmx_npi_rsl_int_blocks:asx1:e -> cvmx_asx1_int_reg [label="asx1"]; * cvmx_pko_reg_error [label="PKO_REG_ERROR|parity|doorbell"]; * cvmx_npi_rsl_int_blocks:pko:e -> cvmx_pko_reg_error [label="pko"]; * cvmx_tim_reg_error [label="TIM_REG_ERROR|mask"]; * cvmx_npi_rsl_int_blocks:tim:e -> cvmx_tim_reg_error [label="tim"]; * cvmx_key_int_sum [label="KEY_INT_SUM|ked0_sbe|ked0_dbe|ked1_sbe|ked1_dbe"]; * cvmx_npi_rsl_int_blocks:key:e -> cvmx_key_int_sum [label="key"]; * cvmx_mio_boot_err [label="MIO_BOOT_ERR|adr_err|wait_err"]; * cvmx_npi_rsl_int_blocks:mio:e -> cvmx_mio_boot_err [label="mio"]; * cvmx_pip_int_reg [label="PIP_INT_REG|prtnxa|badtag|skprunt|todoovr|feperr|beperr"]; * cvmx_npi_rsl_int_blocks:pip:e -> cvmx_pip_int_reg [label="pip"]; * cvmx_fpa_int_sum [label="FPA_INT_SUM|fed0_sbe|fed0_dbe|fed1_sbe|fed1_dbe|q0_und|q0_coff|q0_perr|q1_und|q1_coff|q1_perr|q2_und|q2_coff|q2_perr|q3_und|q3_coff|q3_perr|q4_und|q4_coff|q4_perr|q5_und|q5_coff|q5_perr|q6_und|q6_coff|q6_perr|q7_und|q7_coff|q7_perr"]; * cvmx_npi_rsl_int_blocks:fpa:e -> cvmx_fpa_int_sum [label="fpa"]; * cvmx_lmc0_mem_cfg0 [label="LMCX_MEM_CFG0(0)|sec_err|ded_err"]; * cvmx_npi_rsl_int_blocks:lmc:e -> cvmx_lmc0_mem_cfg0 [label="lmc"]; * cvmx_dfa_err [label="DFA_ERR|cp2sbe|cp2dbe|dtesbe|dtedbe|dteperr|cp2perr|dblovf"]; * cvmx_npi_rsl_int_blocks:dfa:e -> cvmx_dfa_err [label="dfa"]; * cvmx_iob_int_sum [label="IOB_INT_SUM|np_sop|np_eop|p_sop|p_eop"]; * cvmx_npi_rsl_int_blocks:iob:e -> cvmx_iob_int_sum [label="iob"]; * cvmx_zip_error [label="ZIP_ERROR|doorbell"]; * cvmx_npi_rsl_int_blocks:zip:e -> cvmx_zip_error [label="zip"]; * cvmx_gmx0_bad_reg -> cvmx_gmx0_rx0_int_reg [style=invis]; * cvmx_gmx0_rx0_int_reg -> cvmx_gmx0_rx1_int_reg [style=invis]; * cvmx_gmx0_rx1_int_reg -> cvmx_gmx0_rx2_int_reg [style=invis]; * cvmx_gmx0_rx2_int_reg -> cvmx_gmx0_rx3_int_reg [style=invis]; * cvmx_gmx0_rx3_int_reg -> cvmx_gmx0_tx_int_reg [style=invis]; * cvmx_gmx1_bad_reg -> cvmx_gmx1_rx0_int_reg [style=invis]; * cvmx_gmx1_rx0_int_reg -> cvmx_gmx1_rx1_int_reg [style=invis]; * cvmx_gmx1_rx1_int_reg -> cvmx_gmx1_rx2_int_reg [style=invis]; * cvmx_gmx1_rx2_int_reg -> cvmx_gmx1_rx3_int_reg [style=invis]; * cvmx_gmx1_rx3_int_reg -> cvmx_gmx1_tx_int_reg [style=invis]; * cvmx_spx0_int_reg -> cvmx_stx0_int_reg [style=invis]; * cvmx_spx1_int_reg -> cvmx_stx1_int_reg [style=invis]; * cvmx_root:root:e -> cvmx_npi_rsl_int_blocks [label="root"]; * } * @enddot */ #ifdef CVMX_BUILD_FOR_LINUX_KERNEL #include #include #include #include #else #include "cvmx.h" #include "cvmx-error.h" #include "cvmx-error-custom.h" #endif int cvmx_error_initialize_cn38xxp2(void) { cvmx_error_info_t info; int fail = 0; /* CVMX_CIU_INTX_SUM0(0) */ /* CVMX_CIU_INT_SUM1 */ /* CVMX_NPI_RSL_INT_BLOCKS */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.status_mask = 0; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = __CVMX_ERROR_REGISTER_NONE; info.parent.status_addr = 0; info.parent.status_mask = 0; info.func = __cvmx_error_decode; info.user_info = 0; fail |= cvmx_error_add(&info); /* CVMX_L2D_ERR */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_L2D_ERR; info.status_mask = 1ull<<3 /* sec_err */; info.enable_addr = CVMX_L2D_ERR; info.enable_mask = 1ull<<1 /* sec_intena */; info.flags = CVMX_ERROR_FLAGS_ECC_SINGLE_BIT; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<16 /* l2c */; info.func = __cvmx_error_handle_l2d_err_sec_err; info.user_info = (long) "ERROR L2D_ERR[SEC_ERR]: L2D Single Error corrected (SEC)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_L2D_ERR; info.status_mask = 1ull<<4 /* ded_err */; info.enable_addr = CVMX_L2D_ERR; info.enable_mask = 1ull<<2 /* ded_intena */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<16 /* l2c */; info.func = __cvmx_error_handle_l2d_err_ded_err; info.user_info = (long) "ERROR L2D_ERR[DED_ERR]: L2D Double Error detected (DED)\n"; fail |= cvmx_error_add(&info); /* CVMX_L2T_ERR */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_L2T_ERR; info.status_mask = 1ull<<3 /* sec_err */; info.enable_addr = CVMX_L2T_ERR; info.enable_mask = 1ull<<1 /* sec_intena */; info.flags = CVMX_ERROR_FLAGS_ECC_SINGLE_BIT; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<16 /* l2c */; info.func = __cvmx_error_handle_l2t_err_sec_err; info.user_info = (long) "ERROR L2T_ERR[SEC_ERR]: L2T Single Bit Error corrected (SEC)\n" " During every L2 Tag Probe, all 8 sets Tag's (at a\n" " given index) are checked for single bit errors(SBEs).\n" " This bit is set if ANY of the 8 sets contains an SBE.\n" " SBEs are auto corrected in HW and generate an\n" " interrupt(if enabled).\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_L2T_ERR; info.status_mask = 1ull<<4 /* ded_err */; info.enable_addr = CVMX_L2T_ERR; info.enable_mask = 1ull<<2 /* ded_intena */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<16 /* l2c */; info.func = __cvmx_error_handle_l2t_err_ded_err; info.user_info = (long) "ERROR L2T_ERR[DED_ERR]: L2T Double Bit Error detected (DED)\n" " During every L2 Tag Probe, all 8 sets Tag's (at a\n" " given index) are checked for double bit errors(DBEs).\n" " This bit is set if ANY of the 8 sets contains a DBE.\n" " DBEs also generated an interrupt(if enabled).\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_L2T_ERR; info.status_mask = 1ull<<24 /* lckerr */; info.enable_addr = CVMX_L2T_ERR; info.enable_mask = 1ull<<25 /* lck_intena */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<16 /* l2c */; info.func = __cvmx_error_handle_l2t_err_lckerr; info.user_info = (long) "ERROR L2T_ERR[LCKERR]: SW attempted to LOCK DOWN the last available set of\n" " the INDEX (which is ignored by HW - but reported to SW).\n" " The LDD(L1 load-miss) for the LOCK operation is completed\n" " successfully, however the address is NOT locked.\n" " NOTE: 'Available' sets takes the L2C_SPAR*[UMSK*]\n" " into account. For example, if diagnostic PPx has\n" " UMSKx defined to only use SETs [1:0], and SET1 had\n" " been previously LOCKED, then an attempt to LOCK the\n" " last available SET0 would result in a LCKERR. (This\n" " is to ensure that at least 1 SET at each INDEX is\n" " not LOCKED for general use by other PPs).\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_L2T_ERR; info.status_mask = 1ull<<26 /* lckerr2 */; info.enable_addr = CVMX_L2T_ERR; info.enable_mask = 1ull<<27 /* lck_intena2 */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<16 /* l2c */; info.func = __cvmx_error_handle_l2t_err_lckerr2; info.user_info = (long) "ERROR L2T_ERR[LCKERR2]: HW detected a case where a Rd/Wr Miss from PP#n\n" " could not find an available/unlocked set (for\n" " replacement).\n" " Most likely, this is a result of SW mixing SET\n" " PARTITIONING with ADDRESS LOCKING. If SW allows\n" " another PP to LOCKDOWN all SETs available to PP#n,\n" " then a Rd/Wr Miss from PP#n will be unable\n" " to determine a 'valid' replacement set (since LOCKED\n" " addresses should NEVER be replaced).\n" " If such an event occurs, the HW will select the smallest\n" " available SET(specified by UMSK'x)' as the replacement\n" " set, and the address is unlocked.\n"; fail |= cvmx_error_add(&info); /* CVMX_NPI_INT_SUM */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<0 /* rml_rto */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<0 /* rml_rto */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[RML_RTO]: Set '1' when the RML does not receive read data\n" " back from a RSL after sending a read command to\n" " a RSL.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<1 /* rml_wto */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<1 /* rml_wto */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[RML_WTO]: Set '1' when the RML does not receive a commit\n" " back from a RSL after sending a write command to\n" " a RSL.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<3 /* po0_2sml */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<3 /* po0_2sml */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[PO0_2SML]: The packet being sent out on Port0 is smaller\n" " than the NPI_BUFF_SIZE_OUTPUT0[ISIZE] field.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<4 /* po1_2sml */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<4 /* po1_2sml */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[PO1_2SML]: The packet being sent out on Port1 is smaller\n" " than the NPI_BUFF_SIZE_OUTPUT1[ISIZE] field.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<5 /* po2_2sml */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<5 /* po2_2sml */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[PO2_2SML]: The packet being sent out on Port2 is smaller\n" " than the NPI_BUFF_SIZE_OUTPUT2[ISIZE] field.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<6 /* po3_2sml */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<6 /* po3_2sml */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[PO3_2SML]: The packet being sent out on Port3 is smaller\n" " than the NPI_BUFF_SIZE_OUTPUT3[ISIZE] field.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<7 /* i0_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<7 /* i0_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I0_RTOUT]: Port-0 had a read timeout while attempting to\n" " read instructions.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<8 /* i1_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<8 /* i1_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I1_RTOUT]: Port-1 had a read timeout while attempting to\n" " read instructions.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<9 /* i2_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<9 /* i2_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I2_RTOUT]: Port-2 had a read timeout while attempting to\n" " read instructions.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<10 /* i3_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<10 /* i3_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I3_RTOUT]: Port-3 had a read timeout while attempting to\n" " read instructions.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<11 /* i0_overf */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<11 /* i0_overf */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I0_OVERF]: Port-0 had a doorbell overflow. Bit[31] of the\n" " doorbell count was set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<12 /* i1_overf */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<12 /* i1_overf */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I1_OVERF]: Port-1 had a doorbell overflow. Bit[31] of the\n" " doorbell count was set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<13 /* i2_overf */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<13 /* i2_overf */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I2_OVERF]: Port-2 had a doorbell overflow. Bit[31] of the\n" " doorbell count was set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<14 /* i3_overf */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<14 /* i3_overf */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I3_OVERF]: Port-3 had a doorbell overflow. Bit[31] of the\n" " doorbell count was set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<15 /* p0_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<15 /* p0_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P0_RTOUT]: Port-0 had a read timeout while attempting to\n" " read packet data.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<16 /* p1_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<16 /* p1_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P1_RTOUT]: Port-1 had a read timeout while attempting to\n" " read packet data.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<17 /* p2_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<17 /* p2_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P2_RTOUT]: Port-2 had a read timeout while attempting to\n" " read packet data.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<18 /* p3_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<18 /* p3_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P3_RTOUT]: Port-3 had a read timeout while attempting to\n" " read packet data.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<19 /* p0_perr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<19 /* p0_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P0_PERR]: If a parity error occured on the port's packet\n" " data this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<20 /* p1_perr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<20 /* p1_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P1_PERR]: If a parity error occured on the port's packet\n" " data this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<21 /* p2_perr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<21 /* p2_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P2_PERR]: If a parity error occured on the port's packet\n" " data this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<22 /* p3_perr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<22 /* p3_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P3_PERR]: If a parity error occured on the port's packet\n" " data this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<23 /* g0_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<23 /* g0_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[G0_RTOUT]: Port-0 had a read timeout while attempting to\n" " read a gather list.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<24 /* g1_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<24 /* g1_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[G1_RTOUT]: Port-1 had a read timeout while attempting to\n" " read a gather list.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<25 /* g2_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<25 /* g2_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[G2_RTOUT]: Port-2 had a read timeout while attempting to\n" " read a gather list.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<26 /* g3_rtout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<26 /* g3_rtout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[G3_RTOUT]: Port-3 had a read timeout while attempting to\n" " read a gather list.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<27 /* p0_pperr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<27 /* p0_pperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P0_PPERR]: If a parity error occured on the port DATA/INFO\n" " pointer-pair, this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<28 /* p1_pperr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<28 /* p1_pperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P1_PPERR]: If a parity error occured on the port DATA/INFO\n" " pointer-pair, this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<29 /* p2_pperr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<29 /* p2_pperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P2_PPERR]: If a parity error occured on the port DATA/INFO\n" " pointer-pair, this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<30 /* p3_pperr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<30 /* p3_pperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P3_PPERR]: If a parity error occured on the port DATA/INFO\n" " pointer-pair, this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<31 /* p0_ptout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<31 /* p0_ptout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P0_PTOUT]: Port-0 output had a read timeout on a DATA/INFO\n" " pair.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<32 /* p1_ptout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<32 /* p1_ptout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P1_PTOUT]: Port-1 output had a read timeout on a DATA/INFO\n" " pair.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<33 /* p2_ptout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<33 /* p2_ptout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P2_PTOUT]: Port-2 output had a read timeout on a DATA/INFO\n" " pair.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<34 /* p3_ptout */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<34 /* p3_ptout */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P3_PTOUT]: Port-3 output had a read timeout on a DATA/INFO\n" " pair.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<35 /* i0_pperr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<35 /* i0_pperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I0_PPERR]: If a parity error occured on the port's instruction\n" " this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<36 /* i1_pperr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<36 /* i1_pperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I1_PPERR]: If a parity error occured on the port's instruction\n" " this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<37 /* i2_pperr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<37 /* i2_pperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I2_PPERR]: If a parity error occured on the port's instruction\n" " this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<38 /* i3_pperr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<38 /* i3_pperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[I3_PPERR]: If a parity error occured on the port's instruction\n" " this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<39 /* win_rto */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<39 /* win_rto */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[WIN_RTO]: Windowed Load Timed Out.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<40 /* p_dperr */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<40 /* p_dperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[P_DPERR]: If a parity error occured on data written to L2C\n" " from the PCI this bit may be set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 1ull<<41 /* iobdma */; info.enable_addr = CVMX_NPI_INT_ENB; info.enable_mask = 1ull<<41 /* iobdma */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_INT_SUM[IOBDMA]: Requested IOBDMA read size exceeded 128 words.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_INT_SUM; info.status_mask = 0; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<3 /* npi */; info.func = __cvmx_error_decode; info.user_info = 0; fail |= cvmx_error_add(&info); /* CVMX_NPI_PCI_INT_SUM2 */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<0 /* tr_wabt */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<0 /* rtr_wabt */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[TR_WABT]: PCI Target Abort detected on write.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<1 /* mr_wabt */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<1 /* rmr_wabt */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[MR_WABT]: PCI Master Abort detected on write.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<2 /* mr_wtto */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<2 /* rmr_wtto */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[MR_WTTO]: PCI Master Retry Timeout on write.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<3 /* tr_abt */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<3 /* rtr_abt */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[TR_ABT]: PCI Target Abort On Read.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<4 /* mr_abt */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<4 /* rmr_abt */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[MR_ABT]: PCI Master Abort On Read.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<5 /* mr_tto */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<5 /* rmr_tto */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[MR_TTO]: PCI Master Retry Timeout On Read.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<6 /* msi_per */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<6 /* rmsi_per */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[MSI_PER]: PCI MSI Parity Error.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<7 /* msi_tabt */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<7 /* rmsi_tabt */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[MSI_TABT]: PCI MSI Target Abort.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<8 /* msi_mabt */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<8 /* rmsi_mabt */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[MSI_MABT]: PCI MSI Master Abort.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<9 /* msc_msg */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<9 /* rmsc_msg */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[MSC_MSG]: Master Split Completion Message Detected\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<10 /* tsr_abt */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<10 /* rtsr_abt */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[TSR_ABT]: Target Split-Read Abort Detected\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<11 /* serr */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<11 /* rserr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[SERR]: SERR# detected by PCX Core\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<12 /* aperr */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<12 /* raperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[APERR]: Address Parity Error detected by PCX Core\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<13 /* dperr */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<13 /* rdperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[DPERR]: Data Parity Error detected by PCX Core\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<14 /* ill_rwr */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<14 /* ill_rwr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[ILL_RWR]: A write to the disabled PCI registers took place.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<15 /* ill_rrd */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<15 /* ill_rrd */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[ILL_RRD]: A read to the disabled PCI registers took place.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<31 /* win_wr */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<31 /* win_wr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[WIN_WR]: A write to the disabled Window Write Data or\n" " Read-Address Register took place.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<32 /* ill_wr */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<32 /* ill_wr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[ILL_WR]: A write to a disabled area of bar1 or bar2,\n" " when the mem area is disabled.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_NPI_PCI_INT_SUM2; info.status_mask = 1ull<<33 /* ill_rd */; info.enable_addr = CVMX_NPI_PCI_INT_ENB2; info.enable_mask = 1ull<<33 /* ill_rd */; info.flags = 0; info.group = CVMX_ERROR_GROUP_PCI; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_INT_SUM; info.parent.status_mask = 1ull<<2 /* pci_rsl */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR NPI_PCI_INT_SUM2[ILL_RD]: A read to a disabled area of bar1 or bar2,\n" " when the mem area is disabled.\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_BAD_REG(0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(0); info.status_mask = 1ull<<0 /* out_col */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(0)[OUT_COL]: Outbound collision occured between PKO and NCB\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(0); info.status_mask = 1ull<<1 /* ncb_ovr */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(0)[NCB_OVR]: Outbound NCB FIFO Overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(0); info.status_mask = 0xffffull<<2 /* out_ovr */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(0)[OUT_OVR]: Outbound data FIFO overflow (per port)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(0); info.status_mask = 0xfull<<22 /* loststat */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(0)[LOSTSTAT]: TX Statistics data was over-written (per RGM port)\n" " TX Stats are corrupted\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(0); info.status_mask = 1ull<<26 /* statovr */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(0)[STATOVR]: TX Statistics overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(0); info.status_mask = 0xfull<<27 /* inb_nxa */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(0)[INB_NXA]: Inbound port > GMX_RX_PRTS\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_RXX_INT_REG(0,0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,0); info.status_mask = 1ull<<1 /* carext */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,0); info.enable_mask = 1ull<<1 /* carext */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,0)[CAREXT]: RGMII carrier extend error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,0); info.status_mask = 1ull<<2 /* maxerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,0); info.enable_mask = 1ull<<2 /* maxerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,0)[MAXERR]: Frame was received with length > max_length\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,0); info.status_mask = 1ull<<5 /* alnerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,0); info.enable_mask = 1ull<<5 /* alnerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,0)[ALNERR]: Frame was received with an alignment error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,0); info.status_mask = 1ull<<6 /* lenerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,0); info.enable_mask = 1ull<<6 /* lenerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,0)[LENERR]: Frame was received with length error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,0); info.status_mask = 1ull<<8 /* skperr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,0); info.enable_mask = 1ull<<8 /* skperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,0)[SKPERR]: Skipper error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,0); info.status_mask = 1ull<<9 /* niberr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,0); info.enable_mask = 1ull<<9 /* niberr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,0)[NIBERR]: Nibble error (hi_nibble != lo_nibble)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,0); info.status_mask = 1ull<<10 /* ovrerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,0); info.enable_mask = 1ull<<10 /* ovrerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,0)[OVRERR]: Internal Data Aggregation Overflow\n" " This interrupt should never assert\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_RXX_INT_REG(1,0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,0); info.status_mask = 1ull<<1 /* carext */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,0); info.enable_mask = 1ull<<1 /* carext */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 1; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,0)[CAREXT]: RGMII carrier extend error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,0); info.status_mask = 1ull<<2 /* maxerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,0); info.enable_mask = 1ull<<2 /* maxerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 1; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,0)[MAXERR]: Frame was received with length > max_length\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,0); info.status_mask = 1ull<<5 /* alnerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,0); info.enable_mask = 1ull<<5 /* alnerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 1; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,0)[ALNERR]: Frame was received with an alignment error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,0); info.status_mask = 1ull<<6 /* lenerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,0); info.enable_mask = 1ull<<6 /* lenerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 1; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,0)[LENERR]: Frame was received with length error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,0); info.status_mask = 1ull<<8 /* skperr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,0); info.enable_mask = 1ull<<8 /* skperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 1; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,0)[SKPERR]: Skipper error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,0); info.status_mask = 1ull<<9 /* niberr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,0); info.enable_mask = 1ull<<9 /* niberr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 1; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,0)[NIBERR]: Nibble error (hi_nibble != lo_nibble)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,0); info.status_mask = 1ull<<10 /* ovrerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,0); info.enable_mask = 1ull<<10 /* ovrerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 1; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,0)[OVRERR]: Internal Data Aggregation Overflow\n" " This interrupt should never assert\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_RXX_INT_REG(2,0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,0); info.status_mask = 1ull<<1 /* carext */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,0); info.enable_mask = 1ull<<1 /* carext */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 2; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,0)[CAREXT]: RGMII carrier extend error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,0); info.status_mask = 1ull<<2 /* maxerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,0); info.enable_mask = 1ull<<2 /* maxerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 2; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,0)[MAXERR]: Frame was received with length > max_length\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,0); info.status_mask = 1ull<<5 /* alnerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,0); info.enable_mask = 1ull<<5 /* alnerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 2; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,0)[ALNERR]: Frame was received with an alignment error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,0); info.status_mask = 1ull<<6 /* lenerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,0); info.enable_mask = 1ull<<6 /* lenerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 2; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,0)[LENERR]: Frame was received with length error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,0); info.status_mask = 1ull<<8 /* skperr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,0); info.enable_mask = 1ull<<8 /* skperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 2; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,0)[SKPERR]: Skipper error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,0); info.status_mask = 1ull<<9 /* niberr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,0); info.enable_mask = 1ull<<9 /* niberr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 2; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,0)[NIBERR]: Nibble error (hi_nibble != lo_nibble)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,0); info.status_mask = 1ull<<10 /* ovrerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,0); info.enable_mask = 1ull<<10 /* ovrerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 2; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,0)[OVRERR]: Internal Data Aggregation Overflow\n" " This interrupt should never assert\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_RXX_INT_REG(3,0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,0); info.status_mask = 1ull<<1 /* carext */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,0); info.enable_mask = 1ull<<1 /* carext */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 3; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,0)[CAREXT]: RGMII carrier extend error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,0); info.status_mask = 1ull<<2 /* maxerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,0); info.enable_mask = 1ull<<2 /* maxerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 3; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,0)[MAXERR]: Frame was received with length > max_length\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,0); info.status_mask = 1ull<<5 /* alnerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,0); info.enable_mask = 1ull<<5 /* alnerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 3; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,0)[ALNERR]: Frame was received with an alignment error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,0); info.status_mask = 1ull<<6 /* lenerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,0); info.enable_mask = 1ull<<6 /* lenerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 3; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,0)[LENERR]: Frame was received with length error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,0); info.status_mask = 1ull<<8 /* skperr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,0); info.enable_mask = 1ull<<8 /* skperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 3; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,0)[SKPERR]: Skipper error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,0); info.status_mask = 1ull<<9 /* niberr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,0); info.enable_mask = 1ull<<9 /* niberr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 3; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,0)[NIBERR]: Nibble error (hi_nibble != lo_nibble)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,0); info.status_mask = 1ull<<10 /* ovrerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,0); info.enable_mask = 1ull<<10 /* ovrerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 3; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,0)[OVRERR]: Internal Data Aggregation Overflow\n" " This interrupt should never assert\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_TX_INT_REG(0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_TX_INT_REG(0); info.status_mask = 1ull<<0 /* pko_nxa */; info.enable_addr = CVMX_GMXX_TX_INT_EN(0); info.enable_mask = 1ull<<0 /* pko_nxa */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_TX_INT_REG(0)[PKO_NXA]: Port address out-of-range from PKO Interface\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_TX_INT_REG(0); info.status_mask = 1ull<<1 /* ncb_nxa */; info.enable_addr = CVMX_GMXX_TX_INT_EN(0); info.enable_mask = 1ull<<1 /* ncb_nxa */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_TX_INT_REG(0)[NCB_NXA]: Port address out-of-range from NCB Interface\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_TX_INT_REG(0); info.status_mask = 0xfull<<2 /* undflw */; info.enable_addr = CVMX_GMXX_TX_INT_EN(0); info.enable_mask = 0xfull<<2 /* undflw */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<1 /* gmx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_TX_INT_REG(0)[UNDFLW]: TX Underflow (RGMII mode only)\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_BAD_REG(1) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(1); info.status_mask = 1ull<<0 /* out_col */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(1)[OUT_COL]: Outbound collision occured between PKO and NCB\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(1); info.status_mask = 1ull<<1 /* ncb_ovr */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(1)[NCB_OVR]: Outbound NCB FIFO Overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(1); info.status_mask = 0xffffull<<2 /* out_ovr */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(1)[OUT_OVR]: Outbound data FIFO overflow (per port)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(1); info.status_mask = 0xfull<<22 /* loststat */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(1)[LOSTSTAT]: TX Statistics data was over-written (per RGM port)\n" " TX Stats are corrupted\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(1); info.status_mask = 1ull<<26 /* statovr */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(1)[STATOVR]: TX Statistics overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_BAD_REG(1); info.status_mask = 0xfull<<27 /* inb_nxa */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_BAD_REG(1)[INB_NXA]: Inbound port > GMX_RX_PRTS\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_RXX_INT_REG(0,1) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,1); info.status_mask = 1ull<<1 /* carext */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,1); info.enable_mask = 1ull<<1 /* carext */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,1)[CAREXT]: RGMII carrier extend error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,1); info.status_mask = 1ull<<2 /* maxerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,1); info.enable_mask = 1ull<<2 /* maxerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,1)[MAXERR]: Frame was received with length > max_length\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,1); info.status_mask = 1ull<<5 /* alnerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,1); info.enable_mask = 1ull<<5 /* alnerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,1)[ALNERR]: Frame was received with an alignment error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,1); info.status_mask = 1ull<<6 /* lenerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,1); info.enable_mask = 1ull<<6 /* lenerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,1)[LENERR]: Frame was received with length error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,1); info.status_mask = 1ull<<8 /* skperr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,1); info.enable_mask = 1ull<<8 /* skperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,1)[SKPERR]: Skipper error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,1); info.status_mask = 1ull<<9 /* niberr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,1); info.enable_mask = 1ull<<9 /* niberr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,1)[NIBERR]: Nibble error (hi_nibble != lo_nibble)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(0,1); info.status_mask = 1ull<<10 /* ovrerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(0,1); info.enable_mask = 1ull<<10 /* ovrerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(0,1)[OVRERR]: Internal Data Aggregation Overflow\n" " This interrupt should never assert\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_RXX_INT_REG(1,1) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,1); info.status_mask = 1ull<<1 /* carext */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,1); info.enable_mask = 1ull<<1 /* carext */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 17; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,1)[CAREXT]: RGMII carrier extend error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,1); info.status_mask = 1ull<<2 /* maxerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,1); info.enable_mask = 1ull<<2 /* maxerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 17; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,1)[MAXERR]: Frame was received with length > max_length\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,1); info.status_mask = 1ull<<5 /* alnerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,1); info.enable_mask = 1ull<<5 /* alnerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 17; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,1)[ALNERR]: Frame was received with an alignment error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,1); info.status_mask = 1ull<<6 /* lenerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,1); info.enable_mask = 1ull<<6 /* lenerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 17; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,1)[LENERR]: Frame was received with length error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,1); info.status_mask = 1ull<<8 /* skperr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,1); info.enable_mask = 1ull<<8 /* skperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 17; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,1)[SKPERR]: Skipper error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,1); info.status_mask = 1ull<<9 /* niberr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,1); info.enable_mask = 1ull<<9 /* niberr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 17; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,1)[NIBERR]: Nibble error (hi_nibble != lo_nibble)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(1,1); info.status_mask = 1ull<<10 /* ovrerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(1,1); info.enable_mask = 1ull<<10 /* ovrerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 17; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(1,1)[OVRERR]: Internal Data Aggregation Overflow\n" " This interrupt should never assert\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_RXX_INT_REG(2,1) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,1); info.status_mask = 1ull<<1 /* carext */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,1); info.enable_mask = 1ull<<1 /* carext */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 18; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,1)[CAREXT]: RGMII carrier extend error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,1); info.status_mask = 1ull<<2 /* maxerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,1); info.enable_mask = 1ull<<2 /* maxerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 18; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,1)[MAXERR]: Frame was received with length > max_length\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,1); info.status_mask = 1ull<<5 /* alnerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,1); info.enable_mask = 1ull<<5 /* alnerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 18; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,1)[ALNERR]: Frame was received with an alignment error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,1); info.status_mask = 1ull<<6 /* lenerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,1); info.enable_mask = 1ull<<6 /* lenerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 18; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,1)[LENERR]: Frame was received with length error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,1); info.status_mask = 1ull<<8 /* skperr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,1); info.enable_mask = 1ull<<8 /* skperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 18; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,1)[SKPERR]: Skipper error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,1); info.status_mask = 1ull<<9 /* niberr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,1); info.enable_mask = 1ull<<9 /* niberr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 18; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,1)[NIBERR]: Nibble error (hi_nibble != lo_nibble)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(2,1); info.status_mask = 1ull<<10 /* ovrerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(2,1); info.enable_mask = 1ull<<10 /* ovrerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 18; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(2,1)[OVRERR]: Internal Data Aggregation Overflow\n" " This interrupt should never assert\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_RXX_INT_REG(3,1) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,1); info.status_mask = 1ull<<1 /* carext */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,1); info.enable_mask = 1ull<<1 /* carext */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 19; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,1)[CAREXT]: RGMII carrier extend error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,1); info.status_mask = 1ull<<2 /* maxerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,1); info.enable_mask = 1ull<<2 /* maxerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 19; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,1)[MAXERR]: Frame was received with length > max_length\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,1); info.status_mask = 1ull<<5 /* alnerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,1); info.enable_mask = 1ull<<5 /* alnerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 19; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,1)[ALNERR]: Frame was received with an alignment error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,1); info.status_mask = 1ull<<6 /* lenerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,1); info.enable_mask = 1ull<<6 /* lenerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 19; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,1)[LENERR]: Frame was received with length error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,1); info.status_mask = 1ull<<8 /* skperr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,1); info.enable_mask = 1ull<<8 /* skperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 19; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,1)[SKPERR]: Skipper error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,1); info.status_mask = 1ull<<9 /* niberr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,1); info.enable_mask = 1ull<<9 /* niberr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 19; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,1)[NIBERR]: Nibble error (hi_nibble != lo_nibble)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_RXX_INT_REG(3,1); info.status_mask = 1ull<<10 /* ovrerr */; info.enable_addr = CVMX_GMXX_RXX_INT_EN(3,1); info.enable_mask = 1ull<<10 /* ovrerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 19; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_RXX_INT_REG(3,1)[OVRERR]: Internal Data Aggregation Overflow\n" " This interrupt should never assert\n"; fail |= cvmx_error_add(&info); /* CVMX_GMXX_TX_INT_REG(1) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_TX_INT_REG(1); info.status_mask = 1ull<<0 /* pko_nxa */; info.enable_addr = CVMX_GMXX_TX_INT_EN(1); info.enable_mask = 1ull<<0 /* pko_nxa */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_TX_INT_REG(1)[PKO_NXA]: Port address out-of-range from PKO Interface\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_TX_INT_REG(1); info.status_mask = 1ull<<1 /* ncb_nxa */; info.enable_addr = CVMX_GMXX_TX_INT_EN(1); info.enable_mask = 1ull<<1 /* ncb_nxa */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_TX_INT_REG(1)[NCB_NXA]: Port address out-of-range from NCB Interface\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_GMXX_TX_INT_REG(1); info.status_mask = 0xfull<<2 /* undflw */; info.enable_addr = CVMX_GMXX_TX_INT_EN(1); info.enable_mask = 0xfull<<2 /* undflw */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<2 /* gmx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR GMXX_TX_INT_REG(1)[UNDFLW]: TX Underflow (RGMII mode only)\n"; fail |= cvmx_error_add(&info); /* CVMX_IPD_INT_SUM */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_IPD_INT_SUM; info.status_mask = 1ull<<0 /* prc_par0 */; info.enable_addr = CVMX_IPD_INT_ENB; info.enable_mask = 1ull<<0 /* prc_par0 */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<9 /* ipd */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR IPD_INT_SUM[PRC_PAR0]: Set when a parity error is dected for bits\n" " [31:0] of the PBM memory.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_IPD_INT_SUM; info.status_mask = 1ull<<1 /* prc_par1 */; info.enable_addr = CVMX_IPD_INT_ENB; info.enable_mask = 1ull<<1 /* prc_par1 */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<9 /* ipd */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR IPD_INT_SUM[PRC_PAR1]: Set when a parity error is dected for bits\n" " [63:32] of the PBM memory.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_IPD_INT_SUM; info.status_mask = 1ull<<2 /* prc_par2 */; info.enable_addr = CVMX_IPD_INT_ENB; info.enable_mask = 1ull<<2 /* prc_par2 */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<9 /* ipd */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR IPD_INT_SUM[PRC_PAR2]: Set when a parity error is dected for bits\n" " [95:64] of the PBM memory.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_IPD_INT_SUM; info.status_mask = 1ull<<3 /* prc_par3 */; info.enable_addr = CVMX_IPD_INT_ENB; info.enable_mask = 1ull<<3 /* prc_par3 */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<9 /* ipd */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR IPD_INT_SUM[PRC_PAR3]: Set when a parity error is dected for bits\n" " [127:96] of the PBM memory.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_IPD_INT_SUM; info.status_mask = 1ull<<4 /* bp_sub */; info.enable_addr = CVMX_IPD_INT_ENB; info.enable_mask = 1ull<<4 /* bp_sub */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<9 /* ipd */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR IPD_INT_SUM[BP_SUB]: Set when a backpressure subtract is done with a\n" " supplied illegal value.\n"; fail |= cvmx_error_add(&info); /* CVMX_SPXX_INT_REG(0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<0 /* prtnxa */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<0 /* prtnxa */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[PRTNXA]: Port out of range\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<1 /* abnorm */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<1 /* abnorm */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[ABNORM]: Abnormal packet termination (ERR bit)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<4 /* spiovr */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<4 /* spiovr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[SPIOVR]: Spi async FIFO overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<5 /* clserr */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<5 /* clserr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[CLSERR]: Spi4 packet closed on non-16B alignment without EOP\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<6 /* drwnng */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<6 /* drwnng */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[DRWNNG]: Spi4 receive FIFO drowning/overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<7 /* rsverr */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<7 /* rsverr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[RSVERR]: Spi4 reserved control word detected\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<8 /* tpaovr */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<8 /* tpaovr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[TPAOVR]: Selected port has hit TPA overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<9 /* diperr */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<9 /* diperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[DIPERR]: Spi4 DIP4 error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<10 /* syncerr */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<10 /* syncerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[SYNCERR]: Consecutive Spi4 DIP4 errors have exceeded\n" " SPX_ERR_CTL[ERRCNT]\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(0); info.status_mask = 1ull<<11 /* calerr */; info.enable_addr = CVMX_SPXX_INT_MSK(0); info.enable_mask = 1ull<<11 /* calerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(0)[CALERR]: Spi4 Calendar table parity error\n"; fail |= cvmx_error_add(&info); /* CVMX_STXX_INT_REG(0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(0); info.status_mask = 1ull<<0 /* calpar0 */; info.enable_addr = CVMX_STXX_INT_MSK(0); info.enable_mask = 1ull<<0 /* calpar0 */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(0)[CALPAR0]: STX Calendar Table Parity Error Bank0\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(0); info.status_mask = 1ull<<1 /* calpar1 */; info.enable_addr = CVMX_STXX_INT_MSK(0); info.enable_mask = 1ull<<1 /* calpar1 */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(0)[CALPAR1]: STX Calendar Table Parity Error Bank1\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(0); info.status_mask = 1ull<<2 /* ovrbst */; info.enable_addr = CVMX_STXX_INT_MSK(0); info.enable_mask = 1ull<<2 /* ovrbst */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(0)[OVRBST]: Transmit packet burst too big\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(0); info.status_mask = 1ull<<3 /* datovr */; info.enable_addr = CVMX_STXX_INT_MSK(0); info.enable_mask = 1ull<<3 /* datovr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(0)[DATOVR]: Spi4 FIFO overflow error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(0); info.status_mask = 1ull<<4 /* diperr */; info.enable_addr = CVMX_STXX_INT_MSK(0); info.enable_mask = 1ull<<4 /* diperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(0)[DIPERR]: DIP2 error on the Spi4 Status channel\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(0); info.status_mask = 1ull<<5 /* nosync */; info.enable_addr = CVMX_STXX_INT_MSK(0); info.enable_mask = 1ull<<5 /* nosync */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(0)[NOSYNC]: ERRCNT has exceeded STX_DIP_CNT[MAXDIP]\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(0); info.status_mask = 1ull<<6 /* unxfrm */; info.enable_addr = CVMX_STXX_INT_MSK(0); info.enable_mask = 1ull<<6 /* unxfrm */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(0)[UNXFRM]: Unexpected framing sequence\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(0); info.status_mask = 1ull<<7 /* frmerr */; info.enable_addr = CVMX_STXX_INT_MSK(0); info.enable_mask = 1ull<<7 /* frmerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<18 /* spx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(0)[FRMERR]: FRMCNT has exceeded STX_DIP_CNT[MAXFRM]\n"; fail |= cvmx_error_add(&info); /* CVMX_POW_ECC_ERR */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_POW_ECC_ERR; info.status_mask = 1ull<<0 /* sbe */; info.enable_addr = CVMX_POW_ECC_ERR; info.enable_mask = 1ull<<2 /* sbe_ie */; info.flags = CVMX_ERROR_FLAGS_ECC_SINGLE_BIT; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<12 /* pow */; info.func = __cvmx_error_handle_pow_ecc_err_sbe; info.user_info = (long) "ERROR POW_ECC_ERR[SBE]: Single bit error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_POW_ECC_ERR; info.status_mask = 1ull<<1 /* dbe */; info.enable_addr = CVMX_POW_ECC_ERR; info.enable_mask = 1ull<<3 /* dbe_ie */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<12 /* pow */; info.func = __cvmx_error_handle_pow_ecc_err_dbe; info.user_info = (long) "ERROR POW_ECC_ERR[DBE]: Double bit error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_POW_ECC_ERR; info.status_mask = 1ull<<12 /* rpe */; info.enable_addr = CVMX_POW_ECC_ERR; info.enable_mask = 1ull<<13 /* rpe_ie */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<12 /* pow */; info.func = __cvmx_error_handle_pow_ecc_err_rpe; info.user_info = (long) "ERROR POW_ECC_ERR[RPE]: Remote pointer error\n"; fail |= cvmx_error_add(&info); /* CVMX_SPXX_INT_REG(1) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<0 /* prtnxa */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<0 /* prtnxa */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[PRTNXA]: Port out of range\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<1 /* abnorm */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<1 /* abnorm */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[ABNORM]: Abnormal packet termination (ERR bit)\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<4 /* spiovr */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<4 /* spiovr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[SPIOVR]: Spi async FIFO overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<5 /* clserr */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<5 /* clserr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[CLSERR]: Spi4 packet closed on non-16B alignment without EOP\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<6 /* drwnng */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<6 /* drwnng */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[DRWNNG]: Spi4 receive FIFO drowning/overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<7 /* rsverr */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<7 /* rsverr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[RSVERR]: Spi4 reserved control word detected\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<8 /* tpaovr */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<8 /* tpaovr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[TPAOVR]: Selected port has hit TPA overflow\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<9 /* diperr */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<9 /* diperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[DIPERR]: Spi4 DIP4 error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<10 /* syncerr */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<10 /* syncerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[SYNCERR]: Consecutive Spi4 DIP4 errors have exceeded\n" " SPX_ERR_CTL[ERRCNT]\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_SPXX_INT_REG(1); info.status_mask = 1ull<<11 /* calerr */; info.enable_addr = CVMX_SPXX_INT_MSK(1); info.enable_mask = 1ull<<11 /* calerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR SPXX_INT_REG(1)[CALERR]: Spi4 Calendar table parity error\n"; fail |= cvmx_error_add(&info); /* CVMX_STXX_INT_REG(1) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(1); info.status_mask = 1ull<<0 /* calpar0 */; info.enable_addr = CVMX_STXX_INT_MSK(1); info.enable_mask = 1ull<<0 /* calpar0 */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(1)[CALPAR0]: STX Calendar Table Parity Error Bank0\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(1); info.status_mask = 1ull<<1 /* calpar1 */; info.enable_addr = CVMX_STXX_INT_MSK(1); info.enable_mask = 1ull<<1 /* calpar1 */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(1)[CALPAR1]: STX Calendar Table Parity Error Bank1\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(1); info.status_mask = 1ull<<2 /* ovrbst */; info.enable_addr = CVMX_STXX_INT_MSK(1); info.enable_mask = 1ull<<2 /* ovrbst */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(1)[OVRBST]: Transmit packet burst too big\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(1); info.status_mask = 1ull<<3 /* datovr */; info.enable_addr = CVMX_STXX_INT_MSK(1); info.enable_mask = 1ull<<3 /* datovr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(1)[DATOVR]: Spi4 FIFO overflow error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(1); info.status_mask = 1ull<<4 /* diperr */; info.enable_addr = CVMX_STXX_INT_MSK(1); info.enable_mask = 1ull<<4 /* diperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(1)[DIPERR]: DIP2 error on the Spi4 Status channel\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(1); info.status_mask = 1ull<<5 /* nosync */; info.enable_addr = CVMX_STXX_INT_MSK(1); info.enable_mask = 1ull<<5 /* nosync */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(1)[NOSYNC]: ERRCNT has exceeded STX_DIP_CNT[MAXDIP]\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(1); info.status_mask = 1ull<<6 /* unxfrm */; info.enable_addr = CVMX_STXX_INT_MSK(1); info.enable_mask = 1ull<<6 /* unxfrm */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(1)[UNXFRM]: Unexpected framing sequence\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_STXX_INT_REG(1); info.status_mask = 1ull<<7 /* frmerr */; info.enable_addr = CVMX_STXX_INT_MSK(1); info.enable_mask = 1ull<<7 /* frmerr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<19 /* spx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR STXX_INT_REG(1)[FRMERR]: FRMCNT has exceeded STX_DIP_CNT[MAXFRM]\n"; fail |= cvmx_error_add(&info); /* CVMX_ASXX_INT_REG(0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_ASXX_INT_REG(0); info.status_mask = 0xfull<<8 /* txpsh */; info.enable_addr = CVMX_ASXX_INT_EN(0); info.enable_mask = 0xfull<<8 /* txpsh */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<22 /* asx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR ASXX_INT_REG(0)[TXPSH]: TX FIFO overflow on RMGII port\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_ASXX_INT_REG(0); info.status_mask = 0xfull<<4 /* txpop */; info.enable_addr = CVMX_ASXX_INT_EN(0); info.enable_mask = 0xfull<<4 /* txpop */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<22 /* asx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR ASXX_INT_REG(0)[TXPOP]: TX FIFO underflow on RMGII port\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_ASXX_INT_REG(0); info.status_mask = 0xfull<<0 /* ovrflw */; info.enable_addr = CVMX_ASXX_INT_EN(0); info.enable_mask = 0xfull<<0 /* ovrflw */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<22 /* asx0 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR ASXX_INT_REG(0)[OVRFLW]: RX FIFO overflow on RMGII port\n"; fail |= cvmx_error_add(&info); /* CVMX_ASXX_INT_REG(1) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_ASXX_INT_REG(1); info.status_mask = 0xfull<<8 /* txpsh */; info.enable_addr = CVMX_ASXX_INT_EN(1); info.enable_mask = 0xfull<<8 /* txpsh */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<23 /* asx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR ASXX_INT_REG(1)[TXPSH]: TX FIFO overflow on RMGII port\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_ASXX_INT_REG(1); info.status_mask = 0xfull<<4 /* txpop */; info.enable_addr = CVMX_ASXX_INT_EN(1); info.enable_mask = 0xfull<<4 /* txpop */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<23 /* asx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR ASXX_INT_REG(1)[TXPOP]: TX FIFO underflow on RMGII port\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_ASXX_INT_REG(1); info.status_mask = 0xfull<<0 /* ovrflw */; info.enable_addr = CVMX_ASXX_INT_EN(1); info.enable_mask = 0xfull<<0 /* ovrflw */; info.flags = 0; info.group = CVMX_ERROR_GROUP_ETHERNET; info.group_index = 16; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<23 /* asx1 */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR ASXX_INT_REG(1)[OVRFLW]: RX FIFO overflow on RMGII port\n"; fail |= cvmx_error_add(&info); /* CVMX_PKO_REG_ERROR */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_PKO_REG_ERROR; info.status_mask = 1ull<<0 /* parity */; info.enable_addr = CVMX_PKO_REG_INT_MASK; info.enable_mask = 1ull<<0 /* parity */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<10 /* pko */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR PKO_REG_ERROR[PARITY]: Read parity error at port data buffer\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_PKO_REG_ERROR; info.status_mask = 1ull<<1 /* doorbell */; info.enable_addr = CVMX_PKO_REG_INT_MASK; info.enable_mask = 1ull<<1 /* doorbell */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<10 /* pko */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR PKO_REG_ERROR[DOORBELL]: A doorbell count has overflowed\n"; fail |= cvmx_error_add(&info); /* CVMX_TIM_REG_ERROR */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_TIM_REG_ERROR; info.status_mask = 0xffffull<<0 /* mask */; info.enable_addr = CVMX_TIM_REG_INT_MASK; info.enable_mask = 0xffffull<<0 /* mask */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<11 /* tim */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR TIM_REG_ERROR[MASK]: Bit mask indicating the rings in error\n"; fail |= cvmx_error_add(&info); /* CVMX_KEY_INT_SUM */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_KEY_INT_SUM; info.status_mask = 1ull<<0 /* ked0_sbe */; info.enable_addr = CVMX_KEY_INT_ENB; info.enable_mask = 1ull<<0 /* ked0_sbe */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<4 /* key */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR KEY_INT_SUM[KED0_SBE]: Error Bit\n" ; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_KEY_INT_SUM; info.status_mask = 1ull<<1 /* ked0_dbe */; info.enable_addr = CVMX_KEY_INT_ENB; info.enable_mask = 1ull<<1 /* ked0_dbe */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<4 /* key */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR KEY_INT_SUM[KED0_DBE]: Error Bit\n" ; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_KEY_INT_SUM; info.status_mask = 1ull<<2 /* ked1_sbe */; info.enable_addr = CVMX_KEY_INT_ENB; info.enable_mask = 1ull<<2 /* ked1_sbe */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<4 /* key */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR KEY_INT_SUM[KED1_SBE]: Error Bit\n" ; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_KEY_INT_SUM; info.status_mask = 1ull<<3 /* ked1_dbe */; info.enable_addr = CVMX_KEY_INT_ENB; info.enable_mask = 1ull<<3 /* ked1_dbe */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<4 /* key */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR KEY_INT_SUM[KED1_DBE]: Error Bit\n" ; fail |= cvmx_error_add(&info); /* CVMX_MIO_BOOT_ERR */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_MIO_BOOT_ERR; info.status_mask = 1ull<<0 /* adr_err */; info.enable_addr = CVMX_MIO_BOOT_INT; info.enable_mask = 1ull<<0 /* adr_int */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<0 /* mio */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR MIO_BOOT_ERR[ADR_ERR]: Address decode error\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_MIO_BOOT_ERR; info.status_mask = 1ull<<1 /* wait_err */; info.enable_addr = CVMX_MIO_BOOT_INT; info.enable_mask = 1ull<<1 /* wait_int */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<0 /* mio */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR MIO_BOOT_ERR[WAIT_ERR]: Wait mode error\n"; fail |= cvmx_error_add(&info); /* CVMX_PIP_INT_REG */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_PIP_INT_REG; info.status_mask = 1ull<<3 /* prtnxa */; info.enable_addr = CVMX_PIP_INT_EN; info.enable_mask = 1ull<<3 /* prtnxa */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<20 /* pip */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR PIP_INT_REG[PRTNXA]: Non-existent port\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_PIP_INT_REG; info.status_mask = 1ull<<4 /* badtag */; info.enable_addr = CVMX_PIP_INT_EN; info.enable_mask = 1ull<<4 /* badtag */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<20 /* pip */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR PIP_INT_REG[BADTAG]: A bad tag was sent from IPD\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_PIP_INT_REG; info.status_mask = 1ull<<5 /* skprunt */; info.enable_addr = CVMX_PIP_INT_EN; info.enable_mask = 1ull<<5 /* skprunt */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<20 /* pip */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR PIP_INT_REG[SKPRUNT]: Packet was engulfed by skipper\n" " This interrupt can occur with received PARTIAL\n" " packets that are truncated to SKIP bytes or\n" " smaller.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_PIP_INT_REG; info.status_mask = 1ull<<6 /* todoovr */; info.enable_addr = CVMX_PIP_INT_EN; info.enable_mask = 1ull<<6 /* todoovr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<20 /* pip */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR PIP_INT_REG[TODOOVR]: Todo list overflow (see PIP_BCK_PRS[HIWATER])\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_PIP_INT_REG; info.status_mask = 1ull<<7 /* feperr */; info.enable_addr = CVMX_PIP_INT_EN; info.enable_mask = 1ull<<7 /* feperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<20 /* pip */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR PIP_INT_REG[FEPERR]: Parity Error in front end memory\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_PIP_INT_REG; info.status_mask = 1ull<<8 /* beperr */; info.enable_addr = CVMX_PIP_INT_EN; info.enable_mask = 1ull<<8 /* beperr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<20 /* pip */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR PIP_INT_REG[BEPERR]: Parity Error in back end memory\n"; fail |= cvmx_error_add(&info); /* CVMX_FPA_INT_SUM */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<0 /* fed0_sbe */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<0 /* fed0_sbe */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[FED0_SBE]: Set when a Single Bit Error is detected in FPF0.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<1 /* fed0_dbe */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<1 /* fed0_dbe */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[FED0_DBE]: Set when a Double Bit Error is detected in FPF0.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<2 /* fed1_sbe */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<2 /* fed1_sbe */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[FED1_SBE]: Set when a Single Bit Error is detected in FPF1.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<3 /* fed1_dbe */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<3 /* fed1_dbe */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[FED1_DBE]: Set when a Double Bit Error is detected in FPF1.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<4 /* q0_und */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<4 /* q0_und */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q0_UND]: Set when a Queue0 page count available goes\n" " negative.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<5 /* q0_coff */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<5 /* q0_coff */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q0_COFF]: Set when a Queue0 stack end tag is present and\n" " the count available is greater than pointers\n" " present in the FPA.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<6 /* q0_perr */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<6 /* q0_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q0_PERR]: Set when a Queue0 pointer read from the stack in\n" " the L2C does not have the FPA owner ship bit set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<7 /* q1_und */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<7 /* q1_und */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q1_UND]: Set when a Queue0 page count available goes\n" " negative.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<8 /* q1_coff */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<8 /* q1_coff */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q1_COFF]: Set when a Queue0 stack end tag is present and\n" " the count available is greater than pointers\n" " present in the FPA.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<9 /* q1_perr */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<9 /* q1_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q1_PERR]: Set when a Queue0 pointer read from the stack in\n" " the L2C does not have the FPA owner ship bit set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<10 /* q2_und */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<10 /* q2_und */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q2_UND]: Set when a Queue0 page count available goes\n" " negative.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<11 /* q2_coff */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<11 /* q2_coff */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q2_COFF]: Set when a Queue0 stack end tag is present and\n" " the count available is greater than than pointers\n" " present in the FPA.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<12 /* q2_perr */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<12 /* q2_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q2_PERR]: Set when a Queue0 pointer read from the stack in\n" " the L2C does not have the FPA owner ship bit set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<13 /* q3_und */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<13 /* q3_und */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q3_UND]: Set when a Queue0 page count available goes\n" " negative.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<14 /* q3_coff */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<14 /* q3_coff */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q3_COFF]: Set when a Queue0 stack end tag is present and\n" " the count available is greater than than pointers\n" " present in the FPA.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<15 /* q3_perr */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<15 /* q3_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q3_PERR]: Set when a Queue0 pointer read from the stack in\n" " the L2C does not have the FPA owner ship bit set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<16 /* q4_und */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<16 /* q4_und */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q4_UND]: Set when a Queue0 page count available goes\n" " negative.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<17 /* q4_coff */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<17 /* q4_coff */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q4_COFF]: Set when a Queue0 stack end tag is present and\n" " the count available is greater than than pointers\n" " present in the FPA.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<18 /* q4_perr */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<18 /* q4_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q4_PERR]: Set when a Queue0 pointer read from the stack in\n" " the L2C does not have the FPA owner ship bit set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<19 /* q5_und */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<19 /* q5_und */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q5_UND]: Set when a Queue0 page count available goes\n" " negative.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<20 /* q5_coff */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<20 /* q5_coff */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q5_COFF]: Set when a Queue0 stack end tag is present and\n" " the count available is greater than than pointers\n" " present in the FPA.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<21 /* q5_perr */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<21 /* q5_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q5_PERR]: Set when a Queue0 pointer read from the stack in\n" " the L2C does not have the FPA owner ship bit set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<22 /* q6_und */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<22 /* q6_und */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q6_UND]: Set when a Queue0 page count available goes\n" " negative.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<23 /* q6_coff */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<23 /* q6_coff */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q6_COFF]: Set when a Queue0 stack end tag is present and\n" " the count available is greater than than pointers\n" " present in the FPA.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<24 /* q6_perr */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<24 /* q6_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q6_PERR]: Set when a Queue0 pointer read from the stack in\n" " the L2C does not have the FPA owner ship bit set.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<25 /* q7_und */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<25 /* q7_und */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q7_UND]: Set when a Queue0 page count available goes\n" " negative.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<26 /* q7_coff */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<26 /* q7_coff */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q7_COFF]: Set when a Queue0 stack end tag is present and\n" " the count available is greater than than pointers\n" " present in the FPA.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_FPA_INT_SUM; info.status_mask = 1ull<<27 /* q7_perr */; info.enable_addr = CVMX_FPA_INT_ENB; info.enable_mask = 1ull<<27 /* q7_perr */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<5 /* fpa */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR FPA_INT_SUM[Q7_PERR]: Set when a Queue0 pointer read from the stack in\n" " the L2C does not have the FPA owner ship bit set.\n"; fail |= cvmx_error_add(&info); /* CVMX_LMCX_MEM_CFG0(0) */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_LMCX_MEM_CFG0(0); info.status_mask = 0xfull<<21 /* sec_err */; info.enable_addr = CVMX_LMCX_MEM_CFG0(0); info.enable_mask = 1ull<<19 /* intr_sec_ena */; info.flags = CVMX_ERROR_FLAGS_ECC_SINGLE_BIT; info.group = CVMX_ERROR_GROUP_LMC; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<17 /* lmc */; info.func = __cvmx_error_handle_lmcx_mem_cfg0_sec_err; info.user_info = (long) "ERROR LMCX_MEM_CFG0(0)[SEC_ERR]: Single Error (corrected) of Rd Data\n" " In 128b mode, ecc is calulated on 1 cycle worth of data\n" " [21] corresponds to DQ[63:0], Phase0\n" " [22] corresponds to DQ[127:64], Phase0\n" " [23] corresponds to DQ[63:0], Phase1\n" " [24] corresponds to DQ[127:64], Phase1\n" " In 64b mode, ecc is calculated on 2 cycle worth of data\n" " [21] corresponds to DQ[63:0], Phase0, cycle0\n" " [22] corresponds to DQ[63:0], Phase0, cycle1\n" " [23] corresponds to DQ[63:0], Phase1, cycle0\n" " [24] corresponds to DQ[63:0], Phase1, cycle1\n" " Write of 1 will clear the corresponding error bit\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_LMCX_MEM_CFG0(0); info.status_mask = 0xfull<<25 /* ded_err */; info.enable_addr = CVMX_LMCX_MEM_CFG0(0); info.enable_mask = 1ull<<20 /* intr_ded_ena */; info.flags = 0; info.group = CVMX_ERROR_GROUP_LMC; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<17 /* lmc */; info.func = __cvmx_error_handle_lmcx_mem_cfg0_ded_err; info.user_info = (long) "ERROR LMCX_MEM_CFG0(0)[DED_ERR]: Double Error detected (DED) of Rd Data\n" " In 128b mode, ecc is calulated on 1 cycle worth of data\n" " [25] corresponds to DQ[63:0], Phase0\n" " [26] corresponds to DQ[127:64], Phase0\n" " [27] corresponds to DQ[63:0], Phase1\n" " [28] corresponds to DQ[127:64], Phase1\n" " In 64b mode, ecc is calculated on 2 cycle worth of data\n" " [25] corresponds to DQ[63:0], Phase0, cycle0\n" " [26] corresponds to DQ[63:0], Phase0, cycle1\n" " [27] corresponds to DQ[63:0], Phase1, cycle0\n" " [28] corresponds to DQ[63:0], Phase1, cycle1\n" " Write of 1 will clear the corresponding error bit\n"; fail |= cvmx_error_add(&info); /* CVMX_DFA_ERR */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_DFA_ERR; info.status_mask = 1ull<<1 /* cp2sbe */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<6 /* dfa */; info.func = __cvmx_error_handle_dfa_err_cp2sbe; info.user_info = (long) "ERROR DFA_ERR[CP2SBE]: PP-CP2 Single Bit Error Corrected - Status bit\n" " When set, a single bit error had been detected and\n" " corrected for a PP-generated QW Mode read\n" " transaction.\n" " If the CP2DBE=0, then the CP2SYN contains the\n" " failing syndrome (used during correction).\n" " Refer to CP2ECCENA.\n" " If the CP2SBINA had previously been enabled(set),\n" " an interrupt will be posted. Software can clear\n" " the interrupt by writing a 1 to this register bit.\n" " See also: DFA_MEMFADR CSR which contains more data\n" " about the memory address/control to help isolate\n" " the failure.\n" " NOTE: PP-generated LW Mode Read transactions\n" " do not participate in ECC check/correct).\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_DFA_ERR; info.status_mask = 1ull<<2 /* cp2dbe */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<6 /* dfa */; info.func = __cvmx_error_handle_dfa_err_cp2dbe; info.user_info = (long) "ERROR DFA_ERR[CP2DBE]: PP-CP2 Double Bit Error Detected - Status bit\n" " When set, a double bit error had been detected\n" " for a PP-generated QW Mode read transaction.\n" " The CP2SYN contains the failing syndrome.\n" " NOTE: PP-generated LW Mode Read transactions\n" " do not participate in ECC check/correct).\n" " Refer to CP2ECCENA.\n" " If the CP2DBINA had previously been enabled(set),\n" " an interrupt will be posted. Software can clear\n" " the interrupt by writing a 1 to this register bit.\n" " See also: DFA_MEMFADR CSR which contains more data\n" " about the memory address/control to help isolate\n" " the failure.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_DFA_ERR; info.status_mask = 1ull<<14 /* dtesbe */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<6 /* dfa */; info.func = __cvmx_error_handle_dfa_err_dtesbe; info.user_info = (long) "ERROR DFA_ERR[DTESBE]: DTE 29b Single Bit Error Corrected - Status bit\n" " When set, a single bit error had been detected and\n" " corrected for a DTE-generated 36b SIMPLE Mode read\n" " transaction.\n" " If the DTEDBE=0, then the DTESYN contains the\n" " failing syndrome (used during correction).\n" " NOTE: DTE-generated 18b SIMPLE Mode Read\n" " transactions do not participate in ECC check/correct).\n" " If the DTESBINA had previously been enabled(set),\n" " an interrupt will be posted. Software can clear\n" " the interrupt by writing a 1 to this register bit.\n" " See also: DFA_MEMFADR CSR which contains more data\n" " about the memory address/control to help isolate\n" " the failure.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_DFA_ERR; info.status_mask = 1ull<<15 /* dtedbe */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<6 /* dfa */; info.func = __cvmx_error_handle_dfa_err_dtedbe; info.user_info = (long) "ERROR DFA_ERR[DTEDBE]: DTE 29b Double Bit Error Detected - Status bit\n" " When set, a double bit error had been detected\n" " for a DTE-generated 36b SIMPLE Mode read transaction.\n" " The DTESYN contains the failing syndrome.\n" " If the DTEDBINA had previously been enabled(set),\n" " an interrupt will be posted. Software can clear\n" " the interrupt by writing a 1 to this register bit.\n" " See also: DFA_MEMFADR CSR which contains more data\n" " about the memory address/control to help isolate\n" " the failure.\n" " NOTE: DTE-generated 18b SIMPLE Mode Read transactions\n" " do not participate in ECC check/correct).\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_DFA_ERR; info.status_mask = 1ull<<26 /* dteperr */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<6 /* dfa */; info.func = __cvmx_error_handle_dfa_err_dteperr; info.user_info = (long) "ERROR DFA_ERR[DTEPERR]: DTE Parity Error Detected (for 18b SIMPLE mode ONLY)\n" " When set, all DTE-generated 18b SIMPLE Mode read\n" " transactions which encounter a parity error (across\n" " the 17b of data) are reported.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_DFA_ERR; info.status_mask = 1ull<<29 /* cp2perr */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<6 /* dfa */; info.func = __cvmx_error_handle_dfa_err_cp2perr; info.user_info = (long) "ERROR DFA_ERR[CP2PERR]: PP-CP2 Parity Error Detected - Status bit\n" " When set, a parity error had been detected for a\n" " PP-generated LW Mode read transaction.\n" " If the CP2PINA had previously been enabled(set),\n" " an interrupt will be posted. Software can clear\n" " the interrupt by writing a 1 to this register bit.\n" " See also: DFA_MEMFADR CSR which contains more data\n" " about the memory address/control to help isolate\n" " the failure.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_DFA_ERR; info.status_mask = 1ull<<31 /* dblovf */; info.enable_addr = 0; info.enable_mask = 0; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<6 /* dfa */; info.func = __cvmx_error_handle_dfa_err_dblovf; info.user_info = (long) "ERROR DFA_ERR[DBLOVF]: Doorbell Overflow detected - Status bit\n" " When set, the 20b accumulated doorbell register\n" " had overflowed (SW wrote too many doorbell requests).\n" " If the DBLINA had previously been enabled(set),\n" " an interrupt will be posted. Software can clear\n" " the interrupt by writing a 1 to this register bit.\n" " NOTE: Detection of a Doorbell Register overflow\n" " is a catastrophic error which may leave the DFA\n" " HW in an unrecoverable state.\n"; fail |= cvmx_error_add(&info); /* CVMX_IOB_INT_SUM */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_IOB_INT_SUM; info.status_mask = 1ull<<0 /* np_sop */; info.enable_addr = CVMX_IOB_INT_ENB; info.enable_mask = 1ull<<0 /* np_sop */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<30 /* iob */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR IOB_INT_SUM[NP_SOP]: Set when a SOP is followed by an SOP for the same\n" " port for a non-passthrough packet.\n" " The first detected error associated with bits [3:0]\n" " of this register will only be set here. A new bit\n" " can be set when the previous reported bit is cleared.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_IOB_INT_SUM; info.status_mask = 1ull<<1 /* np_eop */; info.enable_addr = CVMX_IOB_INT_ENB; info.enable_mask = 1ull<<1 /* np_eop */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<30 /* iob */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR IOB_INT_SUM[NP_EOP]: Set when a EOP is followed by an EOP for the same\n" " port for a non-passthrough packet.\n" " The first detected error associated with bits [3:0]\n" " of this register will only be set here. A new bit\n" " can be set when the previous reported bit is cleared.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_IOB_INT_SUM; info.status_mask = 1ull<<2 /* p_sop */; info.enable_addr = CVMX_IOB_INT_ENB; info.enable_mask = 1ull<<2 /* p_sop */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<30 /* iob */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR IOB_INT_SUM[P_SOP]: Set when a SOP is followed by an SOP for the same\n" " port for a passthrough packet.\n" " The first detected error associated with bits [3:0]\n" " of this register will only be set here. A new bit\n" " can be set when the previous reported bit is cleared.\n"; fail |= cvmx_error_add(&info); info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_IOB_INT_SUM; info.status_mask = 1ull<<3 /* p_eop */; info.enable_addr = CVMX_IOB_INT_ENB; info.enable_mask = 1ull<<3 /* p_eop */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<30 /* iob */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR IOB_INT_SUM[P_EOP]: Set when a EOP is followed by an EOP for the same\n" " port for a passthrough packet.\n" " The first detected error associated with bits [3:0]\n" " of this register will only be set here. A new bit\n" " can be set when the previous reported bit is cleared.\n"; fail |= cvmx_error_add(&info); /* CVMX_ZIP_ERROR */ info.reg_type = CVMX_ERROR_REGISTER_IO64; info.status_addr = CVMX_ZIP_ERROR; info.status_mask = 1ull<<0 /* doorbell */; info.enable_addr = CVMX_ZIP_INT_MASK; info.enable_mask = 1ull<<0 /* doorbell */; info.flags = 0; info.group = CVMX_ERROR_GROUP_INTERNAL; info.group_index = 0; info.parent.reg_type = CVMX_ERROR_REGISTER_IO64; info.parent.status_addr = CVMX_NPI_RSL_INT_BLOCKS; info.parent.status_mask = 1ull<<7 /* zip */; info.func = __cvmx_error_display; info.user_info = (long) "ERROR ZIP_ERROR[DOORBELL]: A doorbell count has overflowed\n"; fail |= cvmx_error_add(&info); return fail; }