Commit 2a1ef4b5a72614c72fce0e21f44e996ee8f0ef23

Authored by Rajesh Borundia
Committed by David S. Miller
1 parent db404b1361

qlcnic: Fix programming number of arguments in a command.

o Initially we were programming maximum number of arguments.
  Instead we should program number of arguments required in
  a command.
o Maximum number of arguments for 82xx adapter is four. Fix it
  for GET_ESWITCH_STATS command.

Signed-off-by: Rajesh Borundia <rajesh.borundia@qlogic.com>
Signed-off-by: David S. Miller <davem@davemloft.net>

Showing 1 changed file with 2 additions and 2 deletions Inline Diff

drivers/net/ethernet/qlogic/qlcnic/qlcnic_ctx.c
1 /* 1 /*
2 * QLogic qlcnic NIC Driver 2 * QLogic qlcnic NIC Driver
3 * Copyright (c) 2009-2013 QLogic Corporation 3 * Copyright (c) 2009-2013 QLogic Corporation
4 * 4 *
5 * See LICENSE.qlcnic for copyright and licensing details. 5 * See LICENSE.qlcnic for copyright and licensing details.
6 */ 6 */
7 7
8 #include "qlcnic.h" 8 #include "qlcnic.h"
9 9
10 static const struct qlcnic_mailbox_metadata qlcnic_mbx_tbl[] = { 10 static const struct qlcnic_mailbox_metadata qlcnic_mbx_tbl[] = {
11 {QLCNIC_CMD_CREATE_RX_CTX, 4, 1}, 11 {QLCNIC_CMD_CREATE_RX_CTX, 4, 1},
12 {QLCNIC_CMD_DESTROY_RX_CTX, 2, 1}, 12 {QLCNIC_CMD_DESTROY_RX_CTX, 2, 1},
13 {QLCNIC_CMD_CREATE_TX_CTX, 4, 1}, 13 {QLCNIC_CMD_CREATE_TX_CTX, 4, 1},
14 {QLCNIC_CMD_DESTROY_TX_CTX, 2, 1}, 14 {QLCNIC_CMD_DESTROY_TX_CTX, 2, 1},
15 {QLCNIC_CMD_INTRPT_TEST, 4, 1}, 15 {QLCNIC_CMD_INTRPT_TEST, 4, 1},
16 {QLCNIC_CMD_SET_MTU, 4, 1}, 16 {QLCNIC_CMD_SET_MTU, 4, 1},
17 {QLCNIC_CMD_READ_PHY, 4, 2}, 17 {QLCNIC_CMD_READ_PHY, 4, 2},
18 {QLCNIC_CMD_WRITE_PHY, 5, 1}, 18 {QLCNIC_CMD_WRITE_PHY, 5, 1},
19 {QLCNIC_CMD_READ_HW_REG, 4, 1}, 19 {QLCNIC_CMD_READ_HW_REG, 4, 1},
20 {QLCNIC_CMD_GET_FLOW_CTL, 4, 2}, 20 {QLCNIC_CMD_GET_FLOW_CTL, 4, 2},
21 {QLCNIC_CMD_SET_FLOW_CTL, 4, 1}, 21 {QLCNIC_CMD_SET_FLOW_CTL, 4, 1},
22 {QLCNIC_CMD_READ_MAX_MTU, 4, 2}, 22 {QLCNIC_CMD_READ_MAX_MTU, 4, 2},
23 {QLCNIC_CMD_READ_MAX_LRO, 4, 2}, 23 {QLCNIC_CMD_READ_MAX_LRO, 4, 2},
24 {QLCNIC_CMD_MAC_ADDRESS, 4, 3}, 24 {QLCNIC_CMD_MAC_ADDRESS, 4, 3},
25 {QLCNIC_CMD_GET_PCI_INFO, 4, 1}, 25 {QLCNIC_CMD_GET_PCI_INFO, 4, 1},
26 {QLCNIC_CMD_GET_NIC_INFO, 4, 1}, 26 {QLCNIC_CMD_GET_NIC_INFO, 4, 1},
27 {QLCNIC_CMD_SET_NIC_INFO, 4, 1}, 27 {QLCNIC_CMD_SET_NIC_INFO, 4, 1},
28 {QLCNIC_CMD_GET_ESWITCH_CAPABILITY, 4, 3}, 28 {QLCNIC_CMD_GET_ESWITCH_CAPABILITY, 4, 3},
29 {QLCNIC_CMD_TOGGLE_ESWITCH, 4, 1}, 29 {QLCNIC_CMD_TOGGLE_ESWITCH, 4, 1},
30 {QLCNIC_CMD_GET_ESWITCH_STATUS, 4, 3}, 30 {QLCNIC_CMD_GET_ESWITCH_STATUS, 4, 3},
31 {QLCNIC_CMD_SET_PORTMIRRORING, 4, 1}, 31 {QLCNIC_CMD_SET_PORTMIRRORING, 4, 1},
32 {QLCNIC_CMD_CONFIGURE_ESWITCH, 4, 1}, 32 {QLCNIC_CMD_CONFIGURE_ESWITCH, 4, 1},
33 {QLCNIC_CMD_GET_MAC_STATS, 4, 1}, 33 {QLCNIC_CMD_GET_MAC_STATS, 4, 1},
34 {QLCNIC_CMD_GET_ESWITCH_PORT_CONFIG, 4, 3}, 34 {QLCNIC_CMD_GET_ESWITCH_PORT_CONFIG, 4, 3},
35 {QLCNIC_CMD_GET_ESWITCH_STATS, 5, 1}, 35 {QLCNIC_CMD_GET_ESWITCH_STATS, 4, 1},
36 {QLCNIC_CMD_CONFIG_PORT, 4, 1}, 36 {QLCNIC_CMD_CONFIG_PORT, 4, 1},
37 {QLCNIC_CMD_TEMP_SIZE, 4, 4}, 37 {QLCNIC_CMD_TEMP_SIZE, 4, 4},
38 {QLCNIC_CMD_GET_TEMP_HDR, 4, 1}, 38 {QLCNIC_CMD_GET_TEMP_HDR, 4, 1},
39 {QLCNIC_CMD_82XX_SET_DRV_VER, 4, 1}, 39 {QLCNIC_CMD_82XX_SET_DRV_VER, 4, 1},
40 {QLCNIC_CMD_GET_LED_STATUS, 4, 2}, 40 {QLCNIC_CMD_GET_LED_STATUS, 4, 2},
41 {QLCNIC_CMD_MQ_TX_CONFIG_INTR, 2, 3}, 41 {QLCNIC_CMD_MQ_TX_CONFIG_INTR, 2, 3},
42 {QLCNIC_CMD_DCB_QUERY_CAP, 1, 2}, 42 {QLCNIC_CMD_DCB_QUERY_CAP, 1, 2},
43 {QLCNIC_CMD_DCB_QUERY_PARAM, 4, 1}, 43 {QLCNIC_CMD_DCB_QUERY_PARAM, 4, 1},
44 }; 44 };
45 45
46 static inline u32 qlcnic_get_cmd_signature(struct qlcnic_hardware_context *ahw) 46 static inline u32 qlcnic_get_cmd_signature(struct qlcnic_hardware_context *ahw)
47 { 47 {
48 return (ahw->pci_func & 0xff) | ((ahw->fw_hal_version & 0xff) << 8) | 48 return (ahw->pci_func & 0xff) | ((ahw->fw_hal_version & 0xff) << 8) |
49 (0xcafe << 16); 49 (0xcafe << 16);
50 } 50 }
51 51
52 /* Allocate mailbox registers */ 52 /* Allocate mailbox registers */
53 int qlcnic_82xx_alloc_mbx_args(struct qlcnic_cmd_args *mbx, 53 int qlcnic_82xx_alloc_mbx_args(struct qlcnic_cmd_args *mbx,
54 struct qlcnic_adapter *adapter, u32 type) 54 struct qlcnic_adapter *adapter, u32 type)
55 { 55 {
56 int i, size; 56 int i, size;
57 const struct qlcnic_mailbox_metadata *mbx_tbl; 57 const struct qlcnic_mailbox_metadata *mbx_tbl;
58 58
59 mbx_tbl = qlcnic_mbx_tbl; 59 mbx_tbl = qlcnic_mbx_tbl;
60 size = ARRAY_SIZE(qlcnic_mbx_tbl); 60 size = ARRAY_SIZE(qlcnic_mbx_tbl);
61 for (i = 0; i < size; i++) { 61 for (i = 0; i < size; i++) {
62 if (type == mbx_tbl[i].cmd) { 62 if (type == mbx_tbl[i].cmd) {
63 mbx->req.num = mbx_tbl[i].in_args; 63 mbx->req.num = mbx_tbl[i].in_args;
64 mbx->rsp.num = mbx_tbl[i].out_args; 64 mbx->rsp.num = mbx_tbl[i].out_args;
65 mbx->req.arg = kcalloc(mbx->req.num, 65 mbx->req.arg = kcalloc(mbx->req.num,
66 sizeof(u32), GFP_ATOMIC); 66 sizeof(u32), GFP_ATOMIC);
67 if (!mbx->req.arg) 67 if (!mbx->req.arg)
68 return -ENOMEM; 68 return -ENOMEM;
69 mbx->rsp.arg = kcalloc(mbx->rsp.num, 69 mbx->rsp.arg = kcalloc(mbx->rsp.num,
70 sizeof(u32), GFP_ATOMIC); 70 sizeof(u32), GFP_ATOMIC);
71 if (!mbx->rsp.arg) { 71 if (!mbx->rsp.arg) {
72 kfree(mbx->req.arg); 72 kfree(mbx->req.arg);
73 mbx->req.arg = NULL; 73 mbx->req.arg = NULL;
74 return -ENOMEM; 74 return -ENOMEM;
75 } 75 }
76 memset(mbx->req.arg, 0, sizeof(u32) * mbx->req.num); 76 memset(mbx->req.arg, 0, sizeof(u32) * mbx->req.num);
77 memset(mbx->rsp.arg, 0, sizeof(u32) * mbx->rsp.num); 77 memset(mbx->rsp.arg, 0, sizeof(u32) * mbx->rsp.num);
78 mbx->req.arg[0] = type; 78 mbx->req.arg[0] = type;
79 break; 79 break;
80 } 80 }
81 } 81 }
82 return 0; 82 return 0;
83 } 83 }
84 84
85 /* Free up mailbox registers */ 85 /* Free up mailbox registers */
86 void qlcnic_free_mbx_args(struct qlcnic_cmd_args *cmd) 86 void qlcnic_free_mbx_args(struct qlcnic_cmd_args *cmd)
87 { 87 {
88 kfree(cmd->req.arg); 88 kfree(cmd->req.arg);
89 cmd->req.arg = NULL; 89 cmd->req.arg = NULL;
90 kfree(cmd->rsp.arg); 90 kfree(cmd->rsp.arg);
91 cmd->rsp.arg = NULL; 91 cmd->rsp.arg = NULL;
92 } 92 }
93 93
94 static u32 94 static u32
95 qlcnic_poll_rsp(struct qlcnic_adapter *adapter) 95 qlcnic_poll_rsp(struct qlcnic_adapter *adapter)
96 { 96 {
97 u32 rsp; 97 u32 rsp;
98 int timeout = 0, err = 0; 98 int timeout = 0, err = 0;
99 99
100 do { 100 do {
101 /* give atleast 1ms for firmware to respond */ 101 /* give atleast 1ms for firmware to respond */
102 mdelay(1); 102 mdelay(1);
103 103
104 if (++timeout > QLCNIC_OS_CRB_RETRY_COUNT) 104 if (++timeout > QLCNIC_OS_CRB_RETRY_COUNT)
105 return QLCNIC_CDRP_RSP_TIMEOUT; 105 return QLCNIC_CDRP_RSP_TIMEOUT;
106 106
107 rsp = QLCRD32(adapter, QLCNIC_CDRP_CRB_OFFSET, &err); 107 rsp = QLCRD32(adapter, QLCNIC_CDRP_CRB_OFFSET, &err);
108 } while (!QLCNIC_CDRP_IS_RSP(rsp)); 108 } while (!QLCNIC_CDRP_IS_RSP(rsp));
109 109
110 return rsp; 110 return rsp;
111 } 111 }
112 112
113 int qlcnic_82xx_issue_cmd(struct qlcnic_adapter *adapter, 113 int qlcnic_82xx_issue_cmd(struct qlcnic_adapter *adapter,
114 struct qlcnic_cmd_args *cmd) 114 struct qlcnic_cmd_args *cmd)
115 { 115 {
116 int i, err = 0; 116 int i, err = 0;
117 u32 rsp; 117 u32 rsp;
118 u32 signature; 118 u32 signature;
119 struct pci_dev *pdev = adapter->pdev; 119 struct pci_dev *pdev = adapter->pdev;
120 struct qlcnic_hardware_context *ahw = adapter->ahw; 120 struct qlcnic_hardware_context *ahw = adapter->ahw;
121 const char *fmt; 121 const char *fmt;
122 122
123 signature = qlcnic_get_cmd_signature(ahw); 123 signature = qlcnic_get_cmd_signature(ahw);
124 124
125 /* Acquire semaphore before accessing CRB */ 125 /* Acquire semaphore before accessing CRB */
126 if (qlcnic_api_lock(adapter)) { 126 if (qlcnic_api_lock(adapter)) {
127 cmd->rsp.arg[0] = QLCNIC_RCODE_TIMEOUT; 127 cmd->rsp.arg[0] = QLCNIC_RCODE_TIMEOUT;
128 return cmd->rsp.arg[0]; 128 return cmd->rsp.arg[0];
129 } 129 }
130 130
131 QLCWR32(adapter, QLCNIC_SIGN_CRB_OFFSET, signature); 131 QLCWR32(adapter, QLCNIC_SIGN_CRB_OFFSET, signature);
132 for (i = 1; i < QLCNIC_CDRP_MAX_ARGS; i++) 132 for (i = 1; i < cmd->req.num; i++)
133 QLCWR32(adapter, QLCNIC_CDRP_ARG(i), cmd->req.arg[i]); 133 QLCWR32(adapter, QLCNIC_CDRP_ARG(i), cmd->req.arg[i]);
134 QLCWR32(adapter, QLCNIC_CDRP_CRB_OFFSET, 134 QLCWR32(adapter, QLCNIC_CDRP_CRB_OFFSET,
135 QLCNIC_CDRP_FORM_CMD(cmd->req.arg[0])); 135 QLCNIC_CDRP_FORM_CMD(cmd->req.arg[0]));
136 rsp = qlcnic_poll_rsp(adapter); 136 rsp = qlcnic_poll_rsp(adapter);
137 137
138 if (rsp == QLCNIC_CDRP_RSP_TIMEOUT) { 138 if (rsp == QLCNIC_CDRP_RSP_TIMEOUT) {
139 dev_err(&pdev->dev, "command timeout, response = 0x%x\n", rsp); 139 dev_err(&pdev->dev, "command timeout, response = 0x%x\n", rsp);
140 cmd->rsp.arg[0] = QLCNIC_RCODE_TIMEOUT; 140 cmd->rsp.arg[0] = QLCNIC_RCODE_TIMEOUT;
141 } else if (rsp == QLCNIC_CDRP_RSP_FAIL) { 141 } else if (rsp == QLCNIC_CDRP_RSP_FAIL) {
142 cmd->rsp.arg[0] = QLCRD32(adapter, QLCNIC_CDRP_ARG(1), &err); 142 cmd->rsp.arg[0] = QLCRD32(adapter, QLCNIC_CDRP_ARG(1), &err);
143 switch (cmd->rsp.arg[0]) { 143 switch (cmd->rsp.arg[0]) {
144 case QLCNIC_RCODE_INVALID_ARGS: 144 case QLCNIC_RCODE_INVALID_ARGS:
145 fmt = "CDRP invalid args: [%d]\n"; 145 fmt = "CDRP invalid args: [%d]\n";
146 break; 146 break;
147 case QLCNIC_RCODE_NOT_SUPPORTED: 147 case QLCNIC_RCODE_NOT_SUPPORTED:
148 case QLCNIC_RCODE_NOT_IMPL: 148 case QLCNIC_RCODE_NOT_IMPL:
149 fmt = "CDRP command not supported: [%d]\n"; 149 fmt = "CDRP command not supported: [%d]\n";
150 break; 150 break;
151 case QLCNIC_RCODE_NOT_PERMITTED: 151 case QLCNIC_RCODE_NOT_PERMITTED:
152 fmt = "CDRP requested action not permitted: [%d]\n"; 152 fmt = "CDRP requested action not permitted: [%d]\n";
153 break; 153 break;
154 case QLCNIC_RCODE_INVALID: 154 case QLCNIC_RCODE_INVALID:
155 fmt = "CDRP invalid or unknown cmd received: [%d]\n"; 155 fmt = "CDRP invalid or unknown cmd received: [%d]\n";
156 break; 156 break;
157 case QLCNIC_RCODE_TIMEOUT: 157 case QLCNIC_RCODE_TIMEOUT:
158 fmt = "CDRP command timeout: [%d]\n"; 158 fmt = "CDRP command timeout: [%d]\n";
159 break; 159 break;
160 default: 160 default:
161 fmt = "CDRP command failed: [%d]\n"; 161 fmt = "CDRP command failed: [%d]\n";
162 break; 162 break;
163 } 163 }
164 dev_err(&pdev->dev, fmt, cmd->rsp.arg[0]); 164 dev_err(&pdev->dev, fmt, cmd->rsp.arg[0]);
165 qlcnic_dump_mbx(adapter, cmd); 165 qlcnic_dump_mbx(adapter, cmd);
166 } else if (rsp == QLCNIC_CDRP_RSP_OK) 166 } else if (rsp == QLCNIC_CDRP_RSP_OK)
167 cmd->rsp.arg[0] = QLCNIC_RCODE_SUCCESS; 167 cmd->rsp.arg[0] = QLCNIC_RCODE_SUCCESS;
168 168
169 for (i = 1; i < cmd->rsp.num; i++) 169 for (i = 1; i < cmd->rsp.num; i++)
170 cmd->rsp.arg[i] = QLCRD32(adapter, QLCNIC_CDRP_ARG(i), &err); 170 cmd->rsp.arg[i] = QLCRD32(adapter, QLCNIC_CDRP_ARG(i), &err);
171 171
172 /* Release semaphore */ 172 /* Release semaphore */
173 qlcnic_api_unlock(adapter); 173 qlcnic_api_unlock(adapter);
174 return cmd->rsp.arg[0]; 174 return cmd->rsp.arg[0];
175 } 175 }
176 176
177 int qlcnic_fw_cmd_set_drv_version(struct qlcnic_adapter *adapter, u32 fw_cmd) 177 int qlcnic_fw_cmd_set_drv_version(struct qlcnic_adapter *adapter, u32 fw_cmd)
178 { 178 {
179 struct qlcnic_cmd_args cmd; 179 struct qlcnic_cmd_args cmd;
180 u32 arg1, arg2, arg3; 180 u32 arg1, arg2, arg3;
181 char drv_string[12]; 181 char drv_string[12];
182 int err = 0; 182 int err = 0;
183 183
184 memset(drv_string, 0, sizeof(drv_string)); 184 memset(drv_string, 0, sizeof(drv_string));
185 snprintf(drv_string, sizeof(drv_string), "%d"".""%d"".""%d", 185 snprintf(drv_string, sizeof(drv_string), "%d"".""%d"".""%d",
186 _QLCNIC_LINUX_MAJOR, _QLCNIC_LINUX_MINOR, 186 _QLCNIC_LINUX_MAJOR, _QLCNIC_LINUX_MINOR,
187 _QLCNIC_LINUX_SUBVERSION); 187 _QLCNIC_LINUX_SUBVERSION);
188 188
189 err = qlcnic_alloc_mbx_args(&cmd, adapter, fw_cmd); 189 err = qlcnic_alloc_mbx_args(&cmd, adapter, fw_cmd);
190 if (err) 190 if (err)
191 return err; 191 return err;
192 192
193 memcpy(&arg1, drv_string, sizeof(u32)); 193 memcpy(&arg1, drv_string, sizeof(u32));
194 memcpy(&arg2, drv_string + 4, sizeof(u32)); 194 memcpy(&arg2, drv_string + 4, sizeof(u32));
195 memcpy(&arg3, drv_string + 8, sizeof(u32)); 195 memcpy(&arg3, drv_string + 8, sizeof(u32));
196 196
197 cmd.req.arg[1] = arg1; 197 cmd.req.arg[1] = arg1;
198 cmd.req.arg[2] = arg2; 198 cmd.req.arg[2] = arg2;
199 cmd.req.arg[3] = arg3; 199 cmd.req.arg[3] = arg3;
200 200
201 err = qlcnic_issue_cmd(adapter, &cmd); 201 err = qlcnic_issue_cmd(adapter, &cmd);
202 if (err) { 202 if (err) {
203 dev_info(&adapter->pdev->dev, 203 dev_info(&adapter->pdev->dev,
204 "Failed to set driver version in firmware\n"); 204 "Failed to set driver version in firmware\n");
205 err = -EIO; 205 err = -EIO;
206 } 206 }
207 qlcnic_free_mbx_args(&cmd); 207 qlcnic_free_mbx_args(&cmd);
208 return err; 208 return err;
209 } 209 }
210 210
211 int 211 int
212 qlcnic_fw_cmd_set_mtu(struct qlcnic_adapter *adapter, int mtu) 212 qlcnic_fw_cmd_set_mtu(struct qlcnic_adapter *adapter, int mtu)
213 { 213 {
214 int err = 0; 214 int err = 0;
215 struct qlcnic_cmd_args cmd; 215 struct qlcnic_cmd_args cmd;
216 struct qlcnic_recv_context *recv_ctx = adapter->recv_ctx; 216 struct qlcnic_recv_context *recv_ctx = adapter->recv_ctx;
217 217
218 if (recv_ctx->state != QLCNIC_HOST_CTX_STATE_ACTIVE) 218 if (recv_ctx->state != QLCNIC_HOST_CTX_STATE_ACTIVE)
219 return err; 219 return err;
220 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_SET_MTU); 220 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_SET_MTU);
221 if (err) 221 if (err)
222 return err; 222 return err;
223 223
224 cmd.req.arg[1] = recv_ctx->context_id; 224 cmd.req.arg[1] = recv_ctx->context_id;
225 cmd.req.arg[2] = mtu; 225 cmd.req.arg[2] = mtu;
226 226
227 err = qlcnic_issue_cmd(adapter, &cmd); 227 err = qlcnic_issue_cmd(adapter, &cmd);
228 if (err) { 228 if (err) {
229 dev_err(&adapter->pdev->dev, "Failed to set mtu\n"); 229 dev_err(&adapter->pdev->dev, "Failed to set mtu\n");
230 err = -EIO; 230 err = -EIO;
231 } 231 }
232 qlcnic_free_mbx_args(&cmd); 232 qlcnic_free_mbx_args(&cmd);
233 return err; 233 return err;
234 } 234 }
235 235
236 int qlcnic_82xx_fw_cmd_create_rx_ctx(struct qlcnic_adapter *adapter) 236 int qlcnic_82xx_fw_cmd_create_rx_ctx(struct qlcnic_adapter *adapter)
237 { 237 {
238 struct qlcnic_recv_context *recv_ctx = adapter->recv_ctx; 238 struct qlcnic_recv_context *recv_ctx = adapter->recv_ctx;
239 struct qlcnic_hardware_context *ahw = adapter->ahw; 239 struct qlcnic_hardware_context *ahw = adapter->ahw;
240 dma_addr_t hostrq_phys_addr, cardrsp_phys_addr; 240 dma_addr_t hostrq_phys_addr, cardrsp_phys_addr;
241 struct net_device *netdev = adapter->netdev; 241 struct net_device *netdev = adapter->netdev;
242 u32 temp_intr_crb_mode, temp_rds_crb_mode; 242 u32 temp_intr_crb_mode, temp_rds_crb_mode;
243 struct qlcnic_cardrsp_rds_ring *prsp_rds; 243 struct qlcnic_cardrsp_rds_ring *prsp_rds;
244 struct qlcnic_cardrsp_sds_ring *prsp_sds; 244 struct qlcnic_cardrsp_sds_ring *prsp_sds;
245 struct qlcnic_hostrq_rds_ring *prq_rds; 245 struct qlcnic_hostrq_rds_ring *prq_rds;
246 struct qlcnic_hostrq_sds_ring *prq_sds; 246 struct qlcnic_hostrq_sds_ring *prq_sds;
247 struct qlcnic_host_rds_ring *rds_ring; 247 struct qlcnic_host_rds_ring *rds_ring;
248 struct qlcnic_host_sds_ring *sds_ring; 248 struct qlcnic_host_sds_ring *sds_ring;
249 struct qlcnic_cardrsp_rx_ctx *prsp; 249 struct qlcnic_cardrsp_rx_ctx *prsp;
250 struct qlcnic_hostrq_rx_ctx *prq; 250 struct qlcnic_hostrq_rx_ctx *prq;
251 u8 i, nrds_rings, nsds_rings; 251 u8 i, nrds_rings, nsds_rings;
252 struct qlcnic_cmd_args cmd; 252 struct qlcnic_cmd_args cmd;
253 size_t rq_size, rsp_size; 253 size_t rq_size, rsp_size;
254 u32 cap, reg, val, reg2; 254 u32 cap, reg, val, reg2;
255 u64 phys_addr; 255 u64 phys_addr;
256 u16 temp_u16; 256 u16 temp_u16;
257 void *addr; 257 void *addr;
258 int err; 258 int err;
259 259
260 nrds_rings = adapter->max_rds_rings; 260 nrds_rings = adapter->max_rds_rings;
261 nsds_rings = adapter->drv_sds_rings; 261 nsds_rings = adapter->drv_sds_rings;
262 262
263 rq_size = SIZEOF_HOSTRQ_RX(struct qlcnic_hostrq_rx_ctx, nrds_rings, 263 rq_size = SIZEOF_HOSTRQ_RX(struct qlcnic_hostrq_rx_ctx, nrds_rings,
264 nsds_rings); 264 nsds_rings);
265 rsp_size = SIZEOF_CARDRSP_RX(struct qlcnic_cardrsp_rx_ctx, nrds_rings, 265 rsp_size = SIZEOF_CARDRSP_RX(struct qlcnic_cardrsp_rx_ctx, nrds_rings,
266 nsds_rings); 266 nsds_rings);
267 267
268 addr = dma_alloc_coherent(&adapter->pdev->dev, rq_size, 268 addr = dma_alloc_coherent(&adapter->pdev->dev, rq_size,
269 &hostrq_phys_addr, GFP_KERNEL); 269 &hostrq_phys_addr, GFP_KERNEL);
270 if (addr == NULL) 270 if (addr == NULL)
271 return -ENOMEM; 271 return -ENOMEM;
272 prq = addr; 272 prq = addr;
273 273
274 addr = dma_alloc_coherent(&adapter->pdev->dev, rsp_size, 274 addr = dma_alloc_coherent(&adapter->pdev->dev, rsp_size,
275 &cardrsp_phys_addr, GFP_KERNEL); 275 &cardrsp_phys_addr, GFP_KERNEL);
276 if (addr == NULL) { 276 if (addr == NULL) {
277 err = -ENOMEM; 277 err = -ENOMEM;
278 goto out_free_rq; 278 goto out_free_rq;
279 } 279 }
280 prsp = addr; 280 prsp = addr;
281 281
282 prq->host_rsp_dma_addr = cpu_to_le64(cardrsp_phys_addr); 282 prq->host_rsp_dma_addr = cpu_to_le64(cardrsp_phys_addr);
283 283
284 cap = (QLCNIC_CAP0_LEGACY_CONTEXT | QLCNIC_CAP0_LEGACY_MN 284 cap = (QLCNIC_CAP0_LEGACY_CONTEXT | QLCNIC_CAP0_LEGACY_MN
285 | QLCNIC_CAP0_VALIDOFF); 285 | QLCNIC_CAP0_VALIDOFF);
286 cap |= (QLCNIC_CAP0_JUMBO_CONTIGUOUS | QLCNIC_CAP0_LRO_CONTIGUOUS); 286 cap |= (QLCNIC_CAP0_JUMBO_CONTIGUOUS | QLCNIC_CAP0_LRO_CONTIGUOUS);
287 287
288 if (qlcnic_check_multi_tx(adapter) && 288 if (qlcnic_check_multi_tx(adapter) &&
289 !adapter->ahw->diag_test) { 289 !adapter->ahw->diag_test) {
290 cap |= QLCNIC_CAP0_TX_MULTI; 290 cap |= QLCNIC_CAP0_TX_MULTI;
291 } else { 291 } else {
292 temp_u16 = offsetof(struct qlcnic_hostrq_rx_ctx, msix_handler); 292 temp_u16 = offsetof(struct qlcnic_hostrq_rx_ctx, msix_handler);
293 prq->valid_field_offset = cpu_to_le16(temp_u16); 293 prq->valid_field_offset = cpu_to_le16(temp_u16);
294 prq->txrx_sds_binding = nsds_rings - 1; 294 prq->txrx_sds_binding = nsds_rings - 1;
295 temp_intr_crb_mode = QLCNIC_HOST_INT_CRB_MODE_SHARED; 295 temp_intr_crb_mode = QLCNIC_HOST_INT_CRB_MODE_SHARED;
296 prq->host_int_crb_mode = cpu_to_le32(temp_intr_crb_mode); 296 prq->host_int_crb_mode = cpu_to_le32(temp_intr_crb_mode);
297 temp_rds_crb_mode = QLCNIC_HOST_RDS_CRB_MODE_UNIQUE; 297 temp_rds_crb_mode = QLCNIC_HOST_RDS_CRB_MODE_UNIQUE;
298 prq->host_rds_crb_mode = cpu_to_le32(temp_rds_crb_mode); 298 prq->host_rds_crb_mode = cpu_to_le32(temp_rds_crb_mode);
299 } 299 }
300 300
301 prq->capabilities[0] = cpu_to_le32(cap); 301 prq->capabilities[0] = cpu_to_le32(cap);
302 302
303 prq->num_rds_rings = cpu_to_le16(nrds_rings); 303 prq->num_rds_rings = cpu_to_le16(nrds_rings);
304 prq->num_sds_rings = cpu_to_le16(nsds_rings); 304 prq->num_sds_rings = cpu_to_le16(nsds_rings);
305 prq->rds_ring_offset = 0; 305 prq->rds_ring_offset = 0;
306 306
307 val = le32_to_cpu(prq->rds_ring_offset) + 307 val = le32_to_cpu(prq->rds_ring_offset) +
308 (sizeof(struct qlcnic_hostrq_rds_ring) * nrds_rings); 308 (sizeof(struct qlcnic_hostrq_rds_ring) * nrds_rings);
309 prq->sds_ring_offset = cpu_to_le32(val); 309 prq->sds_ring_offset = cpu_to_le32(val);
310 310
311 prq_rds = (struct qlcnic_hostrq_rds_ring *)(prq->data + 311 prq_rds = (struct qlcnic_hostrq_rds_ring *)(prq->data +
312 le32_to_cpu(prq->rds_ring_offset)); 312 le32_to_cpu(prq->rds_ring_offset));
313 313
314 for (i = 0; i < nrds_rings; i++) { 314 for (i = 0; i < nrds_rings; i++) {
315 rds_ring = &recv_ctx->rds_rings[i]; 315 rds_ring = &recv_ctx->rds_rings[i];
316 rds_ring->producer = 0; 316 rds_ring->producer = 0;
317 prq_rds[i].host_phys_addr = cpu_to_le64(rds_ring->phys_addr); 317 prq_rds[i].host_phys_addr = cpu_to_le64(rds_ring->phys_addr);
318 prq_rds[i].ring_size = cpu_to_le32(rds_ring->num_desc); 318 prq_rds[i].ring_size = cpu_to_le32(rds_ring->num_desc);
319 prq_rds[i].ring_kind = cpu_to_le32(i); 319 prq_rds[i].ring_kind = cpu_to_le32(i);
320 prq_rds[i].buff_size = cpu_to_le64(rds_ring->dma_size); 320 prq_rds[i].buff_size = cpu_to_le64(rds_ring->dma_size);
321 } 321 }
322 322
323 prq_sds = (struct qlcnic_hostrq_sds_ring *)(prq->data + 323 prq_sds = (struct qlcnic_hostrq_sds_ring *)(prq->data +
324 le32_to_cpu(prq->sds_ring_offset)); 324 le32_to_cpu(prq->sds_ring_offset));
325 325
326 for (i = 0; i < nsds_rings; i++) { 326 for (i = 0; i < nsds_rings; i++) {
327 sds_ring = &recv_ctx->sds_rings[i]; 327 sds_ring = &recv_ctx->sds_rings[i];
328 sds_ring->consumer = 0; 328 sds_ring->consumer = 0;
329 memset(sds_ring->desc_head, 0, STATUS_DESC_RINGSIZE(sds_ring)); 329 memset(sds_ring->desc_head, 0, STATUS_DESC_RINGSIZE(sds_ring));
330 prq_sds[i].host_phys_addr = cpu_to_le64(sds_ring->phys_addr); 330 prq_sds[i].host_phys_addr = cpu_to_le64(sds_ring->phys_addr);
331 prq_sds[i].ring_size = cpu_to_le32(sds_ring->num_desc); 331 prq_sds[i].ring_size = cpu_to_le32(sds_ring->num_desc);
332 if (qlcnic_check_multi_tx(adapter) && 332 if (qlcnic_check_multi_tx(adapter) &&
333 !adapter->ahw->diag_test) 333 !adapter->ahw->diag_test)
334 prq_sds[i].msi_index = cpu_to_le16(ahw->intr_tbl[i].id); 334 prq_sds[i].msi_index = cpu_to_le16(ahw->intr_tbl[i].id);
335 else 335 else
336 prq_sds[i].msi_index = cpu_to_le16(i); 336 prq_sds[i].msi_index = cpu_to_le16(i);
337 } 337 }
338 338
339 phys_addr = hostrq_phys_addr; 339 phys_addr = hostrq_phys_addr;
340 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_CREATE_RX_CTX); 340 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_CREATE_RX_CTX);
341 if (err) 341 if (err)
342 goto out_free_rsp; 342 goto out_free_rsp;
343 343
344 cmd.req.arg[1] = MSD(phys_addr); 344 cmd.req.arg[1] = MSD(phys_addr);
345 cmd.req.arg[2] = LSD(phys_addr); 345 cmd.req.arg[2] = LSD(phys_addr);
346 cmd.req.arg[3] = rq_size; 346 cmd.req.arg[3] = rq_size;
347 err = qlcnic_issue_cmd(adapter, &cmd); 347 err = qlcnic_issue_cmd(adapter, &cmd);
348 if (err) { 348 if (err) {
349 dev_err(&adapter->pdev->dev, 349 dev_err(&adapter->pdev->dev,
350 "Failed to create rx ctx in firmware%d\n", err); 350 "Failed to create rx ctx in firmware%d\n", err);
351 goto out_free_rsp; 351 goto out_free_rsp;
352 } 352 }
353 353
354 prsp_rds = ((struct qlcnic_cardrsp_rds_ring *) 354 prsp_rds = ((struct qlcnic_cardrsp_rds_ring *)
355 &prsp->data[le32_to_cpu(prsp->rds_ring_offset)]); 355 &prsp->data[le32_to_cpu(prsp->rds_ring_offset)]);
356 356
357 for (i = 0; i < le16_to_cpu(prsp->num_rds_rings); i++) { 357 for (i = 0; i < le16_to_cpu(prsp->num_rds_rings); i++) {
358 rds_ring = &recv_ctx->rds_rings[i]; 358 rds_ring = &recv_ctx->rds_rings[i];
359 reg = le32_to_cpu(prsp_rds[i].host_producer_crb); 359 reg = le32_to_cpu(prsp_rds[i].host_producer_crb);
360 rds_ring->crb_rcv_producer = ahw->pci_base0 + reg; 360 rds_ring->crb_rcv_producer = ahw->pci_base0 + reg;
361 } 361 }
362 362
363 prsp_sds = ((struct qlcnic_cardrsp_sds_ring *) 363 prsp_sds = ((struct qlcnic_cardrsp_sds_ring *)
364 &prsp->data[le32_to_cpu(prsp->sds_ring_offset)]); 364 &prsp->data[le32_to_cpu(prsp->sds_ring_offset)]);
365 365
366 for (i = 0; i < le16_to_cpu(prsp->num_sds_rings); i++) { 366 for (i = 0; i < le16_to_cpu(prsp->num_sds_rings); i++) {
367 sds_ring = &recv_ctx->sds_rings[i]; 367 sds_ring = &recv_ctx->sds_rings[i];
368 reg = le32_to_cpu(prsp_sds[i].host_consumer_crb); 368 reg = le32_to_cpu(prsp_sds[i].host_consumer_crb);
369 if (qlcnic_check_multi_tx(adapter) && !adapter->ahw->diag_test) 369 if (qlcnic_check_multi_tx(adapter) && !adapter->ahw->diag_test)
370 reg2 = ahw->intr_tbl[i].src; 370 reg2 = ahw->intr_tbl[i].src;
371 else 371 else
372 reg2 = le32_to_cpu(prsp_sds[i].interrupt_crb); 372 reg2 = le32_to_cpu(prsp_sds[i].interrupt_crb);
373 373
374 sds_ring->crb_intr_mask = ahw->pci_base0 + reg2; 374 sds_ring->crb_intr_mask = ahw->pci_base0 + reg2;
375 sds_ring->crb_sts_consumer = ahw->pci_base0 + reg; 375 sds_ring->crb_sts_consumer = ahw->pci_base0 + reg;
376 } 376 }
377 377
378 recv_ctx->state = le32_to_cpu(prsp->host_ctx_state); 378 recv_ctx->state = le32_to_cpu(prsp->host_ctx_state);
379 recv_ctx->context_id = le16_to_cpu(prsp->context_id); 379 recv_ctx->context_id = le16_to_cpu(prsp->context_id);
380 recv_ctx->virt_port = prsp->virt_port; 380 recv_ctx->virt_port = prsp->virt_port;
381 381
382 netdev_info(netdev, "Rx Context[%d] Created, state 0x%x\n", 382 netdev_info(netdev, "Rx Context[%d] Created, state 0x%x\n",
383 recv_ctx->context_id, recv_ctx->state); 383 recv_ctx->context_id, recv_ctx->state);
384 qlcnic_free_mbx_args(&cmd); 384 qlcnic_free_mbx_args(&cmd);
385 385
386 out_free_rsp: 386 out_free_rsp:
387 dma_free_coherent(&adapter->pdev->dev, rsp_size, prsp, 387 dma_free_coherent(&adapter->pdev->dev, rsp_size, prsp,
388 cardrsp_phys_addr); 388 cardrsp_phys_addr);
389 out_free_rq: 389 out_free_rq:
390 dma_free_coherent(&adapter->pdev->dev, rq_size, prq, hostrq_phys_addr); 390 dma_free_coherent(&adapter->pdev->dev, rq_size, prq, hostrq_phys_addr);
391 391
392 return err; 392 return err;
393 } 393 }
394 394
395 void qlcnic_82xx_fw_cmd_del_rx_ctx(struct qlcnic_adapter *adapter) 395 void qlcnic_82xx_fw_cmd_del_rx_ctx(struct qlcnic_adapter *adapter)
396 { 396 {
397 int err; 397 int err;
398 struct qlcnic_cmd_args cmd; 398 struct qlcnic_cmd_args cmd;
399 struct qlcnic_recv_context *recv_ctx = adapter->recv_ctx; 399 struct qlcnic_recv_context *recv_ctx = adapter->recv_ctx;
400 400
401 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_DESTROY_RX_CTX); 401 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_DESTROY_RX_CTX);
402 if (err) 402 if (err)
403 return; 403 return;
404 404
405 cmd.req.arg[1] = recv_ctx->context_id; 405 cmd.req.arg[1] = recv_ctx->context_id;
406 err = qlcnic_issue_cmd(adapter, &cmd); 406 err = qlcnic_issue_cmd(adapter, &cmd);
407 if (err) 407 if (err)
408 dev_err(&adapter->pdev->dev, 408 dev_err(&adapter->pdev->dev,
409 "Failed to destroy rx ctx in firmware\n"); 409 "Failed to destroy rx ctx in firmware\n");
410 410
411 recv_ctx->state = QLCNIC_HOST_CTX_STATE_FREED; 411 recv_ctx->state = QLCNIC_HOST_CTX_STATE_FREED;
412 qlcnic_free_mbx_args(&cmd); 412 qlcnic_free_mbx_args(&cmd);
413 } 413 }
414 414
415 int qlcnic_82xx_fw_cmd_create_tx_ctx(struct qlcnic_adapter *adapter, 415 int qlcnic_82xx_fw_cmd_create_tx_ctx(struct qlcnic_adapter *adapter,
416 struct qlcnic_host_tx_ring *tx_ring, 416 struct qlcnic_host_tx_ring *tx_ring,
417 int ring) 417 int ring)
418 { 418 {
419 struct qlcnic_hardware_context *ahw = adapter->ahw; 419 struct qlcnic_hardware_context *ahw = adapter->ahw;
420 struct net_device *netdev = adapter->netdev; 420 struct net_device *netdev = adapter->netdev;
421 struct qlcnic_hostrq_tx_ctx *prq; 421 struct qlcnic_hostrq_tx_ctx *prq;
422 struct qlcnic_hostrq_cds_ring *prq_cds; 422 struct qlcnic_hostrq_cds_ring *prq_cds;
423 struct qlcnic_cardrsp_tx_ctx *prsp; 423 struct qlcnic_cardrsp_tx_ctx *prsp;
424 struct qlcnic_cmd_args cmd; 424 struct qlcnic_cmd_args cmd;
425 u32 temp, intr_mask, temp_int_crb_mode; 425 u32 temp, intr_mask, temp_int_crb_mode;
426 dma_addr_t rq_phys_addr, rsp_phys_addr; 426 dma_addr_t rq_phys_addr, rsp_phys_addr;
427 int temp_nsds_rings, index, err; 427 int temp_nsds_rings, index, err;
428 void *rq_addr, *rsp_addr; 428 void *rq_addr, *rsp_addr;
429 size_t rq_size, rsp_size; 429 size_t rq_size, rsp_size;
430 u64 phys_addr; 430 u64 phys_addr;
431 u16 msix_id; 431 u16 msix_id;
432 432
433 /* reset host resources */ 433 /* reset host resources */
434 tx_ring->producer = 0; 434 tx_ring->producer = 0;
435 tx_ring->sw_consumer = 0; 435 tx_ring->sw_consumer = 0;
436 *(tx_ring->hw_consumer) = 0; 436 *(tx_ring->hw_consumer) = 0;
437 437
438 rq_size = SIZEOF_HOSTRQ_TX(struct qlcnic_hostrq_tx_ctx); 438 rq_size = SIZEOF_HOSTRQ_TX(struct qlcnic_hostrq_tx_ctx);
439 rq_addr = dma_zalloc_coherent(&adapter->pdev->dev, rq_size, 439 rq_addr = dma_zalloc_coherent(&adapter->pdev->dev, rq_size,
440 &rq_phys_addr, GFP_KERNEL); 440 &rq_phys_addr, GFP_KERNEL);
441 if (!rq_addr) 441 if (!rq_addr)
442 return -ENOMEM; 442 return -ENOMEM;
443 443
444 rsp_size = SIZEOF_CARDRSP_TX(struct qlcnic_cardrsp_tx_ctx); 444 rsp_size = SIZEOF_CARDRSP_TX(struct qlcnic_cardrsp_tx_ctx);
445 rsp_addr = dma_zalloc_coherent(&adapter->pdev->dev, rsp_size, 445 rsp_addr = dma_zalloc_coherent(&adapter->pdev->dev, rsp_size,
446 &rsp_phys_addr, GFP_KERNEL); 446 &rsp_phys_addr, GFP_KERNEL);
447 if (!rsp_addr) { 447 if (!rsp_addr) {
448 err = -ENOMEM; 448 err = -ENOMEM;
449 goto out_free_rq; 449 goto out_free_rq;
450 } 450 }
451 451
452 prq = rq_addr; 452 prq = rq_addr;
453 prsp = rsp_addr; 453 prsp = rsp_addr;
454 454
455 prq->host_rsp_dma_addr = cpu_to_le64(rsp_phys_addr); 455 prq->host_rsp_dma_addr = cpu_to_le64(rsp_phys_addr);
456 456
457 temp = (QLCNIC_CAP0_LEGACY_CONTEXT | QLCNIC_CAP0_LEGACY_MN | 457 temp = (QLCNIC_CAP0_LEGACY_CONTEXT | QLCNIC_CAP0_LEGACY_MN |
458 QLCNIC_CAP0_LSO); 458 QLCNIC_CAP0_LSO);
459 if (qlcnic_check_multi_tx(adapter) && !adapter->ahw->diag_test) 459 if (qlcnic_check_multi_tx(adapter) && !adapter->ahw->diag_test)
460 temp |= QLCNIC_CAP0_TX_MULTI; 460 temp |= QLCNIC_CAP0_TX_MULTI;
461 461
462 prq->capabilities[0] = cpu_to_le32(temp); 462 prq->capabilities[0] = cpu_to_le32(temp);
463 463
464 if (qlcnic_check_multi_tx(adapter) && 464 if (qlcnic_check_multi_tx(adapter) &&
465 !adapter->ahw->diag_test) { 465 !adapter->ahw->diag_test) {
466 temp_nsds_rings = adapter->drv_sds_rings; 466 temp_nsds_rings = adapter->drv_sds_rings;
467 index = temp_nsds_rings + ring; 467 index = temp_nsds_rings + ring;
468 msix_id = ahw->intr_tbl[index].id; 468 msix_id = ahw->intr_tbl[index].id;
469 prq->msi_index = cpu_to_le16(msix_id); 469 prq->msi_index = cpu_to_le16(msix_id);
470 } else { 470 } else {
471 temp_int_crb_mode = QLCNIC_HOST_INT_CRB_MODE_SHARED; 471 temp_int_crb_mode = QLCNIC_HOST_INT_CRB_MODE_SHARED;
472 prq->host_int_crb_mode = cpu_to_le32(temp_int_crb_mode); 472 prq->host_int_crb_mode = cpu_to_le32(temp_int_crb_mode);
473 prq->msi_index = 0; 473 prq->msi_index = 0;
474 } 474 }
475 475
476 prq->interrupt_ctl = 0; 476 prq->interrupt_ctl = 0;
477 prq->cmd_cons_dma_addr = cpu_to_le64(tx_ring->hw_cons_phys_addr); 477 prq->cmd_cons_dma_addr = cpu_to_le64(tx_ring->hw_cons_phys_addr);
478 478
479 prq_cds = &prq->cds_ring; 479 prq_cds = &prq->cds_ring;
480 480
481 prq_cds->host_phys_addr = cpu_to_le64(tx_ring->phys_addr); 481 prq_cds->host_phys_addr = cpu_to_le64(tx_ring->phys_addr);
482 prq_cds->ring_size = cpu_to_le32(tx_ring->num_desc); 482 prq_cds->ring_size = cpu_to_le32(tx_ring->num_desc);
483 483
484 phys_addr = rq_phys_addr; 484 phys_addr = rq_phys_addr;
485 485
486 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_CREATE_TX_CTX); 486 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_CREATE_TX_CTX);
487 if (err) 487 if (err)
488 goto out_free_rsp; 488 goto out_free_rsp;
489 489
490 cmd.req.arg[1] = MSD(phys_addr); 490 cmd.req.arg[1] = MSD(phys_addr);
491 cmd.req.arg[2] = LSD(phys_addr); 491 cmd.req.arg[2] = LSD(phys_addr);
492 cmd.req.arg[3] = rq_size; 492 cmd.req.arg[3] = rq_size;
493 err = qlcnic_issue_cmd(adapter, &cmd); 493 err = qlcnic_issue_cmd(adapter, &cmd);
494 494
495 if (err == QLCNIC_RCODE_SUCCESS) { 495 if (err == QLCNIC_RCODE_SUCCESS) {
496 tx_ring->state = le32_to_cpu(prsp->host_ctx_state); 496 tx_ring->state = le32_to_cpu(prsp->host_ctx_state);
497 temp = le32_to_cpu(prsp->cds_ring.host_producer_crb); 497 temp = le32_to_cpu(prsp->cds_ring.host_producer_crb);
498 tx_ring->crb_cmd_producer = adapter->ahw->pci_base0 + temp; 498 tx_ring->crb_cmd_producer = adapter->ahw->pci_base0 + temp;
499 tx_ring->ctx_id = le16_to_cpu(prsp->context_id); 499 tx_ring->ctx_id = le16_to_cpu(prsp->context_id);
500 if (qlcnic_check_multi_tx(adapter) && 500 if (qlcnic_check_multi_tx(adapter) &&
501 !adapter->ahw->diag_test && 501 !adapter->ahw->diag_test &&
502 (adapter->flags & QLCNIC_MSIX_ENABLED)) { 502 (adapter->flags & QLCNIC_MSIX_ENABLED)) {
503 index = adapter->drv_sds_rings + ring; 503 index = adapter->drv_sds_rings + ring;
504 intr_mask = ahw->intr_tbl[index].src; 504 intr_mask = ahw->intr_tbl[index].src;
505 tx_ring->crb_intr_mask = ahw->pci_base0 + intr_mask; 505 tx_ring->crb_intr_mask = ahw->pci_base0 + intr_mask;
506 } 506 }
507 507
508 netdev_info(netdev, "Tx Context[0x%x] Created, state 0x%x\n", 508 netdev_info(netdev, "Tx Context[0x%x] Created, state 0x%x\n",
509 tx_ring->ctx_id, tx_ring->state); 509 tx_ring->ctx_id, tx_ring->state);
510 } else { 510 } else {
511 netdev_err(netdev, "Failed to create tx ctx in firmware%d\n", 511 netdev_err(netdev, "Failed to create tx ctx in firmware%d\n",
512 err); 512 err);
513 err = -EIO; 513 err = -EIO;
514 } 514 }
515 qlcnic_free_mbx_args(&cmd); 515 qlcnic_free_mbx_args(&cmd);
516 516
517 out_free_rsp: 517 out_free_rsp:
518 dma_free_coherent(&adapter->pdev->dev, rsp_size, rsp_addr, 518 dma_free_coherent(&adapter->pdev->dev, rsp_size, rsp_addr,
519 rsp_phys_addr); 519 rsp_phys_addr);
520 out_free_rq: 520 out_free_rq:
521 dma_free_coherent(&adapter->pdev->dev, rq_size, rq_addr, rq_phys_addr); 521 dma_free_coherent(&adapter->pdev->dev, rq_size, rq_addr, rq_phys_addr);
522 522
523 return err; 523 return err;
524 } 524 }
525 525
526 void qlcnic_82xx_fw_cmd_del_tx_ctx(struct qlcnic_adapter *adapter, 526 void qlcnic_82xx_fw_cmd_del_tx_ctx(struct qlcnic_adapter *adapter,
527 struct qlcnic_host_tx_ring *tx_ring) 527 struct qlcnic_host_tx_ring *tx_ring)
528 { 528 {
529 struct qlcnic_cmd_args cmd; 529 struct qlcnic_cmd_args cmd;
530 int ret; 530 int ret;
531 531
532 ret = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_DESTROY_TX_CTX); 532 ret = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_DESTROY_TX_CTX);
533 if (ret) 533 if (ret)
534 return; 534 return;
535 535
536 cmd.req.arg[1] = tx_ring->ctx_id; 536 cmd.req.arg[1] = tx_ring->ctx_id;
537 if (qlcnic_issue_cmd(adapter, &cmd)) 537 if (qlcnic_issue_cmd(adapter, &cmd))
538 dev_err(&adapter->pdev->dev, 538 dev_err(&adapter->pdev->dev,
539 "Failed to destroy tx ctx in firmware\n"); 539 "Failed to destroy tx ctx in firmware\n");
540 qlcnic_free_mbx_args(&cmd); 540 qlcnic_free_mbx_args(&cmd);
541 } 541 }
542 542
543 int 543 int
544 qlcnic_fw_cmd_set_port(struct qlcnic_adapter *adapter, u32 config) 544 qlcnic_fw_cmd_set_port(struct qlcnic_adapter *adapter, u32 config)
545 { 545 {
546 int err; 546 int err;
547 struct qlcnic_cmd_args cmd; 547 struct qlcnic_cmd_args cmd;
548 548
549 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_CONFIG_PORT); 549 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_CONFIG_PORT);
550 if (err) 550 if (err)
551 return err; 551 return err;
552 552
553 cmd.req.arg[1] = config; 553 cmd.req.arg[1] = config;
554 err = qlcnic_issue_cmd(adapter, &cmd); 554 err = qlcnic_issue_cmd(adapter, &cmd);
555 qlcnic_free_mbx_args(&cmd); 555 qlcnic_free_mbx_args(&cmd);
556 return err; 556 return err;
557 } 557 }
558 558
559 int qlcnic_alloc_hw_resources(struct qlcnic_adapter *adapter) 559 int qlcnic_alloc_hw_resources(struct qlcnic_adapter *adapter)
560 { 560 {
561 void *addr; 561 void *addr;
562 int err, ring; 562 int err, ring;
563 struct qlcnic_recv_context *recv_ctx; 563 struct qlcnic_recv_context *recv_ctx;
564 struct qlcnic_host_rds_ring *rds_ring; 564 struct qlcnic_host_rds_ring *rds_ring;
565 struct qlcnic_host_sds_ring *sds_ring; 565 struct qlcnic_host_sds_ring *sds_ring;
566 struct qlcnic_host_tx_ring *tx_ring; 566 struct qlcnic_host_tx_ring *tx_ring;
567 __le32 *ptr; 567 __le32 *ptr;
568 568
569 struct pci_dev *pdev = adapter->pdev; 569 struct pci_dev *pdev = adapter->pdev;
570 570
571 recv_ctx = adapter->recv_ctx; 571 recv_ctx = adapter->recv_ctx;
572 572
573 for (ring = 0; ring < adapter->drv_tx_rings; ring++) { 573 for (ring = 0; ring < adapter->drv_tx_rings; ring++) {
574 tx_ring = &adapter->tx_ring[ring]; 574 tx_ring = &adapter->tx_ring[ring];
575 ptr = (__le32 *)dma_alloc_coherent(&pdev->dev, sizeof(u32), 575 ptr = (__le32 *)dma_alloc_coherent(&pdev->dev, sizeof(u32),
576 &tx_ring->hw_cons_phys_addr, 576 &tx_ring->hw_cons_phys_addr,
577 GFP_KERNEL); 577 GFP_KERNEL);
578 if (ptr == NULL) 578 if (ptr == NULL)
579 return -ENOMEM; 579 return -ENOMEM;
580 580
581 tx_ring->hw_consumer = ptr; 581 tx_ring->hw_consumer = ptr;
582 /* cmd desc ring */ 582 /* cmd desc ring */
583 addr = dma_alloc_coherent(&pdev->dev, TX_DESC_RINGSIZE(tx_ring), 583 addr = dma_alloc_coherent(&pdev->dev, TX_DESC_RINGSIZE(tx_ring),
584 &tx_ring->phys_addr, 584 &tx_ring->phys_addr,
585 GFP_KERNEL); 585 GFP_KERNEL);
586 if (addr == NULL) { 586 if (addr == NULL) {
587 err = -ENOMEM; 587 err = -ENOMEM;
588 goto err_out_free; 588 goto err_out_free;
589 } 589 }
590 590
591 tx_ring->desc_head = addr; 591 tx_ring->desc_head = addr;
592 } 592 }
593 593
594 for (ring = 0; ring < adapter->max_rds_rings; ring++) { 594 for (ring = 0; ring < adapter->max_rds_rings; ring++) {
595 rds_ring = &recv_ctx->rds_rings[ring]; 595 rds_ring = &recv_ctx->rds_rings[ring];
596 addr = dma_alloc_coherent(&adapter->pdev->dev, 596 addr = dma_alloc_coherent(&adapter->pdev->dev,
597 RCV_DESC_RINGSIZE(rds_ring), 597 RCV_DESC_RINGSIZE(rds_ring),
598 &rds_ring->phys_addr, GFP_KERNEL); 598 &rds_ring->phys_addr, GFP_KERNEL);
599 if (addr == NULL) { 599 if (addr == NULL) {
600 err = -ENOMEM; 600 err = -ENOMEM;
601 goto err_out_free; 601 goto err_out_free;
602 } 602 }
603 rds_ring->desc_head = addr; 603 rds_ring->desc_head = addr;
604 604
605 } 605 }
606 606
607 for (ring = 0; ring < adapter->drv_sds_rings; ring++) { 607 for (ring = 0; ring < adapter->drv_sds_rings; ring++) {
608 sds_ring = &recv_ctx->sds_rings[ring]; 608 sds_ring = &recv_ctx->sds_rings[ring];
609 609
610 addr = dma_alloc_coherent(&adapter->pdev->dev, 610 addr = dma_alloc_coherent(&adapter->pdev->dev,
611 STATUS_DESC_RINGSIZE(sds_ring), 611 STATUS_DESC_RINGSIZE(sds_ring),
612 &sds_ring->phys_addr, GFP_KERNEL); 612 &sds_ring->phys_addr, GFP_KERNEL);
613 if (addr == NULL) { 613 if (addr == NULL) {
614 err = -ENOMEM; 614 err = -ENOMEM;
615 goto err_out_free; 615 goto err_out_free;
616 } 616 }
617 sds_ring->desc_head = addr; 617 sds_ring->desc_head = addr;
618 } 618 }
619 619
620 return 0; 620 return 0;
621 621
622 err_out_free: 622 err_out_free:
623 qlcnic_free_hw_resources(adapter); 623 qlcnic_free_hw_resources(adapter);
624 return err; 624 return err;
625 } 625 }
626 626
627 int qlcnic_fw_create_ctx(struct qlcnic_adapter *dev) 627 int qlcnic_fw_create_ctx(struct qlcnic_adapter *dev)
628 { 628 {
629 int i, err, ring; 629 int i, err, ring;
630 630
631 if (dev->flags & QLCNIC_NEED_FLR) { 631 if (dev->flags & QLCNIC_NEED_FLR) {
632 pci_reset_function(dev->pdev); 632 pci_reset_function(dev->pdev);
633 dev->flags &= ~QLCNIC_NEED_FLR; 633 dev->flags &= ~QLCNIC_NEED_FLR;
634 } 634 }
635 635
636 if (qlcnic_83xx_check(dev) && (dev->flags & QLCNIC_MSIX_ENABLED)) { 636 if (qlcnic_83xx_check(dev) && (dev->flags & QLCNIC_MSIX_ENABLED)) {
637 if (dev->ahw->diag_test != QLCNIC_LOOPBACK_TEST) { 637 if (dev->ahw->diag_test != QLCNIC_LOOPBACK_TEST) {
638 err = qlcnic_83xx_config_intrpt(dev, 1); 638 err = qlcnic_83xx_config_intrpt(dev, 1);
639 if (err) 639 if (err)
640 return err; 640 return err;
641 } 641 }
642 } 642 }
643 643
644 if (qlcnic_82xx_check(dev) && (dev->flags & QLCNIC_MSIX_ENABLED) && 644 if (qlcnic_82xx_check(dev) && (dev->flags & QLCNIC_MSIX_ENABLED) &&
645 qlcnic_check_multi_tx(dev) && !dev->ahw->diag_test) { 645 qlcnic_check_multi_tx(dev) && !dev->ahw->diag_test) {
646 err = qlcnic_82xx_mq_intrpt(dev, 1); 646 err = qlcnic_82xx_mq_intrpt(dev, 1);
647 if (err) 647 if (err)
648 return err; 648 return err;
649 } 649 }
650 650
651 err = qlcnic_fw_cmd_create_rx_ctx(dev); 651 err = qlcnic_fw_cmd_create_rx_ctx(dev);
652 if (err) 652 if (err)
653 goto err_out; 653 goto err_out;
654 654
655 for (ring = 0; ring < dev->drv_tx_rings; ring++) { 655 for (ring = 0; ring < dev->drv_tx_rings; ring++) {
656 err = qlcnic_fw_cmd_create_tx_ctx(dev, 656 err = qlcnic_fw_cmd_create_tx_ctx(dev,
657 &dev->tx_ring[ring], 657 &dev->tx_ring[ring],
658 ring); 658 ring);
659 if (err) { 659 if (err) {
660 qlcnic_fw_cmd_del_rx_ctx(dev); 660 qlcnic_fw_cmd_del_rx_ctx(dev);
661 if (ring == 0) 661 if (ring == 0)
662 goto err_out; 662 goto err_out;
663 663
664 for (i = 0; i < ring; i++) 664 for (i = 0; i < ring; i++)
665 qlcnic_fw_cmd_del_tx_ctx(dev, &dev->tx_ring[i]); 665 qlcnic_fw_cmd_del_tx_ctx(dev, &dev->tx_ring[i]);
666 666
667 goto err_out; 667 goto err_out;
668 } 668 }
669 } 669 }
670 670
671 set_bit(__QLCNIC_FW_ATTACHED, &dev->state); 671 set_bit(__QLCNIC_FW_ATTACHED, &dev->state);
672 672
673 return 0; 673 return 0;
674 674
675 err_out: 675 err_out:
676 if (qlcnic_82xx_check(dev) && (dev->flags & QLCNIC_MSIX_ENABLED) && 676 if (qlcnic_82xx_check(dev) && (dev->flags & QLCNIC_MSIX_ENABLED) &&
677 qlcnic_check_multi_tx(dev) && !dev->ahw->diag_test) 677 qlcnic_check_multi_tx(dev) && !dev->ahw->diag_test)
678 qlcnic_82xx_config_intrpt(dev, 0); 678 qlcnic_82xx_config_intrpt(dev, 0);
679 679
680 if (qlcnic_83xx_check(dev) && (dev->flags & QLCNIC_MSIX_ENABLED)) { 680 if (qlcnic_83xx_check(dev) && (dev->flags & QLCNIC_MSIX_ENABLED)) {
681 if (dev->ahw->diag_test != QLCNIC_LOOPBACK_TEST) 681 if (dev->ahw->diag_test != QLCNIC_LOOPBACK_TEST)
682 qlcnic_83xx_config_intrpt(dev, 0); 682 qlcnic_83xx_config_intrpt(dev, 0);
683 } 683 }
684 684
685 return err; 685 return err;
686 } 686 }
687 687
688 void qlcnic_fw_destroy_ctx(struct qlcnic_adapter *adapter) 688 void qlcnic_fw_destroy_ctx(struct qlcnic_adapter *adapter)
689 { 689 {
690 int ring; 690 int ring;
691 691
692 if (test_and_clear_bit(__QLCNIC_FW_ATTACHED, &adapter->state)) { 692 if (test_and_clear_bit(__QLCNIC_FW_ATTACHED, &adapter->state)) {
693 qlcnic_fw_cmd_del_rx_ctx(adapter); 693 qlcnic_fw_cmd_del_rx_ctx(adapter);
694 for (ring = 0; ring < adapter->drv_tx_rings; ring++) 694 for (ring = 0; ring < adapter->drv_tx_rings; ring++)
695 qlcnic_fw_cmd_del_tx_ctx(adapter, 695 qlcnic_fw_cmd_del_tx_ctx(adapter,
696 &adapter->tx_ring[ring]); 696 &adapter->tx_ring[ring]);
697 697
698 if (qlcnic_82xx_check(adapter) && 698 if (qlcnic_82xx_check(adapter) &&
699 (adapter->flags & QLCNIC_MSIX_ENABLED) && 699 (adapter->flags & QLCNIC_MSIX_ENABLED) &&
700 qlcnic_check_multi_tx(adapter) && 700 qlcnic_check_multi_tx(adapter) &&
701 !adapter->ahw->diag_test) 701 !adapter->ahw->diag_test)
702 qlcnic_82xx_config_intrpt(adapter, 0); 702 qlcnic_82xx_config_intrpt(adapter, 0);
703 703
704 if (qlcnic_83xx_check(adapter) && 704 if (qlcnic_83xx_check(adapter) &&
705 (adapter->flags & QLCNIC_MSIX_ENABLED)) { 705 (adapter->flags & QLCNIC_MSIX_ENABLED)) {
706 if (adapter->ahw->diag_test != QLCNIC_LOOPBACK_TEST) 706 if (adapter->ahw->diag_test != QLCNIC_LOOPBACK_TEST)
707 qlcnic_83xx_config_intrpt(adapter, 0); 707 qlcnic_83xx_config_intrpt(adapter, 0);
708 } 708 }
709 /* Allow dma queues to drain after context reset */ 709 /* Allow dma queues to drain after context reset */
710 mdelay(20); 710 mdelay(20);
711 } 711 }
712 } 712 }
713 713
714 void qlcnic_free_hw_resources(struct qlcnic_adapter *adapter) 714 void qlcnic_free_hw_resources(struct qlcnic_adapter *adapter)
715 { 715 {
716 struct qlcnic_recv_context *recv_ctx; 716 struct qlcnic_recv_context *recv_ctx;
717 struct qlcnic_host_rds_ring *rds_ring; 717 struct qlcnic_host_rds_ring *rds_ring;
718 struct qlcnic_host_sds_ring *sds_ring; 718 struct qlcnic_host_sds_ring *sds_ring;
719 struct qlcnic_host_tx_ring *tx_ring; 719 struct qlcnic_host_tx_ring *tx_ring;
720 int ring; 720 int ring;
721 721
722 recv_ctx = adapter->recv_ctx; 722 recv_ctx = adapter->recv_ctx;
723 723
724 for (ring = 0; ring < adapter->drv_tx_rings; ring++) { 724 for (ring = 0; ring < adapter->drv_tx_rings; ring++) {
725 tx_ring = &adapter->tx_ring[ring]; 725 tx_ring = &adapter->tx_ring[ring];
726 if (tx_ring->hw_consumer != NULL) { 726 if (tx_ring->hw_consumer != NULL) {
727 dma_free_coherent(&adapter->pdev->dev, sizeof(u32), 727 dma_free_coherent(&adapter->pdev->dev, sizeof(u32),
728 tx_ring->hw_consumer, 728 tx_ring->hw_consumer,
729 tx_ring->hw_cons_phys_addr); 729 tx_ring->hw_cons_phys_addr);
730 730
731 tx_ring->hw_consumer = NULL; 731 tx_ring->hw_consumer = NULL;
732 } 732 }
733 733
734 if (tx_ring->desc_head != NULL) { 734 if (tx_ring->desc_head != NULL) {
735 dma_free_coherent(&adapter->pdev->dev, 735 dma_free_coherent(&adapter->pdev->dev,
736 TX_DESC_RINGSIZE(tx_ring), 736 TX_DESC_RINGSIZE(tx_ring),
737 tx_ring->desc_head, 737 tx_ring->desc_head,
738 tx_ring->phys_addr); 738 tx_ring->phys_addr);
739 tx_ring->desc_head = NULL; 739 tx_ring->desc_head = NULL;
740 } 740 }
741 } 741 }
742 742
743 for (ring = 0; ring < adapter->max_rds_rings; ring++) { 743 for (ring = 0; ring < adapter->max_rds_rings; ring++) {
744 rds_ring = &recv_ctx->rds_rings[ring]; 744 rds_ring = &recv_ctx->rds_rings[ring];
745 745
746 if (rds_ring->desc_head != NULL) { 746 if (rds_ring->desc_head != NULL) {
747 dma_free_coherent(&adapter->pdev->dev, 747 dma_free_coherent(&adapter->pdev->dev,
748 RCV_DESC_RINGSIZE(rds_ring), 748 RCV_DESC_RINGSIZE(rds_ring),
749 rds_ring->desc_head, 749 rds_ring->desc_head,
750 rds_ring->phys_addr); 750 rds_ring->phys_addr);
751 rds_ring->desc_head = NULL; 751 rds_ring->desc_head = NULL;
752 } 752 }
753 } 753 }
754 754
755 for (ring = 0; ring < adapter->drv_sds_rings; ring++) { 755 for (ring = 0; ring < adapter->drv_sds_rings; ring++) {
756 sds_ring = &recv_ctx->sds_rings[ring]; 756 sds_ring = &recv_ctx->sds_rings[ring];
757 757
758 if (sds_ring->desc_head != NULL) { 758 if (sds_ring->desc_head != NULL) {
759 dma_free_coherent(&adapter->pdev->dev, 759 dma_free_coherent(&adapter->pdev->dev,
760 STATUS_DESC_RINGSIZE(sds_ring), 760 STATUS_DESC_RINGSIZE(sds_ring),
761 sds_ring->desc_head, 761 sds_ring->desc_head,
762 sds_ring->phys_addr); 762 sds_ring->phys_addr);
763 sds_ring->desc_head = NULL; 763 sds_ring->desc_head = NULL;
764 } 764 }
765 } 765 }
766 } 766 }
767 767
768 int qlcnic_82xx_config_intrpt(struct qlcnic_adapter *adapter, u8 op_type) 768 int qlcnic_82xx_config_intrpt(struct qlcnic_adapter *adapter, u8 op_type)
769 { 769 {
770 struct qlcnic_hardware_context *ahw = adapter->ahw; 770 struct qlcnic_hardware_context *ahw = adapter->ahw;
771 struct net_device *netdev = adapter->netdev; 771 struct net_device *netdev = adapter->netdev;
772 struct qlcnic_cmd_args cmd; 772 struct qlcnic_cmd_args cmd;
773 u32 type, val; 773 u32 type, val;
774 int i, err = 0; 774 int i, err = 0;
775 775
776 for (i = 0; i < ahw->num_msix; i++) { 776 for (i = 0; i < ahw->num_msix; i++) {
777 qlcnic_alloc_mbx_args(&cmd, adapter, 777 qlcnic_alloc_mbx_args(&cmd, adapter,
778 QLCNIC_CMD_MQ_TX_CONFIG_INTR); 778 QLCNIC_CMD_MQ_TX_CONFIG_INTR);
779 type = op_type ? QLCNIC_INTRPT_ADD : QLCNIC_INTRPT_DEL; 779 type = op_type ? QLCNIC_INTRPT_ADD : QLCNIC_INTRPT_DEL;
780 val = type | (ahw->intr_tbl[i].type << 4); 780 val = type | (ahw->intr_tbl[i].type << 4);
781 if (ahw->intr_tbl[i].type == QLCNIC_INTRPT_MSIX) 781 if (ahw->intr_tbl[i].type == QLCNIC_INTRPT_MSIX)
782 val |= (ahw->intr_tbl[i].id << 16); 782 val |= (ahw->intr_tbl[i].id << 16);
783 cmd.req.arg[1] = val; 783 cmd.req.arg[1] = val;
784 err = qlcnic_issue_cmd(adapter, &cmd); 784 err = qlcnic_issue_cmd(adapter, &cmd);
785 if (err) { 785 if (err) {
786 netdev_err(netdev, "Failed to %s interrupts %d\n", 786 netdev_err(netdev, "Failed to %s interrupts %d\n",
787 op_type == QLCNIC_INTRPT_ADD ? "Add" : 787 op_type == QLCNIC_INTRPT_ADD ? "Add" :
788 "Delete", err); 788 "Delete", err);
789 qlcnic_free_mbx_args(&cmd); 789 qlcnic_free_mbx_args(&cmd);
790 return err; 790 return err;
791 } 791 }
792 val = cmd.rsp.arg[1]; 792 val = cmd.rsp.arg[1];
793 if (LSB(val)) { 793 if (LSB(val)) {
794 netdev_info(netdev, 794 netdev_info(netdev,
795 "failed to configure interrupt for %d\n", 795 "failed to configure interrupt for %d\n",
796 ahw->intr_tbl[i].id); 796 ahw->intr_tbl[i].id);
797 continue; 797 continue;
798 } 798 }
799 if (op_type) { 799 if (op_type) {
800 ahw->intr_tbl[i].id = MSW(val); 800 ahw->intr_tbl[i].id = MSW(val);
801 ahw->intr_tbl[i].enabled = 1; 801 ahw->intr_tbl[i].enabled = 1;
802 ahw->intr_tbl[i].src = cmd.rsp.arg[2]; 802 ahw->intr_tbl[i].src = cmd.rsp.arg[2];
803 } else { 803 } else {
804 ahw->intr_tbl[i].id = i; 804 ahw->intr_tbl[i].id = i;
805 ahw->intr_tbl[i].enabled = 0; 805 ahw->intr_tbl[i].enabled = 0;
806 ahw->intr_tbl[i].src = 0; 806 ahw->intr_tbl[i].src = 0;
807 } 807 }
808 qlcnic_free_mbx_args(&cmd); 808 qlcnic_free_mbx_args(&cmd);
809 } 809 }
810 810
811 return err; 811 return err;
812 } 812 }
813 813
814 int qlcnic_82xx_get_mac_address(struct qlcnic_adapter *adapter, u8 *mac, 814 int qlcnic_82xx_get_mac_address(struct qlcnic_adapter *adapter, u8 *mac,
815 u8 function) 815 u8 function)
816 { 816 {
817 int err, i; 817 int err, i;
818 struct qlcnic_cmd_args cmd; 818 struct qlcnic_cmd_args cmd;
819 u32 mac_low, mac_high; 819 u32 mac_low, mac_high;
820 820
821 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_MAC_ADDRESS); 821 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_MAC_ADDRESS);
822 if (err) 822 if (err)
823 return err; 823 return err;
824 824
825 cmd.req.arg[1] = function | BIT_8; 825 cmd.req.arg[1] = function | BIT_8;
826 err = qlcnic_issue_cmd(adapter, &cmd); 826 err = qlcnic_issue_cmd(adapter, &cmd);
827 827
828 if (err == QLCNIC_RCODE_SUCCESS) { 828 if (err == QLCNIC_RCODE_SUCCESS) {
829 mac_low = cmd.rsp.arg[1]; 829 mac_low = cmd.rsp.arg[1];
830 mac_high = cmd.rsp.arg[2]; 830 mac_high = cmd.rsp.arg[2];
831 831
832 for (i = 0; i < 2; i++) 832 for (i = 0; i < 2; i++)
833 mac[i] = (u8) (mac_high >> ((1 - i) * 8)); 833 mac[i] = (u8) (mac_high >> ((1 - i) * 8));
834 for (i = 2; i < 6; i++) 834 for (i = 2; i < 6; i++)
835 mac[i] = (u8) (mac_low >> ((5 - i) * 8)); 835 mac[i] = (u8) (mac_low >> ((5 - i) * 8));
836 } else { 836 } else {
837 dev_err(&adapter->pdev->dev, 837 dev_err(&adapter->pdev->dev,
838 "Failed to get mac address%d\n", err); 838 "Failed to get mac address%d\n", err);
839 err = -EIO; 839 err = -EIO;
840 } 840 }
841 qlcnic_free_mbx_args(&cmd); 841 qlcnic_free_mbx_args(&cmd);
842 return err; 842 return err;
843 } 843 }
844 844
845 /* Get info of a NIC partition */ 845 /* Get info of a NIC partition */
846 int qlcnic_82xx_get_nic_info(struct qlcnic_adapter *adapter, 846 int qlcnic_82xx_get_nic_info(struct qlcnic_adapter *adapter,
847 struct qlcnic_info *npar_info, u8 func_id) 847 struct qlcnic_info *npar_info, u8 func_id)
848 { 848 {
849 int err; 849 int err;
850 dma_addr_t nic_dma_t; 850 dma_addr_t nic_dma_t;
851 const struct qlcnic_info_le *nic_info; 851 const struct qlcnic_info_le *nic_info;
852 void *nic_info_addr; 852 void *nic_info_addr;
853 struct qlcnic_cmd_args cmd; 853 struct qlcnic_cmd_args cmd;
854 size_t nic_size = sizeof(struct qlcnic_info_le); 854 size_t nic_size = sizeof(struct qlcnic_info_le);
855 855
856 nic_info_addr = dma_zalloc_coherent(&adapter->pdev->dev, nic_size, 856 nic_info_addr = dma_zalloc_coherent(&adapter->pdev->dev, nic_size,
857 &nic_dma_t, GFP_KERNEL); 857 &nic_dma_t, GFP_KERNEL);
858 if (!nic_info_addr) 858 if (!nic_info_addr)
859 return -ENOMEM; 859 return -ENOMEM;
860 860
861 nic_info = nic_info_addr; 861 nic_info = nic_info_addr;
862 862
863 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_GET_NIC_INFO); 863 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_GET_NIC_INFO);
864 if (err) 864 if (err)
865 goto out_free_dma; 865 goto out_free_dma;
866 866
867 cmd.req.arg[1] = MSD(nic_dma_t); 867 cmd.req.arg[1] = MSD(nic_dma_t);
868 cmd.req.arg[2] = LSD(nic_dma_t); 868 cmd.req.arg[2] = LSD(nic_dma_t);
869 cmd.req.arg[3] = (func_id << 16 | nic_size); 869 cmd.req.arg[3] = (func_id << 16 | nic_size);
870 err = qlcnic_issue_cmd(adapter, &cmd); 870 err = qlcnic_issue_cmd(adapter, &cmd);
871 if (err != QLCNIC_RCODE_SUCCESS) { 871 if (err != QLCNIC_RCODE_SUCCESS) {
872 dev_err(&adapter->pdev->dev, 872 dev_err(&adapter->pdev->dev,
873 "Failed to get nic info%d\n", err); 873 "Failed to get nic info%d\n", err);
874 err = -EIO; 874 err = -EIO;
875 } else { 875 } else {
876 npar_info->pci_func = le16_to_cpu(nic_info->pci_func); 876 npar_info->pci_func = le16_to_cpu(nic_info->pci_func);
877 npar_info->op_mode = le16_to_cpu(nic_info->op_mode); 877 npar_info->op_mode = le16_to_cpu(nic_info->op_mode);
878 npar_info->min_tx_bw = le16_to_cpu(nic_info->min_tx_bw); 878 npar_info->min_tx_bw = le16_to_cpu(nic_info->min_tx_bw);
879 npar_info->max_tx_bw = le16_to_cpu(nic_info->max_tx_bw); 879 npar_info->max_tx_bw = le16_to_cpu(nic_info->max_tx_bw);
880 npar_info->phys_port = le16_to_cpu(nic_info->phys_port); 880 npar_info->phys_port = le16_to_cpu(nic_info->phys_port);
881 npar_info->switch_mode = le16_to_cpu(nic_info->switch_mode); 881 npar_info->switch_mode = le16_to_cpu(nic_info->switch_mode);
882 npar_info->max_tx_ques = le16_to_cpu(nic_info->max_tx_ques); 882 npar_info->max_tx_ques = le16_to_cpu(nic_info->max_tx_ques);
883 npar_info->max_rx_ques = le16_to_cpu(nic_info->max_rx_ques); 883 npar_info->max_rx_ques = le16_to_cpu(nic_info->max_rx_ques);
884 npar_info->capabilities = le32_to_cpu(nic_info->capabilities); 884 npar_info->capabilities = le32_to_cpu(nic_info->capabilities);
885 npar_info->max_mtu = le16_to_cpu(nic_info->max_mtu); 885 npar_info->max_mtu = le16_to_cpu(nic_info->max_mtu);
886 } 886 }
887 887
888 qlcnic_free_mbx_args(&cmd); 888 qlcnic_free_mbx_args(&cmd);
889 out_free_dma: 889 out_free_dma:
890 dma_free_coherent(&adapter->pdev->dev, nic_size, nic_info_addr, 890 dma_free_coherent(&adapter->pdev->dev, nic_size, nic_info_addr,
891 nic_dma_t); 891 nic_dma_t);
892 892
893 return err; 893 return err;
894 } 894 }
895 895
896 /* Configure a NIC partition */ 896 /* Configure a NIC partition */
897 int qlcnic_82xx_set_nic_info(struct qlcnic_adapter *adapter, 897 int qlcnic_82xx_set_nic_info(struct qlcnic_adapter *adapter,
898 struct qlcnic_info *nic) 898 struct qlcnic_info *nic)
899 { 899 {
900 int err = -EIO; 900 int err = -EIO;
901 dma_addr_t nic_dma_t; 901 dma_addr_t nic_dma_t;
902 void *nic_info_addr; 902 void *nic_info_addr;
903 struct qlcnic_cmd_args cmd; 903 struct qlcnic_cmd_args cmd;
904 struct qlcnic_info_le *nic_info; 904 struct qlcnic_info_le *nic_info;
905 size_t nic_size = sizeof(struct qlcnic_info_le); 905 size_t nic_size = sizeof(struct qlcnic_info_le);
906 906
907 if (adapter->ahw->op_mode != QLCNIC_MGMT_FUNC) 907 if (adapter->ahw->op_mode != QLCNIC_MGMT_FUNC)
908 return err; 908 return err;
909 909
910 nic_info_addr = dma_zalloc_coherent(&adapter->pdev->dev, nic_size, 910 nic_info_addr = dma_zalloc_coherent(&adapter->pdev->dev, nic_size,
911 &nic_dma_t, GFP_KERNEL); 911 &nic_dma_t, GFP_KERNEL);
912 if (!nic_info_addr) 912 if (!nic_info_addr)
913 return -ENOMEM; 913 return -ENOMEM;
914 914
915 nic_info = nic_info_addr; 915 nic_info = nic_info_addr;
916 916
917 nic_info->pci_func = cpu_to_le16(nic->pci_func); 917 nic_info->pci_func = cpu_to_le16(nic->pci_func);
918 nic_info->op_mode = cpu_to_le16(nic->op_mode); 918 nic_info->op_mode = cpu_to_le16(nic->op_mode);
919 nic_info->phys_port = cpu_to_le16(nic->phys_port); 919 nic_info->phys_port = cpu_to_le16(nic->phys_port);
920 nic_info->switch_mode = cpu_to_le16(nic->switch_mode); 920 nic_info->switch_mode = cpu_to_le16(nic->switch_mode);
921 nic_info->capabilities = cpu_to_le32(nic->capabilities); 921 nic_info->capabilities = cpu_to_le32(nic->capabilities);
922 nic_info->max_mac_filters = nic->max_mac_filters; 922 nic_info->max_mac_filters = nic->max_mac_filters;
923 nic_info->max_tx_ques = cpu_to_le16(nic->max_tx_ques); 923 nic_info->max_tx_ques = cpu_to_le16(nic->max_tx_ques);
924 nic_info->max_rx_ques = cpu_to_le16(nic->max_rx_ques); 924 nic_info->max_rx_ques = cpu_to_le16(nic->max_rx_ques);
925 nic_info->min_tx_bw = cpu_to_le16(nic->min_tx_bw); 925 nic_info->min_tx_bw = cpu_to_le16(nic->min_tx_bw);
926 nic_info->max_tx_bw = cpu_to_le16(nic->max_tx_bw); 926 nic_info->max_tx_bw = cpu_to_le16(nic->max_tx_bw);
927 927
928 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_SET_NIC_INFO); 928 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_SET_NIC_INFO);
929 if (err) 929 if (err)
930 goto out_free_dma; 930 goto out_free_dma;
931 931
932 cmd.req.arg[1] = MSD(nic_dma_t); 932 cmd.req.arg[1] = MSD(nic_dma_t);
933 cmd.req.arg[2] = LSD(nic_dma_t); 933 cmd.req.arg[2] = LSD(nic_dma_t);
934 cmd.req.arg[3] = ((nic->pci_func << 16) | nic_size); 934 cmd.req.arg[3] = ((nic->pci_func << 16) | nic_size);
935 err = qlcnic_issue_cmd(adapter, &cmd); 935 err = qlcnic_issue_cmd(adapter, &cmd);
936 936
937 if (err != QLCNIC_RCODE_SUCCESS) { 937 if (err != QLCNIC_RCODE_SUCCESS) {
938 dev_err(&adapter->pdev->dev, 938 dev_err(&adapter->pdev->dev,
939 "Failed to set nic info%d\n", err); 939 "Failed to set nic info%d\n", err);
940 err = -EIO; 940 err = -EIO;
941 } 941 }
942 942
943 qlcnic_free_mbx_args(&cmd); 943 qlcnic_free_mbx_args(&cmd);
944 out_free_dma: 944 out_free_dma:
945 dma_free_coherent(&adapter->pdev->dev, nic_size, nic_info_addr, 945 dma_free_coherent(&adapter->pdev->dev, nic_size, nic_info_addr,
946 nic_dma_t); 946 nic_dma_t);
947 947
948 return err; 948 return err;
949 } 949 }
950 950
951 /* Get PCI Info of a partition */ 951 /* Get PCI Info of a partition */
952 int qlcnic_82xx_get_pci_info(struct qlcnic_adapter *adapter, 952 int qlcnic_82xx_get_pci_info(struct qlcnic_adapter *adapter,
953 struct qlcnic_pci_info *pci_info) 953 struct qlcnic_pci_info *pci_info)
954 { 954 {
955 struct qlcnic_hardware_context *ahw = adapter->ahw; 955 struct qlcnic_hardware_context *ahw = adapter->ahw;
956 size_t npar_size = sizeof(struct qlcnic_pci_info_le); 956 size_t npar_size = sizeof(struct qlcnic_pci_info_le);
957 size_t pci_size = npar_size * ahw->max_vnic_func; 957 size_t pci_size = npar_size * ahw->max_vnic_func;
958 u16 nic = 0, fcoe = 0, iscsi = 0; 958 u16 nic = 0, fcoe = 0, iscsi = 0;
959 struct qlcnic_pci_info_le *npar; 959 struct qlcnic_pci_info_le *npar;
960 struct qlcnic_cmd_args cmd; 960 struct qlcnic_cmd_args cmd;
961 dma_addr_t pci_info_dma_t; 961 dma_addr_t pci_info_dma_t;
962 void *pci_info_addr; 962 void *pci_info_addr;
963 int err = 0, i; 963 int err = 0, i;
964 964
965 pci_info_addr = dma_zalloc_coherent(&adapter->pdev->dev, pci_size, 965 pci_info_addr = dma_zalloc_coherent(&adapter->pdev->dev, pci_size,
966 &pci_info_dma_t, GFP_KERNEL); 966 &pci_info_dma_t, GFP_KERNEL);
967 if (!pci_info_addr) 967 if (!pci_info_addr)
968 return -ENOMEM; 968 return -ENOMEM;
969 969
970 npar = pci_info_addr; 970 npar = pci_info_addr;
971 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_GET_PCI_INFO); 971 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_GET_PCI_INFO);
972 if (err) 972 if (err)
973 goto out_free_dma; 973 goto out_free_dma;
974 974
975 cmd.req.arg[1] = MSD(pci_info_dma_t); 975 cmd.req.arg[1] = MSD(pci_info_dma_t);
976 cmd.req.arg[2] = LSD(pci_info_dma_t); 976 cmd.req.arg[2] = LSD(pci_info_dma_t);
977 cmd.req.arg[3] = pci_size; 977 cmd.req.arg[3] = pci_size;
978 err = qlcnic_issue_cmd(adapter, &cmd); 978 err = qlcnic_issue_cmd(adapter, &cmd);
979 979
980 ahw->total_nic_func = 0; 980 ahw->total_nic_func = 0;
981 if (err == QLCNIC_RCODE_SUCCESS) { 981 if (err == QLCNIC_RCODE_SUCCESS) {
982 for (i = 0; i < ahw->max_vnic_func; i++, npar++, pci_info++) { 982 for (i = 0; i < ahw->max_vnic_func; i++, npar++, pci_info++) {
983 pci_info->id = le16_to_cpu(npar->id); 983 pci_info->id = le16_to_cpu(npar->id);
984 pci_info->active = le16_to_cpu(npar->active); 984 pci_info->active = le16_to_cpu(npar->active);
985 if (!pci_info->active) 985 if (!pci_info->active)
986 continue; 986 continue;
987 pci_info->type = le16_to_cpu(npar->type); 987 pci_info->type = le16_to_cpu(npar->type);
988 err = qlcnic_get_pci_func_type(adapter, pci_info->type, 988 err = qlcnic_get_pci_func_type(adapter, pci_info->type,
989 &nic, &fcoe, &iscsi); 989 &nic, &fcoe, &iscsi);
990 pci_info->default_port = 990 pci_info->default_port =
991 le16_to_cpu(npar->default_port); 991 le16_to_cpu(npar->default_port);
992 pci_info->tx_min_bw = 992 pci_info->tx_min_bw =
993 le16_to_cpu(npar->tx_min_bw); 993 le16_to_cpu(npar->tx_min_bw);
994 pci_info->tx_max_bw = 994 pci_info->tx_max_bw =
995 le16_to_cpu(npar->tx_max_bw); 995 le16_to_cpu(npar->tx_max_bw);
996 memcpy(pci_info->mac, npar->mac, ETH_ALEN); 996 memcpy(pci_info->mac, npar->mac, ETH_ALEN);
997 } 997 }
998 } else { 998 } else {
999 dev_err(&adapter->pdev->dev, 999 dev_err(&adapter->pdev->dev,
1000 "Failed to get PCI Info%d\n", err); 1000 "Failed to get PCI Info%d\n", err);
1001 err = -EIO; 1001 err = -EIO;
1002 } 1002 }
1003 1003
1004 ahw->total_nic_func = nic; 1004 ahw->total_nic_func = nic;
1005 ahw->total_pci_func = nic + fcoe + iscsi; 1005 ahw->total_pci_func = nic + fcoe + iscsi;
1006 if (ahw->total_nic_func == 0 || ahw->total_pci_func == 0) { 1006 if (ahw->total_nic_func == 0 || ahw->total_pci_func == 0) {
1007 dev_err(&adapter->pdev->dev, 1007 dev_err(&adapter->pdev->dev,
1008 "%s: Invalid function count: total nic func[%x], total pci func[%x]\n", 1008 "%s: Invalid function count: total nic func[%x], total pci func[%x]\n",
1009 __func__, ahw->total_nic_func, ahw->total_pci_func); 1009 __func__, ahw->total_nic_func, ahw->total_pci_func);
1010 err = -EIO; 1010 err = -EIO;
1011 } 1011 }
1012 qlcnic_free_mbx_args(&cmd); 1012 qlcnic_free_mbx_args(&cmd);
1013 out_free_dma: 1013 out_free_dma:
1014 dma_free_coherent(&adapter->pdev->dev, pci_size, pci_info_addr, 1014 dma_free_coherent(&adapter->pdev->dev, pci_size, pci_info_addr,
1015 pci_info_dma_t); 1015 pci_info_dma_t);
1016 1016
1017 return err; 1017 return err;
1018 } 1018 }
1019 1019
1020 /* Configure eSwitch for port mirroring */ 1020 /* Configure eSwitch for port mirroring */
1021 int qlcnic_config_port_mirroring(struct qlcnic_adapter *adapter, u8 id, 1021 int qlcnic_config_port_mirroring(struct qlcnic_adapter *adapter, u8 id,
1022 u8 enable_mirroring, u8 pci_func) 1022 u8 enable_mirroring, u8 pci_func)
1023 { 1023 {
1024 struct device *dev = &adapter->pdev->dev; 1024 struct device *dev = &adapter->pdev->dev;
1025 struct qlcnic_cmd_args cmd; 1025 struct qlcnic_cmd_args cmd;
1026 int err = -EIO; 1026 int err = -EIO;
1027 u32 arg1; 1027 u32 arg1;
1028 1028
1029 if (adapter->ahw->op_mode != QLCNIC_MGMT_FUNC || 1029 if (adapter->ahw->op_mode != QLCNIC_MGMT_FUNC ||
1030 !(adapter->eswitch[id].flags & QLCNIC_SWITCH_ENABLE)) { 1030 !(adapter->eswitch[id].flags & QLCNIC_SWITCH_ENABLE)) {
1031 dev_err(&adapter->pdev->dev, "%s: Not a management function\n", 1031 dev_err(&adapter->pdev->dev, "%s: Not a management function\n",
1032 __func__); 1032 __func__);
1033 return err; 1033 return err;
1034 } 1034 }
1035 1035
1036 arg1 = id | (enable_mirroring ? BIT_4 : 0); 1036 arg1 = id | (enable_mirroring ? BIT_4 : 0);
1037 arg1 |= pci_func << 8; 1037 arg1 |= pci_func << 8;
1038 1038
1039 err = qlcnic_alloc_mbx_args(&cmd, adapter, 1039 err = qlcnic_alloc_mbx_args(&cmd, adapter,
1040 QLCNIC_CMD_SET_PORTMIRRORING); 1040 QLCNIC_CMD_SET_PORTMIRRORING);
1041 if (err) 1041 if (err)
1042 return err; 1042 return err;
1043 1043
1044 cmd.req.arg[1] = arg1; 1044 cmd.req.arg[1] = arg1;
1045 err = qlcnic_issue_cmd(adapter, &cmd); 1045 err = qlcnic_issue_cmd(adapter, &cmd);
1046 1046
1047 if (err != QLCNIC_RCODE_SUCCESS) 1047 if (err != QLCNIC_RCODE_SUCCESS)
1048 dev_err(dev, "Failed to configure port mirroring for vNIC function %d on eSwitch %d\n", 1048 dev_err(dev, "Failed to configure port mirroring for vNIC function %d on eSwitch %d\n",
1049 pci_func, id); 1049 pci_func, id);
1050 else 1050 else
1051 dev_info(dev, "Configured port mirroring for vNIC function %d on eSwitch %d\n", 1051 dev_info(dev, "Configured port mirroring for vNIC function %d on eSwitch %d\n",
1052 pci_func, id); 1052 pci_func, id);
1053 qlcnic_free_mbx_args(&cmd); 1053 qlcnic_free_mbx_args(&cmd);
1054 1054
1055 return err; 1055 return err;
1056 } 1056 }
1057 1057
1058 int qlcnic_get_port_stats(struct qlcnic_adapter *adapter, const u8 func, 1058 int qlcnic_get_port_stats(struct qlcnic_adapter *adapter, const u8 func,
1059 const u8 rx_tx, struct __qlcnic_esw_statistics *esw_stats) { 1059 const u8 rx_tx, struct __qlcnic_esw_statistics *esw_stats) {
1060 1060
1061 size_t stats_size = sizeof(struct qlcnic_esw_stats_le); 1061 size_t stats_size = sizeof(struct qlcnic_esw_stats_le);
1062 struct qlcnic_esw_stats_le *stats; 1062 struct qlcnic_esw_stats_le *stats;
1063 dma_addr_t stats_dma_t; 1063 dma_addr_t stats_dma_t;
1064 void *stats_addr; 1064 void *stats_addr;
1065 u32 arg1; 1065 u32 arg1;
1066 struct qlcnic_cmd_args cmd; 1066 struct qlcnic_cmd_args cmd;
1067 int err; 1067 int err;
1068 1068
1069 if (esw_stats == NULL) 1069 if (esw_stats == NULL)
1070 return -ENOMEM; 1070 return -ENOMEM;
1071 1071
1072 if ((adapter->ahw->op_mode != QLCNIC_MGMT_FUNC) && 1072 if ((adapter->ahw->op_mode != QLCNIC_MGMT_FUNC) &&
1073 (func != adapter->ahw->pci_func)) { 1073 (func != adapter->ahw->pci_func)) {
1074 dev_err(&adapter->pdev->dev, 1074 dev_err(&adapter->pdev->dev,
1075 "Not privilege to query stats for func=%d", func); 1075 "Not privilege to query stats for func=%d", func);
1076 return -EIO; 1076 return -EIO;
1077 } 1077 }
1078 1078
1079 stats_addr = dma_zalloc_coherent(&adapter->pdev->dev, stats_size, 1079 stats_addr = dma_zalloc_coherent(&adapter->pdev->dev, stats_size,
1080 &stats_dma_t, GFP_KERNEL); 1080 &stats_dma_t, GFP_KERNEL);
1081 if (!stats_addr) 1081 if (!stats_addr)
1082 return -ENOMEM; 1082 return -ENOMEM;
1083 1083
1084 arg1 = func | QLCNIC_STATS_VERSION << 8 | QLCNIC_STATS_PORT << 12; 1084 arg1 = func | QLCNIC_STATS_VERSION << 8 | QLCNIC_STATS_PORT << 12;
1085 arg1 |= rx_tx << 15 | stats_size << 16; 1085 arg1 |= rx_tx << 15 | stats_size << 16;
1086 1086
1087 err = qlcnic_alloc_mbx_args(&cmd, adapter, 1087 err = qlcnic_alloc_mbx_args(&cmd, adapter,
1088 QLCNIC_CMD_GET_ESWITCH_STATS); 1088 QLCNIC_CMD_GET_ESWITCH_STATS);
1089 if (err) 1089 if (err)
1090 goto out_free_dma; 1090 goto out_free_dma;
1091 1091
1092 cmd.req.arg[1] = arg1; 1092 cmd.req.arg[1] = arg1;
1093 cmd.req.arg[2] = MSD(stats_dma_t); 1093 cmd.req.arg[2] = MSD(stats_dma_t);
1094 cmd.req.arg[3] = LSD(stats_dma_t); 1094 cmd.req.arg[3] = LSD(stats_dma_t);
1095 err = qlcnic_issue_cmd(adapter, &cmd); 1095 err = qlcnic_issue_cmd(adapter, &cmd);
1096 1096
1097 if (!err) { 1097 if (!err) {
1098 stats = stats_addr; 1098 stats = stats_addr;
1099 esw_stats->context_id = le16_to_cpu(stats->context_id); 1099 esw_stats->context_id = le16_to_cpu(stats->context_id);
1100 esw_stats->version = le16_to_cpu(stats->version); 1100 esw_stats->version = le16_to_cpu(stats->version);
1101 esw_stats->size = le16_to_cpu(stats->size); 1101 esw_stats->size = le16_to_cpu(stats->size);
1102 esw_stats->multicast_frames = 1102 esw_stats->multicast_frames =
1103 le64_to_cpu(stats->multicast_frames); 1103 le64_to_cpu(stats->multicast_frames);
1104 esw_stats->broadcast_frames = 1104 esw_stats->broadcast_frames =
1105 le64_to_cpu(stats->broadcast_frames); 1105 le64_to_cpu(stats->broadcast_frames);
1106 esw_stats->unicast_frames = le64_to_cpu(stats->unicast_frames); 1106 esw_stats->unicast_frames = le64_to_cpu(stats->unicast_frames);
1107 esw_stats->dropped_frames = le64_to_cpu(stats->dropped_frames); 1107 esw_stats->dropped_frames = le64_to_cpu(stats->dropped_frames);
1108 esw_stats->local_frames = le64_to_cpu(stats->local_frames); 1108 esw_stats->local_frames = le64_to_cpu(stats->local_frames);
1109 esw_stats->errors = le64_to_cpu(stats->errors); 1109 esw_stats->errors = le64_to_cpu(stats->errors);
1110 esw_stats->numbytes = le64_to_cpu(stats->numbytes); 1110 esw_stats->numbytes = le64_to_cpu(stats->numbytes);
1111 } 1111 }
1112 1112
1113 qlcnic_free_mbx_args(&cmd); 1113 qlcnic_free_mbx_args(&cmd);
1114 out_free_dma: 1114 out_free_dma:
1115 dma_free_coherent(&adapter->pdev->dev, stats_size, stats_addr, 1115 dma_free_coherent(&adapter->pdev->dev, stats_size, stats_addr,
1116 stats_dma_t); 1116 stats_dma_t);
1117 1117
1118 return err; 1118 return err;
1119 } 1119 }
1120 1120
1121 /* This routine will retrieve the MAC statistics from firmware */ 1121 /* This routine will retrieve the MAC statistics from firmware */
1122 int qlcnic_get_mac_stats(struct qlcnic_adapter *adapter, 1122 int qlcnic_get_mac_stats(struct qlcnic_adapter *adapter,
1123 struct qlcnic_mac_statistics *mac_stats) 1123 struct qlcnic_mac_statistics *mac_stats)
1124 { 1124 {
1125 struct qlcnic_mac_statistics_le *stats; 1125 struct qlcnic_mac_statistics_le *stats;
1126 struct qlcnic_cmd_args cmd; 1126 struct qlcnic_cmd_args cmd;
1127 size_t stats_size = sizeof(struct qlcnic_mac_statistics_le); 1127 size_t stats_size = sizeof(struct qlcnic_mac_statistics_le);
1128 dma_addr_t stats_dma_t; 1128 dma_addr_t stats_dma_t;
1129 void *stats_addr; 1129 void *stats_addr;
1130 int err; 1130 int err;
1131 1131
1132 if (mac_stats == NULL) 1132 if (mac_stats == NULL)
1133 return -ENOMEM; 1133 return -ENOMEM;
1134 1134
1135 stats_addr = dma_zalloc_coherent(&adapter->pdev->dev, stats_size, 1135 stats_addr = dma_zalloc_coherent(&adapter->pdev->dev, stats_size,
1136 &stats_dma_t, GFP_KERNEL); 1136 &stats_dma_t, GFP_KERNEL);
1137 if (!stats_addr) 1137 if (!stats_addr)
1138 return -ENOMEM; 1138 return -ENOMEM;
1139 1139
1140 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_GET_MAC_STATS); 1140 err = qlcnic_alloc_mbx_args(&cmd, adapter, QLCNIC_CMD_GET_MAC_STATS);
1141 if (err) 1141 if (err)
1142 goto out_free_dma; 1142 goto out_free_dma;
1143 1143
1144 cmd.req.arg[1] = stats_size << 16; 1144 cmd.req.arg[1] = stats_size << 16;
1145 cmd.req.arg[2] = MSD(stats_dma_t); 1145 cmd.req.arg[2] = MSD(stats_dma_t);
1146 cmd.req.arg[3] = LSD(stats_dma_t); 1146 cmd.req.arg[3] = LSD(stats_dma_t);
1147 err = qlcnic_issue_cmd(adapter, &cmd); 1147 err = qlcnic_issue_cmd(adapter, &cmd);
1148 if (!err) { 1148 if (!err) {
1149 stats = stats_addr; 1149 stats = stats_addr;
1150 mac_stats->mac_tx_frames = le64_to_cpu(stats->mac_tx_frames); 1150 mac_stats->mac_tx_frames = le64_to_cpu(stats->mac_tx_frames);
1151 mac_stats->mac_tx_bytes = le64_to_cpu(stats->mac_tx_bytes); 1151 mac_stats->mac_tx_bytes = le64_to_cpu(stats->mac_tx_bytes);
1152 mac_stats->mac_tx_mcast_pkts = 1152 mac_stats->mac_tx_mcast_pkts =
1153 le64_to_cpu(stats->mac_tx_mcast_pkts); 1153 le64_to_cpu(stats->mac_tx_mcast_pkts);
1154 mac_stats->mac_tx_bcast_pkts = 1154 mac_stats->mac_tx_bcast_pkts =
1155 le64_to_cpu(stats->mac_tx_bcast_pkts); 1155 le64_to_cpu(stats->mac_tx_bcast_pkts);
1156 mac_stats->mac_rx_frames = le64_to_cpu(stats->mac_rx_frames); 1156 mac_stats->mac_rx_frames = le64_to_cpu(stats->mac_rx_frames);
1157 mac_stats->mac_rx_bytes = le64_to_cpu(stats->mac_rx_bytes); 1157 mac_stats->mac_rx_bytes = le64_to_cpu(stats->mac_rx_bytes);
1158 mac_stats->mac_rx_mcast_pkts = 1158 mac_stats->mac_rx_mcast_pkts =
1159 le64_to_cpu(stats->mac_rx_mcast_pkts); 1159 le64_to_cpu(stats->mac_rx_mcast_pkts);
1160 mac_stats->mac_rx_length_error = 1160 mac_stats->mac_rx_length_error =
1161 le64_to_cpu(stats->mac_rx_length_error); 1161 le64_to_cpu(stats->mac_rx_length_error);
1162 mac_stats->mac_rx_length_small = 1162 mac_stats->mac_rx_length_small =
1163 le64_to_cpu(stats->mac_rx_length_small); 1163 le64_to_cpu(stats->mac_rx_length_small);
1164 mac_stats->mac_rx_length_large = 1164 mac_stats->mac_rx_length_large =
1165 le64_to_cpu(stats->mac_rx_length_large); 1165 le64_to_cpu(stats->mac_rx_length_large);
1166 mac_stats->mac_rx_jabber = le64_to_cpu(stats->mac_rx_jabber); 1166 mac_stats->mac_rx_jabber = le64_to_cpu(stats->mac_rx_jabber);
1167 mac_stats->mac_rx_dropped = le64_to_cpu(stats->mac_rx_dropped); 1167 mac_stats->mac_rx_dropped = le64_to_cpu(stats->mac_rx_dropped);
1168 mac_stats->mac_rx_crc_error = le64_to_cpu(stats->mac_rx_crc_error); 1168 mac_stats->mac_rx_crc_error = le64_to_cpu(stats->mac_rx_crc_error);
1169 } else { 1169 } else {
1170 dev_err(&adapter->pdev->dev, 1170 dev_err(&adapter->pdev->dev,
1171 "%s: Get mac stats failed, err=%d.\n", __func__, err); 1171 "%s: Get mac stats failed, err=%d.\n", __func__, err);
1172 } 1172 }
1173 1173
1174 qlcnic_free_mbx_args(&cmd); 1174 qlcnic_free_mbx_args(&cmd);
1175 1175
1176 out_free_dma: 1176 out_free_dma:
1177 dma_free_coherent(&adapter->pdev->dev, stats_size, stats_addr, 1177 dma_free_coherent(&adapter->pdev->dev, stats_size, stats_addr,
1178 stats_dma_t); 1178 stats_dma_t);
1179 1179
1180 return err; 1180 return err;
1181 } 1181 }
1182 1182
1183 int qlcnic_get_eswitch_stats(struct qlcnic_adapter *adapter, const u8 eswitch, 1183 int qlcnic_get_eswitch_stats(struct qlcnic_adapter *adapter, const u8 eswitch,
1184 const u8 rx_tx, struct __qlcnic_esw_statistics *esw_stats) { 1184 const u8 rx_tx, struct __qlcnic_esw_statistics *esw_stats) {
1185 1185
1186 struct __qlcnic_esw_statistics port_stats; 1186 struct __qlcnic_esw_statistics port_stats;
1187 u8 i; 1187 u8 i;
1188 int ret = -EIO; 1188 int ret = -EIO;
1189 1189
1190 if (esw_stats == NULL) 1190 if (esw_stats == NULL)
1191 return -ENOMEM; 1191 return -ENOMEM;
1192 if (adapter->ahw->op_mode != QLCNIC_MGMT_FUNC) 1192 if (adapter->ahw->op_mode != QLCNIC_MGMT_FUNC)
1193 return -EIO; 1193 return -EIO;
1194 if (adapter->npars == NULL) 1194 if (adapter->npars == NULL)
1195 return -EIO; 1195 return -EIO;
1196 1196
1197 memset(esw_stats, 0, sizeof(u64)); 1197 memset(esw_stats, 0, sizeof(u64));
1198 esw_stats->unicast_frames = QLCNIC_STATS_NOT_AVAIL; 1198 esw_stats->unicast_frames = QLCNIC_STATS_NOT_AVAIL;
1199 esw_stats->multicast_frames = QLCNIC_STATS_NOT_AVAIL; 1199 esw_stats->multicast_frames = QLCNIC_STATS_NOT_AVAIL;
1200 esw_stats->broadcast_frames = QLCNIC_STATS_NOT_AVAIL; 1200 esw_stats->broadcast_frames = QLCNIC_STATS_NOT_AVAIL;
1201 esw_stats->dropped_frames = QLCNIC_STATS_NOT_AVAIL; 1201 esw_stats->dropped_frames = QLCNIC_STATS_NOT_AVAIL;
1202 esw_stats->errors = QLCNIC_STATS_NOT_AVAIL; 1202 esw_stats->errors = QLCNIC_STATS_NOT_AVAIL;
1203 esw_stats->local_frames = QLCNIC_STATS_NOT_AVAIL; 1203 esw_stats->local_frames = QLCNIC_STATS_NOT_AVAIL;
1204 esw_stats->numbytes = QLCNIC_STATS_NOT_AVAIL; 1204 esw_stats->numbytes = QLCNIC_STATS_NOT_AVAIL;
1205 esw_stats->context_id = eswitch; 1205 esw_stats->context_id = eswitch;
1206 1206
1207 for (i = 0; i < adapter->ahw->total_nic_func; i++) { 1207 for (i = 0; i < adapter->ahw->total_nic_func; i++) {
1208 if (adapter->npars[i].phy_port != eswitch) 1208 if (adapter->npars[i].phy_port != eswitch)
1209 continue; 1209 continue;
1210 1210
1211 memset(&port_stats, 0, sizeof(struct __qlcnic_esw_statistics)); 1211 memset(&port_stats, 0, sizeof(struct __qlcnic_esw_statistics));
1212 if (qlcnic_get_port_stats(adapter, adapter->npars[i].pci_func, 1212 if (qlcnic_get_port_stats(adapter, adapter->npars[i].pci_func,
1213 rx_tx, &port_stats)) 1213 rx_tx, &port_stats))
1214 continue; 1214 continue;
1215 1215
1216 esw_stats->size = port_stats.size; 1216 esw_stats->size = port_stats.size;
1217 esw_stats->version = port_stats.version; 1217 esw_stats->version = port_stats.version;
1218 QLCNIC_ADD_ESW_STATS(esw_stats->unicast_frames, 1218 QLCNIC_ADD_ESW_STATS(esw_stats->unicast_frames,
1219 port_stats.unicast_frames); 1219 port_stats.unicast_frames);
1220 QLCNIC_ADD_ESW_STATS(esw_stats->multicast_frames, 1220 QLCNIC_ADD_ESW_STATS(esw_stats->multicast_frames,
1221 port_stats.multicast_frames); 1221 port_stats.multicast_frames);
1222 QLCNIC_ADD_ESW_STATS(esw_stats->broadcast_frames, 1222 QLCNIC_ADD_ESW_STATS(esw_stats->broadcast_frames,
1223 port_stats.broadcast_frames); 1223 port_stats.broadcast_frames);
1224 QLCNIC_ADD_ESW_STATS(esw_stats->dropped_frames, 1224 QLCNIC_ADD_ESW_STATS(esw_stats->dropped_frames,
1225 port_stats.dropped_frames); 1225 port_stats.dropped_frames);
1226 QLCNIC_ADD_ESW_STATS(esw_stats->errors, 1226 QLCNIC_ADD_ESW_STATS(esw_stats->errors,
1227 port_stats.errors); 1227 port_stats.errors);
1228 QLCNIC_ADD_ESW_STATS(esw_stats->local_frames, 1228 QLCNIC_ADD_ESW_STATS(esw_stats->local_frames,
1229 port_stats.local_frames); 1229 port_stats.local_frames);
1230 QLCNIC_ADD_ESW_STATS(esw_stats->numbytes, 1230 QLCNIC_ADD_ESW_STATS(esw_stats->numbytes,
1231 port_stats.numbytes); 1231 port_stats.numbytes);
1232 ret = 0; 1232 ret = 0;
1233 } 1233 }
1234 return ret; 1234 return ret;
1235 } 1235 }
1236 1236
1237 int qlcnic_clear_esw_stats(struct qlcnic_adapter *adapter, const u8 func_esw, 1237 int qlcnic_clear_esw_stats(struct qlcnic_adapter *adapter, const u8 func_esw,
1238 const u8 port, const u8 rx_tx) 1238 const u8 port, const u8 rx_tx)
1239 { 1239 {
1240 struct qlcnic_hardware_context *ahw = adapter->ahw; 1240 struct qlcnic_hardware_context *ahw = adapter->ahw;
1241 struct qlcnic_cmd_args cmd; 1241 struct qlcnic_cmd_args cmd;
1242 int err; 1242 int err;
1243 u32 arg1; 1243 u32 arg1;
1244 1244
1245 if (ahw->op_mode != QLCNIC_MGMT_FUNC) 1245 if (ahw->op_mode != QLCNIC_MGMT_FUNC)
1246 return -EIO; 1246 return -EIO;
1247 1247
1248 if (func_esw == QLCNIC_STATS_PORT) { 1248 if (func_esw == QLCNIC_STATS_PORT) {
1249 if (port >= ahw->max_vnic_func) 1249 if (port >= ahw->max_vnic_func)
1250 goto err_ret; 1250 goto err_ret;
1251 } else if (func_esw == QLCNIC_STATS_ESWITCH) { 1251 } else if (func_esw == QLCNIC_STATS_ESWITCH) {
1252 if (port >= QLCNIC_NIU_MAX_XG_PORTS) 1252 if (port >= QLCNIC_NIU_MAX_XG_PORTS)
1253 goto err_ret; 1253 goto err_ret;
1254 } else { 1254 } else {
1255 goto err_ret; 1255 goto err_ret;
1256 } 1256 }
1257 1257
1258 if (rx_tx > QLCNIC_QUERY_TX_COUNTER) 1258 if (rx_tx > QLCNIC_QUERY_TX_COUNTER)
1259 goto err_ret; 1259 goto err_ret;
1260 1260
1261 arg1 = port | QLCNIC_STATS_VERSION << 8 | func_esw << 12; 1261 arg1 = port | QLCNIC_STATS_VERSION << 8 | func_esw << 12;
1262 arg1 |= BIT_14 | rx_tx << 15; 1262 arg1 |= BIT_14 | rx_tx << 15;
1263 1263
1264 err = qlcnic_alloc_mbx_args(&cmd, adapter, 1264 err = qlcnic_alloc_mbx_args(&cmd, adapter,
1265 QLCNIC_CMD_GET_ESWITCH_STATS); 1265 QLCNIC_CMD_GET_ESWITCH_STATS);
1266 if (err) 1266 if (err)
1267 return err; 1267 return err;
1268 1268
1269 cmd.req.arg[1] = arg1; 1269 cmd.req.arg[1] = arg1;
1270 err = qlcnic_issue_cmd(adapter, &cmd); 1270 err = qlcnic_issue_cmd(adapter, &cmd);
1271 qlcnic_free_mbx_args(&cmd); 1271 qlcnic_free_mbx_args(&cmd);
1272 return err; 1272 return err;
1273 1273
1274 err_ret: 1274 err_ret:
1275 dev_err(&adapter->pdev->dev, 1275 dev_err(&adapter->pdev->dev,
1276 "Invalid args func_esw %d port %d rx_ctx %d\n", 1276 "Invalid args func_esw %d port %d rx_ctx %d\n",
1277 func_esw, port, rx_tx); 1277 func_esw, port, rx_tx);
1278 return -EIO; 1278 return -EIO;
1279 } 1279 }
1280 1280
1281 static int __qlcnic_get_eswitch_port_config(struct qlcnic_adapter *adapter, 1281 static int __qlcnic_get_eswitch_port_config(struct qlcnic_adapter *adapter,
1282 u32 *arg1, u32 *arg2) 1282 u32 *arg1, u32 *arg2)
1283 { 1283 {
1284 struct device *dev = &adapter->pdev->dev; 1284 struct device *dev = &adapter->pdev->dev;
1285 struct qlcnic_cmd_args cmd; 1285 struct qlcnic_cmd_args cmd;
1286 u8 pci_func = *arg1 >> 8; 1286 u8 pci_func = *arg1 >> 8;
1287 int err; 1287 int err;
1288 1288
1289 err = qlcnic_alloc_mbx_args(&cmd, adapter, 1289 err = qlcnic_alloc_mbx_args(&cmd, adapter,
1290 QLCNIC_CMD_GET_ESWITCH_PORT_CONFIG); 1290 QLCNIC_CMD_GET_ESWITCH_PORT_CONFIG);
1291 if (err) 1291 if (err)
1292 return err; 1292 return err;
1293 1293
1294 cmd.req.arg[1] = *arg1; 1294 cmd.req.arg[1] = *arg1;
1295 err = qlcnic_issue_cmd(adapter, &cmd); 1295 err = qlcnic_issue_cmd(adapter, &cmd);
1296 *arg1 = cmd.rsp.arg[1]; 1296 *arg1 = cmd.rsp.arg[1];
1297 *arg2 = cmd.rsp.arg[2]; 1297 *arg2 = cmd.rsp.arg[2];
1298 qlcnic_free_mbx_args(&cmd); 1298 qlcnic_free_mbx_args(&cmd);
1299 1299
1300 if (err == QLCNIC_RCODE_SUCCESS) 1300 if (err == QLCNIC_RCODE_SUCCESS)
1301 dev_info(dev, "Get eSwitch port config for vNIC function %d\n", 1301 dev_info(dev, "Get eSwitch port config for vNIC function %d\n",
1302 pci_func); 1302 pci_func);
1303 else 1303 else
1304 dev_err(dev, "Failed to get eswitch port config for vNIC function %d\n", 1304 dev_err(dev, "Failed to get eswitch port config for vNIC function %d\n",
1305 pci_func); 1305 pci_func);
1306 return err; 1306 return err;
1307 } 1307 }
1308 /* Configure eSwitch port 1308 /* Configure eSwitch port
1309 op_mode = 0 for setting default port behavior 1309 op_mode = 0 for setting default port behavior
1310 op_mode = 1 for setting vlan id 1310 op_mode = 1 for setting vlan id
1311 op_mode = 2 for deleting vlan id 1311 op_mode = 2 for deleting vlan id
1312 op_type = 0 for vlan_id 1312 op_type = 0 for vlan_id
1313 op_type = 1 for port vlan_id 1313 op_type = 1 for port vlan_id
1314 */ 1314 */
1315 int qlcnic_config_switch_port(struct qlcnic_adapter *adapter, 1315 int qlcnic_config_switch_port(struct qlcnic_adapter *adapter,
1316 struct qlcnic_esw_func_cfg *esw_cfg) 1316 struct qlcnic_esw_func_cfg *esw_cfg)
1317 { 1317 {
1318 struct device *dev = &adapter->pdev->dev; 1318 struct device *dev = &adapter->pdev->dev;
1319 struct qlcnic_cmd_args cmd; 1319 struct qlcnic_cmd_args cmd;
1320 int err = -EIO, index; 1320 int err = -EIO, index;
1321 u32 arg1, arg2 = 0; 1321 u32 arg1, arg2 = 0;
1322 u8 pci_func; 1322 u8 pci_func;
1323 1323
1324 if (adapter->ahw->op_mode != QLCNIC_MGMT_FUNC) { 1324 if (adapter->ahw->op_mode != QLCNIC_MGMT_FUNC) {
1325 dev_err(&adapter->pdev->dev, "%s: Not a management function\n", 1325 dev_err(&adapter->pdev->dev, "%s: Not a management function\n",
1326 __func__); 1326 __func__);
1327 return err; 1327 return err;
1328 } 1328 }
1329 1329
1330 pci_func = esw_cfg->pci_func; 1330 pci_func = esw_cfg->pci_func;
1331 index = qlcnic_is_valid_nic_func(adapter, pci_func); 1331 index = qlcnic_is_valid_nic_func(adapter, pci_func);
1332 if (index < 0) 1332 if (index < 0)
1333 return err; 1333 return err;
1334 arg1 = (adapter->npars[index].phy_port & BIT_0); 1334 arg1 = (adapter->npars[index].phy_port & BIT_0);
1335 arg1 |= (pci_func << 8); 1335 arg1 |= (pci_func << 8);
1336 1336
1337 if (__qlcnic_get_eswitch_port_config(adapter, &arg1, &arg2)) 1337 if (__qlcnic_get_eswitch_port_config(adapter, &arg1, &arg2))
1338 return err; 1338 return err;
1339 arg1 &= ~(0x0ff << 8); 1339 arg1 &= ~(0x0ff << 8);
1340 arg1 |= (pci_func << 8); 1340 arg1 |= (pci_func << 8);
1341 arg1 &= ~(BIT_2 | BIT_3); 1341 arg1 &= ~(BIT_2 | BIT_3);
1342 switch (esw_cfg->op_mode) { 1342 switch (esw_cfg->op_mode) {
1343 case QLCNIC_PORT_DEFAULTS: 1343 case QLCNIC_PORT_DEFAULTS:
1344 arg1 |= (BIT_4 | BIT_6 | BIT_7); 1344 arg1 |= (BIT_4 | BIT_6 | BIT_7);
1345 arg2 |= (BIT_0 | BIT_1); 1345 arg2 |= (BIT_0 | BIT_1);
1346 if (adapter->ahw->capabilities & QLCNIC_FW_CAPABILITY_TSO) 1346 if (adapter->ahw->capabilities & QLCNIC_FW_CAPABILITY_TSO)
1347 arg2 |= (BIT_2 | BIT_3); 1347 arg2 |= (BIT_2 | BIT_3);
1348 if (!(esw_cfg->discard_tagged)) 1348 if (!(esw_cfg->discard_tagged))
1349 arg1 &= ~BIT_4; 1349 arg1 &= ~BIT_4;
1350 if (!(esw_cfg->promisc_mode)) 1350 if (!(esw_cfg->promisc_mode))
1351 arg1 &= ~BIT_6; 1351 arg1 &= ~BIT_6;
1352 if (!(esw_cfg->mac_override)) 1352 if (!(esw_cfg->mac_override))
1353 arg1 &= ~BIT_7; 1353 arg1 &= ~BIT_7;
1354 if (!(esw_cfg->mac_anti_spoof)) 1354 if (!(esw_cfg->mac_anti_spoof))
1355 arg2 &= ~BIT_0; 1355 arg2 &= ~BIT_0;
1356 if (!(esw_cfg->offload_flags & BIT_0)) 1356 if (!(esw_cfg->offload_flags & BIT_0))
1357 arg2 &= ~(BIT_1 | BIT_2 | BIT_3); 1357 arg2 &= ~(BIT_1 | BIT_2 | BIT_3);
1358 if (!(esw_cfg->offload_flags & BIT_1)) 1358 if (!(esw_cfg->offload_flags & BIT_1))
1359 arg2 &= ~BIT_2; 1359 arg2 &= ~BIT_2;
1360 if (!(esw_cfg->offload_flags & BIT_2)) 1360 if (!(esw_cfg->offload_flags & BIT_2))
1361 arg2 &= ~BIT_3; 1361 arg2 &= ~BIT_3;
1362 break; 1362 break;
1363 case QLCNIC_ADD_VLAN: 1363 case QLCNIC_ADD_VLAN:
1364 arg1 &= ~(0x0ffff << 16); 1364 arg1 &= ~(0x0ffff << 16);
1365 arg1 |= (BIT_2 | BIT_5); 1365 arg1 |= (BIT_2 | BIT_5);
1366 arg1 |= (esw_cfg->vlan_id << 16); 1366 arg1 |= (esw_cfg->vlan_id << 16);
1367 break; 1367 break;
1368 case QLCNIC_DEL_VLAN: 1368 case QLCNIC_DEL_VLAN:
1369 arg1 |= (BIT_3 | BIT_5); 1369 arg1 |= (BIT_3 | BIT_5);
1370 arg1 &= ~(0x0ffff << 16); 1370 arg1 &= ~(0x0ffff << 16);
1371 break; 1371 break;
1372 default: 1372 default:
1373 dev_err(&adapter->pdev->dev, "%s: Invalid opmode 0x%x\n", 1373 dev_err(&adapter->pdev->dev, "%s: Invalid opmode 0x%x\n",
1374 __func__, esw_cfg->op_mode); 1374 __func__, esw_cfg->op_mode);
1375 return err; 1375 return err;
1376 } 1376 }
1377 1377
1378 err = qlcnic_alloc_mbx_args(&cmd, adapter, 1378 err = qlcnic_alloc_mbx_args(&cmd, adapter,
1379 QLCNIC_CMD_CONFIGURE_ESWITCH); 1379 QLCNIC_CMD_CONFIGURE_ESWITCH);
1380 if (err) 1380 if (err)
1381 return err; 1381 return err;
1382 1382
1383 cmd.req.arg[1] = arg1; 1383 cmd.req.arg[1] = arg1;
1384 cmd.req.arg[2] = arg2; 1384 cmd.req.arg[2] = arg2;
1385 err = qlcnic_issue_cmd(adapter, &cmd); 1385 err = qlcnic_issue_cmd(adapter, &cmd);
1386 qlcnic_free_mbx_args(&cmd); 1386 qlcnic_free_mbx_args(&cmd);
1387 1387
1388 if (err != QLCNIC_RCODE_SUCCESS) 1388 if (err != QLCNIC_RCODE_SUCCESS)
1389 dev_err(dev, "Failed to configure eswitch for vNIC function %d\n", 1389 dev_err(dev, "Failed to configure eswitch for vNIC function %d\n",
1390 pci_func); 1390 pci_func);
1391 else 1391 else
1392 dev_info(dev, "Configured eSwitch for vNIC function %d\n", 1392 dev_info(dev, "Configured eSwitch for vNIC function %d\n",
1393 pci_func); 1393 pci_func);
1394 1394
1395 return err; 1395 return err;
1396 } 1396 }
1397 1397
1398 int 1398 int
1399 qlcnic_get_eswitch_port_config(struct qlcnic_adapter *adapter, 1399 qlcnic_get_eswitch_port_config(struct qlcnic_adapter *adapter,
1400 struct qlcnic_esw_func_cfg *esw_cfg) 1400 struct qlcnic_esw_func_cfg *esw_cfg)
1401 { 1401 {
1402 u32 arg1, arg2; 1402 u32 arg1, arg2;
1403 int index; 1403 int index;
1404 u8 phy_port; 1404 u8 phy_port;
1405 1405
1406 if (adapter->ahw->op_mode == QLCNIC_MGMT_FUNC) { 1406 if (adapter->ahw->op_mode == QLCNIC_MGMT_FUNC) {
1407 index = qlcnic_is_valid_nic_func(adapter, esw_cfg->pci_func); 1407 index = qlcnic_is_valid_nic_func(adapter, esw_cfg->pci_func);
1408 if (index < 0) 1408 if (index < 0)
1409 return -EIO; 1409 return -EIO;
1410 phy_port = adapter->npars[index].phy_port; 1410 phy_port = adapter->npars[index].phy_port;
1411 } else { 1411 } else {
1412 phy_port = adapter->ahw->physical_port; 1412 phy_port = adapter->ahw->physical_port;
1413 } 1413 }
1414 arg1 = phy_port; 1414 arg1 = phy_port;
1415 arg1 |= (esw_cfg->pci_func << 8); 1415 arg1 |= (esw_cfg->pci_func << 8);
1416 if (__qlcnic_get_eswitch_port_config(adapter, &arg1, &arg2)) 1416 if (__qlcnic_get_eswitch_port_config(adapter, &arg1, &arg2))
1417 return -EIO; 1417 return -EIO;
1418 1418
1419 esw_cfg->discard_tagged = !!(arg1 & BIT_4); 1419 esw_cfg->discard_tagged = !!(arg1 & BIT_4);
1420 esw_cfg->host_vlan_tag = !!(arg1 & BIT_5); 1420 esw_cfg->host_vlan_tag = !!(arg1 & BIT_5);
1421 esw_cfg->promisc_mode = !!(arg1 & BIT_6); 1421 esw_cfg->promisc_mode = !!(arg1 & BIT_6);
1422 esw_cfg->mac_override = !!(arg1 & BIT_7); 1422 esw_cfg->mac_override = !!(arg1 & BIT_7);
1423 esw_cfg->vlan_id = LSW(arg1 >> 16); 1423 esw_cfg->vlan_id = LSW(arg1 >> 16);
1424 esw_cfg->mac_anti_spoof = (arg2 & 0x1); 1424 esw_cfg->mac_anti_spoof = (arg2 & 0x1);
1425 esw_cfg->offload_flags = ((arg2 >> 1) & 0x7); 1425 esw_cfg->offload_flags = ((arg2 >> 1) & 0x7);
1426 1426
1427 return 0; 1427 return 0;
1428 } 1428 }
1429 1429