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