/*1* Copyright (c) 2015-2016 Qlogic Corporation2* All rights reserved.3*4* Redistribution and use in source and binary forms, with or without5* modification, are permitted provided that the following conditions6* are met:7*8* 1. Redistributions of source code must retain the above copyright9* notice, this list of conditions and the following disclaimer.10* 2. Redistributions in binary form must reproduce the above copyright11* notice, this list of conditions and the following disclaimer in the12* documentation and/or other materials provided with the distribution.13*14* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"15* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE16* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE17* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE18* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR19* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF20* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS21* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN22* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)23* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE24* POSSIBILITY OF SUCH DAMAGE.25*/2627#ifndef _BXE_IOCTL_H_28#define _BXE_IOCTL_H_2930#include <sys/cdefs.h>31#include <sys/ioccom.h>323334struct bxe_grcdump {35uint16_t pci_func;36uint32_t grcdump_size;37void *grcdump;38uint32_t grcdump_dwords;39};40typedef struct bxe_grcdump bxe_grcdump_t;4142#define BXE_DRV_NAME_LENGTH 3243#define BXE_DRV_VERSION_LENGTH 3244#define BXE_MFW_VERSION_LENGTH 3245#define BXE_STORMFW_VERSION_LENGTH 3246#define BXE_BUS_INFO_LENGTH 324748struct bxe_drvinfo {49char drv_name[BXE_DRV_NAME_LENGTH];50char drv_version[BXE_DRV_VERSION_LENGTH];51char mfw_version[BXE_MFW_VERSION_LENGTH];52char stormfw_version[BXE_STORMFW_VERSION_LENGTH];53uint32_t eeprom_dump_len; /* in bytes */54uint32_t reg_dump_len; /* in bytes */55char bus_info[BXE_BUS_INFO_LENGTH];56};57typedef struct bxe_drvinfo bxe_drvinfo_t;5859struct bxe_dev_setting {6061uint32_t supported; /* Features this interface supports */62uint32_t advertising;/* Features this interface advertises */63uint32_t speed; /* The forced speed, 10Mb, 100Mb, gigabit */64uint32_t duplex; /* Duplex, half or full */65uint32_t port; /* Which connector port */66uint32_t phy_address;/* port number*/67uint32_t autoneg; /* Enable or disable autonegotiation */68};69typedef struct bxe_dev_setting bxe_dev_setting_t;7071struct bxe_get_regs {72void *reg_buf;73uint32_t reg_buf_len;74};75typedef struct bxe_get_regs bxe_get_regs_t;7677#define BXE_EEPROM_MAX_DATA_LEN 5242887879struct bxe_eeprom {80uint32_t eeprom_cmd;81#define BXE_EEPROM_CMD_SET_EEPROM 0x0182#define BXE_EEPROM_CMD_GET_EEPROM 0x028384void *eeprom_data;85uint32_t eeprom_offset;86uint32_t eeprom_data_len;87uint32_t eeprom_magic;88};89typedef struct bxe_eeprom bxe_eeprom_t;9091struct bxe_reg_rdw {92uint32_t reg_cmd;93#define BXE_READ_REG_CMD 0x0194#define BXE_WRITE_REG_CMD 0x029596uint32_t reg_id;97uint32_t reg_val;98uint32_t reg_access_type;99#define BXE_REG_ACCESS_DIRECT 0x01100#define BXE_REG_ACCESS_INDIRECT 0x02101};102103typedef struct bxe_reg_rdw bxe_reg_rdw_t;104105struct bxe_pcicfg_rdw {106uint32_t cfg_cmd;107#define BXE_READ_PCICFG 0x01108#define BXE_WRITE_PCICFG 0x01109uint32_t cfg_id;110uint32_t cfg_val;111uint32_t cfg_width;112};113114typedef struct bxe_pcicfg_rdw bxe_pcicfg_rdw_t;115116struct bxe_perm_mac_addr {117char mac_addr_str[32];118};119120typedef struct bxe_perm_mac_addr bxe_perm_mac_addr_t;121122123/*124* Read grcdump size125*/126#define BXE_GRC_DUMP_SIZE _IOWR('e', 1, bxe_grcdump_t)127128/*129* Read grcdump130*/131#define BXE_GRC_DUMP _IOWR('e', 2, bxe_grcdump_t)132133/*134* Read driver info135*/136#define BXE_DRV_INFO _IOR('e', 3, bxe_drvinfo_t)137138/*139* Read Device Setting140*/141#define BXE_DEV_SETTING _IOR('e', 4, bxe_dev_setting_t)142143/*144* Get Registers145*/146#define BXE_GET_REGS _IOR('e', 5, bxe_get_regs_t)147148/*149* Get/Set EEPROM150*/151#define BXE_EEPROM _IOWR('e', 6, bxe_eeprom_t)152153/*154* read/write a register155*/156#define BXE_RDW_REG _IOWR('e', 7, bxe_reg_rdw_t)157158/*159* read/write PCIcfg160*/161#define BXE_RDW_PCICFG _IOWR('e', 8, bxe_reg_rdw_t)162163/*164* get permanent mac address165*/166167#define BXE_MAC_ADDR _IOWR('e', 9, bxe_perm_mac_addr_t)168169170#endif /* #ifndef _QLNX_IOCTL_H_ */171172173