xref: /freebsd/sys/dev/bxe/bxe_ioctl.h (revision 685dc743dc3b5645e34836464128e1c0558b404b)
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