2 * Copyright (C) 2009 - QLogic Corporation.
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU General Public License
7 * as published by the Free Software Foundation; either version 2
8 * of the License, or (at your option) any later version.
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
20 * The full GNU General Public License is included in this distribution
21 * in the file called "COPYING".
28 qlcnic_poll_rsp(struct qlcnic_adapter
*adapter
)
34 /* give atleast 1ms for firmware to respond */
37 if (++timeout
> QLCNIC_OS_CRB_RETRY_COUNT
)
38 return QLCNIC_CDRP_RSP_TIMEOUT
;
40 rsp
= QLCRD32(adapter
, QLCNIC_CDRP_CRB_OFFSET
);
41 } while (!QLCNIC_CDRP_IS_RSP(rsp
));
47 qlcnic_issue_cmd(struct qlcnic_adapter
*adapter
,
48 u32 pci_fn
, u32 version
, u32 arg1
, u32 arg2
, u32 arg3
, u32 cmd
)
52 u32 rcode
= QLCNIC_RCODE_SUCCESS
;
53 struct pci_dev
*pdev
= adapter
->pdev
;
55 signature
= QLCNIC_CDRP_SIGNATURE_MAKE(pci_fn
, version
);
57 /* Acquire semaphore before accessing CRB */
58 if (qlcnic_api_lock(adapter
))
59 return QLCNIC_RCODE_TIMEOUT
;
61 QLCWR32(adapter
, QLCNIC_SIGN_CRB_OFFSET
, signature
);
62 QLCWR32(adapter
, QLCNIC_ARG1_CRB_OFFSET
, arg1
);
63 QLCWR32(adapter
, QLCNIC_ARG2_CRB_OFFSET
, arg2
);
64 QLCWR32(adapter
, QLCNIC_ARG3_CRB_OFFSET
, arg3
);
65 QLCWR32(adapter
, QLCNIC_CDRP_CRB_OFFSET
, QLCNIC_CDRP_FORM_CMD(cmd
));
67 rsp
= qlcnic_poll_rsp(adapter
);
69 if (rsp
== QLCNIC_CDRP_RSP_TIMEOUT
) {
70 dev_err(&pdev
->dev
, "card response timeout.\n");
71 rcode
= QLCNIC_RCODE_TIMEOUT
;
72 } else if (rsp
== QLCNIC_CDRP_RSP_FAIL
) {
73 rcode
= QLCRD32(adapter
, QLCNIC_ARG1_CRB_OFFSET
);
74 dev_err(&pdev
->dev
, "failed card response code:0x%x\n",
78 /* Release semaphore */
79 qlcnic_api_unlock(adapter
);
85 qlcnic_fw_cmd_set_mtu(struct qlcnic_adapter
*adapter
, int mtu
)
87 struct qlcnic_recv_context
*recv_ctx
= &adapter
->recv_ctx
;
89 if (recv_ctx
->state
== QLCNIC_HOST_CTX_STATE_ACTIVE
) {
90 if (qlcnic_issue_cmd(adapter
,
91 adapter
->ahw
.pci_func
,
96 QLCNIC_CDRP_CMD_SET_MTU
)) {
98 dev_err(&adapter
->pdev
->dev
, "Failed to set mtu\n");
107 qlcnic_fw_cmd_create_rx_ctx(struct qlcnic_adapter
*adapter
)
110 struct qlcnic_hostrq_rx_ctx
*prq
;
111 struct qlcnic_cardrsp_rx_ctx
*prsp
;
112 struct qlcnic_hostrq_rds_ring
*prq_rds
;
113 struct qlcnic_hostrq_sds_ring
*prq_sds
;
114 struct qlcnic_cardrsp_rds_ring
*prsp_rds
;
115 struct qlcnic_cardrsp_sds_ring
*prsp_sds
;
116 struct qlcnic_host_rds_ring
*rds_ring
;
117 struct qlcnic_host_sds_ring
*sds_ring
;
119 dma_addr_t hostrq_phys_addr
, cardrsp_phys_addr
;
122 int i
, nrds_rings
, nsds_rings
;
123 size_t rq_size
, rsp_size
;
127 struct qlcnic_recv_context
*recv_ctx
= &adapter
->recv_ctx
;
129 nrds_rings
= adapter
->max_rds_rings
;
130 nsds_rings
= adapter
->max_sds_rings
;
133 SIZEOF_HOSTRQ_RX(struct qlcnic_hostrq_rx_ctx
, nrds_rings
,
136 SIZEOF_CARDRSP_RX(struct qlcnic_cardrsp_rx_ctx
, nrds_rings
,
139 addr
= pci_alloc_consistent(adapter
->pdev
,
140 rq_size
, &hostrq_phys_addr
);
143 prq
= (struct qlcnic_hostrq_rx_ctx
*)addr
;
145 addr
= pci_alloc_consistent(adapter
->pdev
,
146 rsp_size
, &cardrsp_phys_addr
);
151 prsp
= (struct qlcnic_cardrsp_rx_ctx
*)addr
;
153 prq
->host_rsp_dma_addr
= cpu_to_le64(cardrsp_phys_addr
);
155 cap
= (QLCNIC_CAP0_LEGACY_CONTEXT
| QLCNIC_CAP0_LEGACY_MN
);
156 cap
|= (QLCNIC_CAP0_JUMBO_CONTIGUOUS
| QLCNIC_CAP0_LRO_CONTIGUOUS
);
158 prq
->capabilities
[0] = cpu_to_le32(cap
);
159 prq
->host_int_crb_mode
=
160 cpu_to_le32(QLCNIC_HOST_INT_CRB_MODE_SHARED
);
161 prq
->host_rds_crb_mode
=
162 cpu_to_le32(QLCNIC_HOST_RDS_CRB_MODE_UNIQUE
);
164 prq
->num_rds_rings
= cpu_to_le16(nrds_rings
);
165 prq
->num_sds_rings
= cpu_to_le16(nsds_rings
);
166 prq
->rds_ring_offset
= cpu_to_le32(0);
168 val
= le32_to_cpu(prq
->rds_ring_offset
) +
169 (sizeof(struct qlcnic_hostrq_rds_ring
) * nrds_rings
);
170 prq
->sds_ring_offset
= cpu_to_le32(val
);
172 prq_rds
= (struct qlcnic_hostrq_rds_ring
*)(prq
->data
+
173 le32_to_cpu(prq
->rds_ring_offset
));
175 for (i
= 0; i
< nrds_rings
; i
++) {
177 rds_ring
= &recv_ctx
->rds_rings
[i
];
179 prq_rds
[i
].host_phys_addr
= cpu_to_le64(rds_ring
->phys_addr
);
180 prq_rds
[i
].ring_size
= cpu_to_le32(rds_ring
->num_desc
);
181 prq_rds
[i
].ring_kind
= cpu_to_le32(i
);
182 prq_rds
[i
].buff_size
= cpu_to_le64(rds_ring
->dma_size
);
185 prq_sds
= (struct qlcnic_hostrq_sds_ring
*)(prq
->data
+
186 le32_to_cpu(prq
->sds_ring_offset
));
188 for (i
= 0; i
< nsds_rings
; i
++) {
190 sds_ring
= &recv_ctx
->sds_rings
[i
];
192 prq_sds
[i
].host_phys_addr
= cpu_to_le64(sds_ring
->phys_addr
);
193 prq_sds
[i
].ring_size
= cpu_to_le32(sds_ring
->num_desc
);
194 prq_sds
[i
].msi_index
= cpu_to_le16(i
);
197 phys_addr
= hostrq_phys_addr
;
198 err
= qlcnic_issue_cmd(adapter
,
199 adapter
->ahw
.pci_func
,
201 (u32
)(phys_addr
>> 32),
202 (u32
)(phys_addr
& 0xffffffff),
204 QLCNIC_CDRP_CMD_CREATE_RX_CTX
);
206 dev_err(&adapter
->pdev
->dev
,
207 "Failed to create rx ctx in firmware%d\n", err
);
212 prsp_rds
= ((struct qlcnic_cardrsp_rds_ring
*)
213 &prsp
->data
[le32_to_cpu(prsp
->rds_ring_offset
)]);
215 for (i
= 0; i
< le16_to_cpu(prsp
->num_rds_rings
); i
++) {
216 rds_ring
= &recv_ctx
->rds_rings
[i
];
218 reg
= le32_to_cpu(prsp_rds
[i
].host_producer_crb
);
219 rds_ring
->crb_rcv_producer
= qlcnic_get_ioaddr(adapter
,
220 QLCNIC_REG(reg
- 0x200));
223 prsp_sds
= ((struct qlcnic_cardrsp_sds_ring
*)
224 &prsp
->data
[le32_to_cpu(prsp
->sds_ring_offset
)]);
226 for (i
= 0; i
< le16_to_cpu(prsp
->num_sds_rings
); i
++) {
227 sds_ring
= &recv_ctx
->sds_rings
[i
];
229 reg
= le32_to_cpu(prsp_sds
[i
].host_consumer_crb
);
230 sds_ring
->crb_sts_consumer
= qlcnic_get_ioaddr(adapter
,
231 QLCNIC_REG(reg
- 0x200));
233 reg
= le32_to_cpu(prsp_sds
[i
].interrupt_crb
);
234 sds_ring
->crb_intr_mask
= qlcnic_get_ioaddr(adapter
,
235 QLCNIC_REG(reg
- 0x200));
238 recv_ctx
->state
= le32_to_cpu(prsp
->host_ctx_state
);
239 recv_ctx
->context_id
= le16_to_cpu(prsp
->context_id
);
240 recv_ctx
->virt_port
= prsp
->virt_port
;
243 pci_free_consistent(adapter
->pdev
, rsp_size
, prsp
, cardrsp_phys_addr
);
245 pci_free_consistent(adapter
->pdev
, rq_size
, prq
, hostrq_phys_addr
);
250 qlcnic_fw_cmd_destroy_rx_ctx(struct qlcnic_adapter
*adapter
)
252 struct qlcnic_recv_context
*recv_ctx
= &adapter
->recv_ctx
;
254 if (qlcnic_issue_cmd(adapter
,
255 adapter
->ahw
.pci_func
,
257 recv_ctx
->context_id
,
258 QLCNIC_DESTROY_CTX_RESET
,
260 QLCNIC_CDRP_CMD_DESTROY_RX_CTX
)) {
262 dev_err(&adapter
->pdev
->dev
,
263 "Failed to destroy rx ctx in firmware\n");
268 qlcnic_fw_cmd_create_tx_ctx(struct qlcnic_adapter
*adapter
)
270 struct qlcnic_hostrq_tx_ctx
*prq
;
271 struct qlcnic_hostrq_cds_ring
*prq_cds
;
272 struct qlcnic_cardrsp_tx_ctx
*prsp
;
273 void *rq_addr
, *rsp_addr
;
274 size_t rq_size
, rsp_size
;
278 dma_addr_t rq_phys_addr
, rsp_phys_addr
;
279 struct qlcnic_host_tx_ring
*tx_ring
= adapter
->tx_ring
;
281 rq_size
= SIZEOF_HOSTRQ_TX(struct qlcnic_hostrq_tx_ctx
);
282 rq_addr
= pci_alloc_consistent(adapter
->pdev
,
283 rq_size
, &rq_phys_addr
);
287 rsp_size
= SIZEOF_CARDRSP_TX(struct qlcnic_cardrsp_tx_ctx
);
288 rsp_addr
= pci_alloc_consistent(adapter
->pdev
,
289 rsp_size
, &rsp_phys_addr
);
295 memset(rq_addr
, 0, rq_size
);
296 prq
= (struct qlcnic_hostrq_tx_ctx
*)rq_addr
;
298 memset(rsp_addr
, 0, rsp_size
);
299 prsp
= (struct qlcnic_cardrsp_tx_ctx
*)rsp_addr
;
301 prq
->host_rsp_dma_addr
= cpu_to_le64(rsp_phys_addr
);
303 temp
= (QLCNIC_CAP0_LEGACY_CONTEXT
| QLCNIC_CAP0_LEGACY_MN
|
305 prq
->capabilities
[0] = cpu_to_le32(temp
);
307 prq
->host_int_crb_mode
=
308 cpu_to_le32(QLCNIC_HOST_INT_CRB_MODE_SHARED
);
310 prq
->interrupt_ctl
= 0;
312 prq
->cmd_cons_dma_addr
= cpu_to_le64(tx_ring
->hw_cons_phys_addr
);
314 prq_cds
= &prq
->cds_ring
;
316 prq_cds
->host_phys_addr
= cpu_to_le64(tx_ring
->phys_addr
);
317 prq_cds
->ring_size
= cpu_to_le32(tx_ring
->num_desc
);
319 phys_addr
= rq_phys_addr
;
320 err
= qlcnic_issue_cmd(adapter
,
321 adapter
->ahw
.pci_func
,
323 (u32
)(phys_addr
>> 32),
324 ((u32
)phys_addr
& 0xffffffff),
326 QLCNIC_CDRP_CMD_CREATE_TX_CTX
);
328 if (err
== QLCNIC_RCODE_SUCCESS
) {
329 temp
= le32_to_cpu(prsp
->cds_ring
.host_producer_crb
);
330 tx_ring
->crb_cmd_producer
= qlcnic_get_ioaddr(adapter
,
331 QLCNIC_REG(temp
- 0x200));
333 adapter
->tx_context_id
=
334 le16_to_cpu(prsp
->context_id
);
336 dev_err(&adapter
->pdev
->dev
,
337 "Failed to create tx ctx in firmware%d\n", err
);
341 pci_free_consistent(adapter
->pdev
, rsp_size
, rsp_addr
, rsp_phys_addr
);
344 pci_free_consistent(adapter
->pdev
, rq_size
, rq_addr
, rq_phys_addr
);
350 qlcnic_fw_cmd_destroy_tx_ctx(struct qlcnic_adapter
*adapter
)
352 if (qlcnic_issue_cmd(adapter
,
353 adapter
->ahw
.pci_func
,
355 adapter
->tx_context_id
,
356 QLCNIC_DESTROY_CTX_RESET
,
358 QLCNIC_CDRP_CMD_DESTROY_TX_CTX
)) {
360 dev_err(&adapter
->pdev
->dev
,
361 "Failed to destroy tx ctx in firmware\n");
366 qlcnic_fw_cmd_query_phy(struct qlcnic_adapter
*adapter
, u32 reg
, u32
*val
)
369 if (qlcnic_issue_cmd(adapter
,
370 adapter
->ahw
.pci_func
,
375 QLCNIC_CDRP_CMD_READ_PHY
)) {
380 return QLCRD32(adapter
, QLCNIC_ARG1_CRB_OFFSET
);
384 qlcnic_fw_cmd_set_phy(struct qlcnic_adapter
*adapter
, u32 reg
, u32 val
)
386 return qlcnic_issue_cmd(adapter
,
387 adapter
->ahw
.pci_func
,
392 QLCNIC_CDRP_CMD_WRITE_PHY
);
395 int qlcnic_alloc_hw_resources(struct qlcnic_adapter
*adapter
)
400 struct qlcnic_recv_context
*recv_ctx
;
401 struct qlcnic_host_rds_ring
*rds_ring
;
402 struct qlcnic_host_sds_ring
*sds_ring
;
403 struct qlcnic_host_tx_ring
*tx_ring
;
405 struct pci_dev
*pdev
= adapter
->pdev
;
407 recv_ctx
= &adapter
->recv_ctx
;
408 tx_ring
= adapter
->tx_ring
;
410 tx_ring
->hw_consumer
= (__le32
*)pci_alloc_consistent(pdev
, sizeof(u32
),
411 &tx_ring
->hw_cons_phys_addr
);
412 if (tx_ring
->hw_consumer
== NULL
) {
413 dev_err(&pdev
->dev
, "failed to allocate tx consumer\n");
416 *(tx_ring
->hw_consumer
) = 0;
419 addr
= pci_alloc_consistent(pdev
, TX_DESC_RINGSIZE(tx_ring
),
420 &tx_ring
->phys_addr
);
423 dev_err(&pdev
->dev
, "failed to allocate tx desc ring\n");
428 tx_ring
->desc_head
= (struct cmd_desc_type0
*)addr
;
430 for (ring
= 0; ring
< adapter
->max_rds_rings
; ring
++) {
431 rds_ring
= &recv_ctx
->rds_rings
[ring
];
432 addr
= pci_alloc_consistent(adapter
->pdev
,
433 RCV_DESC_RINGSIZE(rds_ring
),
434 &rds_ring
->phys_addr
);
437 "failed to allocate rds ring [%d]\n", ring
);
441 rds_ring
->desc_head
= (struct rcv_desc
*)addr
;
445 for (ring
= 0; ring
< adapter
->max_sds_rings
; ring
++) {
446 sds_ring
= &recv_ctx
->sds_rings
[ring
];
448 addr
= pci_alloc_consistent(adapter
->pdev
,
449 STATUS_DESC_RINGSIZE(sds_ring
),
450 &sds_ring
->phys_addr
);
453 "failed to allocate sds ring [%d]\n", ring
);
457 sds_ring
->desc_head
= (struct status_desc
*)addr
;
461 err
= qlcnic_fw_cmd_create_rx_ctx(adapter
);
464 err
= qlcnic_fw_cmd_create_tx_ctx(adapter
);
468 set_bit(__QLCNIC_FW_ATTACHED
, &adapter
->state
);
472 qlcnic_free_hw_resources(adapter
);
476 void qlcnic_free_hw_resources(struct qlcnic_adapter
*adapter
)
478 struct qlcnic_recv_context
*recv_ctx
;
479 struct qlcnic_host_rds_ring
*rds_ring
;
480 struct qlcnic_host_sds_ring
*sds_ring
;
481 struct qlcnic_host_tx_ring
*tx_ring
;
485 if (test_and_clear_bit(__QLCNIC_FW_ATTACHED
, &adapter
->state
)) {
486 qlcnic_fw_cmd_destroy_rx_ctx(adapter
);
487 qlcnic_fw_cmd_destroy_tx_ctx(adapter
);
489 /* Allow dma queues to drain after context reset */
493 recv_ctx
= &adapter
->recv_ctx
;
495 tx_ring
= adapter
->tx_ring
;
496 if (tx_ring
->hw_consumer
!= NULL
) {
497 pci_free_consistent(adapter
->pdev
,
499 tx_ring
->hw_consumer
,
500 tx_ring
->hw_cons_phys_addr
);
501 tx_ring
->hw_consumer
= NULL
;
504 if (tx_ring
->desc_head
!= NULL
) {
505 pci_free_consistent(adapter
->pdev
,
506 TX_DESC_RINGSIZE(tx_ring
),
507 tx_ring
->desc_head
, tx_ring
->phys_addr
);
508 tx_ring
->desc_head
= NULL
;
511 for (ring
= 0; ring
< adapter
->max_rds_rings
; ring
++) {
512 rds_ring
= &recv_ctx
->rds_rings
[ring
];
514 if (rds_ring
->desc_head
!= NULL
) {
515 pci_free_consistent(adapter
->pdev
,
516 RCV_DESC_RINGSIZE(rds_ring
),
518 rds_ring
->phys_addr
);
519 rds_ring
->desc_head
= NULL
;
523 for (ring
= 0; ring
< adapter
->max_sds_rings
; ring
++) {
524 sds_ring
= &recv_ctx
->sds_rings
[ring
];
526 if (sds_ring
->desc_head
!= NULL
) {
527 pci_free_consistent(adapter
->pdev
,
528 STATUS_DESC_RINGSIZE(sds_ring
),
530 sds_ring
->phys_addr
);
531 sds_ring
->desc_head
= NULL
;