freebsd-skq/sys/dev/vxge/vxgehal/vxgehal-mgmtaux.c
gnn d580860e12 Exar driver for X3100 10GbE Server/Storage adapters
Features: Jumbo frames (up to 9600), LRO (Large Receive Offload),
          TSO (TCP segmentation offload), RTH (Receive Traffic Hash).

Submitted by: Sriram Rapuru at Exar
MFC after:	2 weeks
2011-04-28 14:33:15 +00:00

3185 lines
120 KiB
C

/*-
* Copyright(c) 2002-2011 Exar Corp.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification are permitted provided the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. 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.
*
* 3. Neither the name of the Exar Corporation 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 IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
/*$FreeBSD$*/
#include <dev/vxge/vxgehal/vxgehal.h>
#define VXGE_HAL_AUX_SEPA ' '
#define __hal_aux_snprintf(retbuf, bufsize, fmt, key, value, retsize) \
if (bufsize <= 0) \
return (VXGE_HAL_ERR_OUT_OF_SPACE); \
retsize = vxge_os_snprintf(retbuf, bufsize, fmt, key, \
VXGE_HAL_AUX_SEPA, value); \
if (retsize < 0 || retsize >= bufsize) \
return (VXGE_HAL_ERR_OUT_OF_SPACE);
#define __HAL_AUX_ENTRY_DECLARE(size, buf) \
int entrysize = 0, leftsize = size; \
char *ptr; ptr = buf;
#define __HAL_AUX_ENTRY(key, value, fmt) \
__hal_aux_snprintf(ptr, leftsize, "%s%c"fmt"\n", key, value, entrysize)\
ptr += entrysize; leftsize -= entrysize;
#define __HAL_AUX_CONFIG_ENTRY(key, value, fmt) \
if (value == VXGE_HAL_USE_FLASH_DEFAULT) { \
__HAL_AUX_ENTRY(key, "FLASH DEFAULT", "%s"); \
} else { \
__HAL_AUX_ENTRY(key, value, fmt); \
}
#define __HAL_AUX_ENTRY_END(bufsize, retsize) \
*retsize = bufsize - leftsize;
#define __hal_aux_pci_link_info(name, index, var) { \
__HAL_AUX_ENTRY(name, \
(u64)pcim.link_info[index].var, "%llu") \
}
#define __hal_aux_pci_aggr_info(name, index, var) { \
__HAL_AUX_ENTRY(name, \
(u64)pcim.aggr_info[index].var, "%llu") \
}
/*
* vxge_hal_aux_about_read - Retrieve and format about info.
* @devh: HAL device handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Retrieve about info (using vxge_hal_mgmt_about()) and sprintf it
* into the provided @retbuf.
*
* Returns: VXGE_HAL_OK - success.
* VXGE_HAL_ERR_INVALID_DEVICE - Device is not valid.
* VXGE_HAL_ERR_VERSION_CONFLICT - Version it not maching.
* VXGE_HAL_FAIL - Failed to retrieve the information.
*
* See also: vxge_hal_mgmt_about(), vxge_hal_aux_device_dump().
*/
vxge_hal_status_e
vxge_hal_aux_about_read(vxge_hal_device_h devh, int bufsize,
char *retbuf, int *retsize)
{
u32 size = sizeof(vxge_hal_mgmt_about_info_t);
vxge_hal_status_e status;
vxge_hal_mgmt_about_info_t about_info;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
status = vxge_hal_mgmt_about(devh, &about_info, &size);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("vendor", about_info.vendor, "0x%x");
__HAL_AUX_ENTRY("device", about_info.device, "0x%x");
__HAL_AUX_ENTRY("subsys_vendor", about_info.subsys_vendor, "0x%x");
__HAL_AUX_ENTRY("subsys_device", about_info.subsys_device, "0x%x");
__HAL_AUX_ENTRY("board_rev", about_info.board_rev, "0x%x");
__HAL_AUX_ENTRY("vendor_name", about_info.vendor_name, "%s");
__HAL_AUX_ENTRY("chip_name", about_info.chip_name, "%s");
__HAL_AUX_ENTRY("media", about_info.media, "%s");
__HAL_AUX_ENTRY("hal_major", about_info.hal_major, "%s");
__HAL_AUX_ENTRY("hal_minor", about_info.hal_minor, "%s");
__HAL_AUX_ENTRY("hal_fix", about_info.hal_fix, "%s");
__HAL_AUX_ENTRY("hal_build", about_info.hal_build, "%s");
__HAL_AUX_ENTRY("ll_major", about_info.ll_major, "%s");
__HAL_AUX_ENTRY("ll_minor", about_info.ll_minor, "%s");
__HAL_AUX_ENTRY("ll_fix", about_info.ll_fix, "%s");
__HAL_AUX_ENTRY("ll_build", about_info.ll_build, "%s");
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_driver_config_read - Read Driver configuration.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read driver configuration,
*
* Returns: VXGE_HAL_OK - success.
* VXGE_HAL_ERR_VERSION_CONFLICT - Version it not maching.
*
* See also: vxge_hal_aux_device_config_read().
*/
vxge_hal_status_e
vxge_hal_aux_driver_config_read(int bufsize, char *retbuf, int *retsize)
{
u32 size = sizeof(vxge_hal_driver_config_t);
vxge_hal_status_e status;
vxge_hal_driver_config_t drv_config;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
status = vxge_hal_mgmt_driver_config(&drv_config, &size);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("Debug Level",
g_vxge_hal_driver->debug_level, "%u");
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_pci_config_read - Retrieve and format PCI Configuration
* info.
* @devh: HAL device handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Retrieve about info (using vxge_hal_mgmt_pci_config()) and sprintf it
* into the provided @retbuf.
*
* Returns: VXGE_HAL_OK - success.
* VXGE_HAL_ERR_INVALID_DEVICE - Device is not valid.
* VXGE_HAL_ERR_VERSION_CONFLICT - Version it not maching.
*
* See also: vxge_hal_mgmt_pci_config(), vxge_hal_aux_device_dump().
*/
vxge_hal_status_e
vxge_hal_aux_pci_config_read(
vxge_hal_device_h devh,
int bufsize,
char *retbuf,
int *retsize)
{
u8 cap_id;
u16 ext_cap_id;
u16 next_ptr;
u32 size = sizeof(vxge_hal_pci_config_t);
vxge_hal_status_e status;
vxge_hal_pci_config_t *pci_config =
&((__hal_device_t *) devh)->pci_config_space;
vxge_hal_mgmt_pm_cap_t pm_cap;
vxge_hal_mgmt_sid_cap_t sid_cap;
vxge_hal_mgmt_msi_cap_t msi_cap;
vxge_hal_mgmt_msix_cap_t msix_cap;
vxge_hal_pci_err_cap_t err_cap;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
status = vxge_hal_mgmt_pci_config(devh, (u8 *) pci_config, &size);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("vendor_id", pci_config->vendor_id, "0x%04X");
__HAL_AUX_ENTRY("device_id", pci_config->device_id, "0x%04X");
__HAL_AUX_ENTRY("command", pci_config->command, "0x%04X");
__HAL_AUX_ENTRY("status", pci_config->status, "0x%04X");
__HAL_AUX_ENTRY("revision", pci_config->revision, "0x%02X");
__HAL_AUX_ENTRY("pciClass1", pci_config->pciClass[0], "0x%02X");
__HAL_AUX_ENTRY("pciClass2", pci_config->pciClass[1], "0x%02X");
__HAL_AUX_ENTRY("pciClass3", pci_config->pciClass[2], "0x%02X");
__HAL_AUX_ENTRY("cache_line_size",
pci_config->cache_line_size, "0x%02X");
__HAL_AUX_ENTRY("header_type", pci_config->header_type, "0x%02X");
__HAL_AUX_ENTRY("bist", pci_config->bist, "0x%02X");
__HAL_AUX_ENTRY("base_addr0_lo", pci_config->base_addr0_lo, "0x%08X");
__HAL_AUX_ENTRY("base_addr0_hi", pci_config->base_addr0_hi, "0x%08X");
__HAL_AUX_ENTRY("base_addr1_lo", pci_config->base_addr1_lo, "0x%08X");
__HAL_AUX_ENTRY("base_addr1_hi", pci_config->base_addr1_hi, "0x%08X");
__HAL_AUX_ENTRY("not_Implemented1",
pci_config->not_Implemented1, "0x%08X");
__HAL_AUX_ENTRY("not_Implemented2", pci_config->not_Implemented2,
"0x%08X");
__HAL_AUX_ENTRY("cardbus_cis_pointer", pci_config->cardbus_cis_pointer,
"0x%08X");
__HAL_AUX_ENTRY("subsystem_vendor_id", pci_config->subsystem_vendor_id,
"0x%04X");
__HAL_AUX_ENTRY("subsystem_id", pci_config->subsystem_id, "0x%04X");
__HAL_AUX_ENTRY("rom_base", pci_config->rom_base, "0x%08X");
__HAL_AUX_ENTRY("capabilities_pointer",
pci_config->capabilities_pointer, "0x%02X");
__HAL_AUX_ENTRY("interrupt_line", pci_config->interrupt_line, "0x%02X");
__HAL_AUX_ENTRY("interrupt_pin", pci_config->interrupt_pin, "0x%02X");
__HAL_AUX_ENTRY("min_grant", pci_config->min_grant, "0x%02X");
__HAL_AUX_ENTRY("max_latency", pci_config->max_latency, "0x%02X");
next_ptr = pci_config->capabilities_pointer;
while (next_ptr != 0) {
cap_id = VXGE_HAL_PCI_CAP_ID((((u8 *) pci_config) + next_ptr));
switch (cap_id) {
case VXGE_HAL_PCI_CAP_ID_PM:
status = vxge_hal_mgmt_pm_capabilities_get(devh,
&pm_cap);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("PM Capability",
cap_id, "0x%02X");
__HAL_AUX_ENTRY("pm_cap_ver",
pm_cap.pm_cap_ver, "%u");
__HAL_AUX_ENTRY("pm_cap_pme_clock",
pm_cap.pm_cap_pme_clock, "%u");
__HAL_AUX_ENTRY("pm_cap_aux_power",
pm_cap.pm_cap_aux_power, "%u");
__HAL_AUX_ENTRY("pm_cap_dsi",
pm_cap.pm_cap_dsi, "%u");
__HAL_AUX_ENTRY("pm_cap_aux_current",
pm_cap.pm_cap_aux_current, "%u");
__HAL_AUX_ENTRY("pm_cap_cap_d0",
pm_cap.pm_cap_cap_d0, "%u");
__HAL_AUX_ENTRY("pm_cap_cap_d1",
pm_cap.pm_cap_cap_d1, "%u");
__HAL_AUX_ENTRY("pm_cap_pme_d0",
pm_cap.pm_cap_pme_d0, "%u");
__HAL_AUX_ENTRY("pm_cap_pme_d1",
pm_cap.pm_cap_pme_d1, "%u");
__HAL_AUX_ENTRY("pm_cap_pme_d2",
pm_cap.pm_cap_pme_d2, "%u");
__HAL_AUX_ENTRY("pm_cap_pme_d3_hot",
pm_cap.pm_cap_pme_d3_hot, "%u");
__HAL_AUX_ENTRY("pm_cap_pme_d3_cold",
pm_cap.pm_cap_pme_d3_cold, "%u");
__HAL_AUX_ENTRY("pm_ctrl_state",
pm_cap.pm_ctrl_state, "%u");
__HAL_AUX_ENTRY("pm_ctrl_no_soft_reset",
pm_cap.pm_ctrl_no_soft_reset, "%u");
__HAL_AUX_ENTRY("pm_ctrl_pme_enable",
pm_cap.pm_ctrl_pme_enable, "%u");
__HAL_AUX_ENTRY("pm_ctrl_pme_data_sel",
pm_cap.pm_ctrl_pme_data_sel, "%u");
__HAL_AUX_ENTRY("pm_ctrl_pme_data_scale",
pm_cap.pm_ctrl_pme_data_scale, "%u");
__HAL_AUX_ENTRY("pm_ctrl_pme_status",
pm_cap.pm_ctrl_pme_status, "%u");
__HAL_AUX_ENTRY("pm_ppb_ext_b2_b3",
pm_cap.pm_ppb_ext_b2_b3, "%u");
__HAL_AUX_ENTRY("pm_ppb_ext_ecc_en",
pm_cap.pm_ppb_ext_ecc_en, "%u");
__HAL_AUX_ENTRY("pm_data_reg",
pm_cap.pm_data_reg, "%u");
break;
case VXGE_HAL_PCI_CAP_ID_VPD:
break;
case VXGE_HAL_PCI_CAP_ID_SLOTID:
status = vxge_hal_mgmt_sid_capabilities_get(devh,
&sid_cap);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("SID Capability", cap_id, "0x%02X");
__HAL_AUX_ENTRY("sid_number_of_slots",
sid_cap.sid_number_of_slots, "%u");
__HAL_AUX_ENTRY("sid_first_in_chasis",
sid_cap.sid_first_in_chasis, "%u");
__HAL_AUX_ENTRY("sid_chasis_number",
sid_cap.sid_chasis_number, "0x%u");
break;
case VXGE_HAL_PCI_CAP_ID_MSI:
status = vxge_hal_mgmt_msi_capabilities_get(devh,
&msi_cap);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("MSI Capability", cap_id, "0x%02X");
__HAL_AUX_ENTRY("MSI Enable", msi_cap.enable, "%u");
__HAL_AUX_ENTRY("MSI 64bit Address Capable",
msi_cap.is_64bit_addr_capable, "%u");
__HAL_AUX_ENTRY("MSI PVM Capable",
msi_cap.is_pvm_capable, "0x%02X");
__HAL_AUX_ENTRY("MSI Vectors Allocated",
msi_cap.vectors_allocated, "0x%02X");
__HAL_AUX_ENTRY("MSI Max Vectors",
msi_cap.max_vectors_capable, "0x%02X");
if (msi_cap.is_64bit_addr_capable) {
__HAL_AUX_ENTRY("MSI address",
msi_cap.address, "0x%016llX");
} else {
__HAL_AUX_ENTRY("MSI address",
msi_cap.address, "0x%08llX");
}
__HAL_AUX_ENTRY("MSI Data", msi_cap.data, "0x%04X");
if (msi_cap.is_pvm_capable) {
__HAL_AUX_ENTRY("MSI Mask bits",
msi_cap.mask_bits, "0x%08X");
__HAL_AUX_ENTRY("MSI Pending bits",
msi_cap.pending_bits, "0x%08X");
}
break;
case VXGE_HAL_PCI_CAP_ID_VS:
break;
case VXGE_HAL_PCI_CAP_ID_SHPC:
break;
case VXGE_HAL_PCI_CAP_ID_PCIE:
break;
case VXGE_HAL_PCI_CAP_ID_MSIX:
status = vxge_hal_mgmt_msix_capabilities_get(devh,
&msix_cap);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("MSIX Capability", cap_id, "0x%02X");
__HAL_AUX_ENTRY("MSIX Enable", msix_cap.enable, "%u");
__HAL_AUX_ENTRY("MSIX Mask All vectors",
msix_cap.mask_all_vect, "%u");
__HAL_AUX_ENTRY("MSIX Table Size",
msix_cap.table_size, "%u");
__HAL_AUX_ENTRY("MSIX Table Offset",
msix_cap.table_offset, "%u");
__HAL_AUX_ENTRY("MSIX Table BIR",
msix_cap.table_bir, "%u");
__HAL_AUX_ENTRY("MSIX PBA Offset",
msix_cap.pba_offset, "%u");
__HAL_AUX_ENTRY("MSIX PBA BIR", msix_cap.pba_bir, "%u");
break;
case VXGE_HAL_PCI_CAP_ID_AGP:
case VXGE_HAL_PCI_CAP_ID_CHSWP:
case VXGE_HAL_PCI_CAP_ID_PCIX:
case VXGE_HAL_PCI_CAP_ID_HT:
case VXGE_HAL_PCI_CAP_ID_DBGPORT:
case VXGE_HAL_PCI_CAP_ID_CPCICSR:
case VXGE_HAL_PCI_CAP_ID_PCIBSVID:
case VXGE_HAL_PCI_CAP_ID_AGP8X:
case VXGE_HAL_PCI_CAP_ID_SECDEV:
__HAL_AUX_ENTRY("Unexpected Capability",
cap_id, "0x%02X");
break;
default:
__HAL_AUX_ENTRY("Unknown Capability",
cap_id, "0x%02X");
break;
}
next_ptr =
VXGE_HAL_PCI_CAP_NEXT((((u8 *) pci_config) + next_ptr));
}
/* CONSTCOND */
if (VXGE_HAL_PCI_CONFIG_SPACE_SIZE > 0x100) {
next_ptr = 0x100;
while (next_ptr != 0) {
ext_cap_id = (u16) VXGE_HAL_PCI_EXT_CAP_ID(
*(u32 *)((void *)(((u8 *) pci_config) + next_ptr)));
switch (ext_cap_id) {
case VXGE_HAL_PCI_EXT_CAP_ID_ERR:
status =
vxge_hal_mgmt_pci_err_capabilities_get(devh,
&err_cap);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("pci_err_header",
err_cap.pci_err_header, "0x%08X");
__HAL_AUX_ENTRY("pci_err_uncor_status",
err_cap.pci_err_uncor_status, "0x%08X");
__HAL_AUX_ENTRY("pci_err_uncor_mask",
err_cap.pci_err_uncor_mask, "0x%08X");
__HAL_AUX_ENTRY("pci_err_uncor_server",
err_cap.pci_err_uncor_server, "0x%08X");
__HAL_AUX_ENTRY("pci_err_cor_status",
err_cap.pci_err_cor_status, "0x%08X");
__HAL_AUX_ENTRY("pci_err_cap",
err_cap.pci_err_cap, "0x%08X");
__HAL_AUX_ENTRY("err_header_log",
err_cap.err_header_log, "%u");
__HAL_AUX_ENTRY("pci_err_root_command",
err_cap.pci_err_root_command, "0x%08X");
__HAL_AUX_ENTRY("pci_err_root_status",
err_cap.pci_err_root_status, "0x%08X");
__HAL_AUX_ENTRY("pci_err_root_cor_src",
err_cap.pci_err_root_cor_src, "0x%04X");
__HAL_AUX_ENTRY("pci_err_root_src",
err_cap.pci_err_root_src, "0x%04X");
break;
case VXGE_HAL_PCI_EXT_CAP_ID_VC:
break;
case VXGE_HAL_PCI_EXT_CAP_ID_DSN:
break;
case VXGE_HAL_PCI_EXT_CAP_ID_PWR:
break;
default:
__HAL_AUX_ENTRY("Unknown Capability", cap_id,
"0x%02X");
break;
}
next_ptr = (u16) VXGE_HAL_PCI_EXT_CAP_NEXT(
*(u32 *)((void *)(((u8 *) pci_config) + next_ptr)));
}
}
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_device_config_read - Read device configuration.
* @devh: HAL device handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read device configuration,
*
* Returns: VXGE_HAL_OK - success.
* VXGE_HAL_ERR_INVALID_DEVICE - Device is not valid.
* VXGE_HAL_ERR_VERSION_CONFLICT - Version it not maching.
*
* See also: vxge_hal_aux_driver_config_read().
*/
vxge_hal_status_e
vxge_hal_aux_device_config_read(vxge_hal_device_h devh,
int bufsize, char *retbuf, int *retsize)
{
int i;
u32 size = sizeof(vxge_hal_device_config_t);
vxge_hal_status_e status;
vxge_hal_mac_config_t *mac_config;
vxge_hal_device_config_t *dev_config;
vxge_hal_device_t *hldev = (vxge_hal_device_t *) devh;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
dev_config = (vxge_hal_device_config_t *) vxge_os_malloc(hldev->pdev,
sizeof(vxge_hal_device_config_t));
if (dev_config == NULL) {
return (VXGE_HAL_FAIL);
}
status = vxge_hal_mgmt_device_config(devh, dev_config, &size);
if (status != VXGE_HAL_OK) {
vxge_os_free(hldev->pdev, dev_config,
sizeof(vxge_hal_device_config_t));
return (status);
}
__HAL_AUX_CONFIG_ENTRY("DMA Block Pool size-Minimum",
dev_config->dma_blockpool_min, "%u");
__HAL_AUX_CONFIG_ENTRY("DMA Block Pool size-Initial",
dev_config->dma_blockpool_initial, "%u");
__HAL_AUX_CONFIG_ENTRY("DMA Block Pool size-Increment",
dev_config->dma_blockpool_incr, "%u");
__HAL_AUX_CONFIG_ENTRY("DMA Block Pool size-Maximum",
dev_config->dma_blockpool_max, "%u");
for (i = 0; i < VXGE_HAL_MAC_MAX_WIRE_PORTS; i++) {
mac_config = &dev_config->mrpcim_config.mac_config;
__HAL_AUX_CONFIG_ENTRY("port_id",
mac_config->wire_port_config[i].port_id, "%u");
__HAL_AUX_CONFIG_ENTRY("media",
mac_config->wire_port_config[i].media, "%u");
__HAL_AUX_CONFIG_ENTRY("mtu",
mac_config->wire_port_config[i].mtu, "%u");
__HAL_AUX_CONFIG_ENTRY("autoneg_mode",
mac_config->wire_port_config[i].autoneg_mode, "%u");
__HAL_AUX_CONFIG_ENTRY("fixed_use_fsm",
mac_config->wire_port_config[i].fixed_use_fsm, "%u");
__HAL_AUX_CONFIG_ENTRY("antp_use_fsm",
mac_config->wire_port_config[i].antp_use_fsm, "%u");
__HAL_AUX_CONFIG_ENTRY("anbe_use_fsm",
mac_config->wire_port_config[i].anbe_use_fsm, "%u");
__HAL_AUX_CONFIG_ENTRY("link_stability_period",
mac_config->wire_port_config[i].link_stability_period,
"%u");
__HAL_AUX_CONFIG_ENTRY("port_stability_period",
mac_config->wire_port_config[i].port_stability_period,
"%u");
__HAL_AUX_CONFIG_ENTRY("tmac_en",
mac_config->wire_port_config[i].tmac_en, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_en",
mac_config->wire_port_config[i].rmac_en, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_pad",
mac_config->wire_port_config[i].tmac_pad, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_pad_byte",
mac_config->wire_port_config[i].tmac_pad_byte, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_util_period",
mac_config->wire_port_config[i].tmac_util_period, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_strip_fcs",
mac_config->wire_port_config[i].rmac_strip_fcs, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_prom_en",
mac_config->wire_port_config[i].rmac_prom_en, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_discard_pfrm",
mac_config->wire_port_config[i].rmac_discard_pfrm, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_util_period",
mac_config->wire_port_config[i].rmac_util_period, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_pause_gen_en",
mac_config->wire_port_config[i].rmac_pause_gen_en, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_pause_rcv_en",
mac_config->wire_port_config[i].rmac_pause_rcv_en, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_pause_time",
mac_config->wire_port_config[i].rmac_pause_time, "%u");
__HAL_AUX_CONFIG_ENTRY("limiter_en",
mac_config->wire_port_config[i].limiter_en, "%u");
__HAL_AUX_CONFIG_ENTRY("max_limit",
mac_config->wire_port_config[i].max_limit, "%u");
}
/* CONSTCOND */
__HAL_AUX_CONFIG_ENTRY("port_id",
VXGE_HAL_MAC_SWITCH_PORT, "%u");
__HAL_AUX_CONFIG_ENTRY("mtu",
mac_config->switch_port_config.mtu, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_en",
mac_config->switch_port_config.tmac_en, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_en",
mac_config->switch_port_config.rmac_en, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_pad",
mac_config->switch_port_config.tmac_pad, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_pad_byte",
mac_config->switch_port_config.tmac_pad_byte, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_util_period",
mac_config->switch_port_config.tmac_util_period, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_strip_fcs",
mac_config->switch_port_config.rmac_strip_fcs, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_prom_en",
mac_config->switch_port_config.rmac_prom_en, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_discard_pfrm",
mac_config->switch_port_config.rmac_discard_pfrm, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_util_period",
mac_config->switch_port_config.rmac_util_period, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_pause_gen_en",
mac_config->switch_port_config.rmac_pause_gen_en, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_pause_rcv_en",
mac_config->switch_port_config.rmac_pause_rcv_en, "%u");
__HAL_AUX_CONFIG_ENTRY("rmac_pause_time",
mac_config->switch_port_config.rmac_pause_time, "%u");
__HAL_AUX_CONFIG_ENTRY("limiter_en",
mac_config->switch_port_config.limiter_en, "%u");
__HAL_AUX_CONFIG_ENTRY("max_limit",
mac_config->switch_port_config.max_limit, "%u");
__HAL_AUX_CONFIG_ENTRY("network_stability_period",
mac_config->network_stability_period, "%u");
for (i = 0; i < 16; i++) {
__HAL_AUX_CONFIG_ENTRY("mc_pause_threshold[i]",
mac_config->mc_pause_threshold[i], "%u");
}
__HAL_AUX_CONFIG_ENTRY("tmac_perma_stop_en",
mac_config->tmac_perma_stop_en, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_tx_switch_dis",
mac_config->tmac_tx_switch_dis, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_lossy_switch_en",
mac_config->tmac_lossy_switch_en, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_lossy_wire_en",
mac_config->tmac_lossy_wire_en, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_bcast_to_wire_dis",
mac_config->tmac_bcast_to_wire_dis, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_bcast_to_switch_dis",
mac_config->tmac_bcast_to_switch_dis, "%u");
__HAL_AUX_CONFIG_ENTRY("tmac_host_append_fcs_en",
mac_config->tmac_host_append_fcs_en, "%u");
__HAL_AUX_CONFIG_ENTRY("tpa_support_snap_ab_n",
mac_config->tpa_support_snap_ab_n, "%u");
__HAL_AUX_CONFIG_ENTRY("tpa_ecc_enable_n",
mac_config->tpa_ecc_enable_n, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_ignore_frame_err",
mac_config->rpa_ignore_frame_err, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_support_snap_ab_n",
mac_config->rpa_support_snap_ab_n, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_search_for_hao",
mac_config->rpa_search_for_hao, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_support_ipv6_mobile_hdrs",
mac_config->rpa_support_ipv6_mobile_hdrs, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_ipv6_stop_searching",
mac_config->rpa_ipv6_stop_searching, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_no_ps_if_unknown",
mac_config->rpa_no_ps_if_unknown, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_search_for_etype",
mac_config->rpa_search_for_etype, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_repl_l4_comp_csum",
mac_config->rpa_repl_l4_comp_csum, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_repl_l3_incl_cf",
mac_config->rpa_repl_l3_incl_cf, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_repl_l3_comp_csum",
mac_config->rpa_repl_l3_comp_csum, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_repl_ipv4_tcp_incl_ph",
mac_config->rpa_repl_ipv4_tcp_incl_ph, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_repl_ipv6_tcp_incl_ph",
mac_config->rpa_repl_ipv6_tcp_incl_ph, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_repl_ipv4_udp_incl_ph",
mac_config->rpa_repl_ipv4_udp_incl_ph, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_repl_ipv6_udp_incl_ph",
mac_config->rpa_repl_ipv6_udp_incl_ph, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_repl_l4_incl_cf",
mac_config->rpa_repl_l4_incl_cf, "%u");
__HAL_AUX_CONFIG_ENTRY("rpa_repl_strip_vlan_tag",
mac_config->rpa_repl_strip_vlan_tag, "%u");
__HAL_AUX_CONFIG_ENTRY("ISR Polling count",
dev_config->isr_polling_cnt, "%u");
__HAL_AUX_CONFIG_ENTRY("Maximum Payload Size",
dev_config->max_payload_size, "%u");
__HAL_AUX_CONFIG_ENTRY("MMRB Count",
dev_config->mmrb_count, "%u");
__HAL_AUX_CONFIG_ENTRY("Statistics Refresh Time",
dev_config->stats_refresh_time_sec, "%u");
__HAL_AUX_CONFIG_ENTRY("Interrupt Mode",
dev_config->intr_mode, "%u");
__HAL_AUX_CONFIG_ENTRY("Dump on Unknwon Error",
dev_config->dump_on_unknown, "%u");
__HAL_AUX_CONFIG_ENTRY("Dump on Serious Error",
dev_config->dump_on_serr, "%u");
__HAL_AUX_CONFIG_ENTRY("Dump on Critical Error",
dev_config->dump_on_critical, "%u");
__HAL_AUX_CONFIG_ENTRY("Dump on ECC Error",
dev_config->dump_on_eccerr, "%u");
__HAL_AUX_CONFIG_ENTRY("RTH Enable",
dev_config->rth_en, "%u");
__HAL_AUX_CONFIG_ENTRY("RTS MAC Enable",
dev_config->rts_mac_en, "%u");
__HAL_AUX_CONFIG_ENTRY("RTS QOS Enable",
dev_config->rts_qos_en, "%u");
__HAL_AUX_CONFIG_ENTRY("RTS Port Enable",
dev_config->rts_port_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Max CQE Groups",
dev_config->max_cqe_groups, "%u");
__HAL_AUX_CONFIG_ENTRY("Max Number of OD Groups",
dev_config->max_num_wqe_od_groups, "%u");
__HAL_AUX_CONFIG_ENTRY("No WQE Threshold",
dev_config->no_wqe_threshold, "%u");
__HAL_AUX_CONFIG_ENTRY("Refill Threshold-High",
dev_config->refill_threshold_high, "%u");
__HAL_AUX_CONFIG_ENTRY("Refill Threshold-Low",
dev_config->refill_threshold_low, "%u");
__HAL_AUX_CONFIG_ENTRY("Ack Block Limit",
dev_config->ack_blk_limit, "%u");
__HAL_AUX_CONFIG_ENTRY("Poll or Doorbell",
dev_config->poll_or_doorbell, "%u");
__HAL_AUX_CONFIG_ENTRY("stats_read_method",
dev_config->stats_read_method, "%u");
__HAL_AUX_CONFIG_ENTRY("Device Poll Timeout",
dev_config->device_poll_millis, "%u");
__HAL_AUX_CONFIG_ENTRY("debug_level",
dev_config->debug_level, "%u");
__HAL_AUX_CONFIG_ENTRY("debug_mask",
dev_config->debug_mask, "%u");
#if defined(VXGE_TRACE_INTO_CIRCULAR_ARR)
__HAL_AUX_CONFIG_ENTRY("Trace buffer size",
dev_config->tracebuf_size, "%u");
#endif
for (i = 0; i < VXGE_HAL_MAX_VIRTUAL_PATHS; i++) {
if (!(((__hal_device_t *) hldev)->vpath_assignments & mBIT(i)))
continue;
__HAL_AUX_CONFIG_ENTRY("Virtual Path id",
dev_config->vp_config[i].vp_id, "%u");
__HAL_AUX_CONFIG_ENTRY("No Snoop",
dev_config->vp_config[i].no_snoop, "%u");
__HAL_AUX_CONFIG_ENTRY("mtu",
dev_config->vp_config[i].mtu, "%u");
__HAL_AUX_CONFIG_ENTRY("TPA LSOv2 Enable",
dev_config->vp_config[i].tpa_lsov2_en, "%u");
__HAL_AUX_CONFIG_ENTRY("TPA Ignore Frame Error",
dev_config->vp_config[i].tpa_ignore_frame_error, "%u");
__HAL_AUX_CONFIG_ENTRY("TPA IPv6 Keep Searching",
dev_config->vp_config[i].tpa_ipv6_keep_searching, "%u");
__HAL_AUX_CONFIG_ENTRY("TPA L4 pseudo header present",
dev_config->vp_config[i].tpa_l4_pshdr_present, "%u");
__HAL_AUX_CONFIG_ENTRY("TPA support mobile IPv6 Headers",
dev_config->vp_config[i].tpa_support_mobile_ipv6_hdrs,
"%u");
__HAL_AUX_CONFIG_ENTRY("RPA IPv4 TCP Include pseudo header",
dev_config->vp_config[i].rpa_ipv4_tcp_incl_ph, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA IPv6 TCP Include pseudo header",
dev_config->vp_config[i].rpa_ipv6_tcp_incl_ph, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA IPv4 UDP Include pseudo header",
dev_config->vp_config[i].rpa_ipv4_udp_incl_ph, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA IPv6 UDP Include pseudo header",
dev_config->vp_config[i].rpa_ipv6_udp_incl_ph, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA L4 Include CF",
dev_config->vp_config[i].rpa_l4_incl_cf, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA Strip VLAN Tag",
dev_config->vp_config[i].rpa_strip_vlan_tag, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA L4 Comp Csum Enable",
dev_config->vp_config[i].rpa_l4_comp_csum, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA L3 Include CF Enable",
dev_config->vp_config[i].rpa_l3_incl_cf, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA L3 Comp Csum",
dev_config->vp_config[i].rpa_l3_comp_csum, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA Unicast All Address Enable",
dev_config->vp_config[i].rpa_ucast_all_addr_en, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA Unicast All Address Enable",
dev_config->vp_config[i].rpa_ucast_all_addr_en, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA Multicast All Address Enable",
dev_config->vp_config[i].rpa_mcast_all_addr_en, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA Broadcast Enable",
dev_config->vp_config[i].rpa_bcast_en, "%u");
__HAL_AUX_CONFIG_ENTRY("RPA All VID Enable",
dev_config->vp_config[i].rpa_all_vid_en, "%u");
__HAL_AUX_CONFIG_ENTRY("VP Queue L2 Flow",
dev_config->vp_config[i].vp_queue_l2_flow, "%u");
__HAL_AUX_CONFIG_ENTRY("Ring blocks",
dev_config->vp_config[i].ring.ring_length, "%u");
__HAL_AUX_CONFIG_ENTRY("Buffer Mode",
dev_config->vp_config[i].ring.buffer_mode, "%u");
__HAL_AUX_CONFIG_ENTRY("Scatter Mode",
dev_config->vp_config[i].ring.scatter_mode, "%u");
__HAL_AUX_CONFIG_ENTRY("Post Mode",
dev_config->vp_config[i].ring.post_mode, "%u");
__HAL_AUX_CONFIG_ENTRY("Maximum Frame Length",
dev_config->vp_config[i].ring.max_frm_len, "%u");
__HAL_AUX_CONFIG_ENTRY("No Snoop Bits",
dev_config->vp_config[i].ring.no_snoop_bits, "%u");
__HAL_AUX_CONFIG_ENTRY("Rx Timer Value",
dev_config->vp_config[i].ring.rx_timer_val, "%u");
__HAL_AUX_CONFIG_ENTRY("Greedy return",
dev_config->vp_config[i].ring.greedy_return, "%u");
__HAL_AUX_CONFIG_ENTRY("Rx Timer CI",
dev_config->vp_config[i].ring.rx_timer_ci, "%u");
__HAL_AUX_CONFIG_ENTRY("Backoff Interval",
dev_config->vp_config[i].ring.backoff_interval_us, "%u");
__HAL_AUX_CONFIG_ENTRY("Indicate Max Packets",
dev_config->vp_config[i].ring.indicate_max_pkts, "%u");
__HAL_AUX_CONFIG_ENTRY("FIFO Blocks",
dev_config->vp_config[i].fifo.fifo_length, "%u");
__HAL_AUX_CONFIG_ENTRY("Max Frags",
dev_config->vp_config[i].fifo.max_frags, "%u");
__HAL_AUX_CONFIG_ENTRY("Alignment Size",
dev_config->vp_config[i].fifo.alignment_size, "%u");
__HAL_AUX_CONFIG_ENTRY("Maximum Aligned Frags",
dev_config->vp_config[i].fifo.max_aligned_frags, "%u");
__HAL_AUX_CONFIG_ENTRY("Interrupt Enable",
dev_config->vp_config[i].fifo.intr, "%u");
__HAL_AUX_CONFIG_ENTRY("No Snoop Bits",
dev_config->vp_config[i].fifo.no_snoop_bits, "%u");
__HAL_AUX_CONFIG_ENTRY("Interrupt Enable",
dev_config->vp_config[i].tti.intr_enable, "%u");
__HAL_AUX_CONFIG_ENTRY("BTimer Value",
dev_config->vp_config[i].tti.btimer_val, "%u");
__HAL_AUX_CONFIG_ENTRY("Timer AC Enable",
dev_config->vp_config[i].tti.timer_ac_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Timer CI Enable",
dev_config->vp_config[i].tti.timer_ci_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Timer RI Enable",
dev_config->vp_config[i].tti.timer_ri_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Timer Event SF",
dev_config->vp_config[i].tti.rtimer_event_sf, "%u");
__HAL_AUX_CONFIG_ENTRY("RTimer Value",
dev_config->vp_config[i].tti.rtimer_val, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Sel",
dev_config->vp_config[i].tti.util_sel, "%u");
__HAL_AUX_CONFIG_ENTRY("LTimer Value",
dev_config->vp_config[i].tti.ltimer_val, "%u");
__HAL_AUX_CONFIG_ENTRY("Tx Frame Count Enable",
dev_config->vp_config[i].tti.txfrm_cnt_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Txd Count Enable",
dev_config->vp_config[i].tti.txd_cnt_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Range A",
dev_config->vp_config[i].tti.urange_a, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Event Count A",
dev_config->vp_config[i].tti.uec_a, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Range B",
dev_config->vp_config[i].tti.urange_b, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Event Count B",
dev_config->vp_config[i].tti.uec_b, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Range C",
dev_config->vp_config[i].tti.urange_c, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Event Count C",
dev_config->vp_config[i].tti.uec_c, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Event Count D",
dev_config->vp_config[i].tti.uec_d, "%u");
__HAL_AUX_CONFIG_ENTRY("Ufca Interrupt Threshold",
dev_config->vp_config[i].tti.ufca_intr_thres, "%u");
__HAL_AUX_CONFIG_ENTRY("Ufca Low Limit",
dev_config->vp_config[i].tti.ufca_lo_lim, "%u");
__HAL_AUX_CONFIG_ENTRY("Ufca High Limit",
dev_config->vp_config[i].tti.ufca_hi_lim, "%u");
__HAL_AUX_CONFIG_ENTRY("Ufca lbolt period",
dev_config->vp_config[i].tti.ufca_lbolt_period, "%u");
__HAL_AUX_CONFIG_ENTRY("Interrupt Enable",
dev_config->vp_config[i].rti.intr_enable, "%u");
__HAL_AUX_CONFIG_ENTRY("BTimer Value",
dev_config->vp_config[i].rti.btimer_val, "%u");
__HAL_AUX_CONFIG_ENTRY("Timer AC Enable",
dev_config->vp_config[i].rti.timer_ac_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Timer CI Enable",
dev_config->vp_config[i].rti.timer_ci_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Timer RI Enable",
dev_config->vp_config[i].rti.timer_ri_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Timer Event SF",
dev_config->vp_config[i].rti.rtimer_event_sf, "%u");
__HAL_AUX_CONFIG_ENTRY("RTimer Value",
dev_config->vp_config[i].rti.rtimer_val, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Sel",
dev_config->vp_config[i].rti.util_sel, "%u");
__HAL_AUX_CONFIG_ENTRY("LTimer Value",
dev_config->vp_config[i].rti.ltimer_val, "%u");
__HAL_AUX_CONFIG_ENTRY("Tx Frame Count Enable",
dev_config->vp_config[i].rti.txfrm_cnt_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Txd Count Enable",
dev_config->vp_config[i].rti.txd_cnt_en, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Range A",
dev_config->vp_config[i].rti.urange_a, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Event Count A",
dev_config->vp_config[i].rti.uec_a, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Range B",
dev_config->vp_config[i].rti.urange_b, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Event Count B",
dev_config->vp_config[i].rti.uec_b, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Range C",
dev_config->vp_config[i].rti.urange_c, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Event Count C",
dev_config->vp_config[i].rti.uec_c, "%u");
__HAL_AUX_CONFIG_ENTRY("Util Event Count D",
dev_config->vp_config[i].rti.uec_d, "%u");
__HAL_AUX_CONFIG_ENTRY("Ufca Interrupt Threshold",
dev_config->vp_config[i].rti.ufca_intr_thres, "%u");
__HAL_AUX_CONFIG_ENTRY("Ufca Low Limit",
dev_config->vp_config[i].rti.ufca_lo_lim, "%u");
__HAL_AUX_CONFIG_ENTRY("Ufca High Limit",
dev_config->vp_config[i].rti.ufca_hi_lim, "%u");
__HAL_AUX_CONFIG_ENTRY("Ufca lbolt period",
dev_config->vp_config[i].rti.ufca_lbolt_period, "%u");
}
__HAL_AUX_ENTRY_END(bufsize, retsize);
vxge_os_free(hldev->pdev, dev_config,
sizeof(vxge_hal_device_config_t));
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_bar0_read - Read and format X3100 BAR0 register.
* @devh: HAL device handle.
* @offset: Register offset in the BAR0 space.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read X3100 register from BAR0 space.
*
* Returns: VXGE_HAL_OK - success.
* VXGE_HAL_ERR_OUT_OF_SPACE - Buffer size is very small.
* VXGE_HAL_ERR_INVALID_DEVICE - Device is not valid.
* VXGE_HAL_ERR_INVALID_OFFSET - Register offset in the BAR space is not
* valid.
*
* See also: vxge_hal_mgmt_reg_read().
*/
vxge_hal_status_e
vxge_hal_aux_bar0_read(vxge_hal_device_h devh,
unsigned int offset, int bufsize, char *retbuf,
int *retsize)
{
vxge_hal_status_e status;
u64 retval;
status = vxge_hal_mgmt_bar0_read(devh, offset, &retval);
if (status != VXGE_HAL_OK)
return (status);
if (bufsize < VXGE_OS_SPRINTF_STRLEN)
return (VXGE_HAL_ERR_OUT_OF_SPACE);
*retsize = vxge_os_snprintf(retbuf, bufsize,
"0x%04X%c0x%08X%08X\n", offset,
VXGE_HAL_AUX_SEPA, (u32) (retval >> 32), (u32) retval);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_bar1_read - Read and format X3100 BAR1 register.
* @devh: HAL device handle.
* @offset: Register offset in the BAR1 space.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read X3100 register from BAR1 space.
* Returns: VXGE_HAL_OK - success.
* VXGE_HAL_ERR_OUT_OF_SPACE - Buffer size is very small.
* VXGE_HAL_ERR_INVALID_DEVICE - Device is not valid.
* VXGE_HAL_ERR_INVALID_OFFSET - Register offset in the BAR space is not
* valid.
*
* See also: vxge_hal_mgmt_reg_read().
*/
vxge_hal_status_e
vxge_hal_aux_bar1_read(vxge_hal_device_h devh,
unsigned int offset, int bufsize, char *retbuf,
int *retsize)
{
vxge_hal_status_e status;
u64 retval;
status = vxge_hal_mgmt_bar1_read(devh, offset, &retval);
if (status != VXGE_HAL_OK)
return (status);
if (bufsize < VXGE_OS_SPRINTF_STRLEN)
return (VXGE_HAL_ERR_OUT_OF_SPACE);
*retsize = vxge_os_snprintf(retbuf, bufsize, "0x%04X%c0x%08X%08X\n",
offset, VXGE_HAL_AUX_SEPA, (u32) (retval >> 32), (u32) retval);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_bar0_write - Write BAR0 register.
* @devh: HAL device handle.
* @offset: Register offset in the BAR0 space.
* @value: Regsister value (to write).
*
* Write BAR0 register.
*
* Returns: VXGE_HAL_OK - success.
* VXGE_HAL_ERR_INVALID_DEVICE - Device is not valid.
* VXGE_HAL_ERR_INVALID_OFFSET - Register offset in the BAR space is not
* valid.
*
* See also: vxge_hal_mgmt_reg_write().
*/
vxge_hal_status_e
vxge_hal_aux_bar0_write(vxge_hal_device_h devh,
unsigned int offset, u64 value)
{
vxge_hal_status_e status;
status = vxge_hal_mgmt_bar0_write(devh, offset, value);
if (status != VXGE_HAL_OK)
return (status);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_vpath_hw_read - Read vpath hardware statistics.
* @vpath_handle: HAL Vpath handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read vpath hardware statistics. This is a subset of stats counters
* from vxge_hal_vpath_stats_hw_info_t {}.
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_vpath_hw_read(
vxge_hal_vpath_h vpath_handle,
int bufsize,
char *retbuf,
int *retsize)
{
vxge_hal_status_e status;
vxge_hal_vpath_stats_hw_info_t hw_info;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(vpath_handle != NULL);
status = vxge_hal_vpath_hw_stats_enable(vpath_handle);
if (status != VXGE_HAL_OK)
return (status);
status = vxge_hal_vpath_hw_stats_get(vpath_handle, &hw_info);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("ini_num_mwr_sent",
hw_info.ini_num_mwr_sent, "%u");
__HAL_AUX_ENTRY("ini_num_mrd_sent",
hw_info.ini_num_mrd_sent, "%u");
__HAL_AUX_ENTRY("ini_num_cpl_rcvd",
hw_info.ini_num_cpl_rcvd, "%u");
__HAL_AUX_ENTRY("ini_num_mwr_byte_sent",
hw_info.ini_num_mwr_byte_sent, "%llu");
__HAL_AUX_ENTRY("ini_num_cpl_byte_rcvd",
hw_info.ini_num_cpl_byte_rcvd, "%llu");
__HAL_AUX_ENTRY("wrcrdtarb_xoff",
hw_info.wrcrdtarb_xoff, "%u");
__HAL_AUX_ENTRY("rdcrdtarb_xoff",
hw_info.rdcrdtarb_xoff, "%u");
__HAL_AUX_ENTRY("vpath_genstats_count0",
hw_info.vpath_genstats_count0, "%u");
__HAL_AUX_ENTRY("vpath_genstats_count1",
hw_info.vpath_genstats_count1, "%u");
__HAL_AUX_ENTRY("vpath_genstats_count2",
hw_info.vpath_genstats_count2, "%u");
__HAL_AUX_ENTRY("vpath_genstats_count3",
hw_info.vpath_genstats_count3, "%u");
__HAL_AUX_ENTRY("vpath_genstats_count4",
hw_info.vpath_genstats_count4, "%u");
__HAL_AUX_ENTRY("vpath_genstats_count5",
hw_info.vpath_genstats_count5, "%u");
__HAL_AUX_ENTRY("tx_ttl_eth_frms",
hw_info.tx_stats.tx_ttl_eth_frms, "%llu");
__HAL_AUX_ENTRY("tx_ttl_eth_octets",
hw_info.tx_stats.tx_ttl_eth_octets, "%llu");
__HAL_AUX_ENTRY("tx_data_octets",
hw_info.tx_stats.tx_data_octets, "%llu");
__HAL_AUX_ENTRY("tx_mcast_frms",
hw_info.tx_stats.tx_mcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_bcast_frms",
hw_info.tx_stats.tx_bcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_ucast_frms",
hw_info.tx_stats.tx_ucast_frms, "%llu");
__HAL_AUX_ENTRY("tx_tagged_frms",
hw_info.tx_stats.tx_tagged_frms, "%llu");
__HAL_AUX_ENTRY("tx_vld_ip",
hw_info.tx_stats.tx_vld_ip, "%llu");
__HAL_AUX_ENTRY("tx_vld_ip_octets",
hw_info.tx_stats.tx_vld_ip_octets, "%llu");
__HAL_AUX_ENTRY("tx_icmp",
hw_info.tx_stats.tx_icmp, "%llu");
__HAL_AUX_ENTRY("tx_tcp",
hw_info.tx_stats.tx_tcp, "%llu");
__HAL_AUX_ENTRY("tx_rst_tcp",
hw_info.tx_stats.tx_rst_tcp, "%llu");
__HAL_AUX_ENTRY("tx_udp",
hw_info.tx_stats.tx_udp, "%llu");
__HAL_AUX_ENTRY("tx_unknown_protocol",
hw_info.tx_stats.tx_unknown_protocol, "%u");
__HAL_AUX_ENTRY("tx_lost_ip",
hw_info.tx_stats.tx_lost_ip, "%u");
__HAL_AUX_ENTRY("tx_parse_error",
hw_info.tx_stats.tx_parse_error, "%u");
__HAL_AUX_ENTRY("tx_tcp_offload",
hw_info.tx_stats.tx_tcp_offload, "%llu");
__HAL_AUX_ENTRY("tx_retx_tcp_offload",
hw_info.tx_stats.tx_retx_tcp_offload, "%llu");
__HAL_AUX_ENTRY("tx_lost_ip_offload",
hw_info.tx_stats.tx_lost_ip_offload, "%llu");
__HAL_AUX_ENTRY("rx_ttl_eth_frms",
hw_info.rx_stats.rx_ttl_eth_frms, "%llu");
__HAL_AUX_ENTRY("rx_vld_frms",
hw_info.rx_stats.rx_vld_frms, "%llu");
__HAL_AUX_ENTRY("rx_offload_frms",
hw_info.rx_stats.rx_offload_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_eth_octets",
hw_info.rx_stats.rx_ttl_eth_octets, "%llu");
__HAL_AUX_ENTRY("rx_data_octets",
hw_info.rx_stats.rx_data_octets, "%llu");
__HAL_AUX_ENTRY("rx_offload_octets",
hw_info.rx_stats.rx_offload_octets, "%llu");
__HAL_AUX_ENTRY("rx_vld_mcast_frms",
hw_info.rx_stats.rx_vld_mcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_vld_bcast_frms",
hw_info.rx_stats.rx_vld_bcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_accepted_ucast_frms",
hw_info.rx_stats.rx_accepted_ucast_frms, "%llu");
__HAL_AUX_ENTRY("rx_accepted_nucast_frms",
hw_info.rx_stats.rx_accepted_nucast_frms, "%llu");
__HAL_AUX_ENTRY("rx_tagged_frms",
hw_info.rx_stats.rx_tagged_frms, "%llu");
__HAL_AUX_ENTRY("rx_long_frms",
hw_info.rx_stats.rx_long_frms, "%llu");
__HAL_AUX_ENTRY("rx_usized_frms",
hw_info.rx_stats.rx_usized_frms, "%llu");
__HAL_AUX_ENTRY("rx_osized_frms",
hw_info.rx_stats.rx_osized_frms, "%llu");
__HAL_AUX_ENTRY("rx_frag_frms",
hw_info.rx_stats.rx_frag_frms, "%llu");
__HAL_AUX_ENTRY("rx_jabber_frms",
hw_info.rx_stats.rx_jabber_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_64_frms",
hw_info.rx_stats.rx_ttl_64_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_65_127_frms",
hw_info.rx_stats.rx_ttl_65_127_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_128_255_frms",
hw_info.rx_stats.rx_ttl_128_255_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_256_511_frms",
hw_info.rx_stats.rx_ttl_256_511_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_512_1023_frms",
hw_info.rx_stats.rx_ttl_512_1023_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_1024_1518_frms",
hw_info.rx_stats.rx_ttl_1024_1518_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_1519_4095_frms",
hw_info.rx_stats.rx_ttl_1519_4095_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_4096_8191_frms",
hw_info.rx_stats.rx_ttl_4096_8191_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_8192_max_frms",
hw_info.rx_stats.rx_ttl_8192_max_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_gt_max_frms",
hw_info.rx_stats.rx_ttl_gt_max_frms, "%llu");
__HAL_AUX_ENTRY("rx_ip",
hw_info.rx_stats.rx_ip, "%llu");
__HAL_AUX_ENTRY("rx_accepted_ip",
hw_info.rx_stats.rx_accepted_ip, "%llu");
__HAL_AUX_ENTRY("rx_ip_octets",
hw_info.rx_stats.rx_ip_octets, "%llu");
__HAL_AUX_ENTRY("rx_err_ip",
hw_info.rx_stats.rx_err_ip, "%llu");
__HAL_AUX_ENTRY("rx_icmp",
hw_info.rx_stats.rx_icmp, "%llu");
__HAL_AUX_ENTRY("rx_tcp",
hw_info.rx_stats.rx_tcp, "%llu");
__HAL_AUX_ENTRY("rx_udp",
hw_info.rx_stats.rx_udp, "%llu");
__HAL_AUX_ENTRY("rx_err_tcp",
hw_info.rx_stats.rx_err_tcp, "%llu");
__HAL_AUX_ENTRY("rx_lost_frms",
hw_info.rx_stats.rx_lost_frms, "%llu");
__HAL_AUX_ENTRY("rx_lost_ip",
hw_info.rx_stats.rx_lost_ip, "%llu");
__HAL_AUX_ENTRY("rx_lost_ip_offload",
hw_info.rx_stats.rx_lost_ip_offload, "%llu");
__HAL_AUX_ENTRY("rx_various_discard",
hw_info.rx_stats.rx_various_discard, "%u");
__HAL_AUX_ENTRY("rx_sleep_discard",
hw_info.rx_stats.rx_sleep_discard, "%u");
__HAL_AUX_ENTRY("rx_red_discard",
hw_info.rx_stats.rx_red_discard, "%u");
__HAL_AUX_ENTRY("rx_queue_full_discard",
hw_info.rx_stats.rx_queue_full_discard, "%u");
__HAL_AUX_ENTRY("rx_mpa_ok_frms",
hw_info.rx_stats.rx_mpa_ok_frms, "%llu");
__HAL_AUX_ENTRY("prog_event_vnum1",
hw_info.prog_event_vnum1, "%u");
__HAL_AUX_ENTRY("prog_event_vnum0",
hw_info.prog_event_vnum0, "%u");
__HAL_AUX_ENTRY("prog_event_vnum3",
hw_info.prog_event_vnum3, "%u");
__HAL_AUX_ENTRY("prog_event_vnum2",
hw_info.prog_event_vnum2, "%u");
__HAL_AUX_ENTRY("rx_multi_cast_frame_discard",
hw_info.rx_multi_cast_frame_discard, "%u");
__HAL_AUX_ENTRY("rx_frm_transferred",
hw_info.rx_frm_transferred, "%u");
__HAL_AUX_ENTRY("rxd_returned",
hw_info.rxd_returned, "%u");
__HAL_AUX_ENTRY("rx_mpa_len_fail_frms",
hw_info.rx_mpa_len_fail_frms, "%u");
__HAL_AUX_ENTRY("rx_mpa_mrk_fail_frms",
hw_info.rx_mpa_mrk_fail_frms, "%u");
__HAL_AUX_ENTRY("rx_mpa_crc_fail_frms",
hw_info.rx_mpa_crc_fail_frms, "%u");
__HAL_AUX_ENTRY("rx_permitted_frms",
hw_info.rx_permitted_frms, "%u");
__HAL_AUX_ENTRY("rx_vp_reset_discarded_frms",
hw_info.rx_vp_reset_discarded_frms, "%llu");
__HAL_AUX_ENTRY("rx_wol_frms",
hw_info.rx_wol_frms, "%llu");
__HAL_AUX_ENTRY("tx_vp_reset_discarded_frms",
hw_info.tx_vp_reset_discarded_frms, "%llu");
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_device_hw_read - Read device hardware statistics.
* @devh: HAL device handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read device hardware statistics. This is a subset of stats counters
* from vxge_hal_device_stats_hw_info_t {}.
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_device_hw_read(vxge_hal_device_h devh,
int bufsize, char *retbuf, int *retsize)
{
u32 i;
int rsize = 0;
vxge_hal_status_e status;
__hal_device_t *hldev = (__hal_device_t *) devh;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(devh);
for (i = 0; i < VXGE_HAL_MAX_VIRTUAL_PATHS; i++) {
if (!(hldev->vpaths_deployed & mBIT(i)))
continue;
__HAL_AUX_ENTRY("H/W stats for vpath id", i, "%u");
status = vxge_hal_aux_stats_vpath_hw_read(
VXGE_HAL_VIRTUAL_PATH_HANDLE(&hldev->virtual_paths[i]),
leftsize, ptr, &rsize);
if (status != VXGE_HAL_OK)
return (status);
ptr += rsize;
leftsize -= rsize;
}
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
#define __HAL_AUX_VPATH_SW_COMMON_INFO(prefix, common) {\
__HAL_AUX_ENTRY(prefix"full_cnt", (common)->full_cnt, "%u");\
__HAL_AUX_ENTRY(prefix"usage_cnt", (common)->usage_cnt, "%u");\
__HAL_AUX_ENTRY(prefix"usage_max", (common)->usage_max, "%u");\
__HAL_AUX_ENTRY(prefix"avg_compl_per_intr_cnt",\
(common)->avg_compl_per_intr_cnt, "%u");\
__HAL_AUX_ENTRY(prefix"total_compl_cnt",\
(common)->total_compl_cnt, "%u");\
}
/*
* vxge_hal_aux_stats_vpath_sw_fifo_read - Read vpath fifo software statistics.
* @vpath_handle: HAL Vpath handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read vpath fifo software statistics. This is a subset of stats counters
* from vxge_hal_vpath_stats_sw_fifo_info_t {}.
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_vpath_sw_fifo_read(
vxge_hal_vpath_h vpath_handle,
int bufsize,
char *retbuf,
int *retsize)
{
u32 i;
u8 strbuf[256];
vxge_hal_status_e status;
vxge_hal_vpath_stats_sw_fifo_info_t *fifo_info;
vxge_hal_vpath_stats_sw_info_t sw_stats;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(vpath_handle != NULL);
status = vxge_hal_vpath_sw_stats_get(vpath_handle, &sw_stats);
if (status != VXGE_HAL_OK)
return (status);
fifo_info = &sw_stats.fifo_stats;
__HAL_AUX_VPATH_SW_COMMON_INFO("fifo_",
&fifo_info->common_stats);
__HAL_AUX_ENTRY("total_posts",
fifo_info->total_posts, "%u");
__HAL_AUX_ENTRY("total_buffers",
fifo_info->total_buffers, "%u");
__HAL_AUX_ENTRY("avg_buffers_per_post",
fifo_info->avg_buffers_per_post, "%u");
__HAL_AUX_ENTRY("copied_frags",
fifo_info->copied_frags, "%u");
__HAL_AUX_ENTRY("copied_buffers",
fifo_info->copied_buffers, "%u");
__HAL_AUX_ENTRY("avg_buffer_size",
fifo_info->avg_buffer_size, "%u");
__HAL_AUX_ENTRY("avg_post_size",
fifo_info->avg_post_size, "%u");
__HAL_AUX_ENTRY("total_frags",
fifo_info->total_frags, "%u");
__HAL_AUX_ENTRY("copied_frags",
fifo_info->copied_frags, "%u");
__HAL_AUX_ENTRY("total_posts_dang_dtrs",
fifo_info->total_posts_dang_dtrs, "%u");
__HAL_AUX_ENTRY("total_posts_dang_frags",
fifo_info->total_posts_dang_frags, "%u");
for (i = 0; i < 16; i++) {
(void) vxge_os_snprintf((char *) strbuf,
sizeof(strbuf), "txd_t_code_err_cnt[%d]", i);
__HAL_AUX_ENTRY(strbuf,
fifo_info->txd_t_code_err_cnt[i], "%u");
}
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_vpath_sw_ring_read - Read vpath ring software statistics.
* @vpath_handle: HAL Vpath handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read vpath ring software statistics. This is a subset of stats counters
* from vxge_hal_vpath_stats_sw_ring_info_t {}.
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_vpath_sw_ring_read(
vxge_hal_vpath_h vpath_handle,
int bufsize,
char *retbuf,
int *retsize)
{
u32 i;
u8 strbuf[256];
vxge_hal_status_e status;
vxge_hal_vpath_stats_sw_ring_info_t *ring_info;
vxge_hal_vpath_stats_sw_info_t sw_stats;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(vpath_handle != NULL);
status = vxge_hal_vpath_sw_stats_get(vpath_handle, &sw_stats);
if (status != VXGE_HAL_OK)
return (status);
ring_info = &sw_stats.ring_stats;
__HAL_AUX_VPATH_SW_COMMON_INFO("ring_",
&ring_info->common_stats);
for (i = 0; i < 16; i++) {
(void) vxge_os_snprintf((char *) strbuf,
sizeof(strbuf), "rxd_t_code_err_cnt[%d]", i);
__HAL_AUX_ENTRY(strbuf,
ring_info->rxd_t_code_err_cnt[i], "%u");
}
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_vpath_sw_err_read - Read vpath err software statistics.
* @vpath_handle: HAL Vpath handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read vpath err software statistics. This is a subset of stats counters
* from vxge_hal_vpath_stats_sw_err_info_t {}.
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_vpath_sw_err_read(
vxge_hal_vpath_h vpath_handle,
int bufsize,
char *retbuf,
int *retsize)
{
vxge_hal_vpath_stats_sw_err_t *err_info;
__hal_vpath_handle_t *vp = (__hal_vpath_handle_t *) vpath_handle;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(vpath_handle != NULL);
err_info = &vp->vpath->sw_stats->error_stats;
__HAL_AUX_ENTRY("unknown_alarms",
err_info->unknown_alarms, "%u");
__HAL_AUX_ENTRY("network_sustained_fault",
err_info->network_sustained_fault, "%u");
__HAL_AUX_ENTRY("network_sustained_ok",
err_info->network_sustained_ok, "%u");
__HAL_AUX_ENTRY("kdfcctl_fifo0_overwrite",
err_info->kdfcctl_fifo0_overwrite, "%u");
__HAL_AUX_ENTRY("kdfcctl_fifo0_poison",
err_info->kdfcctl_fifo0_poison, "%u");
__HAL_AUX_ENTRY("kdfcctl_fifo0_dma_error",
err_info->kdfcctl_fifo0_dma_error, "%u");
__HAL_AUX_ENTRY("kdfcctl_fifo1_overwrite",
err_info->kdfcctl_fifo1_overwrite, "%u");
__HAL_AUX_ENTRY("kdfcctl_fifo1_poison",
err_info->kdfcctl_fifo1_poison, "%u");
__HAL_AUX_ENTRY("kdfcctl_fifo1_dma_error",
err_info->kdfcctl_fifo1_dma_error, "%u");
__HAL_AUX_ENTRY("kdfcctl_fifo2_overwrite",
err_info->kdfcctl_fifo2_overwrite, "%u");
__HAL_AUX_ENTRY("kdfcctl_fifo2_poison",
err_info->kdfcctl_fifo2_poison, "%u");
__HAL_AUX_ENTRY("kdfcctl_fifo2_dma_error",
err_info->kdfcctl_fifo2_dma_error, "%u");
__HAL_AUX_ENTRY("dblgen_fifo0_overflow",
err_info->dblgen_fifo0_overflow, "%u");
__HAL_AUX_ENTRY("dblgen_fifo1_overflow",
err_info->dblgen_fifo1_overflow, "%u");
__HAL_AUX_ENTRY("dblgen_fifo2_overflow",
err_info->dblgen_fifo2_overflow, "%u");
__HAL_AUX_ENTRY("statsb_pif_chain_error",
err_info->statsb_pif_chain_error, "%u");
__HAL_AUX_ENTRY("statsb_drop_timeout",
err_info->statsb_drop_timeout, "%u");
__HAL_AUX_ENTRY("target_illegal_access",
err_info->target_illegal_access, "%u");
__HAL_AUX_ENTRY("ini_serr_det",
err_info->ini_serr_det, "%u");
__HAL_AUX_ENTRY("pci_config_status_err",
err_info->pci_config_status_err, "%u");
__HAL_AUX_ENTRY("pci_config_uncor_err",
err_info->pci_config_uncor_err, "%u");
__HAL_AUX_ENTRY("pci_config_cor_err",
err_info->pci_config_cor_err, "%u");
__HAL_AUX_ENTRY("mrpcim_to_vpath_alarms",
err_info->mrpcim_to_vpath_alarms, "%u");
__HAL_AUX_ENTRY("srpcim_to_vpath_alarms",
err_info->srpcim_to_vpath_alarms, "%u");
__HAL_AUX_ENTRY("srpcim_msg_to_vpath",
err_info->srpcim_msg_to_vpath, "%u");
__HAL_AUX_ENTRY("prc_ring_bumps",
err_info->prc_ring_bumps, "%u");
__HAL_AUX_ENTRY("prc_rxdcm_sc_err",
err_info->prc_rxdcm_sc_err, "%u");
__HAL_AUX_ENTRY("prc_rxdcm_sc_abort",
err_info->prc_rxdcm_sc_abort, "%u");
__HAL_AUX_ENTRY("prc_quanta_size_err",
err_info->prc_quanta_size_err, "%u");
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_vpath_sw_read - Read vpath soft statistics.
* @vpath_handle: HAL Vpath handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read device hardware statistics. This is a subset of stats counters
* from vxge_hal_vpath_stats_sw_info_t {}.
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_vpath_sw_read(
vxge_hal_vpath_h vpath_handle,
int bufsize,
char *retbuf,
int *retsize)
{
int rsize = 0;
vxge_hal_status_e status;
vxge_hal_vpath_stats_sw_info_t *sw_info;
__hal_vpath_handle_t *vp = (__hal_vpath_handle_t *) vpath_handle;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(vpath_handle != NULL);
sw_info = vp->vpath->sw_stats;
__HAL_AUX_ENTRY("soft_reset_cnt", sw_info->soft_reset_cnt, "%u");
status = vxge_hal_aux_stats_vpath_sw_err_read(vpath_handle,
leftsize, ptr, &rsize);
if (status != VXGE_HAL_OK)
return (status);
ptr += rsize;
leftsize -= rsize;
status = vxge_hal_aux_stats_vpath_sw_ring_read(vpath_handle,
leftsize, ptr, &rsize);
if (status != VXGE_HAL_OK)
return (status);
ptr += rsize;
leftsize -= rsize;
status = vxge_hal_aux_stats_vpath_sw_fifo_read(vpath_handle,
leftsize, ptr, &rsize);
if (status != VXGE_HAL_OK)
return (status);
leftsize -= rsize;
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_device_sw_read - Read device software statistics.
* @devh: HAL device handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read device software statistics. This is a subset of stats counters
* from vxge_hal_device_stats_sw_info_t {}.
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_device_sw_read(vxge_hal_device_h devh,
int bufsize, char *retbuf, int *retsize)
{
u32 i;
int rsize = 0;
vxge_hal_status_e status;
__hal_device_t *hldev = (__hal_device_t *) devh;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(devh);
__HAL_AUX_ENTRY("not_traffic_intr_cnt",
hldev->header.not_traffic_intr_cnt, "%u");
__HAL_AUX_ENTRY("traffic_intr_cnt",
hldev->header.traffic_intr_cnt, "%u");
__HAL_AUX_ENTRY("total_intr_cnt",
hldev->header.not_traffic_intr_cnt +
hldev->header.traffic_intr_cnt, "%u");
__HAL_AUX_ENTRY("soft_reset_cnt",
hldev->stats.sw_dev_info_stats.soft_reset_cnt, "%u");
for (i = 0; i < VXGE_HAL_MAX_VIRTUAL_PATHS; i++) {
if (!(hldev->vpaths_deployed & mBIT(i)))
continue;
__HAL_AUX_ENTRY("S/W stats for vpath id", i, "%u");
status = vxge_hal_aux_stats_vpath_sw_read(
VXGE_HAL_VIRTUAL_PATH_HANDLE(&hldev->virtual_paths[i]),
leftsize, ptr, &rsize);
if (status != VXGE_HAL_OK)
return (status);
ptr += rsize;
leftsize -= rsize;
}
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_device_sw_err_read - Read device software error statistics
* @devh: HAL device handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read device software error statistics. This is a subset of stats counters
* from vxge_hal_device_stats_sw_info_t {}.
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_device_sw_err_read(vxge_hal_device_h devh,
int bufsize, char *retbuf, int *retsize)
{
vxge_hal_device_stats_sw_err_t *sw_err;
__hal_device_t *hldev = (__hal_device_t *) devh;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(devh);
sw_err = &hldev->stats.sw_dev_err_stats;
__HAL_AUX_ENTRY("mrpcim_alarms", sw_err->mrpcim_alarms, "%u");
__HAL_AUX_ENTRY("srpcim_alarms", sw_err->srpcim_alarms, "%u");
__HAL_AUX_ENTRY("vpath_alarms", sw_err->vpath_alarms, "%u");
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_device_read - Read device statistics.
* @devh: HAL device handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read device statistics. This is a subset of stats counters
* from vxge_hal_device_stats_t {}.
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_device_read(vxge_hal_device_h devh,
int bufsize, char *retbuf, int *retsize)
{
char *ptr = retbuf;
int rsize = 0, leftsize = bufsize;
vxge_hal_status_e status;
vxge_assert(devh);
status = vxge_hal_aux_stats_device_hw_read(devh,
leftsize, ptr, &rsize);
if (status != VXGE_HAL_OK)
return (status);
ptr += rsize;
leftsize -= rsize;
status = vxge_hal_aux_stats_device_sw_err_read(devh,
leftsize, ptr, &rsize);
if (status != VXGE_HAL_OK)
return (status);
ptr += rsize;
leftsize -= rsize;
status = vxge_hal_aux_stats_device_sw_read(devh,
leftsize, ptr, &rsize);
if (status != VXGE_HAL_OK)
return (status);
leftsize -= rsize;
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_xpak_read - Read device xpak statistics.
* @devh: HAL device handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read device xpak statistics. This is valid for function 0 device only
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_xpak_read(vxge_hal_device_h devh,
int bufsize, char *retbuf, int *retsize)
{
u32 i;
vxge_hal_mrpcim_xpak_stats_t *xpak_stats;
__hal_device_t *hldev = (__hal_device_t *) devh;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(devh);
if (!(hldev->access_rights & VXGE_HAL_DEVICE_ACCESS_RIGHT_MRPCIM))
return (VXGE_HAL_ERR_PRIVILAGED_OPEARATION);
for (i = 0; i < VXGE_HAL_MAC_MAX_WIRE_PORTS; i++) {
xpak_stats = &hldev->mrpcim->xpak_stats[i];
__HAL_AUX_ENTRY("Wire Port Id : ", i, "%u");
__HAL_AUX_ENTRY("alarm_transceiver_temp_high",
xpak_stats->excess_bias_current, "%u");
__HAL_AUX_ENTRY("alarm_transceiver_temp_high",
xpak_stats->excess_laser_output, "%u");
__HAL_AUX_ENTRY("alarm_transceiver_temp_high",
xpak_stats->excess_temp, "%u");
__HAL_AUX_ENTRY("alarm_transceiver_temp_high",
xpak_stats->alarm_transceiver_temp_high, "%u");
__HAL_AUX_ENTRY("alarm_transceiver_temp_low",
xpak_stats->alarm_transceiver_temp_low, "%u");
__HAL_AUX_ENTRY("alarm_laser_bias_current_high",
xpak_stats->alarm_laser_bias_current_high, "%u");
__HAL_AUX_ENTRY("alarm_laser_bias_current_low",
xpak_stats->alarm_laser_bias_current_low, "%u");
__HAL_AUX_ENTRY("alarm_laser_output_power_high",
xpak_stats->alarm_laser_output_power_high, "%u");
__HAL_AUX_ENTRY("alarm_laser_output_power_low",
xpak_stats->alarm_laser_output_power_low, "%u");
__HAL_AUX_ENTRY("warn_transceiver_temp_high",
xpak_stats->warn_transceiver_temp_high, "%u");
__HAL_AUX_ENTRY("warn_transceiver_temp_low",
xpak_stats->warn_transceiver_temp_low, "%u");
__HAL_AUX_ENTRY("warn_laser_bias_current_high",
xpak_stats->warn_laser_bias_current_high, "%u");
__HAL_AUX_ENTRY("warn_laser_bias_current_low",
xpak_stats->warn_laser_bias_current_low, "%u");
__HAL_AUX_ENTRY("warn_laser_output_power_high",
xpak_stats->warn_laser_output_power_high, "%u");
__HAL_AUX_ENTRY("warn_laser_output_power_low",
xpak_stats->warn_laser_output_power_low, "%u");
}
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_stats_mrpcim_read - Read device mrpcim statistics.
* @devh: HAL device handle.
* @bufsize: Buffer size.
* @retbuf: Buffer pointer.
* @retsize: Size of the result. Cannot be greater than @bufsize.
*
* Read device mrpcim statistics. This is valid for function 0 device only
*
*/
vxge_hal_status_e
vxge_hal_aux_stats_mrpcim_read(vxge_hal_device_h devh,
int bufsize, char *retbuf, int *retsize)
{
vxge_hal_status_e status;
vxge_hal_mrpcim_stats_hw_info_t mrpcim_info;
__hal_device_t *hldev = (__hal_device_t *) devh;
__HAL_AUX_ENTRY_DECLARE(bufsize, retbuf);
vxge_assert(devh);
if (!(hldev->access_rights & VXGE_HAL_DEVICE_ACCESS_RIGHT_MRPCIM))
return (VXGE_HAL_ERR_PRIVILAGED_OPEARATION);
status = vxge_hal_mrpcim_stats_enable(devh);
if (status != VXGE_HAL_OK)
return (status);
status = vxge_hal_mrpcim_stats_get(devh, &mrpcim_info);
if (status != VXGE_HAL_OK)
return (status);
__HAL_AUX_ENTRY("pic_ini_rd_drop", mrpcim_info.pic_ini_rd_drop, "%u");
__HAL_AUX_ENTRY("pic_ini_wr_drop", mrpcim_info.pic_ini_wr_drop, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane0",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[0].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane1",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[1].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane2",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[2].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane3",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[3].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane4",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[4].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane5",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[5].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane6",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[6].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane7",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[7].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane8",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[8].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane9",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[9].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane10",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[10].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane11",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[11].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane12",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[12].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane13",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[13].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane14",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[14].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane15",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[15].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_ph_crdt_depleted_vplane16",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[16].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane0",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[0].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane1",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[1].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane2",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[2].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane3",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[3].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane4",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[4].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane5",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[5].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane6",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[6].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane7",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[7].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane8",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[8].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane9",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[9].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane10",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[10].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane11",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[11].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane12",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[12].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane13",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[13].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane14",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[14].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane15",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[15].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_wrcrdtarb_pd_crdt_depleted_vplane16",
mrpcim_info.pic_wrcrdtarb_pd_crdt_depleted_vplane[16].
pic_wrcrdtarb_pd_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane0",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[0].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane1",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[1].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane2",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[2].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane3",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[3].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane4",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[4].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane5",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[5].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane6",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[6].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane7",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[7].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane8",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[8].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane9",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[9].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane10",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[10].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane11",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[11].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane12",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[12].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane13",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[13].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane14",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[14].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane15",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[15].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_rdcrdtarb_nph_crdt_depleted_vplane16",
mrpcim_info.pic_rdcrdtarb_nph_crdt_depleted_vplane[16].
pic_rdcrdtarb_nph_crdt_depleted, "%u");
__HAL_AUX_ENTRY("pic_ini_rd_vpin_drop",
mrpcim_info.pic_ini_rd_vpin_drop, "%u");
__HAL_AUX_ENTRY("pic_ini_wr_vpin_drop",
mrpcim_info.pic_ini_wr_vpin_drop, "%u");
__HAL_AUX_ENTRY("pic_genstats_count0",
mrpcim_info.pic_genstats_count0, "%u");
__HAL_AUX_ENTRY("pic_genstats_count1",
mrpcim_info.pic_genstats_count1, "%u");
__HAL_AUX_ENTRY("pic_genstats_count2",
mrpcim_info.pic_genstats_count2, "%u");
__HAL_AUX_ENTRY("pic_genstats_count3",
mrpcim_info.pic_genstats_count3, "%u");
__HAL_AUX_ENTRY("pic_genstats_count4",
mrpcim_info.pic_genstats_count4, "%u");
__HAL_AUX_ENTRY("pic_genstats_count5",
mrpcim_info.pic_genstats_count5, "%u");
__HAL_AUX_ENTRY("pci_rstdrop_cpl",
mrpcim_info.pci_rstdrop_cpl, "%u");
__HAL_AUX_ENTRY("pci_rstdrop_msg",
mrpcim_info.pci_rstdrop_msg, "%u");
__HAL_AUX_ENTRY("pci_rstdrop_client1",
mrpcim_info.pci_rstdrop_client1, "%u");
__HAL_AUX_ENTRY("pci_rstdrop_client0",
mrpcim_info.pci_rstdrop_client0, "%u");
__HAL_AUX_ENTRY("pci_rstdrop_client2",
mrpcim_info.pci_rstdrop_client2, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane0",
mrpcim_info.pci_depl_h_vplane[0].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane0",
mrpcim_info.pci_depl_h_vplane[0].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane0",
mrpcim_info.pci_depl_h_vplane[0].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane1",
mrpcim_info.pci_depl_h_vplane[1].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane1",
mrpcim_info.pci_depl_h_vplane[1].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane1",
mrpcim_info.pci_depl_h_vplane[1].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane2",
mrpcim_info.pci_depl_h_vplane[2].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane2",
mrpcim_info.pci_depl_h_vplane[2].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane2",
mrpcim_info.pci_depl_h_vplane[2].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane3",
mrpcim_info.pci_depl_h_vplane[3].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane3",
mrpcim_info.pci_depl_h_vplane[3].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane3",
mrpcim_info.pci_depl_h_vplane[3].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane4",
mrpcim_info.pci_depl_h_vplane[4].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane4",
mrpcim_info.pci_depl_h_vplane[4].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane4",
mrpcim_info.pci_depl_h_vplane[4].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane5",
mrpcim_info.pci_depl_h_vplane[5].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane5",
mrpcim_info.pci_depl_h_vplane[5].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane5",
mrpcim_info.pci_depl_h_vplane[5].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane6",
mrpcim_info.pci_depl_h_vplane[6].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane6",
mrpcim_info.pci_depl_h_vplane[6].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane6",
mrpcim_info.pci_depl_h_vplane[6].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane7",
mrpcim_info.pci_depl_h_vplane[7].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane7",
mrpcim_info.pci_depl_h_vplane[7].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane7",
mrpcim_info.pci_depl_h_vplane[7].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane8",
mrpcim_info.pci_depl_h_vplane[8].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane8",
mrpcim_info.pci_depl_h_vplane[8].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane8",
mrpcim_info.pci_depl_h_vplane[8].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane9",
mrpcim_info.pci_depl_h_vplane[9].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane9",
mrpcim_info.pci_depl_h_vplane[9].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane9",
mrpcim_info.pci_depl_h_vplane[9].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane10",
mrpcim_info.pci_depl_h_vplane[10].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane10",
mrpcim_info.pci_depl_h_vplane[10].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane10",
mrpcim_info.pci_depl_h_vplane[10].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane11",
mrpcim_info.pci_depl_h_vplane[11].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane11",
mrpcim_info.pci_depl_h_vplane[11].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane11",
mrpcim_info.pci_depl_h_vplane[11].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane12",
mrpcim_info.pci_depl_h_vplane[12].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane12",
mrpcim_info.pci_depl_h_vplane[12].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane12",
mrpcim_info.pci_depl_h_vplane[12].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane13",
mrpcim_info.pci_depl_h_vplane[13].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane13",
mrpcim_info.pci_depl_h_vplane[13].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane13",
mrpcim_info.pci_depl_h_vplane[13].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane14",
mrpcim_info.pci_depl_h_vplane[14].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane14",
mrpcim_info.pci_depl_h_vplane[14].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane14",
mrpcim_info.pci_depl_h_vplane[14].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane15",
mrpcim_info.pci_depl_h_vplane[15].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane15",
mrpcim_info.pci_depl_h_vplane[15].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane15",
mrpcim_info.pci_depl_h_vplane[15].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cplh_vplane16",
mrpcim_info.pci_depl_h_vplane[16].pci_depl_cplh, "%u");
__HAL_AUX_ENTRY("pci_depl_nph_vplane16",
mrpcim_info.pci_depl_h_vplane[16].pci_depl_nph, "%u");
__HAL_AUX_ENTRY("pci_depl_ph_vplane16",
mrpcim_info.pci_depl_h_vplane[16].pci_depl_ph, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane0",
mrpcim_info.pci_depl_d_vplane[0].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane0",
mrpcim_info.pci_depl_d_vplane[0].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane0",
mrpcim_info.pci_depl_d_vplane[0].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane1",
mrpcim_info.pci_depl_d_vplane[1].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane1",
mrpcim_info.pci_depl_d_vplane[1].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane1",
mrpcim_info.pci_depl_d_vplane[1].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane2",
mrpcim_info.pci_depl_d_vplane[2].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane2",
mrpcim_info.pci_depl_d_vplane[2].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane2",
mrpcim_info.pci_depl_d_vplane[2].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane3",
mrpcim_info.pci_depl_d_vplane[3].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane3",
mrpcim_info.pci_depl_d_vplane[3].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane3",
mrpcim_info.pci_depl_d_vplane[3].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane4",
mrpcim_info.pci_depl_d_vplane[4].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane4",
mrpcim_info.pci_depl_d_vplane[4].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane4",
mrpcim_info.pci_depl_d_vplane[4].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane5",
mrpcim_info.pci_depl_d_vplane[5].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane5",
mrpcim_info.pci_depl_d_vplane[5].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane5",
mrpcim_info.pci_depl_d_vplane[5].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane6",
mrpcim_info.pci_depl_d_vplane[6].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane6",
mrpcim_info.pci_depl_d_vplane[6].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane6",
mrpcim_info.pci_depl_d_vplane[6].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane7",
mrpcim_info.pci_depl_d_vplane[7].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane7",
mrpcim_info.pci_depl_d_vplane[7].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane7",
mrpcim_info.pci_depl_d_vplane[7].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane8",
mrpcim_info.pci_depl_d_vplane[8].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane8",
mrpcim_info.pci_depl_d_vplane[8].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane8",
mrpcim_info.pci_depl_d_vplane[8].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane9",
mrpcim_info.pci_depl_d_vplane[9].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane9",
mrpcim_info.pci_depl_d_vplane[9].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane9",
mrpcim_info.pci_depl_d_vplane[9].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane10",
mrpcim_info.pci_depl_d_vplane[10].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane10",
mrpcim_info.pci_depl_d_vplane[10].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane10",
mrpcim_info.pci_depl_d_vplane[10].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane11",
mrpcim_info.pci_depl_d_vplane[11].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane11",
mrpcim_info.pci_depl_d_vplane[11].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane11",
mrpcim_info.pci_depl_d_vplane[11].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane12",
mrpcim_info.pci_depl_d_vplane[12].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane12",
mrpcim_info.pci_depl_d_vplane[12].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane12",
mrpcim_info.pci_depl_d_vplane[12].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane13",
mrpcim_info.pci_depl_d_vplane[13].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane13",
mrpcim_info.pci_depl_d_vplane[13].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane13",
mrpcim_info.pci_depl_d_vplane[13].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane14",
mrpcim_info.pci_depl_d_vplane[14].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane14",
mrpcim_info.pci_depl_d_vplane[14].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane14",
mrpcim_info.pci_depl_d_vplane[14].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane15",
mrpcim_info.pci_depl_d_vplane[15].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane15",
mrpcim_info.pci_depl_d_vplane[15].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane15",
mrpcim_info.pci_depl_d_vplane[15].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("pci_depl_cpld_vplane16",
mrpcim_info.pci_depl_d_vplane[16].pci_depl_cpld, "%u");
__HAL_AUX_ENTRY("pci_depl_npd_vplane16",
mrpcim_info.pci_depl_d_vplane[16].pci_depl_npd, "%u");
__HAL_AUX_ENTRY("pci_depl_pd_vplane16",
mrpcim_info.pci_depl_d_vplane[16].pci_depl_pd, "%u");
__HAL_AUX_ENTRY("tx_ttl_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_ttl_frms, "%llu");
__HAL_AUX_ENTRY("tx_ttl_octets_PORT0",
mrpcim_info.xgmac_port[0].tx_ttl_octets, "%llu");
__HAL_AUX_ENTRY("tx_data_octets_PORT0",
mrpcim_info.xgmac_port[0].tx_data_octets, "%llu");
__HAL_AUX_ENTRY("tx_mcast_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_mcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_bcast_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_bcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_ucast_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_ucast_frms, "%llu");
__HAL_AUX_ENTRY("tx_tagged_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_tagged_frms, "%llu");
__HAL_AUX_ENTRY("tx_vld_ip_PORT0",
mrpcim_info.xgmac_port[0].tx_vld_ip, "%llu");
__HAL_AUX_ENTRY("tx_vld_ip_octets_PORT0",
mrpcim_info.xgmac_port[0].tx_vld_ip_octets, "%llu");
__HAL_AUX_ENTRY("tx_icmp_PORT0",
mrpcim_info.xgmac_port[0].tx_icmp, "%llu");
__HAL_AUX_ENTRY("tx_tcp_PORT0",
mrpcim_info.xgmac_port[0].tx_tcp, "%llu");
__HAL_AUX_ENTRY("tx_rst_tcp_PORT0",
mrpcim_info.xgmac_port[0].tx_rst_tcp, "%llu");
__HAL_AUX_ENTRY("tx_udp_PORT0",
mrpcim_info.xgmac_port[0].tx_udp, "%llu");
__HAL_AUX_ENTRY("tx_parse_error_PORT0",
mrpcim_info.xgmac_port[0].tx_parse_error, "%u");
__HAL_AUX_ENTRY("tx_unknown_protocol_PORT0",
mrpcim_info.xgmac_port[0].tx_unknown_protocol, "%u");
__HAL_AUX_ENTRY("tx_pause_ctrl_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_pause_ctrl_frms, "%llu");
__HAL_AUX_ENTRY("tx_marker_pdu_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_marker_pdu_frms, "%u");
__HAL_AUX_ENTRY("tx_lacpdu_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_lacpdu_frms, "%u");
__HAL_AUX_ENTRY("tx_drop_ip_PORT0",
mrpcim_info.xgmac_port[0].tx_drop_ip, "%u");
__HAL_AUX_ENTRY("tx_marker_resp_pdu_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_marker_resp_pdu_frms, "%u");
__HAL_AUX_ENTRY("tx_xgmii_char2_match_PORT0",
mrpcim_info.xgmac_port[0].tx_xgmii_char2_match, "%u");
__HAL_AUX_ENTRY("tx_xgmii_char1_match_PORT0",
mrpcim_info.xgmac_port[0].tx_xgmii_char1_match, "%u");
__HAL_AUX_ENTRY("tx_xgmii_column2_match_PORT0",
mrpcim_info.xgmac_port[0].tx_xgmii_column2_match, "%u");
__HAL_AUX_ENTRY("tx_xgmii_column1_match_PORT0",
mrpcim_info.xgmac_port[0].tx_xgmii_column1_match, "%u");
__HAL_AUX_ENTRY("tx_any_err_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_any_err_frms, "%u");
__HAL_AUX_ENTRY("tx_drop_frms_PORT0",
mrpcim_info.xgmac_port[0].tx_drop_frms, "%u");
__HAL_AUX_ENTRY("rx_ttl_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_frms, "%llu");
__HAL_AUX_ENTRY("rx_vld_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_vld_frms, "%llu");
__HAL_AUX_ENTRY("rx_offload_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_offload_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_octets_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_octets, "%llu");
__HAL_AUX_ENTRY("rx_data_octets_PORT0",
mrpcim_info.xgmac_port[0].rx_data_octets, "%llu");
__HAL_AUX_ENTRY("rx_offload_octets_PORT0",
mrpcim_info.xgmac_port[0].rx_offload_octets, "%llu");
__HAL_AUX_ENTRY("rx_vld_mcast_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_vld_mcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_vld_bcast_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_vld_bcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_accepted_ucast_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_accepted_ucast_frms, "%llu");
__HAL_AUX_ENTRY("rx_accepted_nucast_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_accepted_nucast_frms, "%llu");
__HAL_AUX_ENTRY("rx_tagged_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_tagged_frms, "%llu");
__HAL_AUX_ENTRY("rx_long_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_long_frms, "%llu");
__HAL_AUX_ENTRY("rx_usized_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_usized_frms, "%llu");
__HAL_AUX_ENTRY("rx_osized_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_osized_frms, "%llu");
__HAL_AUX_ENTRY("rx_frag_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_frag_frms, "%llu");
__HAL_AUX_ENTRY("rx_jabber_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_jabber_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_64_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_64_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_65_127_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_65_127_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_128_255_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_128_255_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_256_511_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_256_511_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_512_1023_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_512_1023_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_1024_1518_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_1024_1518_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_1519_4095_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_1519_4095_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_4096_8191_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_4096_8191_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_8192_max_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_8192_max_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_gt_max_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_ttl_gt_max_frms, "%llu");
__HAL_AUX_ENTRY("rx_ip_PORT0",
mrpcim_info.xgmac_port[0].rx_ip, "%llu");
__HAL_AUX_ENTRY("rx_accepted_ip_PORT0",
mrpcim_info.xgmac_port[0].rx_accepted_ip, "%llu");
__HAL_AUX_ENTRY("rx_ip_octets_PORT0",
mrpcim_info.xgmac_port[0].rx_ip_octets, "%llu");
__HAL_AUX_ENTRY("rx_err_ip_PORT0",
mrpcim_info.xgmac_port[0].rx_err_ip, "%llu");
__HAL_AUX_ENTRY("rx_icmp_PORT0",
mrpcim_info.xgmac_port[0].rx_icmp, "%llu");
__HAL_AUX_ENTRY("rx_tcp_PORT0",
mrpcim_info.xgmac_port[0].rx_tcp, "%llu");
__HAL_AUX_ENTRY("rx_udp_PORT0",
mrpcim_info.xgmac_port[0].rx_udp, "%llu");
__HAL_AUX_ENTRY("rx_err_tcp_PORT0",
mrpcim_info.xgmac_port[0].rx_err_tcp, "%llu");
__HAL_AUX_ENTRY("rx_pause_cnt_PORT0",
mrpcim_info.xgmac_port[0].rx_pause_count, "%llu");
__HAL_AUX_ENTRY("rx_pause_ctrl_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_pause_ctrl_frms, "%llu");
__HAL_AUX_ENTRY("rx_unsup_ctrl_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_unsup_ctrl_frms, "%llu");
__HAL_AUX_ENTRY("rx_fcs_err_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_fcs_err_frms, "%llu");
__HAL_AUX_ENTRY("rx_in_rng_len_err_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_in_rng_len_err_frms, "%llu");
__HAL_AUX_ENTRY("rx_out_rng_len_err_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_out_rng_len_err_frms, "%llu");
__HAL_AUX_ENTRY("rx_drop_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_drop_frms, "%llu");
__HAL_AUX_ENTRY("rx_discarded_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_discarded_frms, "%llu");
__HAL_AUX_ENTRY("rx_drop_ip_PORT0",
mrpcim_info.xgmac_port[0].rx_drop_ip, "%llu");
__HAL_AUX_ENTRY("rx_drp_udp_PORT0",
mrpcim_info.xgmac_port[0].rx_drop_udp, "%llu");
__HAL_AUX_ENTRY("rx_marker_pdu_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_marker_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_lacpdu_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_lacpdu_frms, "%u");
__HAL_AUX_ENTRY("rx_unknown_pdu_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_unknown_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_marker_resp_pdu_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_marker_resp_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_fcs_discard_PORT0",
mrpcim_info.xgmac_port[0].rx_fcs_discard, "%u");
__HAL_AUX_ENTRY("rx_illegal_pdu_frms_PORT0",
mrpcim_info.xgmac_port[0].rx_illegal_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_switch_discard_PORT0",
mrpcim_info.xgmac_port[0].rx_switch_discard, "%u");
__HAL_AUX_ENTRY("rx_len_discard_PORT0",
mrpcim_info.xgmac_port[0].rx_len_discard, "%u");
__HAL_AUX_ENTRY("rx_rpa_discard_PORT0",
mrpcim_info.xgmac_port[0].rx_rpa_discard, "%u");
__HAL_AUX_ENTRY("rx_l2_mgmt_discard_PORT0",
mrpcim_info.xgmac_port[0].rx_l2_mgmt_discard, "%u");
__HAL_AUX_ENTRY("rx_rts_discard_PORT0",
mrpcim_info.xgmac_port[0].rx_rts_discard, "%u");
__HAL_AUX_ENTRY("rx_trash_discard_PORT0",
mrpcim_info.xgmac_port[0].rx_trash_discard, "%u");
__HAL_AUX_ENTRY("rx_buff_full_discard_PORT0",
mrpcim_info.xgmac_port[0].rx_buff_full_discard, "%u");
__HAL_AUX_ENTRY("rx_red_discard_PORT0",
mrpcim_info.xgmac_port[0].rx_red_discard, "%u");
__HAL_AUX_ENTRY("rx_xgmii_ctrl_err_cnt_PORT0",
mrpcim_info.xgmac_port[0].rx_xgmii_ctrl_err_cnt, "%u");
__HAL_AUX_ENTRY("rx_xgmii_data_err_cnt_PORT0",
mrpcim_info.xgmac_port[0].rx_xgmii_data_err_cnt, "%u");
__HAL_AUX_ENTRY("rx_xgmii_char1_match_PORT0",
mrpcim_info.xgmac_port[0].rx_xgmii_char1_match, "%u");
__HAL_AUX_ENTRY("rx_xgmii_err_sym_PORT0",
mrpcim_info.xgmac_port[0].rx_xgmii_err_sym, "%u");
__HAL_AUX_ENTRY("rx_xgmii_column1_match_PORT0",
mrpcim_info.xgmac_port[0].rx_xgmii_column1_match, "%u");
__HAL_AUX_ENTRY("rx_xgmii_char2_match_PORT0",
mrpcim_info.xgmac_port[0].rx_xgmii_char2_match, "%u");
__HAL_AUX_ENTRY("rx_local_fault_PORT0",
mrpcim_info.xgmac_port[0].rx_local_fault, "%u");
__HAL_AUX_ENTRY("rx_xgmii_column2_match_PORT0",
mrpcim_info.xgmac_port[0].rx_xgmii_column2_match, "%u");
__HAL_AUX_ENTRY("rx_jettison_PORT0",
mrpcim_info.xgmac_port[0].rx_jettison, "%u");
__HAL_AUX_ENTRY("rx_remote_fault_PORT0",
mrpcim_info.xgmac_port[0].rx_remote_fault, "%u");
__HAL_AUX_ENTRY("tx_ttl_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_ttl_frms, "%llu");
__HAL_AUX_ENTRY("tx_ttl_octets_PORT1",
mrpcim_info.xgmac_port[1].tx_ttl_octets, "%llu");
__HAL_AUX_ENTRY("tx_data_octets_PORT1",
mrpcim_info.xgmac_port[1].tx_data_octets, "%llu");
__HAL_AUX_ENTRY("tx_mcast_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_mcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_bcast_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_bcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_ucast_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_ucast_frms, "%llu");
__HAL_AUX_ENTRY("tx_tagged_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_tagged_frms, "%llu");
__HAL_AUX_ENTRY("tx_vld_ip_PORT1",
mrpcim_info.xgmac_port[1].tx_vld_ip, "%llu");
__HAL_AUX_ENTRY("tx_vld_ip_octets_PORT1",
mrpcim_info.xgmac_port[1].tx_vld_ip_octets, "%llu");
__HAL_AUX_ENTRY("tx_icmp_PORT1",
mrpcim_info.xgmac_port[1].tx_icmp, "%llu");
__HAL_AUX_ENTRY("tx_tcp_PORT1",
mrpcim_info.xgmac_port[1].tx_tcp, "%llu");
__HAL_AUX_ENTRY("tx_rst_tcp_PORT1",
mrpcim_info.xgmac_port[1].tx_rst_tcp, "%llu");
__HAL_AUX_ENTRY("tx_udp_PORT1",
mrpcim_info.xgmac_port[1].tx_udp, "%llu");
__HAL_AUX_ENTRY("tx_parse_error_PORT1",
mrpcim_info.xgmac_port[1].tx_parse_error, "%u");
__HAL_AUX_ENTRY("tx_unknown_protocol_PORT1",
mrpcim_info.xgmac_port[1].tx_unknown_protocol, "%u");
__HAL_AUX_ENTRY("tx_pause_ctrl_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_pause_ctrl_frms, "%llu");
__HAL_AUX_ENTRY("tx_marker_pdu_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_marker_pdu_frms, "%u");
__HAL_AUX_ENTRY("tx_lacpdu_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_lacpdu_frms, "%u");
__HAL_AUX_ENTRY("tx_drop_ip_PORT1",
mrpcim_info.xgmac_port[1].tx_drop_ip, "%u");
__HAL_AUX_ENTRY("tx_marker_resp_pdu_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_marker_resp_pdu_frms, "%u");
__HAL_AUX_ENTRY("tx_xgmii_char2_match_PORT1",
mrpcim_info.xgmac_port[1].tx_xgmii_char2_match, "%u");
__HAL_AUX_ENTRY("tx_xgmii_char1_match_PORT1",
mrpcim_info.xgmac_port[1].tx_xgmii_char1_match, "%u");
__HAL_AUX_ENTRY("tx_xgmii_column2_match_PORT1",
mrpcim_info.xgmac_port[1].tx_xgmii_column2_match, "%u");
__HAL_AUX_ENTRY("tx_xgmii_column1_match_PORT1",
mrpcim_info.xgmac_port[1].tx_xgmii_column1_match, "%u");
__HAL_AUX_ENTRY("tx_any_err_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_any_err_frms, "%u");
__HAL_AUX_ENTRY("tx_drop_frms_PORT1",
mrpcim_info.xgmac_port[1].tx_drop_frms, "%u");
__HAL_AUX_ENTRY("rx_ttl_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_frms, "%llu");
__HAL_AUX_ENTRY("rx_vld_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_vld_frms, "%llu");
__HAL_AUX_ENTRY("rx_offload_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_offload_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_octets_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_octets, "%llu");
__HAL_AUX_ENTRY("rx_data_octets_PORT1",
mrpcim_info.xgmac_port[1].rx_data_octets, "%llu");
__HAL_AUX_ENTRY("rx_offload_octets_PORT1",
mrpcim_info.xgmac_port[1].rx_offload_octets, "%llu");
__HAL_AUX_ENTRY("rx_vld_mcast_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_vld_mcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_vld_bcast_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_vld_bcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_accepted_ucast_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_accepted_ucast_frms, "%llu");
__HAL_AUX_ENTRY("rx_accepted_nucast_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_accepted_nucast_frms, "%llu");
__HAL_AUX_ENTRY("rx_tagged_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_tagged_frms, "%llu");
__HAL_AUX_ENTRY("rx_long_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_long_frms, "%llu");
__HAL_AUX_ENTRY("rx_usized_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_usized_frms, "%llu");
__HAL_AUX_ENTRY("rx_osized_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_osized_frms, "%llu");
__HAL_AUX_ENTRY("rx_frag_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_frag_frms, "%llu");
__HAL_AUX_ENTRY("rx_jabber_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_jabber_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_64_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_64_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_65_127_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_65_127_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_128_255_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_128_255_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_256_511_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_256_511_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_512_1023_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_512_1023_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_1024_1518_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_1024_1518_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_1519_4095_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_1519_4095_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_4096_8191_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_4096_8191_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_8192_max_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_8192_max_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_gt_max_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_ttl_gt_max_frms, "%llu");
__HAL_AUX_ENTRY("rx_ip_PORT1",
mrpcim_info.xgmac_port[1].rx_ip, "%llu");
__HAL_AUX_ENTRY("rx_accepted_ip_PORT1",
mrpcim_info.xgmac_port[1].rx_accepted_ip, "%llu");
__HAL_AUX_ENTRY("rx_ip_octets_PORT1",
mrpcim_info.xgmac_port[1].rx_ip_octets, "%llu");
__HAL_AUX_ENTRY("rx_err_ip_PORT1",
mrpcim_info.xgmac_port[1].rx_err_ip, "%llu");
__HAL_AUX_ENTRY("rx_icmp_PORT1",
mrpcim_info.xgmac_port[1].rx_icmp, "%llu");
__HAL_AUX_ENTRY("rx_tcp_PORT1",
mrpcim_info.xgmac_port[1].rx_tcp, "%llu");
__HAL_AUX_ENTRY("rx_udp_PORT1",
mrpcim_info.xgmac_port[1].rx_udp, "%llu");
__HAL_AUX_ENTRY("rx_err_tcp_PORT1",
mrpcim_info.xgmac_port[1].rx_err_tcp, "%llu");
__HAL_AUX_ENTRY("rx_pause_count_PORT1",
mrpcim_info.xgmac_port[1].rx_pause_count, "%llu");
__HAL_AUX_ENTRY("rx_pause_ctrl_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_pause_ctrl_frms, "%llu");
__HAL_AUX_ENTRY("rx_unsup_ctrl_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_unsup_ctrl_frms, "%llu");
__HAL_AUX_ENTRY("rx_fcs_err_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_fcs_err_frms, "%llu");
__HAL_AUX_ENTRY("rx_in_rng_len_err_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_in_rng_len_err_frms, "%llu");
__HAL_AUX_ENTRY("rx_out_rng_len_err_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_out_rng_len_err_frms, "%llu");
__HAL_AUX_ENTRY("rx_drop_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_drop_frms, "%llu");
__HAL_AUX_ENTRY("rx_discarded_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_discarded_frms, "%llu");
__HAL_AUX_ENTRY("rx_drop_ip_PORT1",
mrpcim_info.xgmac_port[1].rx_drop_ip, "%llu");
__HAL_AUX_ENTRY("rx_drop_udp_PORT1",
mrpcim_info.xgmac_port[1].rx_drop_udp, "%llu");
__HAL_AUX_ENTRY("rx_marker_pdu_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_marker_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_lacpdu_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_lacpdu_frms, "%u");
__HAL_AUX_ENTRY("rx_unknown_pdu_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_unknown_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_marker_resp_pdu_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_marker_resp_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_fcs_discard_PORT1",
mrpcim_info.xgmac_port[1].rx_fcs_discard, "%u");
__HAL_AUX_ENTRY("rx_illegal_pdu_frms_PORT1",
mrpcim_info.xgmac_port[1].rx_illegal_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_switch_discard_PORT1",
mrpcim_info.xgmac_port[1].rx_switch_discard, "%u");
__HAL_AUX_ENTRY("rx_len_discard_PORT1",
mrpcim_info.xgmac_port[1].rx_len_discard, "%u");
__HAL_AUX_ENTRY("rx_rpa_discard_PORT1",
mrpcim_info.xgmac_port[1].rx_rpa_discard, "%u");
__HAL_AUX_ENTRY("rx_l2_mgmt_discard_PORT1",
mrpcim_info.xgmac_port[1].rx_l2_mgmt_discard, "%u");
__HAL_AUX_ENTRY("rx_rts_discard_PORT1",
mrpcim_info.xgmac_port[1].rx_rts_discard, "%u");
__HAL_AUX_ENTRY("rx_trash_discard_PORT1",
mrpcim_info.xgmac_port[1].rx_trash_discard, "%u");
__HAL_AUX_ENTRY("rx_buff_full_discard_PORT1",
mrpcim_info.xgmac_port[1].rx_buff_full_discard, "%u");
__HAL_AUX_ENTRY("rx_red_discard_PORT1",
mrpcim_info.xgmac_port[1].rx_red_discard, "%u");
__HAL_AUX_ENTRY("rx_xgmii_ctrl_err_cnt_PORT1",
mrpcim_info.xgmac_port[1].rx_xgmii_ctrl_err_cnt, "%u");
__HAL_AUX_ENTRY("rx_xgmii_data_err_cnt_PORT1",
mrpcim_info.xgmac_port[1].rx_xgmii_data_err_cnt, "%u");
__HAL_AUX_ENTRY("rx_xgmii_char1_match_PORT1",
mrpcim_info.xgmac_port[1].rx_xgmii_char1_match, "%u");
__HAL_AUX_ENTRY("rx_xgmii_err_sym_PORT1",
mrpcim_info.xgmac_port[1].rx_xgmii_err_sym, "%u");
__HAL_AUX_ENTRY("rx_xgmii_column1_match_PORT1",
mrpcim_info.xgmac_port[1].rx_xgmii_column1_match, "%u");
__HAL_AUX_ENTRY("rx_xgmii_char2_match_PORT1",
mrpcim_info.xgmac_port[1].rx_xgmii_char2_match, "%u");
__HAL_AUX_ENTRY("rx_local_fault_PORT1",
mrpcim_info.xgmac_port[1].rx_local_fault, "%u");
__HAL_AUX_ENTRY("rx_xgmii_column2_match_PORT1",
mrpcim_info.xgmac_port[1].rx_xgmii_column2_match, "%u");
__HAL_AUX_ENTRY("rx_jettison_PORT1",
mrpcim_info.xgmac_port[1].rx_jettison, "%u");
__HAL_AUX_ENTRY("rx_remote_fault_PORT1",
mrpcim_info.xgmac_port[1].rx_remote_fault, "%u");
__HAL_AUX_ENTRY("tx_ttl_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_ttl_frms, "%llu");
__HAL_AUX_ENTRY("tx_ttl_octets_PORT2",
mrpcim_info.xgmac_port[2].tx_ttl_octets, "%llu");
__HAL_AUX_ENTRY("tx_data_octets_PORT2",
mrpcim_info.xgmac_port[2].tx_data_octets, "%llu");
__HAL_AUX_ENTRY("tx_mcast_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_mcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_bcast_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_bcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_ucast_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_ucast_frms, "%llu");
__HAL_AUX_ENTRY("tx_tagged_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_tagged_frms, "%llu");
__HAL_AUX_ENTRY("tx_vld_ip_PORT2",
mrpcim_info.xgmac_port[2].tx_vld_ip, "%llu");
__HAL_AUX_ENTRY("tx_vld_ip_octets_PORT2",
mrpcim_info.xgmac_port[2].tx_vld_ip_octets, "%llu");
__HAL_AUX_ENTRY("tx_icmp_PORT2",
mrpcim_info.xgmac_port[2].tx_icmp, "%llu");
__HAL_AUX_ENTRY("tx_tcp_PORT2",
mrpcim_info.xgmac_port[2].tx_tcp, "%llu");
__HAL_AUX_ENTRY("tx_rst_tcp_PORT2",
mrpcim_info.xgmac_port[2].tx_rst_tcp, "%llu");
__HAL_AUX_ENTRY("tx_udp_PORT2",
mrpcim_info.xgmac_port[2].tx_udp, "%llu");
__HAL_AUX_ENTRY("tx_parse_error_PORT2",
mrpcim_info.xgmac_port[2].tx_parse_error, "%u");
__HAL_AUX_ENTRY("tx_unknown_protocol_PORT2",
mrpcim_info.xgmac_port[2].tx_unknown_protocol, "%u");
__HAL_AUX_ENTRY("tx_pause_ctrl_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_pause_ctrl_frms, "%llu");
__HAL_AUX_ENTRY("tx_marker_pdu_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_marker_pdu_frms, "%u");
__HAL_AUX_ENTRY("tx_lacpdu_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_lacpdu_frms, "%u");
__HAL_AUX_ENTRY("tx_drop_ip_PORT2",
mrpcim_info.xgmac_port[2].tx_drop_ip, "%u");
__HAL_AUX_ENTRY("tx_marker_resp_pdu_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_marker_resp_pdu_frms, "%u");
__HAL_AUX_ENTRY("tx_xgmii_char2_match_PORT2",
mrpcim_info.xgmac_port[2].tx_xgmii_char2_match, "%u");
__HAL_AUX_ENTRY("tx_xgmii_char1_match_PORT2",
mrpcim_info.xgmac_port[2].tx_xgmii_char1_match, "%u");
__HAL_AUX_ENTRY("tx_xgmii_column2_match_PORT2",
mrpcim_info.xgmac_port[2].tx_xgmii_column2_match, "%u");
__HAL_AUX_ENTRY("tx_xgmii_column1_match_PORT2",
mrpcim_info.xgmac_port[2].tx_xgmii_column1_match, "%u");
__HAL_AUX_ENTRY("tx_any_err_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_any_err_frms, "%u");
__HAL_AUX_ENTRY("tx_drop_frms_PORT2",
mrpcim_info.xgmac_port[2].tx_drop_frms, "%u");
__HAL_AUX_ENTRY("rx_ttl_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_frms, "%llu");
__HAL_AUX_ENTRY("rx_vld_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_vld_frms, "%llu");
__HAL_AUX_ENTRY("rx_offload_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_offload_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_octets_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_octets, "%llu");
__HAL_AUX_ENTRY("rx_data_octets_PORT2",
mrpcim_info.xgmac_port[2].rx_data_octets, "%llu");
__HAL_AUX_ENTRY("rx_offload_octets_PORT2",
mrpcim_info.xgmac_port[2].rx_offload_octets, "%llu");
__HAL_AUX_ENTRY("rx_vld_mcast_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_vld_mcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_vld_bcast_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_vld_bcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_accepted_ucast_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_accepted_ucast_frms, "%llu");
__HAL_AUX_ENTRY("rx_accepted_nucast_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_accepted_nucast_frms, "%llu");
__HAL_AUX_ENTRY("rx_tagged_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_tagged_frms, "%llu");
__HAL_AUX_ENTRY("rx_long_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_long_frms, "%llu");
__HAL_AUX_ENTRY("rx_usized_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_usized_frms, "%llu");
__HAL_AUX_ENTRY("rx_osized_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_osized_frms, "%llu");
__HAL_AUX_ENTRY("rx_frag_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_frag_frms, "%llu");
__HAL_AUX_ENTRY("rx_jabber_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_jabber_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_64_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_64_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_65_127_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_65_127_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_128_255_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_128_255_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_256_511_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_256_511_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_512_1023_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_512_1023_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_1024_1518_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_1024_1518_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_1519_4095_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_1519_4095_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_4096_8191_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_4096_8191_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_8192_max_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_8192_max_frms, "%llu");
__HAL_AUX_ENTRY("rx_ttl_gt_max_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_ttl_gt_max_frms, "%llu");
__HAL_AUX_ENTRY("rx_ip_PORT2",
mrpcim_info.xgmac_port[2].rx_ip, "%llu");
__HAL_AUX_ENTRY("rx_accepted_ip_PORT2",
mrpcim_info.xgmac_port[2].rx_accepted_ip, "%llu");
__HAL_AUX_ENTRY("rx_ip_octets_PORT2",
mrpcim_info.xgmac_port[2].rx_ip_octets, "%llu");
__HAL_AUX_ENTRY("rx_err_ip_PORT2",
mrpcim_info.xgmac_port[2].rx_err_ip, "%llu");
__HAL_AUX_ENTRY("rx_icmp_PORT2",
mrpcim_info.xgmac_port[2].rx_icmp, "%llu");
__HAL_AUX_ENTRY("rx_tcp_PORT2",
mrpcim_info.xgmac_port[2].rx_tcp, "%llu");
__HAL_AUX_ENTRY("rx_udp_PORT2",
mrpcim_info.xgmac_port[2].rx_udp, "%llu");
__HAL_AUX_ENTRY("rx_err_tcp_PORT2",
mrpcim_info.xgmac_port[2].rx_err_tcp, "%llu");
__HAL_AUX_ENTRY("rx_pause_count_PORT2",
mrpcim_info.xgmac_port[2].rx_pause_count, "%llu");
__HAL_AUX_ENTRY("rx_pause_ctrl_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_pause_ctrl_frms, "%llu");
__HAL_AUX_ENTRY("rx_unsup_ctrl_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_unsup_ctrl_frms, "%llu");
__HAL_AUX_ENTRY("rx_fcs_err_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_fcs_err_frms, "%llu");
__HAL_AUX_ENTRY("rx_in_rng_len_err_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_in_rng_len_err_frms, "%llu");
__HAL_AUX_ENTRY("rx_out_rng_len_err_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_out_rng_len_err_frms, "%llu");
__HAL_AUX_ENTRY("rx_drop_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_drop_frms, "%llu");
__HAL_AUX_ENTRY("rx_discarded_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_discarded_frms, "%llu");
__HAL_AUX_ENTRY("rx_drop_ip_PORT2",
mrpcim_info.xgmac_port[2].rx_drop_ip, "%llu");
__HAL_AUX_ENTRY("rx_drop_udp_PORT2",
mrpcim_info.xgmac_port[2].rx_drop_udp, "%llu");
__HAL_AUX_ENTRY("rx_marker_pdu_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_marker_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_lacpdu_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_lacpdu_frms, "%u");
__HAL_AUX_ENTRY("rx_unknown_pdu_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_unknown_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_marker_resp_pdu_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_marker_resp_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_fcs_discard_PORT2",
mrpcim_info.xgmac_port[2].rx_fcs_discard, "%u");
__HAL_AUX_ENTRY("rx_illegal_pdu_frms_PORT2",
mrpcim_info.xgmac_port[2].rx_illegal_pdu_frms, "%u");
__HAL_AUX_ENTRY("rx_switch_discard_PORT2",
mrpcim_info.xgmac_port[2].rx_switch_discard, "%u");
__HAL_AUX_ENTRY("rx_len_discard_PORT2",
mrpcim_info.xgmac_port[2].rx_len_discard, "%u");
__HAL_AUX_ENTRY("rx_rpa_discard_PORT2",
mrpcim_info.xgmac_port[2].rx_rpa_discard, "%u");
__HAL_AUX_ENTRY("rx_l2_mgmt_discard_PORT2",
mrpcim_info.xgmac_port[2].rx_l2_mgmt_discard, "%u");
__HAL_AUX_ENTRY("rx_rts_discard_PORT2",
mrpcim_info.xgmac_port[2].rx_rts_discard, "%u");
__HAL_AUX_ENTRY("rx_trash_discard_PORT2",
mrpcim_info.xgmac_port[2].rx_trash_discard, "%u");
__HAL_AUX_ENTRY("rx_buff_full_discard_PORT2",
mrpcim_info.xgmac_port[2].rx_buff_full_discard, "%u");
__HAL_AUX_ENTRY("rx_red_discard_PORT2",
mrpcim_info.xgmac_port[2].rx_red_discard, "%u");
__HAL_AUX_ENTRY("rx_xgmii_ctrl_err_cnt_PORT2",
mrpcim_info.xgmac_port[2].rx_xgmii_ctrl_err_cnt, "%u");
__HAL_AUX_ENTRY("rx_xgmii_data_err_cnt_PORT2",
mrpcim_info.xgmac_port[2].rx_xgmii_data_err_cnt, "%u");
__HAL_AUX_ENTRY("rx_xgmii_char1_match_PORT2",
mrpcim_info.xgmac_port[2].rx_xgmii_char1_match, "%u");
__HAL_AUX_ENTRY("rx_xgmii_err_sym_PORT2",
mrpcim_info.xgmac_port[2].rx_xgmii_err_sym, "%u");
__HAL_AUX_ENTRY("rx_xgmii_column1_match_PORT2",
mrpcim_info.xgmac_port[2].rx_xgmii_column1_match, "%u");
__HAL_AUX_ENTRY("rx_xgmii_char2_match_PORT2",
mrpcim_info.xgmac_port[2].rx_xgmii_char2_match, "%u");
__HAL_AUX_ENTRY("rx_local_fault_PORT2",
mrpcim_info.xgmac_port[2].rx_local_fault, "%u");
__HAL_AUX_ENTRY("rx_xgmii_column2_match_PORT2",
mrpcim_info.xgmac_port[2].rx_xgmii_column2_match, "%u");
__HAL_AUX_ENTRY("rx_jettison_PORT2",
mrpcim_info.xgmac_port[2].rx_jettison, "%u");
__HAL_AUX_ENTRY("rx_remote_fault_PORT2",
mrpcim_info.xgmac_port[2].rx_remote_fault, "%u");
__HAL_AUX_ENTRY("tx_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].tx_frms, "%llu");
__HAL_AUX_ENTRY("tx_data_octets_AGGR0",
mrpcim_info.xgmac_aggr[0].tx_data_octets, "%llu");
__HAL_AUX_ENTRY("tx_mcast_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].tx_mcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_bcast_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].tx_bcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_discarded_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].tx_discarded_frms, "%llu");
__HAL_AUX_ENTRY("tx_errored_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].tx_errored_frms, "%llu");
__HAL_AUX_ENTRY("rx_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].rx_frms, "%llu");
__HAL_AUX_ENTRY("rx_data_octets_AGGR0",
mrpcim_info.xgmac_aggr[0].rx_data_octets, "%llu");
__HAL_AUX_ENTRY("rx_mcast_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].rx_mcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_bcast_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].rx_bcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_discarded_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].rx_discarded_frms, "%llu");
__HAL_AUX_ENTRY("rx_errored_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].rx_errored_frms, "%llu");
__HAL_AUX_ENTRY("rx_unknown_slow_proto_frms_AGGR0",
mrpcim_info.xgmac_aggr[0].rx_unknown_slow_proto_frms, "%llu");
__HAL_AUX_ENTRY("tx_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].tx_frms, "%llu");
__HAL_AUX_ENTRY("tx_data_octets_AGGR1",
mrpcim_info.xgmac_aggr[1].tx_data_octets, "%llu");
__HAL_AUX_ENTRY("tx_mcast_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].tx_mcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_bcast_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].tx_bcast_frms, "%llu");
__HAL_AUX_ENTRY("tx_discarded_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].tx_discarded_frms, "%llu");
__HAL_AUX_ENTRY("tx_errored_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].tx_errored_frms, "%llu");
__HAL_AUX_ENTRY("rx_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].rx_frms, "%llu");
__HAL_AUX_ENTRY("rx_data_octets_AGGR1",
mrpcim_info.xgmac_aggr[1].rx_data_octets, "%llu");
__HAL_AUX_ENTRY("rx_mcast_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].rx_mcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_bcast_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].rx_bcast_frms, "%llu");
__HAL_AUX_ENTRY("rx_discarded_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].rx_discarded_frms, "%llu");
__HAL_AUX_ENTRY("rx_errored_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].rx_errored_frms, "%llu");
__HAL_AUX_ENTRY("rx_unknown_slow_proto_frms_AGGR1",
mrpcim_info.xgmac_aggr[1].rx_unknown_slow_proto_frms, "%llu");
__HAL_AUX_ENTRY("xgmac_global_prog_event_gnum0",
mrpcim_info.xgmac_global_prog_event_gnum0, "%llu");
__HAL_AUX_ENTRY("xgmac_global_prog_event_gnum1",
mrpcim_info.xgmac_global_prog_event_gnum1, "%llu");
__HAL_AUX_ENTRY("xgmac_orp_lro_events",
mrpcim_info.xgmac_orp_lro_events, "%llu");
__HAL_AUX_ENTRY("xgmac_orp_bs_events",
mrpcim_info.xgmac_orp_bs_events, "%llu");
__HAL_AUX_ENTRY("xgmac_orp_iwarp_events",
mrpcim_info.xgmac_orp_iwarp_events, "%llu");
__HAL_AUX_ENTRY("xgmac_tx_permitted_frms",
mrpcim_info.xgmac_tx_permitted_frms, "%u");
__HAL_AUX_ENTRY("xgmac_port2_tx_any_frms",
mrpcim_info.xgmac_port2_tx_any_frms, "%u");
__HAL_AUX_ENTRY("xgmac_port1_tx_any_frms",
mrpcim_info.xgmac_port1_tx_any_frms, "%u");
__HAL_AUX_ENTRY("xgmac_port0_tx_any_frms",
mrpcim_info.xgmac_port0_tx_any_frms, "%u");
__HAL_AUX_ENTRY("xgmac_port2_rx_any_frms",
mrpcim_info.xgmac_port2_rx_any_frms, "%u");
__HAL_AUX_ENTRY("xgmac_port1_rx_any_frms",
mrpcim_info.xgmac_port1_rx_any_frms, "%u");
__HAL_AUX_ENTRY("xgmac_port0_rx_any_frms",
mrpcim_info.xgmac_port0_rx_any_frms, "%u");
__HAL_AUX_ENTRY_END(bufsize, retsize);
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_vpath_ring_dump - Dump vpath ring.
* @vpath_handle: Vpath handle.
*
* Dump vpath ring.
*/
vxge_hal_status_e
vxge_hal_aux_vpath_ring_dump(vxge_hal_vpath_h vpath_handle)
{
u32 i;
char buffer[4096];
__hal_ring_t *ring;
vxge_hal_rxd_h rxdh;
__hal_virtualpath_t *vpath;
vxge_hal_ring_rxd_1_t *rxd1;
vxge_hal_ring_rxd_3_t *rxd3;
vxge_hal_ring_rxd_5_t *rxd5;
vxge_assert(vpath_handle != NULL);
vpath = (__hal_virtualpath_t *)
((__hal_vpath_handle_t *) vpath_handle)->vpath;
ring = (__hal_ring_t *) vpath->ringh;
vxge_os_println("********* vxge RING DUMP BEGIN **********");
vxge_os_println("********* vxge RING RXD LIST **********");
__hal_channel_for_each_dtr(&ring->channel, rxdh, i) {
(void) vxge_os_snprintf(buffer, sizeof(buffer),
"%d : 0x"VXGE_OS_STXFMT, i, (ptr_t) rxdh);
vxge_os_println(buffer);
switch (ring->buffer_mode) {
case 1:
rxd1 = (vxge_hal_ring_rxd_1_t *) rxdh;
(void) vxge_os_snprintf(buffer, sizeof(buffer),
"\thost_control = 0x"VXGE_OS_LLXFMT", "
"control_0 = 0x"VXGE_OS_LLXFMT", "
"control_1 = 0x"VXGE_OS_LLXFMT", "
"buffer0_ptr = 0x"VXGE_OS_LLXFMT,
rxd1->host_control, rxd1->control_0,
rxd1->control_1, rxd1->buffer0_ptr);
break;
case 3:
rxd3 = (vxge_hal_ring_rxd_3_t *) rxdh;
(void) vxge_os_snprintf(buffer, sizeof(buffer),
"\thost_control = 0x"VXGE_OS_LLXFMT", "
"control_0 = 0x"VXGE_OS_LLXFMT", "
"control_1 = 0x"VXGE_OS_LLXFMT", "
"buffer0_ptr = 0x"VXGE_OS_LLXFMT", "
"buffer1_ptr = 0x"VXGE_OS_LLXFMT", "
"buffer2_ptr = 0x"VXGE_OS_LLXFMT,
rxd3->host_control, rxd3->control_0,
rxd3->control_1, rxd3->buffer0_ptr,
rxd3->buffer1_ptr, rxd3->buffer2_ptr);
break;
case 5:
rxd5 = (vxge_hal_ring_rxd_5_t *) rxdh;
(void) vxge_os_snprintf(buffer, sizeof(buffer),
"\thost_control = 0x%x, "
"control_0 = 0x"VXGE_OS_LLXFMT", "
"control_1 = 0x"VXGE_OS_LLXFMT", "
"control_2 = 0x%x, "
"buffer0_ptr = 0x"VXGE_OS_LLXFMT", "
"buffer1_ptr = 0x"VXGE_OS_LLXFMT", "
"buffer2_ptr = 0x"VXGE_OS_LLXFMT", "
"buffer3_ptr = 0x"VXGE_OS_LLXFMT", "
"buffer4_ptr = 0x"VXGE_OS_LLXFMT,
rxd5->host_control, rxd5->control_0,
rxd5->control_1, rxd5->control_2,
rxd5->buffer0_ptr, rxd5->buffer1_ptr,
rxd5->buffer2_ptr, rxd5->buffer3_ptr,
rxd5->buffer4_ptr);
break;
default:
continue;
}
vxge_os_println(buffer);
}
vxge_os_println("******* vxge RING RXD LIST END **********");
vxge_os_println("********* vxge RING DUMP END **********");
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_vpath_fifo_dump - Dump vpath fifo.
* @vpath_handle: Vpath handle.
*
* Dump vpath fifo.
*/
vxge_hal_status_e
vxge_hal_aux_vpath_fifo_dump(vxge_hal_vpath_h vpath_handle)
{
u32 i, j;
char buffer[4096];
__hal_fifo_t *fifo;
vxge_hal_txdl_h txdlh;
__hal_virtualpath_t *vpath;
vxge_hal_fifo_txd_t *txd;
__hal_fifo_txdl_priv_t *txdl_priv;
vxge_assert(vpath_handle != NULL);
vpath = (__hal_virtualpath_t *)
((__hal_vpath_handle_t *) vpath_handle)->vpath;
fifo = (__hal_fifo_t *) vpath->fifoh;
vxge_os_println("********* vxge FIFO DUMP BEGIN **********");
vxge_os_println("********* vxge FIFO TXDL LIST **********");
__hal_channel_for_each_dtr(&fifo->channel, txdlh, j) {
(void) vxge_os_snprintf(buffer, sizeof(buffer),
"TXDL %d : 0x"VXGE_OS_STXFMT, j, (ptr_t) txdlh);
vxge_os_println(buffer);
txdl_priv = VXGE_HAL_FIFO_HAL_PRIV(fifo, txdlh);
for (i = 0, txd = (vxge_hal_fifo_txd_t *) txdlh;
i < txdl_priv->frags; i++, txd++) {
(void) vxge_os_snprintf(buffer, sizeof(buffer),
"\tcontrol_0 = 0x"VXGE_OS_LLXFMT", "
"control_1 = 0x"VXGE_OS_LLXFMT", "
"buffer_ptr = 0x"VXGE_OS_LLXFMT", "
"host_control = 0x"VXGE_OS_LLXFMT,
txd->control_0, txd->control_1,
txd->buffer_pointer, txd->host_control);
vxge_os_println(buffer);
}
}
vxge_os_println("******* vxge FIFO TXDL LIST END **********");
vxge_os_println("********* vxge FIFO DUMP END **********");
return (VXGE_HAL_OK);
}
/*
* vxge_hal_aux_device_dump - Dump driver "about" info and device state.
* @devh: HAL device handle.
*
* Dump driver & device "about" info and device state,
* including all BAR0 registers, hardware and software statistics, PCI
* configuration space.
*/
vxge_hal_status_e
vxge_hal_aux_device_dump(vxge_hal_device_h devh)
{
vxge_hal_status_e status = VXGE_HAL_OK;
__hal_device_t *hldev = (__hal_device_t *) devh;
int retsize;
u32 offset, i;
u64 retval;
vxge_assert(hldev->dump_buf != NULL);
vxge_os_println("********* vxge DEVICE DUMP BEGIN **********");
status = vxge_hal_aux_about_read(hldev, VXGE_HAL_DUMP_BUF_SIZE,
hldev->dump_buf, &retsize);
if (status != VXGE_HAL_OK)
goto error;
vxge_os_println(hldev->dump_buf);
vxge_os_println("******* PCI Config Reg **********");
status = vxge_hal_aux_pci_config_read(hldev, VXGE_HAL_DUMP_BUF_SIZE,
hldev->dump_buf, &retsize);
if (status != VXGE_HAL_OK)
goto error;
vxge_os_println(hldev->dump_buf);
vxge_os_println("******* Legacy Reg **********");
for (offset = 0; offset < sizeof(vxge_hal_legacy_reg_t); offset += 8) {
status = vxge_hal_mgmt_reg_read(devh,
vxge_hal_mgmt_reg_type_legacy, 0, offset, &retval);
if (status != VXGE_HAL_OK)
goto error;
if (!retval)
continue;
vxge_os_printf("0x%04x 0x%08x%08x", offset,
(u32) (retval >> 32), (u32) retval);
}
vxge_os_println("\n");
vxge_os_println("******* TOC Reg *********");
for (offset = 0; offset < sizeof(vxge_hal_toc_reg_t); offset += 8) {
status = vxge_hal_mgmt_reg_read(devh,
vxge_hal_mgmt_reg_type_toc, 0, offset, &retval);
if (status != VXGE_HAL_OK)
goto error;
if (!retval)
continue;
vxge_os_printf("0x%04x 0x%08x%08x", offset,
(u32) (retval >> 32), (u32) retval);
}
vxge_os_println("\n");
vxge_os_println("******* Common Reg **********");
for (offset = 0; offset < sizeof(vxge_hal_common_reg_t); offset += 8) {
status = vxge_hal_mgmt_reg_read(devh,
vxge_hal_mgmt_reg_type_common, 0, offset, &retval);
if (status != VXGE_HAL_OK)
goto error;
if (!retval)
continue;
vxge_os_printf("0x%04x 0x%08x%08x", offset,
(u32) (retval >> 32), (u32) retval);
}
vxge_os_println("\n");
for (i = 0; i < VXGE_HAL_TITAN_PCICFGMGMT_REG_SPACES; i++) {
vxge_os_printf("****** PCI Config Mgmt Reg : %d ********\n", i);
for (offset = 0; offset < sizeof(vxge_hal_pcicfgmgmt_reg_t);
offset += 8) {
status = vxge_hal_mgmt_reg_read(devh,
vxge_hal_mgmt_reg_type_pcicfgmgmt,
i, offset, &retval);
if (status != VXGE_HAL_OK)
continue;
if (!retval)
continue;
vxge_os_printf("0x%04x 0x%08x%08x", offset,
(u32) (retval >> 32), (u32) retval);
}
}
vxge_os_println("\n");
vxge_os_println("******* MRPCIM Reg **********");
for (offset = 0; offset < sizeof(vxge_hal_mrpcim_reg_t);
offset += 8) {
status = vxge_hal_mgmt_reg_read(devh,
vxge_hal_mgmt_reg_type_mrpcim, 0, offset, &retval);
if (status != VXGE_HAL_OK)
continue;
if (!retval)
continue;
vxge_os_printf("0x%04x 0x%08x%08x", offset,
(u32) (retval >> 32), (u32) retval);
}
vxge_os_println("\n");
for (i = 0; i < VXGE_HAL_TITAN_SRPCIM_REG_SPACES; i++) {
vxge_os_printf("******* SRPCIM Reg : %d **********\n", i);
for (offset = 0; offset < sizeof(vxge_hal_srpcim_reg_t);
offset += 8) {
status = vxge_hal_mgmt_reg_read(devh,
vxge_hal_mgmt_reg_type_srpcim, i, offset, &retval);
if (status != VXGE_HAL_OK)
continue;
if (!retval)
continue;
vxge_os_printf("0x%04x 0x%08x%08x", offset,
(u32) (retval >> 32), (u32) retval);
}
}
vxge_os_println("\n");
for (i = 0; i < VXGE_HAL_TITAN_VPMGMT_REG_SPACES; i++) {
vxge_os_printf("******* VPATH MGMT Reg : %d **********\n", i);
for (offset = 0; offset < sizeof(vxge_hal_vpmgmt_reg_t);
offset += 8) {
status = vxge_hal_mgmt_reg_read(devh,
vxge_hal_mgmt_reg_type_vpmgmt, i, offset, &retval);
if (status != VXGE_HAL_OK)
continue;
if (!retval)
continue;
vxge_os_printf("0x%04x 0x%08x%08x", offset,
(u32) (retval >> 32), (u32) retval);
}
}
vxge_os_println("\n");
for (i = 0; i < VXGE_HAL_TITAN_VPATH_REG_SPACES; i++) {
vxge_os_printf("******* VPATH Reg : %d **********\n", i);
for (offset = 0; offset < sizeof(vxge_hal_vpath_reg_t);
offset += 8) {
status = vxge_hal_mgmt_reg_read(devh,
vxge_hal_mgmt_reg_type_vpath, i, offset, &retval);
if (status != VXGE_HAL_OK)
continue;
if (!retval)
continue;
vxge_os_printf("0x%04x 0x%08x%08x", offset,
(u32) (retval >> 32), (u32) retval);
}
}
vxge_os_println("\n");
status = vxge_hal_aux_stats_mrpcim_read(hldev, VXGE_HAL_DUMP_BUF_SIZE,
hldev->dump_buf,
&retsize);
if (status == VXGE_HAL_OK) {
vxge_os_println("******* MRPCIM Stats **********");
vxge_os_println(hldev->dump_buf);
}
vxge_os_println("******* Device Stats **********");
status = vxge_hal_aux_stats_device_read(hldev, VXGE_HAL_DUMP_BUF_SIZE,
hldev->dump_buf, &retsize);
if (status != VXGE_HAL_OK)
goto error;
vxge_os_println(hldev->dump_buf);
vxge_os_println("********* DEVICE DUMP END **********");
error:
return (status);
}