1171095Ssam/*- 2171095Ssam * Copyright (c) 2002-2007 Neterion, Inc. 3171095Ssam * All rights reserved. 4171095Ssam * 5171095Ssam * Redistribution and use in source and binary forms, with or without 6171095Ssam * modification, are permitted provided that the following conditions 7171095Ssam * are met: 8171095Ssam * 1. Redistributions of source code must retain the above copyright 9171095Ssam * notice, this list of conditions and the following disclaimer. 10171095Ssam * 2. Redistributions in binary form must reproduce the above copyright 11171095Ssam * notice, this list of conditions and the following disclaimer in the 12171095Ssam * documentation and/or other materials provided with the distribution. 13171095Ssam * 14171095Ssam * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15171095Ssam * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16171095Ssam * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17171095Ssam * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18171095Ssam * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19171095Ssam * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20171095Ssam * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21171095Ssam * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22171095Ssam * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23171095Ssam * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24171095Ssam * SUCH DAMAGE. 25171095Ssam * 26171095Ssam * $FreeBSD$ 27171095Ssam */ 28171095Ssam 29171095Ssam#ifndef XGE_HAL_MGMT_H 30171095Ssam#define XGE_HAL_MGMT_H 31171095Ssam 32171095Ssam#include <dev/nxge/include/xge-os-pal.h> 33171095Ssam#include <dev/nxge/include/xge-debug.h> 34171095Ssam#include <dev/nxge/include/xgehal-types.h> 35171095Ssam#include <dev/nxge/include/xgehal-config.h> 36171095Ssam#include <dev/nxge/include/xgehal-stats.h> 37171095Ssam#include <dev/nxge/include/xgehal-regs.h> 38171095Ssam#include <dev/nxge/include/xgehal-device.h> 39171095Ssam 40171095Ssam__EXTERN_BEGIN_DECLS 41171095Ssam 42171095Ssam/** 43171095Ssam * struct xge_hal_mgmt_about_info_t - About info. 44171095Ssam * @vendor: PCI Vendor ID. 45171095Ssam * @device: PCI Device ID. 46171095Ssam * @subsys_vendor: PCI Subsystem Vendor ID. 47171095Ssam * @subsys_device: PCI Subsystem Device ID. 48171095Ssam * @board_rev: PCI Board revision, e.g. 3 - for Xena 3. 49171095Ssam * @vendor_name: Neterion, Inc. 50171095Ssam * @chip_name: Xframe. 51171095Ssam * @media: Fiber, copper. 52171095Ssam * @hal_major: HAL major version number. 53171095Ssam * @hal_minor: HAL minor version number. 54171095Ssam * @hal_fix: HAL fix number. 55171095Ssam * @hal_build: HAL build number. 56171095Ssam * @ll_major: Link-layer ULD major version number. 57171095Ssam * @ll_minor: Link-layer ULD minor version number. 58171095Ssam * @ll_fix: Link-layer ULD fix version number. 59171095Ssam * @ll_build: Link-layer ULD build number. 60171095Ssam * @transponder_temperature: TODO 61171095Ssam */ 62171095Ssamtypedef struct xge_hal_mgmt_about_info_t { 63173139Srwatson u16 vendor; 64173139Srwatson u16 device; 65173139Srwatson u16 subsys_vendor; 66173139Srwatson u16 subsys_device; 67173139Srwatson u8 board_rev; 68173139Srwatson char vendor_name[16]; 69173139Srwatson char chip_name[16]; 70173139Srwatson char media[16]; 71173139Srwatson char hal_major[4]; 72173139Srwatson char hal_minor[4]; 73173139Srwatson char hal_fix[4]; 74173139Srwatson char hal_build[16]; 75173139Srwatson char ll_major[4]; 76173139Srwatson char ll_minor[4]; 77173139Srwatson char ll_fix[4]; 78173139Srwatson char ll_build[16]; 79173139Srwatson u32 transponder_temperature; 80171095Ssam} xge_hal_mgmt_about_info_t; 81171095Ssam 82173139Srwatsontypedef xge_hal_stats_hw_info_t xge_hal_mgmt_hw_stats_t; 83173139Srwatsontypedef xge_hal_stats_pcim_info_t xge_hal_mgmt_pcim_stats_t; 84173139Srwatsontypedef xge_hal_stats_sw_err_t xge_hal_mgmt_sw_stats_t; 85173139Srwatsontypedef xge_hal_stats_device_info_t xge_hal_mgmt_device_stats_t; 86173139Srwatsontypedef xge_hal_stats_channel_info_t xge_hal_mgmt_channel_stats_t; 87173139Srwatsontypedef xge_hal_device_config_t xge_hal_mgmt_device_config_t; 88173139Srwatsontypedef xge_hal_driver_config_t xge_hal_mgmt_driver_config_t; 89173139Srwatsontypedef xge_hal_pci_config_t xge_hal_mgmt_pci_config_t; 90171095Ssam 91171095Ssamxge_hal_status_e 92171095Ssamxge_hal_mgmt_about(xge_hal_device_h devh, xge_hal_mgmt_about_info_t *about_info, 93173139Srwatson int size); 94171095Ssam 95171095Ssamxge_hal_status_e 96171095Ssamxge_hal_mgmt_hw_stats(xge_hal_device_h devh, xge_hal_mgmt_hw_stats_t *hw_stats, 97173139Srwatson int size); 98171095Ssam 99171095Ssamxge_hal_status_e 100171095Ssamxge_hal_mgmt_hw_stats_off(xge_hal_device_h devh, int off, int size, char *out); 101171095Ssam 102171095Ssamxge_hal_status_e 103171095Ssamxge_hal_mgmt_pcim_stats(xge_hal_device_h devh, 104173139Srwatson xge_hal_mgmt_pcim_stats_t *pcim_stats, int size); 105171095Ssam 106171095Ssamxge_hal_status_e 107171095Ssamxge_hal_mgmt_pcim_stats_off(xge_hal_device_h devh, int off, int size, 108173139Srwatson char *out); 109171095Ssam 110171095Ssamxge_hal_status_e 111171095Ssamxge_hal_mgmt_sw_stats(xge_hal_device_h devh, xge_hal_mgmt_sw_stats_t *hw_stats, 112173139Srwatson int size); 113171095Ssam 114171095Ssamxge_hal_status_e 115171095Ssamxge_hal_mgmt_device_stats(xge_hal_device_h devh, 116173139Srwatson xge_hal_mgmt_device_stats_t *device_stats, int size); 117171095Ssam 118171095Ssamxge_hal_status_e 119171095Ssamxge_hal_mgmt_channel_stats(xge_hal_channel_h channelh, 120173139Srwatson xge_hal_mgmt_channel_stats_t *channel_stats, int size); 121171095Ssam 122171095Ssamxge_hal_status_e 123171095Ssamxge_hal_mgmt_reg_read(xge_hal_device_h devh, int bar_id, unsigned int offset, 124173139Srwatson u64 *value); 125171095Ssam 126171095Ssamxge_hal_status_e 127173139Srwatsonxge_hal_mgmt_reg_write(xge_hal_device_h devh, int bar_id, unsigned int offset, 128173139Srwatson u64 value); 129171095Ssam 130171095Ssamxge_hal_status_e 131171095Ssamxge_hal_mgmt_pcireg_read(xge_hal_device_h devh, unsigned int offset, 132173139Srwatson int bits, u32 *value); 133171095Ssam 134171095Ssamxge_hal_status_e 135171095Ssamxge_hal_mgmt_device_config(xge_hal_device_h devh, 136173139Srwatson xge_hal_mgmt_device_config_t *dev_config, int size); 137171095Ssam 138171095Ssamxge_hal_status_e 139171095Ssamxge_hal_mgmt_driver_config(xge_hal_mgmt_driver_config_t *drv_config, 140173139Srwatson int size); 141171095Ssam 142171095Ssamxge_hal_status_e 143171095Ssamxge_hal_mgmt_pci_config(xge_hal_device_h devh, 144173139Srwatson xge_hal_mgmt_pci_config_t *pci_config, int size); 145171095Ssam 146171095Ssamxge_hal_status_e 147171095Ssamxge_hal_pma_loopback( xge_hal_device_h devh, int enable ); 148171095Ssam 149171095Ssamxge_hal_status_e 150171095Ssamxge_hal_rldram_test(xge_hal_device_h devh, u64 * data); 151171095Ssam 152171095Ssamu16 153171095Ssamxge_hal_mdio_read( xge_hal_device_h devh, u32 mmd_type, u64 addr ); 154171095Ssam 155171095Ssamxge_hal_status_e 156171095Ssamxge_hal_mdio_write( xge_hal_device_h devh, u32 mmd_type, u64 addr, u32 value ); 157171095Ssam 158171095Ssamu32 159171095Ssamxge_hal_read_xfp_current_temp(xge_hal_device_h devh); 160171095Ssam 161171095Ssamxge_hal_status_e 162171095Ssamxge_hal_read_eeprom(xge_hal_device_h devh, int off, u32* data); 163171095Ssam 164171095Ssamxge_hal_status_e 165171095Ssamxge_hal_write_eeprom(xge_hal_device_h devh, int off, u32 data, int cnt); 166171095Ssam 167171095Ssamxge_hal_status_e 168171095Ssamxge_hal_register_test(xge_hal_device_h devh, u64 *data); 169171095Ssam 170171095Ssamxge_hal_status_e 171171095Ssamxge_hal_eeprom_test(xge_hal_device_h devh, u64 *data); 172171095Ssam 173171095Ssamxge_hal_status_e 174171095Ssamxge_hal_bist_test(xge_hal_device_h devh, u64 *data); 175171095Ssam 176171095Ssamxge_hal_status_e 177171095Ssamxge_hal_link_test(xge_hal_device_h devh, u64 *data); 178171095Ssam 179171095Ssamint 180171095Ssamxge_hal_setpause_data(xge_hal_device_h devh, int tx, int rx); 181171095Ssam 182171095Ssamvoid 183171095Ssamxge_hal_getpause_data(xge_hal_device_h devh, int *tx, int *rx); 184171095Ssam 185171095Ssamvoid 186171095Ssam__hal_updt_stats_xpak(xge_hal_device_t *hldev); 187171095Ssam 188171095Ssamvoid 189171095Ssam__hal_chk_xpak_counter(xge_hal_device_t *hldev, int type, u32 value); 190171095Ssam 191171095Ssam#ifdef XGE_TRACE_INTO_CIRCULAR_ARR 192171095Ssamxge_hal_status_e 193171095Ssamxge_hal_mgmt_trace_read(char *buffer, unsigned buf_size, unsigned *offset, 194173139Srwatson unsigned *read_length); 195171095Ssam#endif 196171095Ssam 197171095Ssamvoid 198171095Ssamxge_hal_restore_link_led(xge_hal_device_h devh); 199171095Ssam 200171095Ssam 201171095Ssamvoid 202171095Ssamxge_hal_flick_link_led(xge_hal_device_h devh); 203171095Ssam 204171095Ssam/* 205171095Ssam * Some set of Xena3 Cards were known to have some link LED 206171095Ssam * Problems. This macro identifies if the card is among them 207171095Ssam * given its Sub system ID. 208171095Ssam */ 209171095Ssam#define CARDS_WITH_FAULTY_LINK_INDICATORS(subid) \ 210173139Srwatson ((((subid >= 0x600B) && (subid <= 0x600D)) || \ 211173139Srwatson ((subid >= 0x640B) && (subid <= 0x640D))) ? 1 : 0) 212171095Ssam#define CHECKBIT(value, nbit) (value & (1 << nbit)) 213171095Ssam 214171095Ssam#ifdef XGE_HAL_USE_MGMT_AUX 215171095Ssam#include <dev/nxge/include/xgehal-mgmtaux.h> 216171095Ssam#endif 217171095Ssam 218171095Ssam__EXTERN_END_DECLS 219171095Ssam 220171095Ssam#endif /* XGE_HAL_MGMT_H */ 221