129e60198SDavid C Somayajulu /* 229e60198SDavid C Somayajulu * Copyright (c) 2015-2016 Qlogic Corporation 329e60198SDavid C Somayajulu * All rights reserved. 429e60198SDavid C Somayajulu * 529e60198SDavid C Somayajulu * Redistribution and use in source and binary forms, with or without 629e60198SDavid C Somayajulu * modification, are permitted provided that the following conditions 729e60198SDavid C Somayajulu * are met: 829e60198SDavid C Somayajulu * 929e60198SDavid C Somayajulu * 1. Redistributions of source code must retain the above copyright 1029e60198SDavid C Somayajulu * notice, this list of conditions and the following disclaimer. 1129e60198SDavid C Somayajulu * 2. Redistributions in binary form must reproduce the above copyright 1229e60198SDavid C Somayajulu * notice, this list of conditions and the following disclaimer in the 1329e60198SDavid C Somayajulu * documentation and/or other materials provided with the distribution. 1429e60198SDavid C Somayajulu * 1529e60198SDavid C Somayajulu * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 1629e60198SDavid C Somayajulu * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 1729e60198SDavid C Somayajulu * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 1829e60198SDavid C Somayajulu * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 1929e60198SDavid C Somayajulu * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 2029e60198SDavid C Somayajulu * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 2129e60198SDavid C Somayajulu * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 2229e60198SDavid C Somayajulu * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 2329e60198SDavid C Somayajulu * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 2429e60198SDavid C Somayajulu * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 2529e60198SDavid C Somayajulu * POSSIBILITY OF SUCH DAMAGE. 2629e60198SDavid C Somayajulu */ 2729e60198SDavid C Somayajulu 2829e60198SDavid C Somayajulu #ifndef _BXE_IOCTL_H_ 2929e60198SDavid C Somayajulu #define _BXE_IOCTL_H_ 3029e60198SDavid C Somayajulu 3129e60198SDavid C Somayajulu #include <sys/cdefs.h> 3229e60198SDavid C Somayajulu #include <sys/ioccom.h> 3329e60198SDavid C Somayajulu 3429e60198SDavid C Somayajulu 3529e60198SDavid C Somayajulu struct bxe_grcdump { 3629e60198SDavid C Somayajulu uint16_t pci_func; 3729e60198SDavid C Somayajulu uint32_t grcdump_size; 3829e60198SDavid C Somayajulu void *grcdump; 3929e60198SDavid C Somayajulu uint32_t grcdump_dwords; 4029e60198SDavid C Somayajulu }; 4129e60198SDavid C Somayajulu typedef struct bxe_grcdump bxe_grcdump_t; 4229e60198SDavid C Somayajulu 43*6ba5a1d9SDavid C Somayajulu #define BXE_DRV_NAME_LENGTH 32 44*6ba5a1d9SDavid C Somayajulu #define BXE_DRV_VERSION_LENGTH 32 45*6ba5a1d9SDavid C Somayajulu #define BXE_MFW_VERSION_LENGTH 32 46*6ba5a1d9SDavid C Somayajulu #define BXE_STORMFW_VERSION_LENGTH 32 47*6ba5a1d9SDavid C Somayajulu #define BXE_BUS_INFO_LENGTH 32 48*6ba5a1d9SDavid C Somayajulu 49*6ba5a1d9SDavid C Somayajulu struct bxe_drvinfo { 50*6ba5a1d9SDavid C Somayajulu char drv_name[BXE_DRV_NAME_LENGTH]; 51*6ba5a1d9SDavid C Somayajulu char drv_version[BXE_DRV_VERSION_LENGTH]; 52*6ba5a1d9SDavid C Somayajulu char mfw_version[BXE_MFW_VERSION_LENGTH]; 53*6ba5a1d9SDavid C Somayajulu char stormfw_version[BXE_STORMFW_VERSION_LENGTH]; 54*6ba5a1d9SDavid C Somayajulu uint32_t eeprom_dump_len; /* in bytes */ 55*6ba5a1d9SDavid C Somayajulu uint32_t reg_dump_len; /* in bytes */ 56*6ba5a1d9SDavid C Somayajulu char bus_info[BXE_BUS_INFO_LENGTH]; 57*6ba5a1d9SDavid C Somayajulu }; 58*6ba5a1d9SDavid C Somayajulu typedef struct bxe_drvinfo bxe_drvinfo_t; 59*6ba5a1d9SDavid C Somayajulu 60*6ba5a1d9SDavid C Somayajulu struct bxe_dev_setting { 61*6ba5a1d9SDavid C Somayajulu 62*6ba5a1d9SDavid C Somayajulu uint32_t supported; /* Features this interface supports */ 63*6ba5a1d9SDavid C Somayajulu uint32_t advertising;/* Features this interface advertises */ 64*6ba5a1d9SDavid C Somayajulu uint32_t speed; /* The forced speed, 10Mb, 100Mb, gigabit */ 65*6ba5a1d9SDavid C Somayajulu uint32_t duplex; /* Duplex, half or full */ 66*6ba5a1d9SDavid C Somayajulu uint32_t port; /* Which connector port */ 67*6ba5a1d9SDavid C Somayajulu uint32_t phy_address;/* port number*/ 68*6ba5a1d9SDavid C Somayajulu uint32_t autoneg; /* Enable or disable autonegotiation */ 69*6ba5a1d9SDavid C Somayajulu }; 70*6ba5a1d9SDavid C Somayajulu typedef struct bxe_dev_setting bxe_dev_setting_t; 71*6ba5a1d9SDavid C Somayajulu 72*6ba5a1d9SDavid C Somayajulu struct bxe_get_regs { 73*6ba5a1d9SDavid C Somayajulu void *reg_buf; 74*6ba5a1d9SDavid C Somayajulu uint32_t reg_buf_len; 75*6ba5a1d9SDavid C Somayajulu }; 76*6ba5a1d9SDavid C Somayajulu typedef struct bxe_get_regs bxe_get_regs_t; 77*6ba5a1d9SDavid C Somayajulu 78*6ba5a1d9SDavid C Somayajulu #define BXE_EEPROM_MAX_DATA_LEN 524288 79*6ba5a1d9SDavid C Somayajulu 80*6ba5a1d9SDavid C Somayajulu struct bxe_eeprom { 81*6ba5a1d9SDavid C Somayajulu uint32_t eeprom_cmd; 82*6ba5a1d9SDavid C Somayajulu #define BXE_EEPROM_CMD_SET_EEPROM 0x01 83*6ba5a1d9SDavid C Somayajulu #define BXE_EEPROM_CMD_GET_EEPROM 0x02 84*6ba5a1d9SDavid C Somayajulu 85*6ba5a1d9SDavid C Somayajulu void *eeprom_data; 86*6ba5a1d9SDavid C Somayajulu uint32_t eeprom_offset; 87*6ba5a1d9SDavid C Somayajulu uint32_t eeprom_data_len; 88*6ba5a1d9SDavid C Somayajulu uint32_t eeprom_magic; 89*6ba5a1d9SDavid C Somayajulu }; 90*6ba5a1d9SDavid C Somayajulu typedef struct bxe_eeprom bxe_eeprom_t; 91*6ba5a1d9SDavid C Somayajulu 92*6ba5a1d9SDavid C Somayajulu struct bxe_reg_rdw { 93*6ba5a1d9SDavid C Somayajulu uint32_t reg_cmd; 94*6ba5a1d9SDavid C Somayajulu #define BXE_READ_REG_CMD 0x01 95*6ba5a1d9SDavid C Somayajulu #define BXE_WRITE_REG_CMD 0x02 96*6ba5a1d9SDavid C Somayajulu 97*6ba5a1d9SDavid C Somayajulu uint32_t reg_id; 98*6ba5a1d9SDavid C Somayajulu uint32_t reg_val; 99*6ba5a1d9SDavid C Somayajulu uint32_t reg_access_type; 100*6ba5a1d9SDavid C Somayajulu #define BXE_REG_ACCESS_DIRECT 0x01 101*6ba5a1d9SDavid C Somayajulu #define BXE_REG_ACCESS_INDIRECT 0x02 102*6ba5a1d9SDavid C Somayajulu }; 103*6ba5a1d9SDavid C Somayajulu 104*6ba5a1d9SDavid C Somayajulu typedef struct bxe_reg_rdw bxe_reg_rdw_t; 105*6ba5a1d9SDavid C Somayajulu 106*6ba5a1d9SDavid C Somayajulu struct bxe_pcicfg_rdw { 107*6ba5a1d9SDavid C Somayajulu uint32_t cfg_cmd; 108*6ba5a1d9SDavid C Somayajulu #define BXE_READ_PCICFG 0x01 109*6ba5a1d9SDavid C Somayajulu #define BXE_WRITE_PCICFG 0x01 110*6ba5a1d9SDavid C Somayajulu uint32_t cfg_id; 111*6ba5a1d9SDavid C Somayajulu uint32_t cfg_val; 112*6ba5a1d9SDavid C Somayajulu uint32_t cfg_width; 113*6ba5a1d9SDavid C Somayajulu }; 114*6ba5a1d9SDavid C Somayajulu 115*6ba5a1d9SDavid C Somayajulu typedef struct bxe_pcicfg_rdw bxe_pcicfg_rdw_t; 116*6ba5a1d9SDavid C Somayajulu 117*6ba5a1d9SDavid C Somayajulu struct bxe_perm_mac_addr { 118*6ba5a1d9SDavid C Somayajulu char mac_addr_str[32]; 119*6ba5a1d9SDavid C Somayajulu }; 120*6ba5a1d9SDavid C Somayajulu 121*6ba5a1d9SDavid C Somayajulu typedef struct bxe_perm_mac_addr bxe_perm_mac_addr_t; 122*6ba5a1d9SDavid C Somayajulu 12329e60198SDavid C Somayajulu 12429e60198SDavid C Somayajulu /* 12529e60198SDavid C Somayajulu * Read grcdump size 12629e60198SDavid C Somayajulu */ 12729e60198SDavid C Somayajulu #define BXE_GRC_DUMP_SIZE _IOWR('e', 1, bxe_grcdump_t) 12829e60198SDavid C Somayajulu 12929e60198SDavid C Somayajulu /* 13029e60198SDavid C Somayajulu * Read grcdump 13129e60198SDavid C Somayajulu */ 13229e60198SDavid C Somayajulu #define BXE_GRC_DUMP _IOWR('e', 2, bxe_grcdump_t) 13329e60198SDavid C Somayajulu 134*6ba5a1d9SDavid C Somayajulu /* 135*6ba5a1d9SDavid C Somayajulu * Read driver info 136*6ba5a1d9SDavid C Somayajulu */ 137*6ba5a1d9SDavid C Somayajulu #define BXE_DRV_INFO _IOR('e', 3, bxe_drvinfo_t) 138*6ba5a1d9SDavid C Somayajulu 139*6ba5a1d9SDavid C Somayajulu /* 140*6ba5a1d9SDavid C Somayajulu * Read Device Setting 141*6ba5a1d9SDavid C Somayajulu */ 142*6ba5a1d9SDavid C Somayajulu #define BXE_DEV_SETTING _IOR('e', 4, bxe_dev_setting_t) 143*6ba5a1d9SDavid C Somayajulu 144*6ba5a1d9SDavid C Somayajulu /* 145*6ba5a1d9SDavid C Somayajulu * Get Registers 146*6ba5a1d9SDavid C Somayajulu */ 147*6ba5a1d9SDavid C Somayajulu #define BXE_GET_REGS _IOR('e', 5, bxe_get_regs_t) 148*6ba5a1d9SDavid C Somayajulu 149*6ba5a1d9SDavid C Somayajulu /* 150*6ba5a1d9SDavid C Somayajulu * Get/Set EEPROM 151*6ba5a1d9SDavid C Somayajulu */ 152*6ba5a1d9SDavid C Somayajulu #define BXE_EEPROM _IOWR('e', 6, bxe_eeprom_t) 153*6ba5a1d9SDavid C Somayajulu 154*6ba5a1d9SDavid C Somayajulu /* 155*6ba5a1d9SDavid C Somayajulu * read/write a register 156*6ba5a1d9SDavid C Somayajulu */ 157*6ba5a1d9SDavid C Somayajulu #define BXE_RDW_REG _IOWR('e', 7, bxe_reg_rdw_t) 158*6ba5a1d9SDavid C Somayajulu 159*6ba5a1d9SDavid C Somayajulu /* 160*6ba5a1d9SDavid C Somayajulu * read/write PCIcfg 161*6ba5a1d9SDavid C Somayajulu */ 162*6ba5a1d9SDavid C Somayajulu #define BXE_RDW_PCICFG _IOWR('e', 8, bxe_reg_rdw_t) 163*6ba5a1d9SDavid C Somayajulu 164*6ba5a1d9SDavid C Somayajulu /* 165*6ba5a1d9SDavid C Somayajulu * get permanent mac address 166*6ba5a1d9SDavid C Somayajulu */ 167*6ba5a1d9SDavid C Somayajulu 168*6ba5a1d9SDavid C Somayajulu #define BXE_MAC_ADDR _IOWR('e', 9, bxe_perm_mac_addr_t) 169*6ba5a1d9SDavid C Somayajulu 17029e60198SDavid C Somayajulu 17129e60198SDavid C Somayajulu #endif /* #ifndef _QLNX_IOCTL_H_ */ 172