3be4cb0b4a
changes: 01 - Enhanced LRO: LRO feature is extended to support multi-buffer mode. Previously, Ethernet frames received in contiguous buffers were offloaded. Now, frames received in multiple non-contiguous buffers can be offloaded, as well. The driver now supports LRO for jumbo frames. 02 - Locks Optimization: The driver code was re-organized to limit the use of locks. Moreover, lock contention was reduced by replacing wait locks with try locks. 03 - Code Optimization: The driver code was re-factored to eliminate some memcpy operations. Fast path loops were optimized. 04 - Tag Creations: Physical Buffer Tags are now optimized based upon frame size. For better performance, Physical Memory Maps are now re-used. 05 - Configuration: Features such as TSO, LRO, and Interrupt Mode can be configured either at load or at run time. Rx buffer mode (mode 1 or mode 2) can be configured at load time through kenv. 06 - Driver Statistics: Run time statistics are enhanced to provide better visibility into the driver performance. 07 - Bug Fixes: The driver contains fixes for the problems discovered and reported since last submission. 08 - MSI support: Added Message Signaled Interrupt feature which currently uses 1 message. 09 Removed feature: Rx 3 buffer mode feature has been removed. Driver now supports 1, 2 and 5 buffer modes of which 2 and 5 buffer modes can be used for header separation. 10 Compiler warning: Fixed compiler warning when compiled for 32 bit system. 11 Copyright notice: Source files are updated with the proper copyright notice. MFC after: 3 days Submitted by: Alicia Pena <Alicia dot Pena at neterion dot com>, Muhammad Shafiq <Muhammad dot Shafiq at neterion dot com>
221 lines
6.8 KiB
C
221 lines
6.8 KiB
C
/*-
|
|
* Copyright (c) 2002-2007 Neterion, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that 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.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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$
|
|
*/
|
|
|
|
#ifndef XGE_HAL_MGMT_H
|
|
#define XGE_HAL_MGMT_H
|
|
|
|
#include <dev/nxge/include/xge-os-pal.h>
|
|
#include <dev/nxge/include/xge-debug.h>
|
|
#include <dev/nxge/include/xgehal-types.h>
|
|
#include <dev/nxge/include/xgehal-config.h>
|
|
#include <dev/nxge/include/xgehal-stats.h>
|
|
#include <dev/nxge/include/xgehal-regs.h>
|
|
#include <dev/nxge/include/xgehal-device.h>
|
|
|
|
__EXTERN_BEGIN_DECLS
|
|
|
|
/**
|
|
* struct xge_hal_mgmt_about_info_t - About info.
|
|
* @vendor: PCI Vendor ID.
|
|
* @device: PCI Device ID.
|
|
* @subsys_vendor: PCI Subsystem Vendor ID.
|
|
* @subsys_device: PCI Subsystem Device ID.
|
|
* @board_rev: PCI Board revision, e.g. 3 - for Xena 3.
|
|
* @vendor_name: Neterion, Inc.
|
|
* @chip_name: Xframe.
|
|
* @media: Fiber, copper.
|
|
* @hal_major: HAL major version number.
|
|
* @hal_minor: HAL minor version number.
|
|
* @hal_fix: HAL fix number.
|
|
* @hal_build: HAL build number.
|
|
* @ll_major: Link-layer ULD major version number.
|
|
* @ll_minor: Link-layer ULD minor version number.
|
|
* @ll_fix: Link-layer ULD fix version number.
|
|
* @ll_build: Link-layer ULD build number.
|
|
* @transponder_temperature: TODO
|
|
*/
|
|
typedef struct xge_hal_mgmt_about_info_t {
|
|
u16 vendor;
|
|
u16 device;
|
|
u16 subsys_vendor;
|
|
u16 subsys_device;
|
|
u8 board_rev;
|
|
char vendor_name[16];
|
|
char chip_name[16];
|
|
char media[16];
|
|
char hal_major[4];
|
|
char hal_minor[4];
|
|
char hal_fix[4];
|
|
char hal_build[16];
|
|
char ll_major[4];
|
|
char ll_minor[4];
|
|
char ll_fix[4];
|
|
char ll_build[16];
|
|
u32 transponder_temperature;
|
|
} xge_hal_mgmt_about_info_t;
|
|
|
|
typedef xge_hal_stats_hw_info_t xge_hal_mgmt_hw_stats_t;
|
|
typedef xge_hal_stats_pcim_info_t xge_hal_mgmt_pcim_stats_t;
|
|
typedef xge_hal_stats_sw_err_t xge_hal_mgmt_sw_stats_t;
|
|
typedef xge_hal_stats_device_info_t xge_hal_mgmt_device_stats_t;
|
|
typedef xge_hal_stats_channel_info_t xge_hal_mgmt_channel_stats_t;
|
|
typedef xge_hal_device_config_t xge_hal_mgmt_device_config_t;
|
|
typedef xge_hal_driver_config_t xge_hal_mgmt_driver_config_t;
|
|
typedef xge_hal_pci_config_t xge_hal_mgmt_pci_config_t;
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_about(xge_hal_device_h devh, xge_hal_mgmt_about_info_t *about_info,
|
|
int size);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_hw_stats(xge_hal_device_h devh, xge_hal_mgmt_hw_stats_t *hw_stats,
|
|
int size);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_hw_stats_off(xge_hal_device_h devh, int off, int size, char *out);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_pcim_stats(xge_hal_device_h devh,
|
|
xge_hal_mgmt_pcim_stats_t *pcim_stats, int size);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_pcim_stats_off(xge_hal_device_h devh, int off, int size,
|
|
char *out);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_sw_stats(xge_hal_device_h devh, xge_hal_mgmt_sw_stats_t *hw_stats,
|
|
int size);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_device_stats(xge_hal_device_h devh,
|
|
xge_hal_mgmt_device_stats_t *device_stats, int size);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_channel_stats(xge_hal_channel_h channelh,
|
|
xge_hal_mgmt_channel_stats_t *channel_stats, int size);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_reg_read(xge_hal_device_h devh, int bar_id, unsigned int offset,
|
|
u64 *value);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_reg_write(xge_hal_device_h devh, int bar_id, unsigned int offset,
|
|
u64 value);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_pcireg_read(xge_hal_device_h devh, unsigned int offset,
|
|
int bits, u32 *value);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_device_config(xge_hal_device_h devh,
|
|
xge_hal_mgmt_device_config_t *dev_config, int size);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_driver_config(xge_hal_mgmt_driver_config_t *drv_config,
|
|
int size);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_pci_config(xge_hal_device_h devh,
|
|
xge_hal_mgmt_pci_config_t *pci_config, int size);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_pma_loopback( xge_hal_device_h devh, int enable );
|
|
|
|
xge_hal_status_e
|
|
xge_hal_rldram_test(xge_hal_device_h devh, u64 * data);
|
|
|
|
u16
|
|
xge_hal_mdio_read( xge_hal_device_h devh, u32 mmd_type, u64 addr );
|
|
|
|
xge_hal_status_e
|
|
xge_hal_mdio_write( xge_hal_device_h devh, u32 mmd_type, u64 addr, u32 value );
|
|
|
|
u32
|
|
xge_hal_read_xfp_current_temp(xge_hal_device_h devh);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_read_eeprom(xge_hal_device_h devh, int off, u32* data);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_write_eeprom(xge_hal_device_h devh, int off, u32 data, int cnt);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_register_test(xge_hal_device_h devh, u64 *data);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_eeprom_test(xge_hal_device_h devh, u64 *data);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_bist_test(xge_hal_device_h devh, u64 *data);
|
|
|
|
xge_hal_status_e
|
|
xge_hal_link_test(xge_hal_device_h devh, u64 *data);
|
|
|
|
int
|
|
xge_hal_setpause_data(xge_hal_device_h devh, int tx, int rx);
|
|
|
|
void
|
|
xge_hal_getpause_data(xge_hal_device_h devh, int *tx, int *rx);
|
|
|
|
void
|
|
__hal_updt_stats_xpak(xge_hal_device_t *hldev);
|
|
|
|
void
|
|
__hal_chk_xpak_counter(xge_hal_device_t *hldev, int type, u32 value);
|
|
|
|
#ifdef XGE_TRACE_INTO_CIRCULAR_ARR
|
|
xge_hal_status_e
|
|
xge_hal_mgmt_trace_read(char *buffer, unsigned buf_size, unsigned *offset,
|
|
unsigned *read_length);
|
|
#endif
|
|
|
|
void
|
|
xge_hal_restore_link_led(xge_hal_device_h devh);
|
|
|
|
|
|
void
|
|
xge_hal_flick_link_led(xge_hal_device_h devh);
|
|
|
|
/*
|
|
* Some set of Xena3 Cards were known to have some link LED
|
|
* Problems. This macro identifies if the card is among them
|
|
* given its Sub system ID.
|
|
*/
|
|
#define CARDS_WITH_FAULTY_LINK_INDICATORS(subid) \
|
|
((((subid >= 0x600B) && (subid <= 0x600D)) || \
|
|
((subid >= 0x640B) && (subid <= 0x640D))) ? 1 : 0)
|
|
#define CHECKBIT(value, nbit) (value & (1 << nbit))
|
|
|
|
#ifdef XGE_HAL_USE_MGMT_AUX
|
|
#include <dev/nxge/include/xgehal-mgmtaux.h>
|
|
#endif
|
|
|
|
__EXTERN_END_DECLS
|
|
|
|
#endif /* XGE_HAL_MGMT_H */
|