xref: /linux/drivers/scsi/be2iscsi/be_cmds.c (revision 23c996fc2bc1978a02c64eddb90b4ab5d309c8df)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright 2017 Broadcom. All Rights Reserved.
4  * The term "Broadcom" refers to Broadcom Limited and/or its subsidiaries.
5  *
6  * Contact Information:
7  * linux-drivers@broadcom.com
8  */
9 
10 #include <scsi/iscsi_proto.h>
11 
12 #include "be_main.h"
13 #include "be.h"
14 #include "be_mgmt.h"
15 
16 /* UE Status Low CSR */
17 static const char * const desc_ue_status_low[] = {
18 	"CEV",
19 	"CTX",
20 	"DBUF",
21 	"ERX",
22 	"Host",
23 	"MPU",
24 	"NDMA",
25 	"PTC ",
26 	"RDMA ",
27 	"RXF ",
28 	"RXIPS ",
29 	"RXULP0 ",
30 	"RXULP1 ",
31 	"RXULP2 ",
32 	"TIM ",
33 	"TPOST ",
34 	"TPRE ",
35 	"TXIPS ",
36 	"TXULP0 ",
37 	"TXULP1 ",
38 	"UC ",
39 	"WDMA ",
40 	"TXULP2 ",
41 	"HOST1 ",
42 	"P0_OB_LINK ",
43 	"P1_OB_LINK ",
44 	"HOST_GPIO ",
45 	"MBOX ",
46 	"AXGMAC0",
47 	"AXGMAC1",
48 	"JTAG",
49 	"MPU_INTPEND"
50 };
51 
52 /* UE Status High CSR */
53 static const char * const desc_ue_status_hi[] = {
54 	"LPCMEMHOST",
55 	"MGMT_MAC",
56 	"PCS0ONLINE",
57 	"MPU_IRAM",
58 	"PCS1ONLINE",
59 	"PCTL0",
60 	"PCTL1",
61 	"PMEM",
62 	"RR",
63 	"TXPB",
64 	"RXPP",
65 	"XAUI",
66 	"TXP",
67 	"ARM",
68 	"IPC",
69 	"HOST2",
70 	"HOST3",
71 	"HOST4",
72 	"HOST5",
73 	"HOST6",
74 	"HOST7",
75 	"HOST8",
76 	"HOST9",
77 	"NETC",
78 	"Unknown",
79 	"Unknown",
80 	"Unknown",
81 	"Unknown",
82 	"Unknown",
83 	"Unknown",
84 	"Unknown",
85 	"Unknown"
86 };
87 
88 struct be_mcc_wrb *alloc_mcc_wrb(struct beiscsi_hba *phba,
89 				 unsigned int *ref_tag)
90 {
91 	struct be_queue_info *mccq = &phba->ctrl.mcc_obj.q;
92 	struct be_mcc_wrb *wrb = NULL;
93 	unsigned int tag;
94 
95 	spin_lock(&phba->ctrl.mcc_lock);
96 	if (mccq->used == mccq->len) {
97 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT |
98 			    BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
99 			    "BC_%d : MCC queue full: WRB used %u tag avail %u\n",
100 			    mccq->used, phba->ctrl.mcc_tag_available);
101 		goto alloc_failed;
102 	}
103 
104 	if (!phba->ctrl.mcc_tag_available)
105 		goto alloc_failed;
106 
107 	tag = phba->ctrl.mcc_tag[phba->ctrl.mcc_alloc_index];
108 	if (!tag) {
109 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT |
110 			    BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
111 			    "BC_%d : MCC tag 0 allocated: tag avail %u alloc index %u\n",
112 			    phba->ctrl.mcc_tag_available,
113 			    phba->ctrl.mcc_alloc_index);
114 		goto alloc_failed;
115 	}
116 
117 	/* return this tag for further reference */
118 	*ref_tag = tag;
119 	phba->ctrl.mcc_tag[phba->ctrl.mcc_alloc_index] = 0;
120 	phba->ctrl.mcc_tag_status[tag] = 0;
121 	phba->ctrl.ptag_state[tag].tag_state = 0;
122 	phba->ctrl.ptag_state[tag].cbfn = NULL;
123 	phba->ctrl.mcc_tag_available--;
124 	if (phba->ctrl.mcc_alloc_index == (MAX_MCC_CMD - 1))
125 		phba->ctrl.mcc_alloc_index = 0;
126 	else
127 		phba->ctrl.mcc_alloc_index++;
128 
129 	wrb = queue_head_node(mccq);
130 	memset(wrb, 0, sizeof(*wrb));
131 	wrb->tag0 = tag;
132 	wrb->tag0 |= (mccq->head << MCC_Q_WRB_IDX_SHIFT) & MCC_Q_WRB_IDX_MASK;
133 	queue_head_inc(mccq);
134 	mccq->used++;
135 
136 alloc_failed:
137 	spin_unlock(&phba->ctrl.mcc_lock);
138 	return wrb;
139 }
140 
141 void free_mcc_wrb(struct be_ctrl_info *ctrl, unsigned int tag)
142 {
143 	struct be_queue_info *mccq = &ctrl->mcc_obj.q;
144 
145 	spin_lock(&ctrl->mcc_lock);
146 	tag = tag & MCC_Q_CMD_TAG_MASK;
147 	ctrl->mcc_tag[ctrl->mcc_free_index] = tag;
148 	if (ctrl->mcc_free_index == (MAX_MCC_CMD - 1))
149 		ctrl->mcc_free_index = 0;
150 	else
151 		ctrl->mcc_free_index++;
152 	ctrl->mcc_tag_available++;
153 	mccq->used--;
154 	spin_unlock(&ctrl->mcc_lock);
155 }
156 
157 /*
158  * beiscsi_mcc_compl_status - Return the status of MCC completion
159  * @phba: Driver private structure
160  * @tag: Tag for the MBX Command
161  * @wrb: the WRB used for the MBX Command
162  * @mbx_cmd_mem: ptr to memory allocated for MBX Cmd
163  *
164  * return
165  * Success: 0
166  * Failure: Non-Zero
167  */
168 int __beiscsi_mcc_compl_status(struct beiscsi_hba *phba,
169 			       unsigned int tag,
170 			       struct be_mcc_wrb **wrb,
171 			       struct be_dma_mem *mbx_cmd_mem)
172 {
173 	struct be_queue_info *mccq = &phba->ctrl.mcc_obj.q;
174 	uint16_t status = 0, addl_status = 0, wrb_num = 0;
175 	struct be_cmd_resp_hdr *mbx_resp_hdr;
176 	struct be_cmd_req_hdr *mbx_hdr;
177 	struct be_mcc_wrb *temp_wrb;
178 	uint32_t mcc_tag_status;
179 	int rc = 0;
180 
181 	mcc_tag_status = phba->ctrl.mcc_tag_status[tag];
182 	status = (mcc_tag_status & CQE_STATUS_MASK);
183 	addl_status = ((mcc_tag_status & CQE_STATUS_ADDL_MASK) >>
184 			CQE_STATUS_ADDL_SHIFT);
185 
186 	if (mbx_cmd_mem) {
187 		mbx_hdr = (struct be_cmd_req_hdr *)mbx_cmd_mem->va;
188 	} else {
189 		wrb_num = (mcc_tag_status & CQE_STATUS_WRB_MASK) >>
190 			  CQE_STATUS_WRB_SHIFT;
191 		temp_wrb = (struct be_mcc_wrb *)queue_get_wrb(mccq, wrb_num);
192 		mbx_hdr = embedded_payload(temp_wrb);
193 
194 		if (wrb)
195 			*wrb = temp_wrb;
196 	}
197 
198 	if (status || addl_status) {
199 		beiscsi_log(phba, KERN_WARNING,
200 			    BEISCSI_LOG_INIT | BEISCSI_LOG_EH |
201 			    BEISCSI_LOG_CONFIG,
202 			    "BC_%d : MBX Cmd Failed for Subsys : %d Opcode : %d with Status : %d and Extd_Status : %d\n",
203 			    mbx_hdr->subsystem, mbx_hdr->opcode,
204 			    status, addl_status);
205 		rc = -EIO;
206 		if (status == MCC_STATUS_INSUFFICIENT_BUFFER) {
207 			mbx_resp_hdr = (struct be_cmd_resp_hdr *)mbx_hdr;
208 			beiscsi_log(phba, KERN_WARNING,
209 				    BEISCSI_LOG_INIT | BEISCSI_LOG_EH |
210 				    BEISCSI_LOG_CONFIG,
211 				    "BC_%d : Insufficient Buffer Error Resp_Len : %d Actual_Resp_Len : %d\n",
212 				    mbx_resp_hdr->response_length,
213 				    mbx_resp_hdr->actual_resp_len);
214 			rc = -EAGAIN;
215 		}
216 	}
217 
218 	return rc;
219 }
220 
221 /*
222  * beiscsi_mccq_compl_wait()- Process completion in MCC CQ
223  * @phba: Driver private structure
224  * @tag: Tag for the MBX Command
225  * @wrb: the WRB used for the MBX Command
226  * @mbx_cmd_mem: ptr to memory allocated for MBX Cmd
227  *
228  * Waits for MBX completion with the passed TAG.
229  *
230  * return
231  * Success: 0
232  * Failure: Non-Zero
233  **/
234 int beiscsi_mccq_compl_wait(struct beiscsi_hba *phba,
235 			    unsigned int tag,
236 			    struct be_mcc_wrb **wrb,
237 			    struct be_dma_mem *mbx_cmd_mem)
238 {
239 	int rc = 0;
240 
241 	if (!tag || tag > MAX_MCC_CMD) {
242 		__beiscsi_log(phba, KERN_ERR,
243 			      "BC_%d : invalid tag %u\n", tag);
244 		return -EINVAL;
245 	}
246 
247 	if (beiscsi_hba_in_error(phba)) {
248 		clear_bit(MCC_TAG_STATE_RUNNING,
249 			  &phba->ctrl.ptag_state[tag].tag_state);
250 		return -EIO;
251 	}
252 
253 	/* wait for the mccq completion */
254 	rc = wait_event_interruptible_timeout(phba->ctrl.mcc_wait[tag],
255 					      phba->ctrl.mcc_tag_status[tag],
256 					      msecs_to_jiffies(
257 						BEISCSI_HOST_MBX_TIMEOUT));
258 	/**
259 	 * Return EIO if port is being disabled. Associated DMA memory, if any,
260 	 * is freed by the caller. When port goes offline, MCCQ is cleaned up
261 	 * so does WRB.
262 	 */
263 	if (!test_bit(BEISCSI_HBA_ONLINE, &phba->state)) {
264 		clear_bit(MCC_TAG_STATE_RUNNING,
265 			  &phba->ctrl.ptag_state[tag].tag_state);
266 		return -EIO;
267 	}
268 
269 	/**
270 	 * If MBOX cmd timeout expired, tag and resource allocated
271 	 * for cmd is not freed until FW returns completion.
272 	 */
273 	if (rc <= 0) {
274 		struct be_dma_mem *tag_mem;
275 
276 		/**
277 		 * PCI/DMA memory allocated and posted in non-embedded mode
278 		 * will have mbx_cmd_mem != NULL.
279 		 * Save virtual and bus addresses for the command so that it
280 		 * can be freed later.
281 		 **/
282 		tag_mem = &phba->ctrl.ptag_state[tag].tag_mem_state;
283 		if (mbx_cmd_mem) {
284 			tag_mem->size = mbx_cmd_mem->size;
285 			tag_mem->va = mbx_cmd_mem->va;
286 			tag_mem->dma = mbx_cmd_mem->dma;
287 		} else
288 			tag_mem->size = 0;
289 
290 		/* first make tag_mem_state visible to all */
291 		wmb();
292 		set_bit(MCC_TAG_STATE_TIMEOUT,
293 				&phba->ctrl.ptag_state[tag].tag_state);
294 
295 		beiscsi_log(phba, KERN_ERR,
296 			    BEISCSI_LOG_INIT | BEISCSI_LOG_EH |
297 			    BEISCSI_LOG_CONFIG,
298 			    "BC_%d : MBX Cmd Completion timed out\n");
299 		return -EBUSY;
300 	}
301 
302 	rc = __beiscsi_mcc_compl_status(phba, tag, wrb, mbx_cmd_mem);
303 
304 	free_mcc_wrb(&phba->ctrl, tag);
305 	return rc;
306 }
307 
308 /*
309  * beiscsi_process_mbox_compl()- Check the MBX completion status
310  * @ctrl: Function specific MBX data structure
311  * @compl: Completion status of MBX Command
312  *
313  * Check for the MBX completion status when BMBX method used
314  *
315  * return
316  * Success: Zero
317  * Failure: Non-Zero
318  **/
319 static int beiscsi_process_mbox_compl(struct be_ctrl_info *ctrl,
320 				      struct be_mcc_compl *compl)
321 {
322 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
323 	struct beiscsi_hba *phba = pci_get_drvdata(ctrl->pdev);
324 	struct be_cmd_req_hdr *hdr = embedded_payload(wrb);
325 	u16 compl_status, extd_status;
326 
327 	/**
328 	 * To check if valid bit is set, check the entire word as we don't know
329 	 * the endianness of the data (old entry is host endian while a new
330 	 * entry is little endian)
331 	 */
332 	if (!compl->flags) {
333 		beiscsi_log(phba, KERN_ERR,
334 				BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
335 				"BC_%d : BMBX busy, no completion\n");
336 		return -EBUSY;
337 	}
338 	compl->flags = le32_to_cpu(compl->flags);
339 	WARN_ON((compl->flags & CQE_FLAGS_VALID_MASK) == 0);
340 
341 	/**
342 	 * Just swap the status to host endian;
343 	 * mcc tag is opaquely copied from mcc_wrb.
344 	 */
345 	be_dws_le_to_cpu(compl, 4);
346 	compl_status = (compl->status >> CQE_STATUS_COMPL_SHIFT) &
347 		CQE_STATUS_COMPL_MASK;
348 	extd_status = (compl->status >> CQE_STATUS_EXTD_SHIFT) &
349 		CQE_STATUS_EXTD_MASK;
350 	/* Need to reset the entire word that houses the valid bit */
351 	compl->flags = 0;
352 
353 	if (compl_status == MCC_STATUS_SUCCESS)
354 		return 0;
355 
356 	beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
357 		    "BC_%d : error in cmd completion: Subsystem : %d Opcode : %d status(compl/extd)=%d/%d\n",
358 		    hdr->subsystem, hdr->opcode, compl_status, extd_status);
359 	return compl_status;
360 }
361 
362 static void beiscsi_process_async_link(struct beiscsi_hba *phba,
363 				       struct be_mcc_compl *compl)
364 {
365 	struct be_async_event_link_state *evt;
366 
367 	evt = (struct be_async_event_link_state *)compl;
368 
369 	phba->port_speed = evt->port_speed;
370 	/**
371 	 * Check logical link status in ASYNC event.
372 	 * This has been newly introduced in SKH-R Firmware 10.0.338.45.
373 	 **/
374 	if (evt->port_link_status & BE_ASYNC_LINK_UP_MASK) {
375 		set_bit(BEISCSI_HBA_LINK_UP, &phba->state);
376 		if (test_bit(BEISCSI_HBA_BOOT_FOUND, &phba->state))
377 			beiscsi_start_boot_work(phba, BE_BOOT_INVALID_SHANDLE);
378 		__beiscsi_log(phba, KERN_ERR,
379 			      "BC_%d : Link Up on Port %d tag 0x%x\n",
380 			      evt->physical_port, evt->event_tag);
381 	} else {
382 		clear_bit(BEISCSI_HBA_LINK_UP, &phba->state);
383 		__beiscsi_log(phba, KERN_ERR,
384 			      "BC_%d : Link Down on Port %d tag 0x%x\n",
385 			      evt->physical_port, evt->event_tag);
386 		iscsi_host_for_each_session(phba->shost,
387 					    beiscsi_session_fail);
388 	}
389 }
390 
391 static char *beiscsi_port_misconf_event_msg[] = {
392 	"Physical Link is functional.",
393 	"Optics faulted/incorrectly installed/not installed - Reseat optics, if issue not resolved, replace.",
394 	"Optics of two types installed - Remove one optic or install matching pair of optics.",
395 	"Incompatible optics - Replace with compatible optics for card to function.",
396 	"Unqualified optics - Replace with Avago optics for Warranty and Technical Support.",
397 	"Uncertified optics - Replace with Avago Certified optics to enable link operation."
398 };
399 
400 static void beiscsi_process_async_sli(struct beiscsi_hba *phba,
401 				      struct be_mcc_compl *compl)
402 {
403 	struct be_async_event_sli *async_sli;
404 	u8 evt_type, state, old_state, le;
405 	char *sev = KERN_WARNING;
406 	char *msg = NULL;
407 
408 	evt_type = compl->flags >> ASYNC_TRAILER_EVENT_TYPE_SHIFT;
409 	evt_type &= ASYNC_TRAILER_EVENT_TYPE_MASK;
410 
411 	/* processing only MISCONFIGURED physical port event */
412 	if (evt_type != ASYNC_SLI_EVENT_TYPE_MISCONFIGURED)
413 		return;
414 
415 	async_sli = (struct be_async_event_sli *)compl;
416 	state = async_sli->event_data1 >>
417 		 (phba->fw_config.phys_port * 8) & 0xff;
418 	le = async_sli->event_data2 >>
419 		 (phba->fw_config.phys_port * 8) & 0xff;
420 
421 	old_state = phba->optic_state;
422 	phba->optic_state = state;
423 
424 	if (state >= ARRAY_SIZE(beiscsi_port_misconf_event_msg)) {
425 		/* fw is reporting a state we don't know, log and return */
426 		__beiscsi_log(phba, KERN_ERR,
427 			    "BC_%d : Port %c: Unrecognized optic state 0x%x\n",
428 			    phba->port_name, async_sli->event_data1);
429 		return;
430 	}
431 
432 	if (ASYNC_SLI_LINK_EFFECT_VALID(le)) {
433 		/* log link effect for unqualified-4, uncertified-5 optics */
434 		if (state > 3)
435 			msg = (ASYNC_SLI_LINK_EFFECT_STATE(le)) ?
436 				" Link is non-operational." :
437 				" Link is operational.";
438 		/* 1 - info */
439 		if (ASYNC_SLI_LINK_EFFECT_SEV(le) == 1)
440 			sev = KERN_INFO;
441 		/* 2 - error */
442 		if (ASYNC_SLI_LINK_EFFECT_SEV(le) == 2)
443 			sev = KERN_ERR;
444 	}
445 
446 	if (old_state != phba->optic_state)
447 		__beiscsi_log(phba, sev, "BC_%d : Port %c: %s%s\n",
448 			      phba->port_name,
449 			      beiscsi_port_misconf_event_msg[state],
450 			      !msg ? "" : msg);
451 }
452 
453 void beiscsi_process_async_event(struct beiscsi_hba *phba,
454 				struct be_mcc_compl *compl)
455 {
456 	char *sev = KERN_INFO;
457 	u8 evt_code;
458 
459 	/* interpret flags as an async trailer */
460 	evt_code = compl->flags >> ASYNC_TRAILER_EVENT_CODE_SHIFT;
461 	evt_code &= ASYNC_TRAILER_EVENT_CODE_MASK;
462 	switch (evt_code) {
463 	case ASYNC_EVENT_CODE_LINK_STATE:
464 		beiscsi_process_async_link(phba, compl);
465 		break;
466 	case ASYNC_EVENT_CODE_ISCSI:
467 		if (test_bit(BEISCSI_HBA_BOOT_FOUND, &phba->state))
468 			beiscsi_start_boot_work(phba, BE_BOOT_INVALID_SHANDLE);
469 		sev = KERN_ERR;
470 		break;
471 	case ASYNC_EVENT_CODE_SLI:
472 		beiscsi_process_async_sli(phba, compl);
473 		break;
474 	default:
475 		/* event not registered */
476 		sev = KERN_ERR;
477 	}
478 
479 	beiscsi_log(phba, sev, BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
480 		    "BC_%d : ASYNC Event %x: status 0x%08x flags 0x%08x\n",
481 		    evt_code, compl->status, compl->flags);
482 }
483 
484 int beiscsi_process_mcc_compl(struct be_ctrl_info *ctrl,
485 			      struct be_mcc_compl *compl)
486 {
487 	struct beiscsi_hba *phba = pci_get_drvdata(ctrl->pdev);
488 	u16 compl_status, extd_status;
489 	struct be_dma_mem *tag_mem;
490 	unsigned int tag, wrb_idx;
491 
492 	be_dws_le_to_cpu(compl, 4);
493 	tag = (compl->tag0 & MCC_Q_CMD_TAG_MASK);
494 	wrb_idx = (compl->tag0 & CQE_STATUS_WRB_MASK) >> CQE_STATUS_WRB_SHIFT;
495 
496 	if (!test_bit(MCC_TAG_STATE_RUNNING,
497 		      &ctrl->ptag_state[tag].tag_state)) {
498 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_MBOX |
499 			    BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
500 			    "BC_%d : MBX cmd completed but not posted\n");
501 		return 0;
502 	}
503 
504 	/* end MCC with this tag */
505 	clear_bit(MCC_TAG_STATE_RUNNING, &ctrl->ptag_state[tag].tag_state);
506 
507 	if (test_bit(MCC_TAG_STATE_TIMEOUT, &ctrl->ptag_state[tag].tag_state)) {
508 		beiscsi_log(phba, KERN_WARNING,
509 			    BEISCSI_LOG_MBOX | BEISCSI_LOG_INIT |
510 			    BEISCSI_LOG_CONFIG,
511 			    "BC_%d : MBX Completion for timeout Command from FW\n");
512 		/**
513 		 * Check for the size before freeing resource.
514 		 * Only for non-embedded cmd, PCI resource is allocated.
515 		 **/
516 		tag_mem = &ctrl->ptag_state[tag].tag_mem_state;
517 		if (tag_mem->size) {
518 			dma_free_coherent(&ctrl->pdev->dev, tag_mem->size,
519 					tag_mem->va, tag_mem->dma);
520 			tag_mem->size = 0;
521 		}
522 		free_mcc_wrb(ctrl, tag);
523 		return 0;
524 	}
525 
526 	compl_status = (compl->status >> CQE_STATUS_COMPL_SHIFT) &
527 		       CQE_STATUS_COMPL_MASK;
528 	extd_status = (compl->status >> CQE_STATUS_EXTD_SHIFT) &
529 		      CQE_STATUS_EXTD_MASK;
530 	/* The ctrl.mcc_tag_status[tag] is filled with
531 	 * [31] = valid, [30:24] = Rsvd, [23:16] = wrb, [15:8] = extd_status,
532 	 * [7:0] = compl_status
533 	 */
534 	ctrl->mcc_tag_status[tag] = CQE_VALID_MASK;
535 	ctrl->mcc_tag_status[tag] |= (wrb_idx << CQE_STATUS_WRB_SHIFT);
536 	ctrl->mcc_tag_status[tag] |= (extd_status << CQE_STATUS_ADDL_SHIFT) &
537 				     CQE_STATUS_ADDL_MASK;
538 	ctrl->mcc_tag_status[tag] |= (compl_status & CQE_STATUS_MASK);
539 
540 	if (test_bit(MCC_TAG_STATE_ASYNC, &ctrl->ptag_state[tag].tag_state)) {
541 		if (ctrl->ptag_state[tag].cbfn)
542 			ctrl->ptag_state[tag].cbfn(phba, tag);
543 		else
544 			__beiscsi_log(phba, KERN_ERR,
545 				      "BC_%d : MBX ASYNC command with no callback\n");
546 		free_mcc_wrb(ctrl, tag);
547 		return 0;
548 	}
549 
550 	if (test_bit(MCC_TAG_STATE_IGNORE, &ctrl->ptag_state[tag].tag_state)) {
551 		/* just check completion status and free wrb */
552 		__beiscsi_mcc_compl_status(phba, tag, NULL, NULL);
553 		free_mcc_wrb(ctrl, tag);
554 		return 0;
555 	}
556 
557 	wake_up_interruptible(&ctrl->mcc_wait[tag]);
558 	return 0;
559 }
560 
561 void be_mcc_notify(struct beiscsi_hba *phba, unsigned int tag)
562 {
563 	struct be_queue_info *mccq = &phba->ctrl.mcc_obj.q;
564 	u32 val = 0;
565 
566 	set_bit(MCC_TAG_STATE_RUNNING, &phba->ctrl.ptag_state[tag].tag_state);
567 	val |= mccq->id & DB_MCCQ_RING_ID_MASK;
568 	val |= 1 << DB_MCCQ_NUM_POSTED_SHIFT;
569 	/* make request available for DMA */
570 	wmb();
571 	iowrite32(val, phba->db_va + DB_MCCQ_OFFSET);
572 }
573 
574 /*
575  * be_mbox_db_ready_poll()- Check ready status
576  * @ctrl: Function specific MBX data structure
577  *
578  * Check for the ready status of FW to send BMBX
579  * commands to adapter.
580  *
581  * return
582  * Success: 0
583  * Failure: Non-Zero
584  **/
585 static int be_mbox_db_ready_poll(struct be_ctrl_info *ctrl)
586 {
587 	/* wait 30s for generic non-flash MBOX operation */
588 #define BEISCSI_MBX_RDY_BIT_TIMEOUT	30000
589 	void __iomem *db = ctrl->db + MPU_MAILBOX_DB_OFFSET;
590 	struct beiscsi_hba *phba = pci_get_drvdata(ctrl->pdev);
591 	unsigned long timeout;
592 	u32 ready;
593 
594 	/*
595 	 * This BMBX busy wait path is used during init only.
596 	 * For the commands executed during init, 5s should suffice.
597 	 */
598 	timeout = jiffies + msecs_to_jiffies(BEISCSI_MBX_RDY_BIT_TIMEOUT);
599 	do {
600 		if (beiscsi_hba_in_error(phba))
601 			return -EIO;
602 
603 		ready = ioread32(db);
604 		if (ready == 0xffffffff)
605 			return -EIO;
606 
607 		ready &= MPU_MAILBOX_DB_RDY_MASK;
608 		if (ready)
609 			return 0;
610 
611 		if (time_after(jiffies, timeout))
612 			break;
613 		/* 1ms sleep is enough in most cases */
614 		schedule_timeout_uninterruptible(msecs_to_jiffies(1));
615 	} while (!ready);
616 
617 	beiscsi_log(phba, KERN_ERR,
618 			BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
619 			"BC_%d : FW Timed Out\n");
620 	set_bit(BEISCSI_HBA_FW_TIMEOUT, &phba->state);
621 	return -EBUSY;
622 }
623 
624 /*
625  * be_mbox_notify: Notify adapter of new BMBX command
626  * @ctrl: Function specific MBX data structure
627  *
628  * Ring doorbell to inform adapter of a BMBX command
629  * to process
630  *
631  * return
632  * Success: 0
633  * Failure: Non-Zero
634  **/
635 static int be_mbox_notify(struct be_ctrl_info *ctrl)
636 {
637 	int status;
638 	u32 val = 0;
639 	void __iomem *db = ctrl->db + MPU_MAILBOX_DB_OFFSET;
640 	struct be_dma_mem *mbox_mem = &ctrl->mbox_mem;
641 	struct be_mcc_mailbox *mbox = mbox_mem->va;
642 
643 	status = be_mbox_db_ready_poll(ctrl);
644 	if (status)
645 		return status;
646 
647 	val &= ~MPU_MAILBOX_DB_RDY_MASK;
648 	val |= MPU_MAILBOX_DB_HI_MASK;
649 	val |= (upper_32_bits(mbox_mem->dma) >> 2) << 2;
650 	iowrite32(val, db);
651 
652 	status = be_mbox_db_ready_poll(ctrl);
653 	if (status)
654 		return status;
655 
656 	val = 0;
657 	val &= ~MPU_MAILBOX_DB_RDY_MASK;
658 	val &= ~MPU_MAILBOX_DB_HI_MASK;
659 	val |= (u32) (mbox_mem->dma >> 4) << 2;
660 	iowrite32(val, db);
661 
662 	status = be_mbox_db_ready_poll(ctrl);
663 	if (status)
664 		return status;
665 
666 	/* RDY is set; small delay before CQE read. */
667 	udelay(1);
668 
669 	status = beiscsi_process_mbox_compl(ctrl, &mbox->compl);
670 	return status;
671 }
672 
673 void be_wrb_hdr_prepare(struct be_mcc_wrb *wrb, u32 payload_len,
674 			bool embedded, u8 sge_cnt)
675 {
676 	if (embedded)
677 		wrb->emb_sgecnt_special |= MCC_WRB_EMBEDDED_MASK;
678 	else
679 		wrb->emb_sgecnt_special |= (sge_cnt & MCC_WRB_SGE_CNT_MASK) <<
680 					   MCC_WRB_SGE_CNT_SHIFT;
681 	wrb->payload_length = payload_len;
682 	be_dws_cpu_to_le(wrb, 8);
683 }
684 
685 void be_cmd_hdr_prepare(struct be_cmd_req_hdr *req_hdr,
686 			u8 subsystem, u8 opcode, u32 cmd_len)
687 {
688 	req_hdr->opcode = opcode;
689 	req_hdr->subsystem = subsystem;
690 	req_hdr->request_length = cpu_to_le32(cmd_len - sizeof(*req_hdr));
691 	req_hdr->timeout = BEISCSI_FW_MBX_TIMEOUT;
692 }
693 
694 static void be_cmd_page_addrs_prepare(struct phys_addr *pages, u32 max_pages,
695 							struct be_dma_mem *mem)
696 {
697 	int i, buf_pages;
698 	u64 dma = (u64) mem->dma;
699 
700 	buf_pages = min(PAGES_4K_SPANNED(mem->va, mem->size), max_pages);
701 	for (i = 0; i < buf_pages; i++) {
702 		pages[i].lo = cpu_to_le32(dma & 0xFFFFFFFF);
703 		pages[i].hi = cpu_to_le32(upper_32_bits(dma));
704 		dma += PAGE_SIZE_4K;
705 	}
706 }
707 
708 static u32 eq_delay_to_mult(u32 usec_delay)
709 {
710 #define MAX_INTR_RATE 651042
711 	const u32 round = 10;
712 	u32 multiplier;
713 
714 	if (usec_delay == 0)
715 		multiplier = 0;
716 	else {
717 		u32 interrupt_rate = 1000000 / usec_delay;
718 		if (interrupt_rate == 0)
719 			multiplier = 1023;
720 		else {
721 			multiplier = (MAX_INTR_RATE - interrupt_rate) * round;
722 			multiplier /= interrupt_rate;
723 			multiplier = (multiplier + round / 2) / round;
724 			multiplier = min(multiplier, (u32) 1023);
725 		}
726 	}
727 	return multiplier;
728 }
729 
730 struct be_mcc_wrb *wrb_from_mbox(struct be_dma_mem *mbox_mem)
731 {
732 	return &((struct be_mcc_mailbox *)(mbox_mem->va))->wrb;
733 }
734 
735 int beiscsi_cmd_eq_create(struct be_ctrl_info *ctrl,
736 			  struct be_queue_info *eq, int eq_delay)
737 {
738 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
739 	struct be_cmd_req_eq_create *req = embedded_payload(wrb);
740 	struct be_cmd_resp_eq_create *resp = embedded_payload(wrb);
741 	struct be_dma_mem *q_mem = &eq->dma_mem;
742 	int status;
743 
744 	mutex_lock(&ctrl->mbox_lock);
745 	memset(wrb, 0, sizeof(*wrb));
746 
747 	be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
748 
749 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_COMMON,
750 			OPCODE_COMMON_EQ_CREATE, sizeof(*req));
751 
752 	req->num_pages = cpu_to_le16(PAGES_4K_SPANNED(q_mem->va, q_mem->size));
753 
754 	AMAP_SET_BITS(struct amap_eq_context, func, req->context,
755 						PCI_FUNC(ctrl->pdev->devfn));
756 	AMAP_SET_BITS(struct amap_eq_context, valid, req->context, 1);
757 	AMAP_SET_BITS(struct amap_eq_context, size, req->context, 0);
758 	AMAP_SET_BITS(struct amap_eq_context, count, req->context,
759 					__ilog2_u32(eq->len / 256));
760 	AMAP_SET_BITS(struct amap_eq_context, delaymult, req->context,
761 					eq_delay_to_mult(eq_delay));
762 	be_dws_cpu_to_le(req->context, sizeof(req->context));
763 
764 	be_cmd_page_addrs_prepare(req->pages, ARRAY_SIZE(req->pages), q_mem);
765 
766 	status = be_mbox_notify(ctrl);
767 	if (!status) {
768 		eq->id = le16_to_cpu(resp->eq_id);
769 		eq->created = true;
770 	}
771 	mutex_unlock(&ctrl->mbox_lock);
772 	return status;
773 }
774 
775 int beiscsi_cmd_cq_create(struct be_ctrl_info *ctrl,
776 			  struct be_queue_info *cq, struct be_queue_info *eq,
777 			  bool sol_evts, bool no_delay, int coalesce_wm)
778 {
779 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
780 	struct be_cmd_req_cq_create *req = embedded_payload(wrb);
781 	struct be_cmd_resp_cq_create *resp = embedded_payload(wrb);
782 	struct beiscsi_hba *phba = pci_get_drvdata(ctrl->pdev);
783 	struct be_dma_mem *q_mem = &cq->dma_mem;
784 	void *ctxt = &req->context;
785 	int status;
786 
787 	mutex_lock(&ctrl->mbox_lock);
788 	memset(wrb, 0, sizeof(*wrb));
789 
790 	be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
791 
792 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_COMMON,
793 			OPCODE_COMMON_CQ_CREATE, sizeof(*req));
794 
795 	req->num_pages = cpu_to_le16(PAGES_4K_SPANNED(q_mem->va, q_mem->size));
796 	if (is_chip_be2_be3r(phba)) {
797 		AMAP_SET_BITS(struct amap_cq_context, coalescwm,
798 			      ctxt, coalesce_wm);
799 		AMAP_SET_BITS(struct amap_cq_context, nodelay, ctxt, no_delay);
800 		AMAP_SET_BITS(struct amap_cq_context, count, ctxt,
801 			      __ilog2_u32(cq->len / 256));
802 		AMAP_SET_BITS(struct amap_cq_context, valid, ctxt, 1);
803 		AMAP_SET_BITS(struct amap_cq_context, solevent, ctxt, sol_evts);
804 		AMAP_SET_BITS(struct amap_cq_context, eventable, ctxt, 1);
805 		AMAP_SET_BITS(struct amap_cq_context, eqid, ctxt, eq->id);
806 		AMAP_SET_BITS(struct amap_cq_context, armed, ctxt, 1);
807 		AMAP_SET_BITS(struct amap_cq_context, func, ctxt,
808 			      PCI_FUNC(ctrl->pdev->devfn));
809 	} else {
810 		req->hdr.version = MBX_CMD_VER2;
811 		req->page_size = 1;
812 		AMAP_SET_BITS(struct amap_cq_context_v2, coalescwm,
813 			      ctxt, coalesce_wm);
814 		AMAP_SET_BITS(struct amap_cq_context_v2, nodelay,
815 			      ctxt, no_delay);
816 		AMAP_SET_BITS(struct amap_cq_context_v2, count, ctxt,
817 			      __ilog2_u32(cq->len / 256));
818 		AMAP_SET_BITS(struct amap_cq_context_v2, valid, ctxt, 1);
819 		AMAP_SET_BITS(struct amap_cq_context_v2, eventable, ctxt, 1);
820 		AMAP_SET_BITS(struct amap_cq_context_v2, eqid, ctxt, eq->id);
821 		AMAP_SET_BITS(struct amap_cq_context_v2, armed, ctxt, 1);
822 	}
823 
824 	be_dws_cpu_to_le(ctxt, sizeof(req->context));
825 
826 	be_cmd_page_addrs_prepare(req->pages, ARRAY_SIZE(req->pages), q_mem);
827 
828 	status = be_mbox_notify(ctrl);
829 	if (!status) {
830 		cq->id = le16_to_cpu(resp->cq_id);
831 		cq->created = true;
832 	} else
833 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
834 			    "BC_%d : In be_cmd_cq_create, status=ox%08x\n",
835 			    status);
836 
837 	mutex_unlock(&ctrl->mbox_lock);
838 
839 	return status;
840 }
841 
842 static u32 be_encoded_q_len(int q_len)
843 {
844 	u32 len_encoded = fls(q_len);	/* log2(len) + 1 */
845 	if (len_encoded == 16)
846 		len_encoded = 0;
847 	return len_encoded;
848 }
849 
850 int beiscsi_cmd_mccq_create(struct beiscsi_hba *phba,
851 			struct be_queue_info *mccq,
852 			struct be_queue_info *cq)
853 {
854 	struct be_mcc_wrb *wrb;
855 	struct be_cmd_req_mcc_create_ext *req;
856 	struct be_dma_mem *q_mem = &mccq->dma_mem;
857 	struct be_ctrl_info *ctrl;
858 	void *ctxt;
859 	int status;
860 
861 	mutex_lock(&phba->ctrl.mbox_lock);
862 	ctrl = &phba->ctrl;
863 	wrb = wrb_from_mbox(&ctrl->mbox_mem);
864 	memset(wrb, 0, sizeof(*wrb));
865 	req = embedded_payload(wrb);
866 	ctxt = &req->context;
867 
868 	be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
869 
870 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_COMMON,
871 			OPCODE_COMMON_MCC_CREATE_EXT, sizeof(*req));
872 
873 	req->num_pages = PAGES_4K_SPANNED(q_mem->va, q_mem->size);
874 	req->async_evt_bitmap = 1 << ASYNC_EVENT_CODE_LINK_STATE;
875 	req->async_evt_bitmap |= 1 << ASYNC_EVENT_CODE_ISCSI;
876 	req->async_evt_bitmap |= 1 << ASYNC_EVENT_CODE_SLI;
877 
878 	AMAP_SET_BITS(struct amap_mcc_context, fid, ctxt,
879 		      PCI_FUNC(phba->pcidev->devfn));
880 	AMAP_SET_BITS(struct amap_mcc_context, valid, ctxt, 1);
881 	AMAP_SET_BITS(struct amap_mcc_context, ring_size, ctxt,
882 		be_encoded_q_len(mccq->len));
883 	AMAP_SET_BITS(struct amap_mcc_context, cq_id, ctxt, cq->id);
884 
885 	be_dws_cpu_to_le(ctxt, sizeof(req->context));
886 
887 	be_cmd_page_addrs_prepare(req->pages, ARRAY_SIZE(req->pages), q_mem);
888 
889 	status = be_mbox_notify(ctrl);
890 	if (!status) {
891 		struct be_cmd_resp_mcc_create *resp = embedded_payload(wrb);
892 		mccq->id = le16_to_cpu(resp->id);
893 		mccq->created = true;
894 	}
895 	mutex_unlock(&phba->ctrl.mbox_lock);
896 
897 	return status;
898 }
899 
900 int beiscsi_cmd_q_destroy(struct be_ctrl_info *ctrl, struct be_queue_info *q,
901 			  int queue_type)
902 {
903 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
904 	struct be_cmd_req_q_destroy *req = embedded_payload(wrb);
905 	struct beiscsi_hba *phba = pci_get_drvdata(ctrl->pdev);
906 	u8 subsys = 0, opcode = 0;
907 	int status;
908 
909 	beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
910 		    "BC_%d : In beiscsi_cmd_q_destroy "
911 		    "queue_type : %d\n", queue_type);
912 
913 	mutex_lock(&ctrl->mbox_lock);
914 	memset(wrb, 0, sizeof(*wrb));
915 	be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
916 
917 	switch (queue_type) {
918 	case QTYPE_EQ:
919 		subsys = CMD_SUBSYSTEM_COMMON;
920 		opcode = OPCODE_COMMON_EQ_DESTROY;
921 		break;
922 	case QTYPE_CQ:
923 		subsys = CMD_SUBSYSTEM_COMMON;
924 		opcode = OPCODE_COMMON_CQ_DESTROY;
925 		break;
926 	case QTYPE_MCCQ:
927 		subsys = CMD_SUBSYSTEM_COMMON;
928 		opcode = OPCODE_COMMON_MCC_DESTROY;
929 		break;
930 	case QTYPE_WRBQ:
931 		subsys = CMD_SUBSYSTEM_ISCSI;
932 		opcode = OPCODE_COMMON_ISCSI_WRBQ_DESTROY;
933 		break;
934 	case QTYPE_DPDUQ:
935 		subsys = CMD_SUBSYSTEM_ISCSI;
936 		opcode = OPCODE_COMMON_ISCSI_DEFQ_DESTROY;
937 		break;
938 	case QTYPE_SGL:
939 		subsys = CMD_SUBSYSTEM_ISCSI;
940 		opcode = OPCODE_COMMON_ISCSI_CFG_REMOVE_SGL_PAGES;
941 		break;
942 	default:
943 		mutex_unlock(&ctrl->mbox_lock);
944 		BUG();
945 	}
946 	be_cmd_hdr_prepare(&req->hdr, subsys, opcode, sizeof(*req));
947 	if (queue_type != QTYPE_SGL)
948 		req->id = cpu_to_le16(q->id);
949 
950 	status = be_mbox_notify(ctrl);
951 
952 	mutex_unlock(&ctrl->mbox_lock);
953 	return status;
954 }
955 
956 /**
957  * be_cmd_create_default_pdu_queue()- Create DEFQ for the adapter
958  * @ctrl: ptr to ctrl_info
959  * @cq: Completion Queue
960  * @dq: Default Queue
961  * @length: ring size
962  * @entry_size: size of each entry in DEFQ
963  * @is_header: Header or Data DEFQ
964  * @ulp_num: Bind to which ULP
965  *
966  * Create HDR/Data DEFQ for the passed ULP. Unsol PDU are posted
967  * on this queue by the FW
968  *
969  * return
970  *	Success: 0
971  *	Failure: Non-Zero Value
972  *
973  **/
974 int be_cmd_create_default_pdu_queue(struct be_ctrl_info *ctrl,
975 				    struct be_queue_info *cq,
976 				    struct be_queue_info *dq, int length,
977 				    int entry_size, uint8_t is_header,
978 				    uint8_t ulp_num)
979 {
980 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
981 	struct be_defq_create_req *req = embedded_payload(wrb);
982 	struct be_dma_mem *q_mem = &dq->dma_mem;
983 	struct beiscsi_hba *phba = pci_get_drvdata(ctrl->pdev);
984 	void *ctxt = &req->context;
985 	int status;
986 
987 	mutex_lock(&ctrl->mbox_lock);
988 	memset(wrb, 0, sizeof(*wrb));
989 
990 	be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
991 
992 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_ISCSI,
993 			   OPCODE_COMMON_ISCSI_DEFQ_CREATE, sizeof(*req));
994 
995 	req->num_pages = PAGES_4K_SPANNED(q_mem->va, q_mem->size);
996 	if (phba->fw_config.dual_ulp_aware) {
997 		req->ulp_num = ulp_num;
998 		req->dua_feature |= (1 << BEISCSI_DUAL_ULP_AWARE_BIT);
999 		req->dua_feature |= (1 << BEISCSI_BIND_Q_TO_ULP_BIT);
1000 	}
1001 
1002 	if (is_chip_be2_be3r(phba)) {
1003 		AMAP_SET_BITS(struct amap_be_default_pdu_context,
1004 			      rx_pdid, ctxt, 0);
1005 		AMAP_SET_BITS(struct amap_be_default_pdu_context,
1006 			      rx_pdid_valid, ctxt, 1);
1007 		AMAP_SET_BITS(struct amap_be_default_pdu_context,
1008 			      pci_func_id, ctxt, PCI_FUNC(ctrl->pdev->devfn));
1009 		AMAP_SET_BITS(struct amap_be_default_pdu_context,
1010 			      ring_size, ctxt,
1011 			      be_encoded_q_len(length /
1012 			      sizeof(struct phys_addr)));
1013 		AMAP_SET_BITS(struct amap_be_default_pdu_context,
1014 			      default_buffer_size, ctxt, entry_size);
1015 		AMAP_SET_BITS(struct amap_be_default_pdu_context,
1016 			      cq_id_recv, ctxt,	cq->id);
1017 	} else {
1018 		AMAP_SET_BITS(struct amap_default_pdu_context_ext,
1019 			      rx_pdid, ctxt, 0);
1020 		AMAP_SET_BITS(struct amap_default_pdu_context_ext,
1021 			      rx_pdid_valid, ctxt, 1);
1022 		AMAP_SET_BITS(struct amap_default_pdu_context_ext,
1023 			      ring_size, ctxt,
1024 			      be_encoded_q_len(length /
1025 			      sizeof(struct phys_addr)));
1026 		AMAP_SET_BITS(struct amap_default_pdu_context_ext,
1027 			      default_buffer_size, ctxt, entry_size);
1028 		AMAP_SET_BITS(struct amap_default_pdu_context_ext,
1029 			      cq_id_recv, ctxt, cq->id);
1030 	}
1031 
1032 	be_dws_cpu_to_le(ctxt, sizeof(req->context));
1033 
1034 	be_cmd_page_addrs_prepare(req->pages, ARRAY_SIZE(req->pages), q_mem);
1035 
1036 	status = be_mbox_notify(ctrl);
1037 	if (!status) {
1038 		struct be_ring *defq_ring;
1039 		struct be_defq_create_resp *resp = embedded_payload(wrb);
1040 
1041 		dq->id = le16_to_cpu(resp->id);
1042 		dq->created = true;
1043 		if (is_header)
1044 			defq_ring = &phba->phwi_ctrlr->default_pdu_hdr[ulp_num];
1045 		else
1046 			defq_ring = &phba->phwi_ctrlr->
1047 				    default_pdu_data[ulp_num];
1048 
1049 		defq_ring->id = dq->id;
1050 
1051 		if (!phba->fw_config.dual_ulp_aware) {
1052 			defq_ring->ulp_num = BEISCSI_ULP0;
1053 			defq_ring->doorbell_offset = DB_RXULP0_OFFSET;
1054 		} else {
1055 			defq_ring->ulp_num = resp->ulp_num;
1056 			defq_ring->doorbell_offset = resp->doorbell_offset;
1057 		}
1058 	}
1059 	mutex_unlock(&ctrl->mbox_lock);
1060 
1061 	return status;
1062 }
1063 
1064 /**
1065  * be_cmd_wrbq_create()- Create WRBQ
1066  * @ctrl: ptr to ctrl_info
1067  * @q_mem: memory details for the queue
1068  * @wrbq: queue info
1069  * @pwrb_context: ptr to wrb_context
1070  * @ulp_num: ULP on which the WRBQ is to be created
1071  *
1072  * Create WRBQ on the passed ULP_NUM.
1073  *
1074  **/
1075 int be_cmd_wrbq_create(struct be_ctrl_info *ctrl,
1076 			struct be_dma_mem *q_mem,
1077 			struct be_queue_info *wrbq,
1078 			struct hwi_wrb_context *pwrb_context,
1079 			uint8_t ulp_num)
1080 {
1081 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
1082 	struct be_wrbq_create_req *req = embedded_payload(wrb);
1083 	struct be_wrbq_create_resp *resp = embedded_payload(wrb);
1084 	struct beiscsi_hba *phba = pci_get_drvdata(ctrl->pdev);
1085 	int status;
1086 
1087 	mutex_lock(&ctrl->mbox_lock);
1088 	memset(wrb, 0, sizeof(*wrb));
1089 
1090 	be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
1091 
1092 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_ISCSI,
1093 		OPCODE_COMMON_ISCSI_WRBQ_CREATE, sizeof(*req));
1094 	req->num_pages = PAGES_4K_SPANNED(q_mem->va, q_mem->size);
1095 
1096 	if (phba->fw_config.dual_ulp_aware) {
1097 		req->ulp_num = ulp_num;
1098 		req->dua_feature |= (1 << BEISCSI_DUAL_ULP_AWARE_BIT);
1099 		req->dua_feature |= (1 << BEISCSI_BIND_Q_TO_ULP_BIT);
1100 	}
1101 
1102 	be_cmd_page_addrs_prepare(req->pages, ARRAY_SIZE(req->pages), q_mem);
1103 
1104 	status = be_mbox_notify(ctrl);
1105 	if (!status) {
1106 		wrbq->id = le16_to_cpu(resp->cid);
1107 		wrbq->created = true;
1108 
1109 		pwrb_context->cid = wrbq->id;
1110 		if (!phba->fw_config.dual_ulp_aware) {
1111 			pwrb_context->doorbell_offset = DB_TXULP0_OFFSET;
1112 			pwrb_context->ulp_num = BEISCSI_ULP0;
1113 		} else {
1114 			pwrb_context->ulp_num = resp->ulp_num;
1115 			pwrb_context->doorbell_offset = resp->doorbell_offset;
1116 		}
1117 	}
1118 	mutex_unlock(&ctrl->mbox_lock);
1119 	return status;
1120 }
1121 
1122 int be_cmd_iscsi_post_template_hdr(struct be_ctrl_info *ctrl,
1123 				    struct be_dma_mem *q_mem)
1124 {
1125 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
1126 	struct be_post_template_pages_req *req = embedded_payload(wrb);
1127 	int status;
1128 
1129 	mutex_lock(&ctrl->mbox_lock);
1130 
1131 	memset(wrb, 0, sizeof(*wrb));
1132 	be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
1133 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_COMMON,
1134 			   OPCODE_COMMON_ADD_TEMPLATE_HEADER_BUFFERS,
1135 			   sizeof(*req));
1136 
1137 	req->num_pages = PAGES_4K_SPANNED(q_mem->va, q_mem->size);
1138 	req->type = BEISCSI_TEMPLATE_HDR_TYPE_ISCSI;
1139 	be_cmd_page_addrs_prepare(req->pages, ARRAY_SIZE(req->pages), q_mem);
1140 
1141 	status = be_mbox_notify(ctrl);
1142 	mutex_unlock(&ctrl->mbox_lock);
1143 	return status;
1144 }
1145 
1146 int be_cmd_iscsi_remove_template_hdr(struct be_ctrl_info *ctrl)
1147 {
1148 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
1149 	struct be_remove_template_pages_req *req = embedded_payload(wrb);
1150 	int status;
1151 
1152 	mutex_lock(&ctrl->mbox_lock);
1153 
1154 	memset(wrb, 0, sizeof(*wrb));
1155 	be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
1156 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_COMMON,
1157 			   OPCODE_COMMON_REMOVE_TEMPLATE_HEADER_BUFFERS,
1158 			   sizeof(*req));
1159 
1160 	req->type = BEISCSI_TEMPLATE_HDR_TYPE_ISCSI;
1161 
1162 	status = be_mbox_notify(ctrl);
1163 	mutex_unlock(&ctrl->mbox_lock);
1164 	return status;
1165 }
1166 
1167 int be_cmd_iscsi_post_sgl_pages(struct be_ctrl_info *ctrl,
1168 				struct be_dma_mem *q_mem,
1169 				u32 page_offset, u32 num_pages)
1170 {
1171 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
1172 	struct be_post_sgl_pages_req *req = embedded_payload(wrb);
1173 	struct beiscsi_hba *phba = pci_get_drvdata(ctrl->pdev);
1174 	int status;
1175 	unsigned int curr_pages;
1176 	u32 temp_num_pages = num_pages;
1177 
1178 	if (num_pages == 0xff)
1179 		num_pages = 1;
1180 
1181 	mutex_lock(&ctrl->mbox_lock);
1182 	do {
1183 		memset(wrb, 0, sizeof(*wrb));
1184 		be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
1185 		be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_ISCSI,
1186 				   OPCODE_COMMON_ISCSI_CFG_POST_SGL_PAGES,
1187 				   sizeof(*req));
1188 		curr_pages = BE_NUMBER_OF_FIELD(struct be_post_sgl_pages_req,
1189 						pages);
1190 		req->num_pages = min(num_pages, curr_pages);
1191 		req->page_offset = page_offset;
1192 		be_cmd_page_addrs_prepare(req->pages, req->num_pages, q_mem);
1193 		q_mem->dma = q_mem->dma + (req->num_pages * PAGE_SIZE);
1194 		page_offset += req->num_pages;
1195 		num_pages -= req->num_pages;
1196 
1197 		if (temp_num_pages == 0xff)
1198 			req->num_pages = temp_num_pages;
1199 
1200 		status = be_mbox_notify(ctrl);
1201 		if (status) {
1202 			beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1203 				    "BC_%d : FW CMD to map iscsi frags failed.\n");
1204 
1205 			goto error;
1206 		}
1207 	} while (num_pages > 0);
1208 error:
1209 	mutex_unlock(&ctrl->mbox_lock);
1210 	if (status != 0)
1211 		beiscsi_cmd_q_destroy(ctrl, NULL, QTYPE_SGL);
1212 	return status;
1213 }
1214 
1215 /**
1216  * be_cmd_set_vlan()- Configure VLAN paramters on the adapter
1217  * @phba: device priv structure instance
1218  * @vlan_tag: TAG to be set
1219  *
1220  * Set the VLAN_TAG for the adapter or Disable VLAN on adapter
1221  *
1222  * returns
1223  *	TAG for the MBX Cmd
1224  * **/
1225 int be_cmd_set_vlan(struct beiscsi_hba *phba,
1226 		     uint16_t vlan_tag)
1227 {
1228 	unsigned int tag;
1229 	struct be_mcc_wrb *wrb;
1230 	struct be_cmd_set_vlan_req *req;
1231 	struct be_ctrl_info *ctrl = &phba->ctrl;
1232 
1233 	if (mutex_lock_interruptible(&ctrl->mbox_lock))
1234 		return 0;
1235 	wrb = alloc_mcc_wrb(phba, &tag);
1236 	if (!wrb) {
1237 		mutex_unlock(&ctrl->mbox_lock);
1238 		return 0;
1239 	}
1240 
1241 	req = embedded_payload(wrb);
1242 	be_wrb_hdr_prepare(wrb, sizeof(*wrb), true, 0);
1243 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_ISCSI,
1244 			   OPCODE_COMMON_ISCSI_NTWK_SET_VLAN,
1245 			   sizeof(*req));
1246 
1247 	req->interface_hndl = phba->interface_handle;
1248 	req->vlan_priority = vlan_tag;
1249 
1250 	be_mcc_notify(phba, tag);
1251 	mutex_unlock(&ctrl->mbox_lock);
1252 
1253 	return tag;
1254 }
1255 
1256 int beiscsi_check_supported_fw(struct be_ctrl_info *ctrl,
1257 			       struct beiscsi_hba *phba)
1258 {
1259 	struct be_dma_mem nonemb_cmd;
1260 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
1261 	struct be_mgmt_controller_attributes *req;
1262 	struct be_sge *sge = nonembedded_sgl(wrb);
1263 	int status = 0;
1264 
1265 	nonemb_cmd.va = dma_alloc_coherent(&ctrl->pdev->dev,
1266 				sizeof(struct be_mgmt_controller_attributes),
1267 				&nonemb_cmd.dma, GFP_KERNEL);
1268 	if (nonemb_cmd.va == NULL) {
1269 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1270 			    "BG_%d : dma_alloc_coherent failed in %s\n",
1271 			    __func__);
1272 		return -ENOMEM;
1273 	}
1274 	nonemb_cmd.size = sizeof(struct be_mgmt_controller_attributes);
1275 	req = nonemb_cmd.va;
1276 	memset(req, 0, sizeof(*req));
1277 	mutex_lock(&ctrl->mbox_lock);
1278 	memset(wrb, 0, sizeof(*wrb));
1279 	be_wrb_hdr_prepare(wrb, sizeof(*req), false, 1);
1280 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_COMMON,
1281 			   OPCODE_COMMON_GET_CNTL_ATTRIBUTES, sizeof(*req));
1282 	sge->pa_hi = cpu_to_le32(upper_32_bits(nonemb_cmd.dma));
1283 	sge->pa_lo = cpu_to_le32(nonemb_cmd.dma & 0xFFFFFFFF);
1284 	sge->len = cpu_to_le32(nonemb_cmd.size);
1285 	status = be_mbox_notify(ctrl);
1286 	if (!status) {
1287 		struct be_mgmt_controller_attributes_resp *resp = nonemb_cmd.va;
1288 
1289 		beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
1290 			    "BG_%d : Firmware Version of CMD : %s\n"
1291 			    "Firmware Version is : %s\n"
1292 			    "Developer Build, not performing version check...\n",
1293 			    resp->params.hba_attribs
1294 			    .flashrom_version_string,
1295 			    resp->params.hba_attribs.
1296 			    firmware_version_string);
1297 
1298 		phba->fw_config.iscsi_features =
1299 				resp->params.hba_attribs.iscsi_features;
1300 		beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
1301 			    "BM_%d : phba->fw_config.iscsi_features = %d\n",
1302 			    phba->fw_config.iscsi_features);
1303 		memcpy(phba->fw_ver_str, resp->params.hba_attribs.
1304 		       firmware_version_string, BEISCSI_VER_STRLEN);
1305 	} else
1306 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1307 			    "BG_%d :  Failed in beiscsi_check_supported_fw\n");
1308 	mutex_unlock(&ctrl->mbox_lock);
1309 	if (nonemb_cmd.va)
1310 		dma_free_coherent(&ctrl->pdev->dev, nonemb_cmd.size,
1311 				    nonemb_cmd.va, nonemb_cmd.dma);
1312 
1313 	return status;
1314 }
1315 
1316 /**
1317  * beiscsi_get_fw_config()- Get the FW config for the function
1318  * @ctrl: ptr to Ctrl Info
1319  * @phba: ptr to the dev priv structure
1320  *
1321  * Get the FW config and resources available for the function.
1322  * The resources are created based on the count received here.
1323  *
1324  * return
1325  *	Success: 0
1326  *	Failure: Non-Zero Value
1327  **/
1328 int beiscsi_get_fw_config(struct be_ctrl_info *ctrl,
1329 			  struct beiscsi_hba *phba)
1330 {
1331 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
1332 	struct be_fw_cfg *pfw_cfg = embedded_payload(wrb);
1333 	uint32_t cid_count, icd_count;
1334 	int status = -EINVAL;
1335 	uint8_t ulp_num = 0;
1336 
1337 	mutex_lock(&ctrl->mbox_lock);
1338 	memset(wrb, 0, sizeof(*wrb));
1339 	be_wrb_hdr_prepare(wrb, sizeof(*pfw_cfg), true, 0);
1340 
1341 	be_cmd_hdr_prepare(&pfw_cfg->hdr, CMD_SUBSYSTEM_COMMON,
1342 			   OPCODE_COMMON_QUERY_FIRMWARE_CONFIG,
1343 			   EMBED_MBX_MAX_PAYLOAD_SIZE);
1344 
1345 	if (be_mbox_notify(ctrl)) {
1346 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1347 			    "BG_%d : Failed in beiscsi_get_fw_config\n");
1348 		goto fail_init;
1349 	}
1350 
1351 	/* FW response formats depend on port id */
1352 	phba->fw_config.phys_port = pfw_cfg->phys_port;
1353 	if (phba->fw_config.phys_port >= BEISCSI_PHYS_PORT_MAX) {
1354 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1355 			    "BG_%d : invalid physical port id %d\n",
1356 			    phba->fw_config.phys_port);
1357 		goto fail_init;
1358 	}
1359 
1360 	/* populate and check FW config against min and max values */
1361 	if (!is_chip_be2_be3r(phba)) {
1362 		phba->fw_config.eqid_count = pfw_cfg->eqid_count;
1363 		phba->fw_config.cqid_count = pfw_cfg->cqid_count;
1364 		if (phba->fw_config.eqid_count == 0 ||
1365 		    phba->fw_config.eqid_count > 2048) {
1366 			beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1367 				    "BG_%d : invalid EQ count %d\n",
1368 				    phba->fw_config.eqid_count);
1369 			goto fail_init;
1370 		}
1371 		if (phba->fw_config.cqid_count == 0 ||
1372 		    phba->fw_config.cqid_count > 4096) {
1373 			beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1374 				    "BG_%d : invalid CQ count %d\n",
1375 				    phba->fw_config.cqid_count);
1376 			goto fail_init;
1377 		}
1378 		beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
1379 			    "BG_%d : EQ_Count : %d CQ_Count : %d\n",
1380 			    phba->fw_config.eqid_count,
1381 			    phba->fw_config.cqid_count);
1382 	}
1383 
1384 	/**
1385 	 * Check on which all ULP iSCSI Protocol is loaded.
1386 	 * Set the Bit for those ULP. This set flag is used
1387 	 * at all places in the code to check on which ULP
1388 	 * iSCSi Protocol is loaded
1389 	 **/
1390 	for (ulp_num = 0; ulp_num < BEISCSI_ULP_COUNT; ulp_num++) {
1391 		if (pfw_cfg->ulp[ulp_num].ulp_mode &
1392 		    BEISCSI_ULP_ISCSI_INI_MODE) {
1393 			set_bit(ulp_num, &phba->fw_config.ulp_supported);
1394 
1395 			/* Get the CID, ICD and Chain count for each ULP */
1396 			phba->fw_config.iscsi_cid_start[ulp_num] =
1397 				pfw_cfg->ulp[ulp_num].sq_base;
1398 			phba->fw_config.iscsi_cid_count[ulp_num] =
1399 				pfw_cfg->ulp[ulp_num].sq_count;
1400 
1401 			phba->fw_config.iscsi_icd_start[ulp_num] =
1402 				pfw_cfg->ulp[ulp_num].icd_base;
1403 			phba->fw_config.iscsi_icd_count[ulp_num] =
1404 				pfw_cfg->ulp[ulp_num].icd_count;
1405 
1406 			phba->fw_config.iscsi_chain_start[ulp_num] =
1407 				pfw_cfg->chain_icd[ulp_num].chain_base;
1408 			phba->fw_config.iscsi_chain_count[ulp_num] =
1409 				pfw_cfg->chain_icd[ulp_num].chain_count;
1410 
1411 			beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
1412 				    "BG_%d : Function loaded on ULP : %d\n"
1413 				    "\tiscsi_cid_count : %d\n"
1414 				    "\tiscsi_cid_start : %d\n"
1415 				    "\t iscsi_icd_count : %d\n"
1416 				    "\t iscsi_icd_start : %d\n",
1417 				    ulp_num,
1418 				    phba->fw_config.
1419 				    iscsi_cid_count[ulp_num],
1420 				    phba->fw_config.
1421 				    iscsi_cid_start[ulp_num],
1422 				    phba->fw_config.
1423 				    iscsi_icd_count[ulp_num],
1424 				    phba->fw_config.
1425 				    iscsi_icd_start[ulp_num]);
1426 		}
1427 	}
1428 
1429 	if (phba->fw_config.ulp_supported == 0) {
1430 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1431 			    "BG_%d : iSCSI initiator mode not set: ULP0 %x ULP1 %x\n",
1432 			    pfw_cfg->ulp[BEISCSI_ULP0].ulp_mode,
1433 			    pfw_cfg->ulp[BEISCSI_ULP1].ulp_mode);
1434 		goto fail_init;
1435 	}
1436 
1437 	/**
1438 	 * ICD is shared among ULPs. Use icd_count of any one loaded ULP
1439 	 **/
1440 	for (ulp_num = 0; ulp_num < BEISCSI_ULP_COUNT; ulp_num++)
1441 		if (test_bit(ulp_num, &phba->fw_config.ulp_supported))
1442 			break;
1443 	icd_count = phba->fw_config.iscsi_icd_count[ulp_num];
1444 	if (icd_count == 0 || icd_count > 65536) {
1445 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1446 			    "BG_%d: invalid ICD count %d\n", icd_count);
1447 		goto fail_init;
1448 	}
1449 
1450 	cid_count = BEISCSI_GET_CID_COUNT(phba, BEISCSI_ULP0) +
1451 		    BEISCSI_GET_CID_COUNT(phba, BEISCSI_ULP1);
1452 	if (cid_count == 0 || cid_count > 4096) {
1453 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1454 			    "BG_%d: invalid CID count %d\n", cid_count);
1455 		goto fail_init;
1456 	}
1457 
1458 	/**
1459 	 * Check FW is dual ULP aware i.e. can handle either
1460 	 * of the protocols.
1461 	 */
1462 	phba->fw_config.dual_ulp_aware = (pfw_cfg->function_mode &
1463 					  BEISCSI_FUNC_DUA_MODE);
1464 
1465 	beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
1466 		    "BG_%d : DUA Mode : 0x%x\n",
1467 		    phba->fw_config.dual_ulp_aware);
1468 
1469 	/* all set, continue using this FW config */
1470 	status = 0;
1471 fail_init:
1472 	mutex_unlock(&ctrl->mbox_lock);
1473 	return status;
1474 }
1475 
1476 /**
1477  * beiscsi_get_port_name()- Get port name for the function
1478  * @ctrl: ptr to Ctrl Info
1479  * @phba: ptr to the dev priv structure
1480  *
1481  * Get the alphanumeric character for port
1482  *
1483  **/
1484 int beiscsi_get_port_name(struct be_ctrl_info *ctrl, struct beiscsi_hba *phba)
1485 {
1486 	int ret = 0;
1487 	struct be_mcc_wrb *wrb;
1488 	struct be_cmd_get_port_name *ioctl;
1489 
1490 	mutex_lock(&ctrl->mbox_lock);
1491 	wrb = wrb_from_mbox(&ctrl->mbox_mem);
1492 	memset(wrb, 0, sizeof(*wrb));
1493 	ioctl = embedded_payload(wrb);
1494 
1495 	be_wrb_hdr_prepare(wrb, sizeof(*ioctl), true, 0);
1496 	be_cmd_hdr_prepare(&ioctl->h.req_hdr, CMD_SUBSYSTEM_COMMON,
1497 			   OPCODE_COMMON_GET_PORT_NAME,
1498 			   EMBED_MBX_MAX_PAYLOAD_SIZE);
1499 	ret = be_mbox_notify(ctrl);
1500 	phba->port_name = 0;
1501 	if (!ret) {
1502 		phba->port_name = ioctl->p.resp.port_names >>
1503 				  (phba->fw_config.phys_port * 8) & 0xff;
1504 	} else {
1505 		beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
1506 			    "BG_%d : GET_PORT_NAME ret 0x%x status 0x%x\n",
1507 			    ret, ioctl->h.resp_hdr.status);
1508 	}
1509 
1510 	if (phba->port_name == 0)
1511 		phba->port_name = '?';
1512 
1513 	mutex_unlock(&ctrl->mbox_lock);
1514 	return ret;
1515 }
1516 
1517 int beiscsi_set_host_data(struct beiscsi_hba *phba)
1518 {
1519 	struct be_ctrl_info *ctrl = &phba->ctrl;
1520 	struct be_cmd_set_host_data *ioctl;
1521 	struct be_mcc_wrb *wrb;
1522 	int ret = 0;
1523 
1524 	if (is_chip_be2_be3r(phba))
1525 		return ret;
1526 
1527 	mutex_lock(&ctrl->mbox_lock);
1528 	wrb = wrb_from_mbox(&ctrl->mbox_mem);
1529 	memset(wrb, 0, sizeof(*wrb));
1530 	ioctl = embedded_payload(wrb);
1531 
1532 	be_wrb_hdr_prepare(wrb, sizeof(*ioctl), true, 0);
1533 	be_cmd_hdr_prepare(&ioctl->h.req_hdr, CMD_SUBSYSTEM_COMMON,
1534 			   OPCODE_COMMON_SET_HOST_DATA,
1535 			   EMBED_MBX_MAX_PAYLOAD_SIZE);
1536 	ioctl->param.req.param_id = BE_CMD_SET_HOST_PARAM_ID;
1537 	ioctl->param.req.param_len =
1538 		snprintf((char *)ioctl->param.req.param_data,
1539 			 sizeof(ioctl->param.req.param_data),
1540 			 "Linux iSCSI v%s", BUILD_STR);
1541 	ioctl->param.req.param_len = ALIGN(ioctl->param.req.param_len + 1, 4);
1542 	if (ioctl->param.req.param_len > BE_CMD_MAX_DRV_VERSION)
1543 		ioctl->param.req.param_len = BE_CMD_MAX_DRV_VERSION;
1544 	ret = be_mbox_notify(ctrl);
1545 	if (!ret) {
1546 		beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
1547 			    "BG_%d : HBA set host driver version\n");
1548 	} else {
1549 		/**
1550 		 * Check "MCC_STATUS_INVALID_LENGTH" for SKH.
1551 		 * Older FW versions return this error.
1552 		 */
1553 		if (ret == MCC_STATUS_ILLEGAL_REQUEST ||
1554 				ret == MCC_STATUS_INVALID_LENGTH)
1555 			__beiscsi_log(phba, KERN_INFO,
1556 				      "BG_%d : HBA failed to set host driver version\n");
1557 	}
1558 
1559 	mutex_unlock(&ctrl->mbox_lock);
1560 	return ret;
1561 }
1562 
1563 int beiscsi_set_uer_feature(struct beiscsi_hba *phba)
1564 {
1565 	struct be_ctrl_info *ctrl = &phba->ctrl;
1566 	struct be_cmd_set_features *ioctl;
1567 	struct be_mcc_wrb *wrb;
1568 	int ret = 0;
1569 
1570 	mutex_lock(&ctrl->mbox_lock);
1571 	wrb = wrb_from_mbox(&ctrl->mbox_mem);
1572 	memset(wrb, 0, sizeof(*wrb));
1573 	ioctl = embedded_payload(wrb);
1574 
1575 	be_wrb_hdr_prepare(wrb, sizeof(*ioctl), true, 0);
1576 	be_cmd_hdr_prepare(&ioctl->h.req_hdr, CMD_SUBSYSTEM_COMMON,
1577 			   OPCODE_COMMON_SET_FEATURES,
1578 			   EMBED_MBX_MAX_PAYLOAD_SIZE);
1579 	ioctl->feature = BE_CMD_SET_FEATURE_UER;
1580 	ioctl->param_len = sizeof(ioctl->param.req);
1581 	ioctl->param.req.uer = BE_CMD_UER_SUPP_BIT;
1582 	ret = be_mbox_notify(ctrl);
1583 	if (!ret) {
1584 		phba->ue2rp = ioctl->param.resp.ue2rp;
1585 		set_bit(BEISCSI_HBA_UER_SUPP, &phba->state);
1586 		beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
1587 			    "BG_%d : HBA error recovery supported\n");
1588 	} else {
1589 		/**
1590 		 * Check "MCC_STATUS_INVALID_LENGTH" for SKH.
1591 		 * Older FW versions return this error.
1592 		 */
1593 		if (ret == MCC_STATUS_ILLEGAL_REQUEST ||
1594 		    ret == MCC_STATUS_INVALID_LENGTH)
1595 			__beiscsi_log(phba, KERN_INFO,
1596 				      "BG_%d : HBA error recovery not supported\n");
1597 	}
1598 
1599 	mutex_unlock(&ctrl->mbox_lock);
1600 	return ret;
1601 }
1602 
1603 static u32 beiscsi_get_post_stage(struct beiscsi_hba *phba)
1604 {
1605 	u32 sem;
1606 
1607 	if (is_chip_be2_be3r(phba))
1608 		sem = ioread32(phba->csr_va + SLIPORT_SEMAPHORE_OFFSET_BEx);
1609 	else
1610 		pci_read_config_dword(phba->pcidev,
1611 				      SLIPORT_SEMAPHORE_OFFSET_SH, &sem);
1612 	return sem;
1613 }
1614 
1615 int beiscsi_check_fw_rdy(struct beiscsi_hba *phba)
1616 {
1617 	u32 loop, post, rdy = 0;
1618 
1619 	loop = 1000;
1620 	while (loop--) {
1621 		post = beiscsi_get_post_stage(phba);
1622 		if (post & POST_ERROR_BIT)
1623 			break;
1624 		if ((post & POST_STAGE_MASK) == POST_STAGE_ARMFW_RDY) {
1625 			rdy = 1;
1626 			break;
1627 		}
1628 		msleep(60);
1629 	}
1630 
1631 	if (!rdy) {
1632 		__beiscsi_log(phba, KERN_ERR,
1633 			      "BC_%d : FW not ready 0x%x\n", post);
1634 	}
1635 
1636 	return rdy;
1637 }
1638 
1639 int beiscsi_cmd_function_reset(struct beiscsi_hba *phba)
1640 {
1641 	struct be_ctrl_info *ctrl = &phba->ctrl;
1642 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
1643 	struct be_post_sgl_pages_req *req;
1644 	int status;
1645 
1646 	mutex_lock(&ctrl->mbox_lock);
1647 
1648 	req = embedded_payload(wrb);
1649 	be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
1650 	be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_COMMON,
1651 			   OPCODE_COMMON_FUNCTION_RESET, sizeof(*req));
1652 	status = be_mbox_notify(ctrl);
1653 
1654 	mutex_unlock(&ctrl->mbox_lock);
1655 	return status;
1656 }
1657 
1658 int beiscsi_cmd_special_wrb(struct be_ctrl_info *ctrl, u32 load)
1659 {
1660 	struct be_mcc_wrb *wrb = wrb_from_mbox(&ctrl->mbox_mem);
1661 	struct beiscsi_hba *phba = pci_get_drvdata(ctrl->pdev);
1662 	u8 *endian_check;
1663 	int status;
1664 
1665 	mutex_lock(&ctrl->mbox_lock);
1666 	memset(wrb, 0, sizeof(*wrb));
1667 
1668 	endian_check = (u8 *) wrb;
1669 	if (load) {
1670 		/* to start communicating */
1671 		*endian_check++ = 0xFF;
1672 		*endian_check++ = 0x12;
1673 		*endian_check++ = 0x34;
1674 		*endian_check++ = 0xFF;
1675 		*endian_check++ = 0xFF;
1676 		*endian_check++ = 0x56;
1677 		*endian_check++ = 0x78;
1678 		*endian_check++ = 0xFF;
1679 	} else {
1680 		/* to stop communicating */
1681 		*endian_check++ = 0xFF;
1682 		*endian_check++ = 0xAA;
1683 		*endian_check++ = 0xBB;
1684 		*endian_check++ = 0xFF;
1685 		*endian_check++ = 0xFF;
1686 		*endian_check++ = 0xCC;
1687 		*endian_check++ = 0xDD;
1688 		*endian_check = 0xFF;
1689 	}
1690 	be_dws_cpu_to_le(wrb, sizeof(*wrb));
1691 
1692 	status = be_mbox_notify(ctrl);
1693 	if (status)
1694 		beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
1695 			    "BC_%d : special WRB message failed\n");
1696 	mutex_unlock(&ctrl->mbox_lock);
1697 	return status;
1698 }
1699 
1700 int beiscsi_init_sliport(struct beiscsi_hba *phba)
1701 {
1702 	int status;
1703 
1704 	/* check POST stage before talking to FW */
1705 	status = beiscsi_check_fw_rdy(phba);
1706 	if (!status)
1707 		return -EIO;
1708 
1709 	/* clear all error states after checking FW rdy */
1710 	phba->state &= ~BEISCSI_HBA_IN_ERR;
1711 
1712 	/* check again UER support */
1713 	phba->state &= ~BEISCSI_HBA_UER_SUPP;
1714 
1715 	/*
1716 	 * SLI COMMON_FUNCTION_RESET completion is indicated by BMBX RDY bit.
1717 	 * It should clean up any stale info in FW for this fn.
1718 	 */
1719 	status = beiscsi_cmd_function_reset(phba);
1720 	if (status) {
1721 		beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
1722 			    "BC_%d : SLI Function Reset failed\n");
1723 		return status;
1724 	}
1725 
1726 	/* indicate driver is loading */
1727 	return beiscsi_cmd_special_wrb(&phba->ctrl, 1);
1728 }
1729 
1730 /**
1731  * beiscsi_cmd_iscsi_cleanup()- Inform FW to cleanup EP data structures.
1732  * @phba: pointer to dev priv structure
1733  * @ulp: ULP number.
1734  *
1735  * return
1736  *	Success: 0
1737  *	Failure: Non-Zero Value
1738  **/
1739 int beiscsi_cmd_iscsi_cleanup(struct beiscsi_hba *phba, unsigned short ulp)
1740 {
1741 	struct be_ctrl_info *ctrl = &phba->ctrl;
1742 	struct iscsi_cleanup_req_v1 *req_v1;
1743 	struct iscsi_cleanup_req *req;
1744 	u16 hdr_ring_id, data_ring_id;
1745 	struct be_mcc_wrb *wrb;
1746 	int status;
1747 
1748 	mutex_lock(&ctrl->mbox_lock);
1749 	wrb = wrb_from_mbox(&ctrl->mbox_mem);
1750 
1751 	hdr_ring_id = HWI_GET_DEF_HDRQ_ID(phba, ulp);
1752 	data_ring_id = HWI_GET_DEF_BUFQ_ID(phba, ulp);
1753 	if (is_chip_be2_be3r(phba)) {
1754 		req = embedded_payload(wrb);
1755 		be_wrb_hdr_prepare(wrb, sizeof(*req), true, 0);
1756 		be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_ISCSI,
1757 				   OPCODE_COMMON_ISCSI_CLEANUP, sizeof(*req));
1758 		req->chute = (1 << ulp);
1759 		/* BE2/BE3 FW creates 8-bit ring id */
1760 		req->hdr_ring_id = hdr_ring_id;
1761 		req->data_ring_id = data_ring_id;
1762 	} else {
1763 		req_v1 = embedded_payload(wrb);
1764 		be_wrb_hdr_prepare(wrb, sizeof(*req_v1), true, 0);
1765 		be_cmd_hdr_prepare(&req_v1->hdr, CMD_SUBSYSTEM_ISCSI,
1766 				   OPCODE_COMMON_ISCSI_CLEANUP,
1767 				   sizeof(*req_v1));
1768 		req_v1->hdr.version = 1;
1769 		req_v1->chute = (1 << ulp);
1770 		req_v1->hdr_ring_id = cpu_to_le16(hdr_ring_id);
1771 		req_v1->data_ring_id = cpu_to_le16(data_ring_id);
1772 	}
1773 
1774 	status = be_mbox_notify(ctrl);
1775 	if (status)
1776 		beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
1777 			    "BG_%d : %s failed %d\n", __func__, ulp);
1778 	mutex_unlock(&ctrl->mbox_lock);
1779 	return status;
1780 }
1781 
1782 /*
1783  * beiscsi_detect_ue()- Detect Unrecoverable Error on adapter
1784  * @phba: Driver priv structure
1785  *
1786  * Read registers linked to UE and check for the UE status
1787  **/
1788 int beiscsi_detect_ue(struct beiscsi_hba *phba)
1789 {
1790 	uint32_t ue_mask_hi = 0, ue_mask_lo = 0;
1791 	uint32_t ue_hi = 0, ue_lo = 0;
1792 	uint8_t i = 0;
1793 	int ret = 0;
1794 
1795 	pci_read_config_dword(phba->pcidev,
1796 			      PCICFG_UE_STATUS_LOW, &ue_lo);
1797 	pci_read_config_dword(phba->pcidev,
1798 			      PCICFG_UE_STATUS_MASK_LOW,
1799 			      &ue_mask_lo);
1800 	pci_read_config_dword(phba->pcidev,
1801 			      PCICFG_UE_STATUS_HIGH,
1802 			      &ue_hi);
1803 	pci_read_config_dword(phba->pcidev,
1804 			      PCICFG_UE_STATUS_MASK_HI,
1805 			      &ue_mask_hi);
1806 
1807 	ue_lo = (ue_lo & ~ue_mask_lo);
1808 	ue_hi = (ue_hi & ~ue_mask_hi);
1809 
1810 
1811 	if (ue_lo || ue_hi) {
1812 		set_bit(BEISCSI_HBA_IN_UE, &phba->state);
1813 		__beiscsi_log(phba, KERN_ERR,
1814 			      "BC_%d : HBA error detected\n");
1815 		ret = 1;
1816 	}
1817 
1818 	if (ue_lo) {
1819 		for (i = 0; ue_lo; ue_lo >>= 1, i++) {
1820 			if (ue_lo & 1)
1821 				__beiscsi_log(phba, KERN_ERR,
1822 					      "BC_%d : UE_LOW %s bit set\n",
1823 					      desc_ue_status_low[i]);
1824 		}
1825 	}
1826 
1827 	if (ue_hi) {
1828 		for (i = 0; ue_hi; ue_hi >>= 1, i++) {
1829 			if (ue_hi & 1)
1830 				__beiscsi_log(phba, KERN_ERR,
1831 					      "BC_%d : UE_HIGH %s bit set\n",
1832 					      desc_ue_status_hi[i]);
1833 		}
1834 	}
1835 	return ret;
1836 }
1837 
1838 /*
1839  * beiscsi_detect_tpe()- Detect Transient Parity Error on adapter
1840  * @phba: Driver priv structure
1841  *
1842  * Read SLIPORT SEMAPHORE register to check for UER
1843  *
1844  **/
1845 int beiscsi_detect_tpe(struct beiscsi_hba *phba)
1846 {
1847 	u32 post, status;
1848 	int ret = 0;
1849 
1850 	post = beiscsi_get_post_stage(phba);
1851 	status = post & POST_STAGE_MASK;
1852 	if ((status & POST_ERR_RECOVERY_CODE_MASK) ==
1853 	    POST_STAGE_RECOVERABLE_ERR) {
1854 		set_bit(BEISCSI_HBA_IN_TPE, &phba->state);
1855 		__beiscsi_log(phba, KERN_INFO,
1856 			      "BC_%d : HBA error recoverable: 0x%x\n", post);
1857 		ret = 1;
1858 	} else {
1859 		__beiscsi_log(phba, KERN_INFO,
1860 			      "BC_%d : HBA in UE: 0x%x\n", post);
1861 	}
1862 
1863 	return ret;
1864 }
1865