1 /* 2 * Copyright (c) 2005-2010 Brocade Communications Systems, Inc. 3 * All rights reserved 4 * www.brocade.com 5 * 6 * Linux driver for Brocade Fibre Channel Host Bus Adapter. 7 * 8 * This program is free software; you can redistribute it and/or modify it 9 * under the terms of the GNU General Public License (GPL) Version 2 as 10 * published by the Free Software Foundation 11 * 12 * This program is distributed in the hope that it will be useful, but 13 * WITHOUT ANY WARRANTY; without even the implied warranty of 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 15 * General Public License for more details. 16 */ 17 18 /* 19 * bfad.c Linux driver PCI interface module. 20 */ 21 #include <linux/module.h> 22 #include <linux/kthread.h> 23 #include <linux/errno.h> 24 #include <linux/sched.h> 25 #include <linux/init.h> 26 #include <linux/fs.h> 27 #include <linux/pci.h> 28 #include <linux/firmware.h> 29 #include <asm/uaccess.h> 30 #include <asm/fcntl.h> 31 32 #include "bfad_drv.h" 33 #include "bfad_im.h" 34 #include "bfa_fcs.h" 35 #include "bfa_defs.h" 36 #include "bfa.h" 37 38 BFA_TRC_FILE(LDRV, BFAD); 39 DEFINE_MUTEX(bfad_mutex); 40 LIST_HEAD(bfad_list); 41 42 static int bfad_inst; 43 static int num_sgpgs_parm; 44 int supported_fc4s; 45 char *host_name, *os_name, *os_patch; 46 int num_rports, num_ios, num_tms; 47 int num_fcxps, num_ufbufs; 48 int reqq_size, rspq_size, num_sgpgs; 49 int rport_del_timeout = BFA_FCS_RPORT_DEF_DEL_TIMEOUT; 50 int bfa_lun_queue_depth = BFAD_LUN_QUEUE_DEPTH; 51 int bfa_io_max_sge = BFAD_IO_MAX_SGE; 52 int bfa_log_level = 3; /* WARNING log level */ 53 int ioc_auto_recover = BFA_TRUE; 54 int bfa_linkup_delay = -1; 55 int fdmi_enable = BFA_TRUE; 56 int pcie_max_read_reqsz; 57 int bfa_debugfs_enable = 1; 58 int msix_disable_cb = 0, msix_disable_ct = 0; 59 60 u32 bfi_image_ct_fc_size, bfi_image_ct_cna_size, bfi_image_cb_fc_size; 61 u32 *bfi_image_ct_fc, *bfi_image_ct_cna, *bfi_image_cb_fc; 62 63 static const char *msix_name_ct[] = { 64 "cpe0", "cpe1", "cpe2", "cpe3", 65 "rme0", "rme1", "rme2", "rme3", 66 "ctrl" }; 67 68 static const char *msix_name_cb[] = { 69 "cpe0", "cpe1", "cpe2", "cpe3", 70 "rme0", "rme1", "rme2", "rme3", 71 "eemc", "elpu0", "elpu1", "epss", "mlpu" }; 72 73 MODULE_FIRMWARE(BFAD_FW_FILE_CT_FC); 74 MODULE_FIRMWARE(BFAD_FW_FILE_CT_CNA); 75 MODULE_FIRMWARE(BFAD_FW_FILE_CB_FC); 76 77 module_param(os_name, charp, S_IRUGO | S_IWUSR); 78 MODULE_PARM_DESC(os_name, "OS name of the hba host machine"); 79 module_param(os_patch, charp, S_IRUGO | S_IWUSR); 80 MODULE_PARM_DESC(os_patch, "OS patch level of the hba host machine"); 81 module_param(host_name, charp, S_IRUGO | S_IWUSR); 82 MODULE_PARM_DESC(host_name, "Hostname of the hba host machine"); 83 module_param(num_rports, int, S_IRUGO | S_IWUSR); 84 MODULE_PARM_DESC(num_rports, "Max number of rports supported per port " 85 "(physical/logical), default=1024"); 86 module_param(num_ios, int, S_IRUGO | S_IWUSR); 87 MODULE_PARM_DESC(num_ios, "Max number of ioim requests, default=2000"); 88 module_param(num_tms, int, S_IRUGO | S_IWUSR); 89 MODULE_PARM_DESC(num_tms, "Max number of task im requests, default=128"); 90 module_param(num_fcxps, int, S_IRUGO | S_IWUSR); 91 MODULE_PARM_DESC(num_fcxps, "Max number of fcxp requests, default=64"); 92 module_param(num_ufbufs, int, S_IRUGO | S_IWUSR); 93 MODULE_PARM_DESC(num_ufbufs, "Max number of unsolicited frame " 94 "buffers, default=64"); 95 module_param(reqq_size, int, S_IRUGO | S_IWUSR); 96 MODULE_PARM_DESC(reqq_size, "Max number of request queue elements, " 97 "default=256"); 98 module_param(rspq_size, int, S_IRUGO | S_IWUSR); 99 MODULE_PARM_DESC(rspq_size, "Max number of response queue elements, " 100 "default=64"); 101 module_param(num_sgpgs, int, S_IRUGO | S_IWUSR); 102 MODULE_PARM_DESC(num_sgpgs, "Number of scatter/gather pages, default=2048"); 103 module_param(rport_del_timeout, int, S_IRUGO | S_IWUSR); 104 MODULE_PARM_DESC(rport_del_timeout, "Rport delete timeout, default=90 secs, " 105 "Range[>0]"); 106 module_param(bfa_lun_queue_depth, int, S_IRUGO | S_IWUSR); 107 MODULE_PARM_DESC(bfa_lun_queue_depth, "Lun queue depth, default=32, Range[>0]"); 108 module_param(bfa_io_max_sge, int, S_IRUGO | S_IWUSR); 109 MODULE_PARM_DESC(bfa_io_max_sge, "Max io scatter/gather elements, default=255"); 110 module_param(bfa_log_level, int, S_IRUGO | S_IWUSR); 111 MODULE_PARM_DESC(bfa_log_level, "Driver log level, default=3, " 112 "Range[Critical:1|Error:2|Warning:3|Info:4]"); 113 module_param(ioc_auto_recover, int, S_IRUGO | S_IWUSR); 114 MODULE_PARM_DESC(ioc_auto_recover, "IOC auto recovery, default=1, " 115 "Range[off:0|on:1]"); 116 module_param(bfa_linkup_delay, int, S_IRUGO | S_IWUSR); 117 MODULE_PARM_DESC(bfa_linkup_delay, "Link up delay, default=30 secs for " 118 "boot port. Otherwise 10 secs in RHEL4 & 0 for " 119 "[RHEL5, SLES10, ESX40] Range[>0]"); 120 module_param(msix_disable_cb, int, S_IRUGO | S_IWUSR); 121 MODULE_PARM_DESC(msix_disable_cb, "Disable Message Signaled Interrupts " 122 "for Brocade-415/425/815/825 cards, default=0, " 123 " Range[false:0|true:1]"); 124 module_param(msix_disable_ct, int, S_IRUGO | S_IWUSR); 125 MODULE_PARM_DESC(msix_disable_ct, "Disable Message Signaled Interrupts " 126 "if possible for Brocade-1010/1020/804/1007/902/1741 " 127 "cards, default=0, Range[false:0|true:1]"); 128 module_param(fdmi_enable, int, S_IRUGO | S_IWUSR); 129 MODULE_PARM_DESC(fdmi_enable, "Enables fdmi registration, default=1, " 130 "Range[false:0|true:1]"); 131 module_param(pcie_max_read_reqsz, int, S_IRUGO | S_IWUSR); 132 MODULE_PARM_DESC(pcie_max_read_reqsz, "PCIe max read request size, default=0 " 133 "(use system setting), Range[128|256|512|1024|2048|4096]"); 134 module_param(bfa_debugfs_enable, int, S_IRUGO | S_IWUSR); 135 MODULE_PARM_DESC(bfa_debugfs_enable, "Enables debugfs feature, default=1," 136 " Range[false:0|true:1]"); 137 138 static void 139 bfad_sm_uninit(struct bfad_s *bfad, enum bfad_sm_event event); 140 static void 141 bfad_sm_created(struct bfad_s *bfad, enum bfad_sm_event event); 142 static void 143 bfad_sm_initializing(struct bfad_s *bfad, enum bfad_sm_event event); 144 static void 145 bfad_sm_operational(struct bfad_s *bfad, enum bfad_sm_event event); 146 static void 147 bfad_sm_stopping(struct bfad_s *bfad, enum bfad_sm_event event); 148 static void 149 bfad_sm_failed(struct bfad_s *bfad, enum bfad_sm_event event); 150 static void 151 bfad_sm_fcs_exit(struct bfad_s *bfad, enum bfad_sm_event event); 152 153 /* 154 * Beginning state for the driver instance, awaiting the pci_probe event 155 */ 156 static void 157 bfad_sm_uninit(struct bfad_s *bfad, enum bfad_sm_event event) 158 { 159 bfa_trc(bfad, event); 160 161 switch (event) { 162 case BFAD_E_CREATE: 163 bfa_sm_set_state(bfad, bfad_sm_created); 164 bfad->bfad_tsk = kthread_create(bfad_worker, (void *) bfad, 165 "%s", "bfad_worker"); 166 if (IS_ERR(bfad->bfad_tsk)) { 167 printk(KERN_INFO "bfad[%d]: Kernel thread " 168 "creation failed!\n", bfad->inst_no); 169 bfa_sm_send_event(bfad, BFAD_E_KTHREAD_CREATE_FAILED); 170 } 171 bfa_sm_send_event(bfad, BFAD_E_INIT); 172 break; 173 174 case BFAD_E_STOP: 175 /* Ignore stop; already in uninit */ 176 break; 177 178 default: 179 bfa_sm_fault(bfad, event); 180 } 181 } 182 183 /* 184 * Driver Instance is created, awaiting event INIT to initialize the bfad 185 */ 186 static void 187 bfad_sm_created(struct bfad_s *bfad, enum bfad_sm_event event) 188 { 189 unsigned long flags; 190 191 bfa_trc(bfad, event); 192 193 switch (event) { 194 case BFAD_E_INIT: 195 bfa_sm_set_state(bfad, bfad_sm_initializing); 196 197 init_completion(&bfad->comp); 198 199 /* Enable Interrupt and wait bfa_init completion */ 200 if (bfad_setup_intr(bfad)) { 201 printk(KERN_WARNING "bfad%d: bfad_setup_intr failed\n", 202 bfad->inst_no); 203 bfa_sm_send_event(bfad, BFAD_E_INTR_INIT_FAILED); 204 break; 205 } 206 207 spin_lock_irqsave(&bfad->bfad_lock, flags); 208 bfa_iocfc_init(&bfad->bfa); 209 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 210 211 /* Set up interrupt handler for each vectors */ 212 if ((bfad->bfad_flags & BFAD_MSIX_ON) && 213 bfad_install_msix_handler(bfad)) { 214 printk(KERN_WARNING "%s: install_msix failed, bfad%d\n", 215 __func__, bfad->inst_no); 216 } 217 218 bfad_init_timer(bfad); 219 220 wait_for_completion(&bfad->comp); 221 222 if ((bfad->bfad_flags & BFAD_HAL_INIT_DONE)) { 223 bfa_sm_send_event(bfad, BFAD_E_INIT_SUCCESS); 224 } else { 225 bfad->bfad_flags |= BFAD_HAL_INIT_FAIL; 226 bfa_sm_send_event(bfad, BFAD_E_INIT_FAILED); 227 } 228 229 break; 230 231 case BFAD_E_KTHREAD_CREATE_FAILED: 232 bfa_sm_set_state(bfad, bfad_sm_uninit); 233 break; 234 235 default: 236 bfa_sm_fault(bfad, event); 237 } 238 } 239 240 static void 241 bfad_sm_initializing(struct bfad_s *bfad, enum bfad_sm_event event) 242 { 243 int retval; 244 unsigned long flags; 245 246 bfa_trc(bfad, event); 247 248 switch (event) { 249 case BFAD_E_INIT_SUCCESS: 250 kthread_stop(bfad->bfad_tsk); 251 spin_lock_irqsave(&bfad->bfad_lock, flags); 252 bfad->bfad_tsk = NULL; 253 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 254 255 retval = bfad_start_ops(bfad); 256 if (retval != BFA_STATUS_OK) 257 break; 258 bfa_sm_set_state(bfad, bfad_sm_operational); 259 break; 260 261 case BFAD_E_INTR_INIT_FAILED: 262 bfa_sm_set_state(bfad, bfad_sm_uninit); 263 kthread_stop(bfad->bfad_tsk); 264 spin_lock_irqsave(&bfad->bfad_lock, flags); 265 bfad->bfad_tsk = NULL; 266 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 267 break; 268 269 case BFAD_E_INIT_FAILED: 270 bfa_sm_set_state(bfad, bfad_sm_failed); 271 break; 272 default: 273 bfa_sm_fault(bfad, event); 274 } 275 } 276 277 static void 278 bfad_sm_failed(struct bfad_s *bfad, enum bfad_sm_event event) 279 { 280 int retval; 281 282 bfa_trc(bfad, event); 283 284 switch (event) { 285 case BFAD_E_INIT_SUCCESS: 286 retval = bfad_start_ops(bfad); 287 if (retval != BFA_STATUS_OK) 288 break; 289 bfa_sm_set_state(bfad, bfad_sm_operational); 290 break; 291 292 case BFAD_E_STOP: 293 if (bfad->bfad_flags & BFAD_CFG_PPORT_DONE) 294 bfad_uncfg_pport(bfad); 295 if (bfad->bfad_flags & BFAD_FC4_PROBE_DONE) { 296 bfad_im_probe_undo(bfad); 297 bfad->bfad_flags &= ~BFAD_FC4_PROBE_DONE; 298 } 299 bfad_stop(bfad); 300 break; 301 302 case BFAD_E_EXIT_COMP: 303 bfa_sm_set_state(bfad, bfad_sm_uninit); 304 bfad_remove_intr(bfad); 305 del_timer_sync(&bfad->hal_tmo); 306 break; 307 308 default: 309 bfa_sm_fault(bfad, event); 310 } 311 } 312 313 static void 314 bfad_sm_operational(struct bfad_s *bfad, enum bfad_sm_event event) 315 { 316 bfa_trc(bfad, event); 317 318 switch (event) { 319 case BFAD_E_STOP: 320 bfa_sm_set_state(bfad, bfad_sm_fcs_exit); 321 bfad_fcs_stop(bfad); 322 break; 323 324 default: 325 bfa_sm_fault(bfad, event); 326 } 327 } 328 329 static void 330 bfad_sm_fcs_exit(struct bfad_s *bfad, enum bfad_sm_event event) 331 { 332 bfa_trc(bfad, event); 333 334 switch (event) { 335 case BFAD_E_FCS_EXIT_COMP: 336 bfa_sm_set_state(bfad, bfad_sm_stopping); 337 bfad_stop(bfad); 338 break; 339 340 default: 341 bfa_sm_fault(bfad, event); 342 } 343 } 344 345 static void 346 bfad_sm_stopping(struct bfad_s *bfad, enum bfad_sm_event event) 347 { 348 bfa_trc(bfad, event); 349 350 switch (event) { 351 case BFAD_E_EXIT_COMP: 352 bfa_sm_set_state(bfad, bfad_sm_uninit); 353 bfad_remove_intr(bfad); 354 del_timer_sync(&bfad->hal_tmo); 355 bfad_im_probe_undo(bfad); 356 bfad->bfad_flags &= ~BFAD_FC4_PROBE_DONE; 357 bfad_uncfg_pport(bfad); 358 break; 359 360 default: 361 bfa_sm_fault(bfad, event); 362 break; 363 } 364 } 365 366 /* 367 * BFA callbacks 368 */ 369 void 370 bfad_hcb_comp(void *arg, bfa_status_t status) 371 { 372 struct bfad_hal_comp *fcomp = (struct bfad_hal_comp *)arg; 373 374 fcomp->status = status; 375 complete(&fcomp->comp); 376 } 377 378 /* 379 * bfa_init callback 380 */ 381 void 382 bfa_cb_init(void *drv, bfa_status_t init_status) 383 { 384 struct bfad_s *bfad = drv; 385 386 if (init_status == BFA_STATUS_OK) { 387 bfad->bfad_flags |= BFAD_HAL_INIT_DONE; 388 389 /* 390 * If BFAD_HAL_INIT_FAIL flag is set: 391 * Wake up the kernel thread to start 392 * the bfad operations after HAL init done 393 */ 394 if ((bfad->bfad_flags & BFAD_HAL_INIT_FAIL)) { 395 bfad->bfad_flags &= ~BFAD_HAL_INIT_FAIL; 396 wake_up_process(bfad->bfad_tsk); 397 } 398 } 399 400 complete(&bfad->comp); 401 } 402 403 /* 404 * BFA_FCS callbacks 405 */ 406 struct bfad_port_s * 407 bfa_fcb_lport_new(struct bfad_s *bfad, struct bfa_fcs_lport_s *port, 408 enum bfa_lport_role roles, struct bfad_vf_s *vf_drv, 409 struct bfad_vport_s *vp_drv) 410 { 411 bfa_status_t rc; 412 struct bfad_port_s *port_drv; 413 414 if (!vp_drv && !vf_drv) { 415 port_drv = &bfad->pport; 416 port_drv->pvb_type = BFAD_PORT_PHYS_BASE; 417 } else if (!vp_drv && vf_drv) { 418 port_drv = &vf_drv->base_port; 419 port_drv->pvb_type = BFAD_PORT_VF_BASE; 420 } else if (vp_drv && !vf_drv) { 421 port_drv = &vp_drv->drv_port; 422 port_drv->pvb_type = BFAD_PORT_PHYS_VPORT; 423 } else { 424 port_drv = &vp_drv->drv_port; 425 port_drv->pvb_type = BFAD_PORT_VF_VPORT; 426 } 427 428 port_drv->fcs_port = port; 429 port_drv->roles = roles; 430 431 if (roles & BFA_LPORT_ROLE_FCP_IM) { 432 rc = bfad_im_port_new(bfad, port_drv); 433 if (rc != BFA_STATUS_OK) { 434 bfad_im_port_delete(bfad, port_drv); 435 port_drv = NULL; 436 } 437 } 438 439 return port_drv; 440 } 441 442 void 443 bfa_fcb_lport_delete(struct bfad_s *bfad, enum bfa_lport_role roles, 444 struct bfad_vf_s *vf_drv, struct bfad_vport_s *vp_drv) 445 { 446 struct bfad_port_s *port_drv; 447 448 /* this will be only called from rmmod context */ 449 if (vp_drv && !vp_drv->comp_del) { 450 port_drv = (vp_drv) ? (&(vp_drv)->drv_port) : 451 ((vf_drv) ? (&(vf_drv)->base_port) : 452 (&(bfad)->pport)); 453 bfa_trc(bfad, roles); 454 if (roles & BFA_LPORT_ROLE_FCP_IM) 455 bfad_im_port_delete(bfad, port_drv); 456 } 457 } 458 459 /* 460 * FCS RPORT alloc callback, after successful PLOGI by FCS 461 */ 462 bfa_status_t 463 bfa_fcb_rport_alloc(struct bfad_s *bfad, struct bfa_fcs_rport_s **rport, 464 struct bfad_rport_s **rport_drv) 465 { 466 bfa_status_t rc = BFA_STATUS_OK; 467 468 *rport_drv = kzalloc(sizeof(struct bfad_rport_s), GFP_ATOMIC); 469 if (*rport_drv == NULL) { 470 rc = BFA_STATUS_ENOMEM; 471 goto ext; 472 } 473 474 *rport = &(*rport_drv)->fcs_rport; 475 476 ext: 477 return rc; 478 } 479 480 /* 481 * FCS PBC VPORT Create 482 */ 483 void 484 bfa_fcb_pbc_vport_create(struct bfad_s *bfad, struct bfi_pbc_vport_s pbc_vport) 485 { 486 487 struct bfa_lport_cfg_s port_cfg = {0}; 488 struct bfad_vport_s *vport; 489 int rc; 490 491 vport = kzalloc(sizeof(struct bfad_vport_s), GFP_KERNEL); 492 if (!vport) { 493 bfa_trc(bfad, 0); 494 return; 495 } 496 497 vport->drv_port.bfad = bfad; 498 port_cfg.roles = BFA_LPORT_ROLE_FCP_IM; 499 port_cfg.pwwn = pbc_vport.vp_pwwn; 500 port_cfg.nwwn = pbc_vport.vp_nwwn; 501 port_cfg.preboot_vp = BFA_TRUE; 502 503 rc = bfa_fcs_pbc_vport_create(&vport->fcs_vport, &bfad->bfa_fcs, 0, 504 &port_cfg, vport); 505 506 if (rc != BFA_STATUS_OK) { 507 bfa_trc(bfad, 0); 508 return; 509 } 510 511 list_add_tail(&vport->list_entry, &bfad->pbc_vport_list); 512 } 513 514 void 515 bfad_hal_mem_release(struct bfad_s *bfad) 516 { 517 int i; 518 struct bfa_meminfo_s *hal_meminfo = &bfad->meminfo; 519 struct bfa_mem_elem_s *meminfo_elem; 520 521 for (i = 0; i < BFA_MEM_TYPE_MAX; i++) { 522 meminfo_elem = &hal_meminfo->meminfo[i]; 523 if (meminfo_elem->kva != NULL) { 524 switch (meminfo_elem->mem_type) { 525 case BFA_MEM_TYPE_KVA: 526 vfree(meminfo_elem->kva); 527 break; 528 case BFA_MEM_TYPE_DMA: 529 dma_free_coherent(&bfad->pcidev->dev, 530 meminfo_elem->mem_len, 531 meminfo_elem->kva, 532 (dma_addr_t) meminfo_elem->dma); 533 break; 534 default: 535 WARN_ON(1); 536 break; 537 } 538 } 539 } 540 541 memset(hal_meminfo, 0, sizeof(struct bfa_meminfo_s)); 542 } 543 544 void 545 bfad_update_hal_cfg(struct bfa_iocfc_cfg_s *bfa_cfg) 546 { 547 if (num_rports > 0) 548 bfa_cfg->fwcfg.num_rports = num_rports; 549 if (num_ios > 0) 550 bfa_cfg->fwcfg.num_ioim_reqs = num_ios; 551 if (num_tms > 0) 552 bfa_cfg->fwcfg.num_tskim_reqs = num_tms; 553 if (num_fcxps > 0) 554 bfa_cfg->fwcfg.num_fcxp_reqs = num_fcxps; 555 if (num_ufbufs > 0) 556 bfa_cfg->fwcfg.num_uf_bufs = num_ufbufs; 557 if (reqq_size > 0) 558 bfa_cfg->drvcfg.num_reqq_elems = reqq_size; 559 if (rspq_size > 0) 560 bfa_cfg->drvcfg.num_rspq_elems = rspq_size; 561 if (num_sgpgs > 0) 562 bfa_cfg->drvcfg.num_sgpgs = num_sgpgs; 563 564 /* 565 * populate the hal values back to the driver for sysfs use. 566 * otherwise, the default values will be shown as 0 in sysfs 567 */ 568 num_rports = bfa_cfg->fwcfg.num_rports; 569 num_ios = bfa_cfg->fwcfg.num_ioim_reqs; 570 num_tms = bfa_cfg->fwcfg.num_tskim_reqs; 571 num_fcxps = bfa_cfg->fwcfg.num_fcxp_reqs; 572 num_ufbufs = bfa_cfg->fwcfg.num_uf_bufs; 573 reqq_size = bfa_cfg->drvcfg.num_reqq_elems; 574 rspq_size = bfa_cfg->drvcfg.num_rspq_elems; 575 num_sgpgs = bfa_cfg->drvcfg.num_sgpgs; 576 } 577 578 bfa_status_t 579 bfad_hal_mem_alloc(struct bfad_s *bfad) 580 { 581 int i; 582 struct bfa_meminfo_s *hal_meminfo = &bfad->meminfo; 583 struct bfa_mem_elem_s *meminfo_elem; 584 dma_addr_t phys_addr; 585 void *kva; 586 bfa_status_t rc = BFA_STATUS_OK; 587 int retry_count = 0; 588 int reset_value = 1; 589 int min_num_sgpgs = 512; 590 591 bfa_cfg_get_default(&bfad->ioc_cfg); 592 593 retry: 594 bfad_update_hal_cfg(&bfad->ioc_cfg); 595 bfad->cfg_data.ioc_queue_depth = bfad->ioc_cfg.fwcfg.num_ioim_reqs; 596 bfa_cfg_get_meminfo(&bfad->ioc_cfg, hal_meminfo); 597 598 for (i = 0; i < BFA_MEM_TYPE_MAX; i++) { 599 meminfo_elem = &hal_meminfo->meminfo[i]; 600 switch (meminfo_elem->mem_type) { 601 case BFA_MEM_TYPE_KVA: 602 kva = vmalloc(meminfo_elem->mem_len); 603 if (kva == NULL) { 604 bfad_hal_mem_release(bfad); 605 rc = BFA_STATUS_ENOMEM; 606 goto ext; 607 } 608 memset(kva, 0, meminfo_elem->mem_len); 609 meminfo_elem->kva = kva; 610 break; 611 case BFA_MEM_TYPE_DMA: 612 kva = dma_alloc_coherent(&bfad->pcidev->dev, 613 meminfo_elem->mem_len, &phys_addr, GFP_KERNEL); 614 if (kva == NULL) { 615 bfad_hal_mem_release(bfad); 616 /* 617 * If we cannot allocate with default 618 * num_sgpages try with half the value. 619 */ 620 if (num_sgpgs > min_num_sgpgs) { 621 printk(KERN_INFO 622 "bfad[%d]: memory allocation failed" 623 " with num_sgpgs: %d\n", 624 bfad->inst_no, num_sgpgs); 625 nextLowerInt(&num_sgpgs); 626 printk(KERN_INFO 627 "bfad[%d]: trying to allocate memory" 628 " with num_sgpgs: %d\n", 629 bfad->inst_no, num_sgpgs); 630 retry_count++; 631 goto retry; 632 } else { 633 if (num_sgpgs_parm > 0) 634 num_sgpgs = num_sgpgs_parm; 635 else { 636 reset_value = 637 (1 << retry_count); 638 num_sgpgs *= reset_value; 639 } 640 rc = BFA_STATUS_ENOMEM; 641 goto ext; 642 } 643 } 644 645 if (num_sgpgs_parm > 0) 646 num_sgpgs = num_sgpgs_parm; 647 else { 648 reset_value = (1 << retry_count); 649 num_sgpgs *= reset_value; 650 } 651 652 memset(kva, 0, meminfo_elem->mem_len); 653 meminfo_elem->kva = kva; 654 meminfo_elem->dma = phys_addr; 655 break; 656 default: 657 break; 658 659 } 660 } 661 ext: 662 return rc; 663 } 664 665 /* 666 * Create a vport under a vf. 667 */ 668 bfa_status_t 669 bfad_vport_create(struct bfad_s *bfad, u16 vf_id, 670 struct bfa_lport_cfg_s *port_cfg, struct device *dev) 671 { 672 struct bfad_vport_s *vport; 673 int rc = BFA_STATUS_OK; 674 unsigned long flags; 675 struct completion fcomp; 676 677 vport = kzalloc(sizeof(struct bfad_vport_s), GFP_KERNEL); 678 if (!vport) { 679 rc = BFA_STATUS_ENOMEM; 680 goto ext; 681 } 682 683 vport->drv_port.bfad = bfad; 684 spin_lock_irqsave(&bfad->bfad_lock, flags); 685 rc = bfa_fcs_vport_create(&vport->fcs_vport, &bfad->bfa_fcs, vf_id, 686 port_cfg, vport); 687 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 688 689 if (rc != BFA_STATUS_OK) 690 goto ext_free_vport; 691 692 if (port_cfg->roles & BFA_LPORT_ROLE_FCP_IM) { 693 rc = bfad_im_scsi_host_alloc(bfad, vport->drv_port.im_port, 694 dev); 695 if (rc != BFA_STATUS_OK) 696 goto ext_free_fcs_vport; 697 } 698 699 spin_lock_irqsave(&bfad->bfad_lock, flags); 700 bfa_fcs_vport_start(&vport->fcs_vport); 701 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 702 703 return BFA_STATUS_OK; 704 705 ext_free_fcs_vport: 706 spin_lock_irqsave(&bfad->bfad_lock, flags); 707 vport->comp_del = &fcomp; 708 init_completion(vport->comp_del); 709 bfa_fcs_vport_delete(&vport->fcs_vport); 710 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 711 wait_for_completion(vport->comp_del); 712 ext_free_vport: 713 kfree(vport); 714 ext: 715 return rc; 716 } 717 718 void 719 bfad_bfa_tmo(unsigned long data) 720 { 721 struct bfad_s *bfad = (struct bfad_s *) data; 722 unsigned long flags; 723 struct list_head doneq; 724 725 spin_lock_irqsave(&bfad->bfad_lock, flags); 726 727 bfa_timer_beat(&bfad->bfa.timer_mod); 728 729 bfa_comp_deq(&bfad->bfa, &doneq); 730 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 731 732 if (!list_empty(&doneq)) { 733 bfa_comp_process(&bfad->bfa, &doneq); 734 spin_lock_irqsave(&bfad->bfad_lock, flags); 735 bfa_comp_free(&bfad->bfa, &doneq); 736 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 737 } 738 739 mod_timer(&bfad->hal_tmo, 740 jiffies + msecs_to_jiffies(BFA_TIMER_FREQ)); 741 } 742 743 void 744 bfad_init_timer(struct bfad_s *bfad) 745 { 746 init_timer(&bfad->hal_tmo); 747 bfad->hal_tmo.function = bfad_bfa_tmo; 748 bfad->hal_tmo.data = (unsigned long)bfad; 749 750 mod_timer(&bfad->hal_tmo, 751 jiffies + msecs_to_jiffies(BFA_TIMER_FREQ)); 752 } 753 754 int 755 bfad_pci_init(struct pci_dev *pdev, struct bfad_s *bfad) 756 { 757 int rc = -ENODEV; 758 759 if (pci_enable_device(pdev)) { 760 printk(KERN_ERR "pci_enable_device fail %p\n", pdev); 761 goto out; 762 } 763 764 if (pci_request_regions(pdev, BFAD_DRIVER_NAME)) 765 goto out_disable_device; 766 767 pci_set_master(pdev); 768 769 770 if (pci_set_dma_mask(pdev, DMA_BIT_MASK(64)) != 0) 771 if (pci_set_dma_mask(pdev, DMA_BIT_MASK(32)) != 0) { 772 printk(KERN_ERR "pci_set_dma_mask fail %p\n", pdev); 773 goto out_release_region; 774 } 775 776 bfad->pci_bar0_kva = pci_iomap(pdev, 0, pci_resource_len(pdev, 0)); 777 778 if (bfad->pci_bar0_kva == NULL) { 779 printk(KERN_ERR "Fail to map bar0\n"); 780 goto out_release_region; 781 } 782 783 bfad->hal_pcidev.pci_slot = PCI_SLOT(pdev->devfn); 784 bfad->hal_pcidev.pci_func = PCI_FUNC(pdev->devfn); 785 bfad->hal_pcidev.pci_bar_kva = bfad->pci_bar0_kva; 786 bfad->hal_pcidev.device_id = pdev->device; 787 bfad->pci_name = pci_name(pdev); 788 789 bfad->pci_attr.vendor_id = pdev->vendor; 790 bfad->pci_attr.device_id = pdev->device; 791 bfad->pci_attr.ssid = pdev->subsystem_device; 792 bfad->pci_attr.ssvid = pdev->subsystem_vendor; 793 bfad->pci_attr.pcifn = PCI_FUNC(pdev->devfn); 794 795 bfad->pcidev = pdev; 796 797 /* Adjust PCIe Maximum Read Request Size */ 798 if (pcie_max_read_reqsz > 0) { 799 int pcie_cap_reg; 800 u16 pcie_dev_ctl; 801 u16 mask = 0xffff; 802 803 switch (pcie_max_read_reqsz) { 804 case 128: 805 mask = 0x0; 806 break; 807 case 256: 808 mask = 0x1000; 809 break; 810 case 512: 811 mask = 0x2000; 812 break; 813 case 1024: 814 mask = 0x3000; 815 break; 816 case 2048: 817 mask = 0x4000; 818 break; 819 case 4096: 820 mask = 0x5000; 821 break; 822 default: 823 break; 824 } 825 826 pcie_cap_reg = pci_find_capability(pdev, PCI_CAP_ID_EXP); 827 if (mask != 0xffff && pcie_cap_reg) { 828 pcie_cap_reg += 0x08; 829 pci_read_config_word(pdev, pcie_cap_reg, &pcie_dev_ctl); 830 if ((pcie_dev_ctl & 0x7000) != mask) { 831 printk(KERN_WARNING "BFA[%s]: " 832 "pcie_max_read_request_size is %d, " 833 "reset to %d\n", bfad->pci_name, 834 (1 << ((pcie_dev_ctl & 0x7000) >> 12)) << 7, 835 pcie_max_read_reqsz); 836 837 pcie_dev_ctl &= ~0x7000; 838 pci_write_config_word(pdev, pcie_cap_reg, 839 pcie_dev_ctl | mask); 840 } 841 } 842 } 843 844 return 0; 845 846 out_release_region: 847 pci_release_regions(pdev); 848 out_disable_device: 849 pci_disable_device(pdev); 850 out: 851 return rc; 852 } 853 854 void 855 bfad_pci_uninit(struct pci_dev *pdev, struct bfad_s *bfad) 856 { 857 pci_iounmap(pdev, bfad->pci_bar0_kva); 858 pci_release_regions(pdev); 859 pci_disable_device(pdev); 860 pci_set_drvdata(pdev, NULL); 861 } 862 863 bfa_status_t 864 bfad_drv_init(struct bfad_s *bfad) 865 { 866 bfa_status_t rc; 867 unsigned long flags; 868 869 bfad->cfg_data.rport_del_timeout = rport_del_timeout; 870 bfad->cfg_data.lun_queue_depth = bfa_lun_queue_depth; 871 bfad->cfg_data.io_max_sge = bfa_io_max_sge; 872 bfad->cfg_data.binding_method = FCP_PWWN_BINDING; 873 874 rc = bfad_hal_mem_alloc(bfad); 875 if (rc != BFA_STATUS_OK) { 876 printk(KERN_WARNING "bfad%d bfad_hal_mem_alloc failure\n", 877 bfad->inst_no); 878 printk(KERN_WARNING 879 "Not enough memory to attach all Brocade HBA ports, %s", 880 "System may need more memory.\n"); 881 goto out_hal_mem_alloc_failure; 882 } 883 884 bfad->bfa.trcmod = bfad->trcmod; 885 bfad->bfa.plog = &bfad->plog_buf; 886 bfa_plog_init(&bfad->plog_buf); 887 bfa_plog_str(&bfad->plog_buf, BFA_PL_MID_DRVR, BFA_PL_EID_DRIVER_START, 888 0, "Driver Attach"); 889 890 bfa_attach(&bfad->bfa, bfad, &bfad->ioc_cfg, &bfad->meminfo, 891 &bfad->hal_pcidev); 892 893 /* FCS INIT */ 894 spin_lock_irqsave(&bfad->bfad_lock, flags); 895 bfad->bfa_fcs.trcmod = bfad->trcmod; 896 bfa_fcs_attach(&bfad->bfa_fcs, &bfad->bfa, bfad, BFA_FALSE); 897 bfad->bfa_fcs.fdmi_enabled = fdmi_enable; 898 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 899 900 bfad->bfad_flags |= BFAD_DRV_INIT_DONE; 901 902 return BFA_STATUS_OK; 903 904 out_hal_mem_alloc_failure: 905 return BFA_STATUS_FAILED; 906 } 907 908 void 909 bfad_drv_uninit(struct bfad_s *bfad) 910 { 911 unsigned long flags; 912 913 spin_lock_irqsave(&bfad->bfad_lock, flags); 914 init_completion(&bfad->comp); 915 bfa_iocfc_stop(&bfad->bfa); 916 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 917 wait_for_completion(&bfad->comp); 918 919 del_timer_sync(&bfad->hal_tmo); 920 bfa_isr_disable(&bfad->bfa); 921 bfa_detach(&bfad->bfa); 922 bfad_remove_intr(bfad); 923 bfad_hal_mem_release(bfad); 924 925 bfad->bfad_flags &= ~BFAD_DRV_INIT_DONE; 926 } 927 928 void 929 bfad_drv_start(struct bfad_s *bfad) 930 { 931 unsigned long flags; 932 933 spin_lock_irqsave(&bfad->bfad_lock, flags); 934 bfa_iocfc_start(&bfad->bfa); 935 bfa_fcs_fabric_modstart(&bfad->bfa_fcs); 936 bfad->bfad_flags |= BFAD_HAL_START_DONE; 937 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 938 939 if (bfad->im) 940 flush_workqueue(bfad->im->drv_workq); 941 } 942 943 void 944 bfad_fcs_stop(struct bfad_s *bfad) 945 { 946 unsigned long flags; 947 948 spin_lock_irqsave(&bfad->bfad_lock, flags); 949 init_completion(&bfad->comp); 950 bfad->pport.flags |= BFAD_PORT_DELETE; 951 bfa_fcs_exit(&bfad->bfa_fcs); 952 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 953 wait_for_completion(&bfad->comp); 954 955 bfa_sm_send_event(bfad, BFAD_E_FCS_EXIT_COMP); 956 } 957 958 void 959 bfad_stop(struct bfad_s *bfad) 960 { 961 unsigned long flags; 962 963 spin_lock_irqsave(&bfad->bfad_lock, flags); 964 init_completion(&bfad->comp); 965 bfa_iocfc_stop(&bfad->bfa); 966 bfad->bfad_flags &= ~BFAD_HAL_START_DONE; 967 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 968 wait_for_completion(&bfad->comp); 969 970 bfa_sm_send_event(bfad, BFAD_E_EXIT_COMP); 971 } 972 973 bfa_status_t 974 bfad_cfg_pport(struct bfad_s *bfad, enum bfa_lport_role role) 975 { 976 int rc = BFA_STATUS_OK; 977 978 /* Allocate scsi_host for the physical port */ 979 if ((supported_fc4s & BFA_LPORT_ROLE_FCP_IM) && 980 (role & BFA_LPORT_ROLE_FCP_IM)) { 981 if (bfad->pport.im_port == NULL) { 982 rc = BFA_STATUS_FAILED; 983 goto out; 984 } 985 986 rc = bfad_im_scsi_host_alloc(bfad, bfad->pport.im_port, 987 &bfad->pcidev->dev); 988 if (rc != BFA_STATUS_OK) 989 goto out; 990 991 bfad->pport.roles |= BFA_LPORT_ROLE_FCP_IM; 992 } 993 994 /* Setup the debugfs node for this scsi_host */ 995 if (bfa_debugfs_enable) 996 bfad_debugfs_init(&bfad->pport); 997 998 bfad->bfad_flags |= BFAD_CFG_PPORT_DONE; 999 1000 out: 1001 return rc; 1002 } 1003 1004 void 1005 bfad_uncfg_pport(struct bfad_s *bfad) 1006 { 1007 /* Remove the debugfs node for this scsi_host */ 1008 kfree(bfad->regdata); 1009 bfad_debugfs_exit(&bfad->pport); 1010 1011 if ((supported_fc4s & BFA_LPORT_ROLE_FCP_IM) && 1012 (bfad->pport.roles & BFA_LPORT_ROLE_FCP_IM)) { 1013 bfad_im_scsi_host_free(bfad, bfad->pport.im_port); 1014 bfad_im_port_clean(bfad->pport.im_port); 1015 kfree(bfad->pport.im_port); 1016 bfad->pport.roles &= ~BFA_LPORT_ROLE_FCP_IM; 1017 } 1018 1019 bfad->bfad_flags &= ~BFAD_CFG_PPORT_DONE; 1020 } 1021 1022 bfa_status_t 1023 bfad_start_ops(struct bfad_s *bfad) { 1024 1025 int retval; 1026 unsigned long flags; 1027 struct bfad_vport_s *vport, *vport_new; 1028 struct bfa_fcs_driver_info_s driver_info; 1029 1030 /* Fill the driver_info info to fcs*/ 1031 memset(&driver_info, 0, sizeof(driver_info)); 1032 strncpy(driver_info.version, BFAD_DRIVER_VERSION, 1033 sizeof(driver_info.version) - 1); 1034 if (host_name) 1035 strncpy(driver_info.host_machine_name, host_name, 1036 sizeof(driver_info.host_machine_name) - 1); 1037 if (os_name) 1038 strncpy(driver_info.host_os_name, os_name, 1039 sizeof(driver_info.host_os_name) - 1); 1040 if (os_patch) 1041 strncpy(driver_info.host_os_patch, os_patch, 1042 sizeof(driver_info.host_os_patch) - 1); 1043 1044 strncpy(driver_info.os_device_name, bfad->pci_name, 1045 sizeof(driver_info.os_device_name - 1)); 1046 1047 /* FCS INIT */ 1048 spin_lock_irqsave(&bfad->bfad_lock, flags); 1049 bfa_fcs_driver_info_init(&bfad->bfa_fcs, &driver_info); 1050 bfa_fcs_init(&bfad->bfa_fcs); 1051 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1052 1053 retval = bfad_cfg_pport(bfad, BFA_LPORT_ROLE_FCP_IM); 1054 if (retval != BFA_STATUS_OK) { 1055 if (bfa_sm_cmp_state(bfad, bfad_sm_initializing)) 1056 bfa_sm_set_state(bfad, bfad_sm_failed); 1057 bfad_stop(bfad); 1058 return BFA_STATUS_FAILED; 1059 } 1060 1061 /* BFAD level FC4 IM specific resource allocation */ 1062 retval = bfad_im_probe(bfad); 1063 if (retval != BFA_STATUS_OK) { 1064 printk(KERN_WARNING "bfad_im_probe failed\n"); 1065 if (bfa_sm_cmp_state(bfad, bfad_sm_initializing)) 1066 bfa_sm_set_state(bfad, bfad_sm_failed); 1067 bfad_im_probe_undo(bfad); 1068 bfad->bfad_flags &= ~BFAD_FC4_PROBE_DONE; 1069 bfad_uncfg_pport(bfad); 1070 bfad_stop(bfad); 1071 return BFA_STATUS_FAILED; 1072 } else 1073 bfad->bfad_flags |= BFAD_FC4_PROBE_DONE; 1074 1075 bfad_drv_start(bfad); 1076 1077 /* Complete pbc vport create */ 1078 list_for_each_entry_safe(vport, vport_new, &bfad->pbc_vport_list, 1079 list_entry) { 1080 struct fc_vport_identifiers vid; 1081 struct fc_vport *fc_vport; 1082 char pwwn_buf[BFA_STRING_32]; 1083 1084 memset(&vid, 0, sizeof(vid)); 1085 vid.roles = FC_PORT_ROLE_FCP_INITIATOR; 1086 vid.vport_type = FC_PORTTYPE_NPIV; 1087 vid.disable = false; 1088 vid.node_name = wwn_to_u64((u8 *) 1089 (&((vport->fcs_vport).lport.port_cfg.nwwn))); 1090 vid.port_name = wwn_to_u64((u8 *) 1091 (&((vport->fcs_vport).lport.port_cfg.pwwn))); 1092 fc_vport = fc_vport_create(bfad->pport.im_port->shost, 0, &vid); 1093 if (!fc_vport) { 1094 wwn2str(pwwn_buf, vid.port_name); 1095 printk(KERN_WARNING "bfad%d: failed to create pbc vport" 1096 " %s\n", bfad->inst_no, pwwn_buf); 1097 } 1098 list_del(&vport->list_entry); 1099 kfree(vport); 1100 } 1101 1102 /* 1103 * If bfa_linkup_delay is set to -1 default; try to retrive the 1104 * value using the bfad_get_linkup_delay(); else use the 1105 * passed in module param value as the bfa_linkup_delay. 1106 */ 1107 if (bfa_linkup_delay < 0) { 1108 bfa_linkup_delay = bfad_get_linkup_delay(bfad); 1109 bfad_rport_online_wait(bfad); 1110 bfa_linkup_delay = -1; 1111 } else 1112 bfad_rport_online_wait(bfad); 1113 1114 BFA_LOG(KERN_INFO, bfad, bfa_log_level, "bfa device claimed\n"); 1115 1116 return BFA_STATUS_OK; 1117 } 1118 1119 int 1120 bfad_worker(void *ptr) 1121 { 1122 struct bfad_s *bfad; 1123 unsigned long flags; 1124 1125 bfad = (struct bfad_s *)ptr; 1126 1127 while (!kthread_should_stop()) { 1128 1129 /* Send event BFAD_E_INIT_SUCCESS */ 1130 bfa_sm_send_event(bfad, BFAD_E_INIT_SUCCESS); 1131 1132 spin_lock_irqsave(&bfad->bfad_lock, flags); 1133 bfad->bfad_tsk = NULL; 1134 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1135 1136 break; 1137 } 1138 1139 return 0; 1140 } 1141 1142 /* 1143 * BFA driver interrupt functions 1144 */ 1145 irqreturn_t 1146 bfad_intx(int irq, void *dev_id) 1147 { 1148 struct bfad_s *bfad = dev_id; 1149 struct list_head doneq; 1150 unsigned long flags; 1151 bfa_boolean_t rc; 1152 1153 spin_lock_irqsave(&bfad->bfad_lock, flags); 1154 rc = bfa_intx(&bfad->bfa); 1155 if (!rc) { 1156 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1157 return IRQ_NONE; 1158 } 1159 1160 bfa_comp_deq(&bfad->bfa, &doneq); 1161 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1162 1163 if (!list_empty(&doneq)) { 1164 bfa_comp_process(&bfad->bfa, &doneq); 1165 1166 spin_lock_irqsave(&bfad->bfad_lock, flags); 1167 bfa_comp_free(&bfad->bfa, &doneq); 1168 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1169 } 1170 1171 return IRQ_HANDLED; 1172 1173 } 1174 1175 static irqreturn_t 1176 bfad_msix(int irq, void *dev_id) 1177 { 1178 struct bfad_msix_s *vec = dev_id; 1179 struct bfad_s *bfad = vec->bfad; 1180 struct list_head doneq; 1181 unsigned long flags; 1182 1183 spin_lock_irqsave(&bfad->bfad_lock, flags); 1184 1185 bfa_msix(&bfad->bfa, vec->msix.entry); 1186 bfa_comp_deq(&bfad->bfa, &doneq); 1187 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1188 1189 if (!list_empty(&doneq)) { 1190 bfa_comp_process(&bfad->bfa, &doneq); 1191 1192 spin_lock_irqsave(&bfad->bfad_lock, flags); 1193 bfa_comp_free(&bfad->bfa, &doneq); 1194 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1195 } 1196 1197 return IRQ_HANDLED; 1198 } 1199 1200 /* 1201 * Initialize the MSIX entry table. 1202 */ 1203 static void 1204 bfad_init_msix_entry(struct bfad_s *bfad, struct msix_entry *msix_entries, 1205 int mask, int max_bit) 1206 { 1207 int i; 1208 int match = 0x00000001; 1209 1210 for (i = 0, bfad->nvec = 0; i < MAX_MSIX_ENTRY; i++) { 1211 if (mask & match) { 1212 bfad->msix_tab[bfad->nvec].msix.entry = i; 1213 bfad->msix_tab[bfad->nvec].bfad = bfad; 1214 msix_entries[bfad->nvec].entry = i; 1215 bfad->nvec++; 1216 } 1217 1218 match <<= 1; 1219 } 1220 1221 } 1222 1223 int 1224 bfad_install_msix_handler(struct bfad_s *bfad) 1225 { 1226 int i, error = 0; 1227 1228 for (i = 0; i < bfad->nvec; i++) { 1229 sprintf(bfad->msix_tab[i].name, "bfa-%s-%s", 1230 bfad->pci_name, 1231 ((bfa_asic_id_ct(bfad->hal_pcidev.device_id)) ? 1232 msix_name_ct[i] : msix_name_cb[i])); 1233 1234 error = request_irq(bfad->msix_tab[i].msix.vector, 1235 (irq_handler_t) bfad_msix, 0, 1236 bfad->msix_tab[i].name, &bfad->msix_tab[i]); 1237 bfa_trc(bfad, i); 1238 bfa_trc(bfad, bfad->msix_tab[i].msix.vector); 1239 if (error) { 1240 int j; 1241 1242 for (j = 0; j < i; j++) 1243 free_irq(bfad->msix_tab[j].msix.vector, 1244 &bfad->msix_tab[j]); 1245 1246 return 1; 1247 } 1248 } 1249 1250 return 0; 1251 } 1252 1253 /* 1254 * Setup MSIX based interrupt. 1255 */ 1256 int 1257 bfad_setup_intr(struct bfad_s *bfad) 1258 { 1259 int error = 0; 1260 u32 mask = 0, i, num_bit = 0, max_bit = 0; 1261 struct msix_entry msix_entries[MAX_MSIX_ENTRY]; 1262 struct pci_dev *pdev = bfad->pcidev; 1263 1264 /* Call BFA to get the msix map for this PCI function. */ 1265 bfa_msix_getvecs(&bfad->bfa, &mask, &num_bit, &max_bit); 1266 1267 /* Set up the msix entry table */ 1268 bfad_init_msix_entry(bfad, msix_entries, mask, max_bit); 1269 1270 if ((bfa_asic_id_ct(pdev->device) && !msix_disable_ct) || 1271 (!bfa_asic_id_ct(pdev->device) && !msix_disable_cb)) { 1272 1273 error = pci_enable_msix(bfad->pcidev, msix_entries, bfad->nvec); 1274 if (error) { 1275 /* 1276 * Only error number of vector is available. 1277 * We don't have a mechanism to map multiple 1278 * interrupts into one vector, so even if we 1279 * can try to request less vectors, we don't 1280 * know how to associate interrupt events to 1281 * vectors. Linux doesn't dupicate vectors 1282 * in the MSIX table for this case. 1283 */ 1284 1285 printk(KERN_WARNING "bfad%d: " 1286 "pci_enable_msix failed (%d)," 1287 " use line based.\n", bfad->inst_no, error); 1288 1289 goto line_based; 1290 } 1291 1292 /* Save the vectors */ 1293 for (i = 0; i < bfad->nvec; i++) { 1294 bfa_trc(bfad, msix_entries[i].vector); 1295 bfad->msix_tab[i].msix.vector = msix_entries[i].vector; 1296 } 1297 1298 bfa_msix_init(&bfad->bfa, bfad->nvec); 1299 1300 bfad->bfad_flags |= BFAD_MSIX_ON; 1301 1302 return error; 1303 } 1304 1305 line_based: 1306 error = 0; 1307 if (request_irq 1308 (bfad->pcidev->irq, (irq_handler_t) bfad_intx, BFAD_IRQ_FLAGS, 1309 BFAD_DRIVER_NAME, bfad) != 0) { 1310 /* Enable interrupt handler failed */ 1311 return 1; 1312 } 1313 1314 return error; 1315 } 1316 1317 void 1318 bfad_remove_intr(struct bfad_s *bfad) 1319 { 1320 int i; 1321 1322 if (bfad->bfad_flags & BFAD_MSIX_ON) { 1323 for (i = 0; i < bfad->nvec; i++) 1324 free_irq(bfad->msix_tab[i].msix.vector, 1325 &bfad->msix_tab[i]); 1326 1327 pci_disable_msix(bfad->pcidev); 1328 bfad->bfad_flags &= ~BFAD_MSIX_ON; 1329 } else { 1330 free_irq(bfad->pcidev->irq, bfad); 1331 } 1332 } 1333 1334 /* 1335 * PCI probe entry. 1336 */ 1337 int 1338 bfad_pci_probe(struct pci_dev *pdev, const struct pci_device_id *pid) 1339 { 1340 struct bfad_s *bfad; 1341 int error = -ENODEV, retval; 1342 1343 /* For single port cards - only claim function 0 */ 1344 if ((pdev->device == BFA_PCI_DEVICE_ID_FC_8G1P) && 1345 (PCI_FUNC(pdev->devfn) != 0)) 1346 return -ENODEV; 1347 1348 bfad = kzalloc(sizeof(struct bfad_s), GFP_KERNEL); 1349 if (!bfad) { 1350 error = -ENOMEM; 1351 goto out; 1352 } 1353 1354 bfad->trcmod = kzalloc(sizeof(struct bfa_trc_mod_s), GFP_KERNEL); 1355 if (!bfad->trcmod) { 1356 printk(KERN_WARNING "Error alloc trace buffer!\n"); 1357 error = -ENOMEM; 1358 goto out_alloc_trace_failure; 1359 } 1360 1361 /* TRACE INIT */ 1362 bfa_trc_init(bfad->trcmod); 1363 bfa_trc(bfad, bfad_inst); 1364 1365 if (!(bfad_load_fwimg(pdev))) { 1366 kfree(bfad->trcmod); 1367 goto out_alloc_trace_failure; 1368 } 1369 1370 retval = bfad_pci_init(pdev, bfad); 1371 if (retval) { 1372 printk(KERN_WARNING "bfad_pci_init failure!\n"); 1373 error = retval; 1374 goto out_pci_init_failure; 1375 } 1376 1377 mutex_lock(&bfad_mutex); 1378 bfad->inst_no = bfad_inst++; 1379 list_add_tail(&bfad->list_entry, &bfad_list); 1380 mutex_unlock(&bfad_mutex); 1381 1382 /* Initializing the state machine: State set to uninit */ 1383 bfa_sm_set_state(bfad, bfad_sm_uninit); 1384 1385 spin_lock_init(&bfad->bfad_lock); 1386 pci_set_drvdata(pdev, bfad); 1387 1388 bfad->ref_count = 0; 1389 bfad->pport.bfad = bfad; 1390 INIT_LIST_HEAD(&bfad->pbc_vport_list); 1391 1392 retval = bfad_drv_init(bfad); 1393 if (retval != BFA_STATUS_OK) 1394 goto out_drv_init_failure; 1395 1396 bfa_sm_send_event(bfad, BFAD_E_CREATE); 1397 1398 if (bfa_sm_cmp_state(bfad, bfad_sm_uninit)) 1399 goto out_bfad_sm_failure; 1400 1401 return 0; 1402 1403 out_bfad_sm_failure: 1404 bfa_detach(&bfad->bfa); 1405 bfad_hal_mem_release(bfad); 1406 out_drv_init_failure: 1407 mutex_lock(&bfad_mutex); 1408 bfad_inst--; 1409 list_del(&bfad->list_entry); 1410 mutex_unlock(&bfad_mutex); 1411 bfad_pci_uninit(pdev, bfad); 1412 out_pci_init_failure: 1413 kfree(bfad->trcmod); 1414 out_alloc_trace_failure: 1415 kfree(bfad); 1416 out: 1417 return error; 1418 } 1419 1420 /* 1421 * PCI remove entry. 1422 */ 1423 void 1424 bfad_pci_remove(struct pci_dev *pdev) 1425 { 1426 struct bfad_s *bfad = pci_get_drvdata(pdev); 1427 unsigned long flags; 1428 1429 bfa_trc(bfad, bfad->inst_no); 1430 1431 spin_lock_irqsave(&bfad->bfad_lock, flags); 1432 if (bfad->bfad_tsk != NULL) { 1433 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1434 kthread_stop(bfad->bfad_tsk); 1435 } else { 1436 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1437 } 1438 1439 /* Send Event BFAD_E_STOP */ 1440 bfa_sm_send_event(bfad, BFAD_E_STOP); 1441 1442 /* Driver detach and dealloc mem */ 1443 spin_lock_irqsave(&bfad->bfad_lock, flags); 1444 bfa_detach(&bfad->bfa); 1445 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 1446 bfad_hal_mem_release(bfad); 1447 1448 /* Cleaning the BFAD instance */ 1449 mutex_lock(&bfad_mutex); 1450 bfad_inst--; 1451 list_del(&bfad->list_entry); 1452 mutex_unlock(&bfad_mutex); 1453 bfad_pci_uninit(pdev, bfad); 1454 1455 kfree(bfad->trcmod); 1456 kfree(bfad); 1457 } 1458 1459 struct pci_device_id bfad_id_table[] = { 1460 { 1461 .vendor = BFA_PCI_VENDOR_ID_BROCADE, 1462 .device = BFA_PCI_DEVICE_ID_FC_8G2P, 1463 .subvendor = PCI_ANY_ID, 1464 .subdevice = PCI_ANY_ID, 1465 }, 1466 { 1467 .vendor = BFA_PCI_VENDOR_ID_BROCADE, 1468 .device = BFA_PCI_DEVICE_ID_FC_8G1P, 1469 .subvendor = PCI_ANY_ID, 1470 .subdevice = PCI_ANY_ID, 1471 }, 1472 { 1473 .vendor = BFA_PCI_VENDOR_ID_BROCADE, 1474 .device = BFA_PCI_DEVICE_ID_CT, 1475 .subvendor = PCI_ANY_ID, 1476 .subdevice = PCI_ANY_ID, 1477 .class = (PCI_CLASS_SERIAL_FIBER << 8), 1478 .class_mask = ~0, 1479 }, 1480 { 1481 .vendor = BFA_PCI_VENDOR_ID_BROCADE, 1482 .device = BFA_PCI_DEVICE_ID_CT_FC, 1483 .subvendor = PCI_ANY_ID, 1484 .subdevice = PCI_ANY_ID, 1485 .class = (PCI_CLASS_SERIAL_FIBER << 8), 1486 .class_mask = ~0, 1487 }, 1488 1489 {0, 0}, 1490 }; 1491 1492 MODULE_DEVICE_TABLE(pci, bfad_id_table); 1493 1494 static struct pci_driver bfad_pci_driver = { 1495 .name = BFAD_DRIVER_NAME, 1496 .id_table = bfad_id_table, 1497 .probe = bfad_pci_probe, 1498 .remove = __devexit_p(bfad_pci_remove), 1499 }; 1500 1501 /* 1502 * Driver module init. 1503 */ 1504 static int __init 1505 bfad_init(void) 1506 { 1507 int error = 0; 1508 1509 printk(KERN_INFO "Brocade BFA FC/FCOE SCSI driver - version: %s\n", 1510 BFAD_DRIVER_VERSION); 1511 1512 if (num_sgpgs > 0) 1513 num_sgpgs_parm = num_sgpgs; 1514 1515 error = bfad_im_module_init(); 1516 if (error) { 1517 error = -ENOMEM; 1518 printk(KERN_WARNING "bfad_im_module_init failure\n"); 1519 goto ext; 1520 } 1521 1522 if (strcmp(FCPI_NAME, " fcpim") == 0) 1523 supported_fc4s |= BFA_LPORT_ROLE_FCP_IM; 1524 1525 bfa_auto_recover = ioc_auto_recover; 1526 bfa_fcs_rport_set_del_timeout(rport_del_timeout); 1527 1528 error = pci_register_driver(&bfad_pci_driver); 1529 if (error) { 1530 printk(KERN_WARNING "pci_register_driver failure\n"); 1531 goto ext; 1532 } 1533 1534 return 0; 1535 1536 ext: 1537 bfad_im_module_exit(); 1538 return error; 1539 } 1540 1541 /* 1542 * Driver module exit. 1543 */ 1544 static void __exit 1545 bfad_exit(void) 1546 { 1547 pci_unregister_driver(&bfad_pci_driver); 1548 bfad_im_module_exit(); 1549 bfad_free_fwimg(); 1550 } 1551 1552 /* Firmware handling */ 1553 u32 * 1554 bfad_read_firmware(struct pci_dev *pdev, u32 **bfi_image, 1555 u32 *bfi_image_size, char *fw_name) 1556 { 1557 const struct firmware *fw; 1558 1559 if (request_firmware(&fw, fw_name, &pdev->dev)) { 1560 printk(KERN_ALERT "Can't locate firmware %s\n", fw_name); 1561 goto error; 1562 } 1563 1564 *bfi_image = vmalloc(fw->size); 1565 if (NULL == *bfi_image) { 1566 printk(KERN_ALERT "Fail to allocate buffer for fw image " 1567 "size=%x!\n", (u32) fw->size); 1568 goto error; 1569 } 1570 1571 memcpy(*bfi_image, fw->data, fw->size); 1572 *bfi_image_size = fw->size/sizeof(u32); 1573 1574 return *bfi_image; 1575 1576 error: 1577 return NULL; 1578 } 1579 1580 u32 * 1581 bfad_get_firmware_buf(struct pci_dev *pdev) 1582 { 1583 if (pdev->device == BFA_PCI_DEVICE_ID_CT_FC) { 1584 if (bfi_image_ct_fc_size == 0) 1585 bfad_read_firmware(pdev, &bfi_image_ct_fc, 1586 &bfi_image_ct_fc_size, BFAD_FW_FILE_CT_FC); 1587 return bfi_image_ct_fc; 1588 } else if (pdev->device == BFA_PCI_DEVICE_ID_CT) { 1589 if (bfi_image_ct_cna_size == 0) 1590 bfad_read_firmware(pdev, &bfi_image_ct_cna, 1591 &bfi_image_ct_cna_size, BFAD_FW_FILE_CT_CNA); 1592 return bfi_image_ct_cna; 1593 } else { 1594 if (bfi_image_cb_fc_size == 0) 1595 bfad_read_firmware(pdev, &bfi_image_cb_fc, 1596 &bfi_image_cb_fc_size, BFAD_FW_FILE_CB_FC); 1597 return bfi_image_cb_fc; 1598 } 1599 } 1600 1601 module_init(bfad_init); 1602 module_exit(bfad_exit); 1603 MODULE_LICENSE("GPL"); 1604 MODULE_DESCRIPTION("Brocade Fibre Channel HBA Driver" BFAD_PROTO_NAME); 1605 MODULE_AUTHOR("Brocade Communications Systems, Inc."); 1606 MODULE_VERSION(BFAD_DRIVER_VERSION); 1607