1 /* 2 * Linux network driver for QLogic BR-series Converged Network Adapter. 3 * 4 * This program is free software; you can redistribute it and/or modify it 5 * under the terms of the GNU General Public License (GPL) Version 2 as 6 * published by the Free Software Foundation 7 * 8 * This program is distributed in the hope that it will be useful, but 9 * WITHOUT ANY WARRANTY; without even the implied warranty of 10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 11 * General Public License for more details. 12 */ 13 /* 14 * Copyright (c) 2005-2014 Brocade Communications Systems, Inc. 15 * Copyright (c) 2014-2015 QLogic Corporation 16 * All rights reserved 17 * www.qlogic.com 18 */ 19 #include "bna.h" 20 #include "bfi.h" 21 22 /* IB */ 23 static void 24 bna_ib_coalescing_timeo_set(struct bna_ib *ib, u8 coalescing_timeo) 25 { 26 ib->coalescing_timeo = coalescing_timeo; 27 ib->door_bell.doorbell_ack = BNA_DOORBELL_IB_INT_ACK( 28 (u32)ib->coalescing_timeo, 0); 29 } 30 31 /* RXF */ 32 33 #define bna_rxf_vlan_cfg_soft_reset(rxf) \ 34 do { \ 35 (rxf)->vlan_pending_bitmask = (u8)BFI_VLAN_BMASK_ALL; \ 36 (rxf)->vlan_strip_pending = true; \ 37 } while (0) 38 39 #define bna_rxf_rss_cfg_soft_reset(rxf) \ 40 do { \ 41 if ((rxf)->rss_status == BNA_STATUS_T_ENABLED) \ 42 (rxf)->rss_pending = (BNA_RSS_F_RIT_PENDING | \ 43 BNA_RSS_F_CFG_PENDING | \ 44 BNA_RSS_F_STATUS_PENDING); \ 45 } while (0) 46 47 static int bna_rxf_cfg_apply(struct bna_rxf *rxf); 48 static void bna_rxf_cfg_reset(struct bna_rxf *rxf); 49 static int bna_rxf_ucast_cfg_apply(struct bna_rxf *rxf); 50 static int bna_rxf_promisc_cfg_apply(struct bna_rxf *rxf); 51 static int bna_rxf_allmulti_cfg_apply(struct bna_rxf *rxf); 52 static int bna_rxf_vlan_strip_cfg_apply(struct bna_rxf *rxf); 53 static int bna_rxf_ucast_cfg_reset(struct bna_rxf *rxf, 54 enum bna_cleanup_type cleanup); 55 static int bna_rxf_promisc_cfg_reset(struct bna_rxf *rxf, 56 enum bna_cleanup_type cleanup); 57 static int bna_rxf_allmulti_cfg_reset(struct bna_rxf *rxf, 58 enum bna_cleanup_type cleanup); 59 60 bfa_fsm_state_decl(bna_rxf, stopped, struct bna_rxf, 61 enum bna_rxf_event); 62 bfa_fsm_state_decl(bna_rxf, cfg_wait, struct bna_rxf, 63 enum bna_rxf_event); 64 bfa_fsm_state_decl(bna_rxf, started, struct bna_rxf, 65 enum bna_rxf_event); 66 bfa_fsm_state_decl(bna_rxf, last_resp_wait, struct bna_rxf, 67 enum bna_rxf_event); 68 69 static void 70 bna_rxf_sm_stopped_entry(struct bna_rxf *rxf) 71 { 72 call_rxf_stop_cbfn(rxf); 73 } 74 75 static void 76 bna_rxf_sm_stopped(struct bna_rxf *rxf, enum bna_rxf_event event) 77 { 78 switch (event) { 79 case RXF_E_START: 80 bfa_fsm_set_state(rxf, bna_rxf_sm_cfg_wait); 81 break; 82 83 case RXF_E_STOP: 84 call_rxf_stop_cbfn(rxf); 85 break; 86 87 case RXF_E_FAIL: 88 /* No-op */ 89 break; 90 91 case RXF_E_CONFIG: 92 call_rxf_cam_fltr_cbfn(rxf); 93 break; 94 95 default: 96 bfa_sm_fault(event); 97 } 98 } 99 100 static void 101 bna_rxf_sm_cfg_wait_entry(struct bna_rxf *rxf) 102 { 103 if (!bna_rxf_cfg_apply(rxf)) { 104 /* No more pending config updates */ 105 bfa_fsm_set_state(rxf, bna_rxf_sm_started); 106 } 107 } 108 109 static void 110 bna_rxf_sm_cfg_wait(struct bna_rxf *rxf, enum bna_rxf_event event) 111 { 112 switch (event) { 113 case RXF_E_STOP: 114 bfa_fsm_set_state(rxf, bna_rxf_sm_last_resp_wait); 115 break; 116 117 case RXF_E_FAIL: 118 bna_rxf_cfg_reset(rxf); 119 call_rxf_start_cbfn(rxf); 120 call_rxf_cam_fltr_cbfn(rxf); 121 bfa_fsm_set_state(rxf, bna_rxf_sm_stopped); 122 break; 123 124 case RXF_E_CONFIG: 125 /* No-op */ 126 break; 127 128 case RXF_E_FW_RESP: 129 if (!bna_rxf_cfg_apply(rxf)) { 130 /* No more pending config updates */ 131 bfa_fsm_set_state(rxf, bna_rxf_sm_started); 132 } 133 break; 134 135 default: 136 bfa_sm_fault(event); 137 } 138 } 139 140 static void 141 bna_rxf_sm_started_entry(struct bna_rxf *rxf) 142 { 143 call_rxf_start_cbfn(rxf); 144 call_rxf_cam_fltr_cbfn(rxf); 145 } 146 147 static void 148 bna_rxf_sm_started(struct bna_rxf *rxf, enum bna_rxf_event event) 149 { 150 switch (event) { 151 case RXF_E_STOP: 152 case RXF_E_FAIL: 153 bna_rxf_cfg_reset(rxf); 154 bfa_fsm_set_state(rxf, bna_rxf_sm_stopped); 155 break; 156 157 case RXF_E_CONFIG: 158 bfa_fsm_set_state(rxf, bna_rxf_sm_cfg_wait); 159 break; 160 161 default: 162 bfa_sm_fault(event); 163 } 164 } 165 166 static void 167 bna_rxf_sm_last_resp_wait_entry(struct bna_rxf *rxf) 168 { 169 } 170 171 static void 172 bna_rxf_sm_last_resp_wait(struct bna_rxf *rxf, enum bna_rxf_event event) 173 { 174 switch (event) { 175 case RXF_E_FAIL: 176 case RXF_E_FW_RESP: 177 bna_rxf_cfg_reset(rxf); 178 bfa_fsm_set_state(rxf, bna_rxf_sm_stopped); 179 break; 180 181 default: 182 bfa_sm_fault(event); 183 } 184 } 185 186 static void 187 bna_bfi_ucast_req(struct bna_rxf *rxf, struct bna_mac *mac, 188 enum bfi_enet_h2i_msgs req_type) 189 { 190 struct bfi_enet_ucast_req *req = &rxf->bfi_enet_cmd.ucast_req; 191 192 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, req_type, 0, rxf->rx->rid); 193 req->mh.num_entries = htons( 194 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_ucast_req))); 195 ether_addr_copy(req->mac_addr, mac->addr); 196 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 197 sizeof(struct bfi_enet_ucast_req), &req->mh); 198 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 199 } 200 201 static void 202 bna_bfi_mcast_add_req(struct bna_rxf *rxf, struct bna_mac *mac) 203 { 204 struct bfi_enet_mcast_add_req *req = 205 &rxf->bfi_enet_cmd.mcast_add_req; 206 207 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, BFI_ENET_H2I_MAC_MCAST_ADD_REQ, 208 0, rxf->rx->rid); 209 req->mh.num_entries = htons( 210 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_mcast_add_req))); 211 ether_addr_copy(req->mac_addr, mac->addr); 212 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 213 sizeof(struct bfi_enet_mcast_add_req), &req->mh); 214 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 215 } 216 217 static void 218 bna_bfi_mcast_del_req(struct bna_rxf *rxf, u16 handle) 219 { 220 struct bfi_enet_mcast_del_req *req = 221 &rxf->bfi_enet_cmd.mcast_del_req; 222 223 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, BFI_ENET_H2I_MAC_MCAST_DEL_REQ, 224 0, rxf->rx->rid); 225 req->mh.num_entries = htons( 226 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_mcast_del_req))); 227 req->handle = htons(handle); 228 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 229 sizeof(struct bfi_enet_mcast_del_req), &req->mh); 230 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 231 } 232 233 static void 234 bna_bfi_mcast_filter_req(struct bna_rxf *rxf, enum bna_status status) 235 { 236 struct bfi_enet_enable_req *req = &rxf->bfi_enet_cmd.req; 237 238 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, 239 BFI_ENET_H2I_MAC_MCAST_FILTER_REQ, 0, rxf->rx->rid); 240 req->mh.num_entries = htons( 241 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_enable_req))); 242 req->enable = status; 243 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 244 sizeof(struct bfi_enet_enable_req), &req->mh); 245 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 246 } 247 248 static void 249 bna_bfi_rx_promisc_req(struct bna_rxf *rxf, enum bna_status status) 250 { 251 struct bfi_enet_enable_req *req = &rxf->bfi_enet_cmd.req; 252 253 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, 254 BFI_ENET_H2I_RX_PROMISCUOUS_REQ, 0, rxf->rx->rid); 255 req->mh.num_entries = htons( 256 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_enable_req))); 257 req->enable = status; 258 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 259 sizeof(struct bfi_enet_enable_req), &req->mh); 260 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 261 } 262 263 static void 264 bna_bfi_rx_vlan_filter_set(struct bna_rxf *rxf, u8 block_idx) 265 { 266 struct bfi_enet_rx_vlan_req *req = &rxf->bfi_enet_cmd.vlan_req; 267 int i; 268 int j; 269 270 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, 271 BFI_ENET_H2I_RX_VLAN_SET_REQ, 0, rxf->rx->rid); 272 req->mh.num_entries = htons( 273 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_rx_vlan_req))); 274 req->block_idx = block_idx; 275 for (i = 0; i < (BFI_ENET_VLAN_BLOCK_SIZE / 32); i++) { 276 j = (block_idx * (BFI_ENET_VLAN_BLOCK_SIZE / 32)) + i; 277 if (rxf->vlan_filter_status == BNA_STATUS_T_ENABLED) 278 req->bit_mask[i] = 279 htonl(rxf->vlan_filter_table[j]); 280 else 281 req->bit_mask[i] = 0xFFFFFFFF; 282 } 283 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 284 sizeof(struct bfi_enet_rx_vlan_req), &req->mh); 285 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 286 } 287 288 static void 289 bna_bfi_vlan_strip_enable(struct bna_rxf *rxf) 290 { 291 struct bfi_enet_enable_req *req = &rxf->bfi_enet_cmd.req; 292 293 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, 294 BFI_ENET_H2I_RX_VLAN_STRIP_ENABLE_REQ, 0, rxf->rx->rid); 295 req->mh.num_entries = htons( 296 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_enable_req))); 297 req->enable = rxf->vlan_strip_status; 298 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 299 sizeof(struct bfi_enet_enable_req), &req->mh); 300 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 301 } 302 303 static void 304 bna_bfi_rit_cfg(struct bna_rxf *rxf) 305 { 306 struct bfi_enet_rit_req *req = &rxf->bfi_enet_cmd.rit_req; 307 308 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, 309 BFI_ENET_H2I_RIT_CFG_REQ, 0, rxf->rx->rid); 310 req->mh.num_entries = htons( 311 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_rit_req))); 312 req->size = htons(rxf->rit_size); 313 memcpy(&req->table[0], rxf->rit, rxf->rit_size); 314 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 315 sizeof(struct bfi_enet_rit_req), &req->mh); 316 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 317 } 318 319 static void 320 bna_bfi_rss_cfg(struct bna_rxf *rxf) 321 { 322 struct bfi_enet_rss_cfg_req *req = &rxf->bfi_enet_cmd.rss_req; 323 int i; 324 325 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, 326 BFI_ENET_H2I_RSS_CFG_REQ, 0, rxf->rx->rid); 327 req->mh.num_entries = htons( 328 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_rss_cfg_req))); 329 req->cfg.type = rxf->rss_cfg.hash_type; 330 req->cfg.mask = rxf->rss_cfg.hash_mask; 331 for (i = 0; i < BFI_ENET_RSS_KEY_LEN; i++) 332 req->cfg.key[i] = 333 htonl(rxf->rss_cfg.toeplitz_hash_key[i]); 334 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 335 sizeof(struct bfi_enet_rss_cfg_req), &req->mh); 336 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 337 } 338 339 static void 340 bna_bfi_rss_enable(struct bna_rxf *rxf) 341 { 342 struct bfi_enet_enable_req *req = &rxf->bfi_enet_cmd.req; 343 344 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, 345 BFI_ENET_H2I_RSS_ENABLE_REQ, 0, rxf->rx->rid); 346 req->mh.num_entries = htons( 347 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_enable_req))); 348 req->enable = rxf->rss_status; 349 bfa_msgq_cmd_set(&rxf->msgq_cmd, NULL, NULL, 350 sizeof(struct bfi_enet_enable_req), &req->mh); 351 bfa_msgq_cmd_post(&rxf->rx->bna->msgq, &rxf->msgq_cmd); 352 } 353 354 /* This function gets the multicast MAC that has already been added to CAM */ 355 static struct bna_mac * 356 bna_rxf_mcmac_get(struct bna_rxf *rxf, const u8 *mac_addr) 357 { 358 struct bna_mac *mac; 359 360 list_for_each_entry(mac, &rxf->mcast_active_q, qe) 361 if (ether_addr_equal(mac->addr, mac_addr)) 362 return mac; 363 364 list_for_each_entry(mac, &rxf->mcast_pending_del_q, qe) 365 if (ether_addr_equal(mac->addr, mac_addr)) 366 return mac; 367 368 return NULL; 369 } 370 371 static struct bna_mcam_handle * 372 bna_rxf_mchandle_get(struct bna_rxf *rxf, int handle) 373 { 374 struct bna_mcam_handle *mchandle; 375 376 list_for_each_entry(mchandle, &rxf->mcast_handle_q, qe) 377 if (mchandle->handle == handle) 378 return mchandle; 379 380 return NULL; 381 } 382 383 static void 384 bna_rxf_mchandle_attach(struct bna_rxf *rxf, u8 *mac_addr, int handle) 385 { 386 struct bna_mac *mcmac; 387 struct bna_mcam_handle *mchandle; 388 389 mcmac = bna_rxf_mcmac_get(rxf, mac_addr); 390 mchandle = bna_rxf_mchandle_get(rxf, handle); 391 if (mchandle == NULL) { 392 mchandle = bna_mcam_mod_handle_get(&rxf->rx->bna->mcam_mod); 393 mchandle->handle = handle; 394 mchandle->refcnt = 0; 395 list_add_tail(&mchandle->qe, &rxf->mcast_handle_q); 396 } 397 mchandle->refcnt++; 398 mcmac->handle = mchandle; 399 } 400 401 static int 402 bna_rxf_mcast_del(struct bna_rxf *rxf, struct bna_mac *mac, 403 enum bna_cleanup_type cleanup) 404 { 405 struct bna_mcam_handle *mchandle; 406 int ret = 0; 407 408 mchandle = mac->handle; 409 if (mchandle == NULL) 410 return ret; 411 412 mchandle->refcnt--; 413 if (mchandle->refcnt == 0) { 414 if (cleanup == BNA_HARD_CLEANUP) { 415 bna_bfi_mcast_del_req(rxf, mchandle->handle); 416 ret = 1; 417 } 418 list_del(&mchandle->qe); 419 bna_mcam_mod_handle_put(&rxf->rx->bna->mcam_mod, mchandle); 420 } 421 mac->handle = NULL; 422 423 return ret; 424 } 425 426 static int 427 bna_rxf_mcast_cfg_apply(struct bna_rxf *rxf) 428 { 429 struct bna_mac *mac = NULL; 430 int ret; 431 432 /* First delete multicast entries to maintain the count */ 433 while (!list_empty(&rxf->mcast_pending_del_q)) { 434 mac = list_first_entry(&rxf->mcast_pending_del_q, 435 struct bna_mac, qe); 436 ret = bna_rxf_mcast_del(rxf, mac, BNA_HARD_CLEANUP); 437 list_move_tail(&mac->qe, bna_mcam_mod_del_q(rxf->rx->bna)); 438 if (ret) 439 return ret; 440 } 441 442 /* Add multicast entries */ 443 if (!list_empty(&rxf->mcast_pending_add_q)) { 444 mac = list_first_entry(&rxf->mcast_pending_add_q, 445 struct bna_mac, qe); 446 list_move_tail(&mac->qe, &rxf->mcast_active_q); 447 bna_bfi_mcast_add_req(rxf, mac); 448 return 1; 449 } 450 451 return 0; 452 } 453 454 static int 455 bna_rxf_vlan_cfg_apply(struct bna_rxf *rxf) 456 { 457 u8 vlan_pending_bitmask; 458 int block_idx = 0; 459 460 if (rxf->vlan_pending_bitmask) { 461 vlan_pending_bitmask = rxf->vlan_pending_bitmask; 462 while (!(vlan_pending_bitmask & 0x1)) { 463 block_idx++; 464 vlan_pending_bitmask >>= 1; 465 } 466 rxf->vlan_pending_bitmask &= ~BIT(block_idx); 467 bna_bfi_rx_vlan_filter_set(rxf, block_idx); 468 return 1; 469 } 470 471 return 0; 472 } 473 474 static int 475 bna_rxf_mcast_cfg_reset(struct bna_rxf *rxf, enum bna_cleanup_type cleanup) 476 { 477 struct bna_mac *mac; 478 int ret; 479 480 /* Throw away delete pending mcast entries */ 481 while (!list_empty(&rxf->mcast_pending_del_q)) { 482 mac = list_first_entry(&rxf->mcast_pending_del_q, 483 struct bna_mac, qe); 484 ret = bna_rxf_mcast_del(rxf, mac, cleanup); 485 list_move_tail(&mac->qe, bna_mcam_mod_del_q(rxf->rx->bna)); 486 if (ret) 487 return ret; 488 } 489 490 /* Move active mcast entries to pending_add_q */ 491 while (!list_empty(&rxf->mcast_active_q)) { 492 mac = list_first_entry(&rxf->mcast_active_q, 493 struct bna_mac, qe); 494 list_move_tail(&mac->qe, &rxf->mcast_pending_add_q); 495 if (bna_rxf_mcast_del(rxf, mac, cleanup)) 496 return 1; 497 } 498 499 return 0; 500 } 501 502 static int 503 bna_rxf_rss_cfg_apply(struct bna_rxf *rxf) 504 { 505 if (rxf->rss_pending) { 506 if (rxf->rss_pending & BNA_RSS_F_RIT_PENDING) { 507 rxf->rss_pending &= ~BNA_RSS_F_RIT_PENDING; 508 bna_bfi_rit_cfg(rxf); 509 return 1; 510 } 511 512 if (rxf->rss_pending & BNA_RSS_F_CFG_PENDING) { 513 rxf->rss_pending &= ~BNA_RSS_F_CFG_PENDING; 514 bna_bfi_rss_cfg(rxf); 515 return 1; 516 } 517 518 if (rxf->rss_pending & BNA_RSS_F_STATUS_PENDING) { 519 rxf->rss_pending &= ~BNA_RSS_F_STATUS_PENDING; 520 bna_bfi_rss_enable(rxf); 521 return 1; 522 } 523 } 524 525 return 0; 526 } 527 528 static int 529 bna_rxf_cfg_apply(struct bna_rxf *rxf) 530 { 531 if (bna_rxf_ucast_cfg_apply(rxf)) 532 return 1; 533 534 if (bna_rxf_mcast_cfg_apply(rxf)) 535 return 1; 536 537 if (bna_rxf_promisc_cfg_apply(rxf)) 538 return 1; 539 540 if (bna_rxf_allmulti_cfg_apply(rxf)) 541 return 1; 542 543 if (bna_rxf_vlan_cfg_apply(rxf)) 544 return 1; 545 546 if (bna_rxf_vlan_strip_cfg_apply(rxf)) 547 return 1; 548 549 if (bna_rxf_rss_cfg_apply(rxf)) 550 return 1; 551 552 return 0; 553 } 554 555 static void 556 bna_rxf_cfg_reset(struct bna_rxf *rxf) 557 { 558 bna_rxf_ucast_cfg_reset(rxf, BNA_SOFT_CLEANUP); 559 bna_rxf_mcast_cfg_reset(rxf, BNA_SOFT_CLEANUP); 560 bna_rxf_promisc_cfg_reset(rxf, BNA_SOFT_CLEANUP); 561 bna_rxf_allmulti_cfg_reset(rxf, BNA_SOFT_CLEANUP); 562 bna_rxf_vlan_cfg_soft_reset(rxf); 563 bna_rxf_rss_cfg_soft_reset(rxf); 564 } 565 566 static void 567 bna_rit_init(struct bna_rxf *rxf, int rit_size) 568 { 569 struct bna_rx *rx = rxf->rx; 570 struct bna_rxp *rxp; 571 int offset = 0; 572 573 rxf->rit_size = rit_size; 574 list_for_each_entry(rxp, &rx->rxp_q, qe) { 575 rxf->rit[offset] = rxp->cq.ccb->id; 576 offset++; 577 } 578 } 579 580 void 581 bna_bfi_rxf_cfg_rsp(struct bna_rxf *rxf, struct bfi_msgq_mhdr *msghdr) 582 { 583 bfa_fsm_send_event(rxf, RXF_E_FW_RESP); 584 } 585 586 void 587 bna_bfi_rxf_ucast_set_rsp(struct bna_rxf *rxf, 588 struct bfi_msgq_mhdr *msghdr) 589 { 590 struct bfi_enet_rsp *rsp = 591 container_of(msghdr, struct bfi_enet_rsp, mh); 592 593 if (rsp->error) { 594 /* Clear ucast from cache */ 595 rxf->ucast_active_set = 0; 596 } 597 598 bfa_fsm_send_event(rxf, RXF_E_FW_RESP); 599 } 600 601 void 602 bna_bfi_rxf_mcast_add_rsp(struct bna_rxf *rxf, 603 struct bfi_msgq_mhdr *msghdr) 604 { 605 struct bfi_enet_mcast_add_req *req = 606 &rxf->bfi_enet_cmd.mcast_add_req; 607 struct bfi_enet_mcast_add_rsp *rsp = 608 container_of(msghdr, struct bfi_enet_mcast_add_rsp, mh); 609 610 bna_rxf_mchandle_attach(rxf, (u8 *)&req->mac_addr, 611 ntohs(rsp->handle)); 612 bfa_fsm_send_event(rxf, RXF_E_FW_RESP); 613 } 614 615 static void 616 bna_rxf_init(struct bna_rxf *rxf, 617 struct bna_rx *rx, 618 struct bna_rx_config *q_config, 619 struct bna_res_info *res_info) 620 { 621 rxf->rx = rx; 622 623 INIT_LIST_HEAD(&rxf->ucast_pending_add_q); 624 INIT_LIST_HEAD(&rxf->ucast_pending_del_q); 625 rxf->ucast_pending_set = 0; 626 rxf->ucast_active_set = 0; 627 INIT_LIST_HEAD(&rxf->ucast_active_q); 628 rxf->ucast_pending_mac = NULL; 629 630 INIT_LIST_HEAD(&rxf->mcast_pending_add_q); 631 INIT_LIST_HEAD(&rxf->mcast_pending_del_q); 632 INIT_LIST_HEAD(&rxf->mcast_active_q); 633 INIT_LIST_HEAD(&rxf->mcast_handle_q); 634 635 rxf->rit = (u8 *) 636 res_info[BNA_RX_RES_MEM_T_RIT].res_u.mem_info.mdl[0].kva; 637 bna_rit_init(rxf, q_config->num_paths); 638 639 rxf->rss_status = q_config->rss_status; 640 if (rxf->rss_status == BNA_STATUS_T_ENABLED) { 641 rxf->rss_cfg = q_config->rss_config; 642 rxf->rss_pending |= BNA_RSS_F_CFG_PENDING; 643 rxf->rss_pending |= BNA_RSS_F_RIT_PENDING; 644 rxf->rss_pending |= BNA_RSS_F_STATUS_PENDING; 645 } 646 647 rxf->vlan_filter_status = BNA_STATUS_T_DISABLED; 648 memset(rxf->vlan_filter_table, 0, 649 (sizeof(u32) * (BFI_ENET_VLAN_ID_MAX / 32))); 650 rxf->vlan_filter_table[0] |= 1; /* for pure priority tagged frames */ 651 rxf->vlan_pending_bitmask = (u8)BFI_VLAN_BMASK_ALL; 652 653 rxf->vlan_strip_status = q_config->vlan_strip_status; 654 655 bfa_fsm_set_state(rxf, bna_rxf_sm_stopped); 656 } 657 658 static void 659 bna_rxf_uninit(struct bna_rxf *rxf) 660 { 661 struct bna_mac *mac; 662 663 rxf->ucast_pending_set = 0; 664 rxf->ucast_active_set = 0; 665 666 while (!list_empty(&rxf->ucast_pending_add_q)) { 667 mac = list_first_entry(&rxf->ucast_pending_add_q, 668 struct bna_mac, qe); 669 list_move_tail(&mac->qe, bna_ucam_mod_free_q(rxf->rx->bna)); 670 } 671 672 if (rxf->ucast_pending_mac) { 673 list_add_tail(&rxf->ucast_pending_mac->qe, 674 bna_ucam_mod_free_q(rxf->rx->bna)); 675 rxf->ucast_pending_mac = NULL; 676 } 677 678 while (!list_empty(&rxf->mcast_pending_add_q)) { 679 mac = list_first_entry(&rxf->mcast_pending_add_q, 680 struct bna_mac, qe); 681 list_move_tail(&mac->qe, bna_mcam_mod_free_q(rxf->rx->bna)); 682 } 683 684 rxf->rxmode_pending = 0; 685 rxf->rxmode_pending_bitmask = 0; 686 if (rxf->rx->bna->promisc_rid == rxf->rx->rid) 687 rxf->rx->bna->promisc_rid = BFI_INVALID_RID; 688 if (rxf->rx->bna->default_mode_rid == rxf->rx->rid) 689 rxf->rx->bna->default_mode_rid = BFI_INVALID_RID; 690 691 rxf->rss_pending = 0; 692 rxf->vlan_strip_pending = false; 693 694 rxf->rx = NULL; 695 } 696 697 static void 698 bna_rx_cb_rxf_started(struct bna_rx *rx) 699 { 700 bfa_fsm_send_event(rx, RX_E_RXF_STARTED); 701 } 702 703 static void 704 bna_rxf_start(struct bna_rxf *rxf) 705 { 706 rxf->start_cbfn = bna_rx_cb_rxf_started; 707 rxf->start_cbarg = rxf->rx; 708 bfa_fsm_send_event(rxf, RXF_E_START); 709 } 710 711 static void 712 bna_rx_cb_rxf_stopped(struct bna_rx *rx) 713 { 714 bfa_fsm_send_event(rx, RX_E_RXF_STOPPED); 715 } 716 717 static void 718 bna_rxf_stop(struct bna_rxf *rxf) 719 { 720 rxf->stop_cbfn = bna_rx_cb_rxf_stopped; 721 rxf->stop_cbarg = rxf->rx; 722 bfa_fsm_send_event(rxf, RXF_E_STOP); 723 } 724 725 static void 726 bna_rxf_fail(struct bna_rxf *rxf) 727 { 728 bfa_fsm_send_event(rxf, RXF_E_FAIL); 729 } 730 731 enum bna_cb_status 732 bna_rx_ucast_set(struct bna_rx *rx, const u8 *ucmac) 733 { 734 struct bna_rxf *rxf = &rx->rxf; 735 736 if (rxf->ucast_pending_mac == NULL) { 737 rxf->ucast_pending_mac = 738 bna_cam_mod_mac_get(bna_ucam_mod_free_q(rxf->rx->bna)); 739 if (rxf->ucast_pending_mac == NULL) 740 return BNA_CB_UCAST_CAM_FULL; 741 } 742 743 ether_addr_copy(rxf->ucast_pending_mac->addr, ucmac); 744 rxf->ucast_pending_set = 1; 745 rxf->cam_fltr_cbfn = NULL; 746 rxf->cam_fltr_cbarg = rx->bna->bnad; 747 748 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 749 750 return BNA_CB_SUCCESS; 751 } 752 753 enum bna_cb_status 754 bna_rx_mcast_add(struct bna_rx *rx, const u8 *addr, 755 void (*cbfn)(struct bnad *, struct bna_rx *)) 756 { 757 struct bna_rxf *rxf = &rx->rxf; 758 struct bna_mac *mac; 759 760 /* Check if already added or pending addition */ 761 if (bna_mac_find(&rxf->mcast_active_q, addr) || 762 bna_mac_find(&rxf->mcast_pending_add_q, addr)) { 763 if (cbfn) 764 cbfn(rx->bna->bnad, rx); 765 return BNA_CB_SUCCESS; 766 } 767 768 mac = bna_cam_mod_mac_get(bna_mcam_mod_free_q(rxf->rx->bna)); 769 if (mac == NULL) 770 return BNA_CB_MCAST_LIST_FULL; 771 ether_addr_copy(mac->addr, addr); 772 list_add_tail(&mac->qe, &rxf->mcast_pending_add_q); 773 774 rxf->cam_fltr_cbfn = cbfn; 775 rxf->cam_fltr_cbarg = rx->bna->bnad; 776 777 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 778 779 return BNA_CB_SUCCESS; 780 } 781 782 enum bna_cb_status 783 bna_rx_ucast_listset(struct bna_rx *rx, int count, const u8 *uclist) 784 { 785 struct bna_ucam_mod *ucam_mod = &rx->bna->ucam_mod; 786 struct bna_rxf *rxf = &rx->rxf; 787 struct list_head list_head; 788 const u8 *mcaddr; 789 struct bna_mac *mac, *del_mac; 790 int i; 791 792 /* Purge the pending_add_q */ 793 while (!list_empty(&rxf->ucast_pending_add_q)) { 794 mac = list_first_entry(&rxf->ucast_pending_add_q, 795 struct bna_mac, qe); 796 list_move_tail(&mac->qe, &ucam_mod->free_q); 797 } 798 799 /* Schedule active_q entries for deletion */ 800 while (!list_empty(&rxf->ucast_active_q)) { 801 mac = list_first_entry(&rxf->ucast_active_q, 802 struct bna_mac, qe); 803 del_mac = bna_cam_mod_mac_get(&ucam_mod->del_q); 804 ether_addr_copy(del_mac->addr, mac->addr); 805 del_mac->handle = mac->handle; 806 list_add_tail(&del_mac->qe, &rxf->ucast_pending_del_q); 807 list_move_tail(&mac->qe, &ucam_mod->free_q); 808 } 809 810 /* Allocate nodes */ 811 INIT_LIST_HEAD(&list_head); 812 for (i = 0, mcaddr = uclist; i < count; i++) { 813 mac = bna_cam_mod_mac_get(&ucam_mod->free_q); 814 if (mac == NULL) 815 goto err_return; 816 ether_addr_copy(mac->addr, mcaddr); 817 list_add_tail(&mac->qe, &list_head); 818 mcaddr += ETH_ALEN; 819 } 820 821 /* Add the new entries */ 822 while (!list_empty(&list_head)) { 823 mac = list_first_entry(&list_head, struct bna_mac, qe); 824 list_move_tail(&mac->qe, &rxf->ucast_pending_add_q); 825 } 826 827 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 828 829 return BNA_CB_SUCCESS; 830 831 err_return: 832 while (!list_empty(&list_head)) { 833 mac = list_first_entry(&list_head, struct bna_mac, qe); 834 list_move_tail(&mac->qe, &ucam_mod->free_q); 835 } 836 837 return BNA_CB_UCAST_CAM_FULL; 838 } 839 840 enum bna_cb_status 841 bna_rx_mcast_listset(struct bna_rx *rx, int count, const u8 *mclist) 842 { 843 struct bna_mcam_mod *mcam_mod = &rx->bna->mcam_mod; 844 struct bna_rxf *rxf = &rx->rxf; 845 struct list_head list_head; 846 const u8 *mcaddr; 847 struct bna_mac *mac, *del_mac; 848 int i; 849 850 /* Purge the pending_add_q */ 851 while (!list_empty(&rxf->mcast_pending_add_q)) { 852 mac = list_first_entry(&rxf->mcast_pending_add_q, 853 struct bna_mac, qe); 854 list_move_tail(&mac->qe, &mcam_mod->free_q); 855 } 856 857 /* Schedule active_q entries for deletion */ 858 while (!list_empty(&rxf->mcast_active_q)) { 859 mac = list_first_entry(&rxf->mcast_active_q, 860 struct bna_mac, qe); 861 del_mac = bna_cam_mod_mac_get(&mcam_mod->del_q); 862 ether_addr_copy(del_mac->addr, mac->addr); 863 del_mac->handle = mac->handle; 864 list_add_tail(&del_mac->qe, &rxf->mcast_pending_del_q); 865 mac->handle = NULL; 866 list_move_tail(&mac->qe, &mcam_mod->free_q); 867 } 868 869 /* Allocate nodes */ 870 INIT_LIST_HEAD(&list_head); 871 for (i = 0, mcaddr = mclist; i < count; i++) { 872 mac = bna_cam_mod_mac_get(&mcam_mod->free_q); 873 if (mac == NULL) 874 goto err_return; 875 ether_addr_copy(mac->addr, mcaddr); 876 list_add_tail(&mac->qe, &list_head); 877 878 mcaddr += ETH_ALEN; 879 } 880 881 /* Add the new entries */ 882 while (!list_empty(&list_head)) { 883 mac = list_first_entry(&list_head, struct bna_mac, qe); 884 list_move_tail(&mac->qe, &rxf->mcast_pending_add_q); 885 } 886 887 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 888 889 return BNA_CB_SUCCESS; 890 891 err_return: 892 while (!list_empty(&list_head)) { 893 mac = list_first_entry(&list_head, struct bna_mac, qe); 894 list_move_tail(&mac->qe, &mcam_mod->free_q); 895 } 896 897 return BNA_CB_MCAST_LIST_FULL; 898 } 899 900 void 901 bna_rx_mcast_delall(struct bna_rx *rx) 902 { 903 struct bna_rxf *rxf = &rx->rxf; 904 struct bna_mac *mac, *del_mac; 905 int need_hw_config = 0; 906 907 /* Purge all entries from pending_add_q */ 908 while (!list_empty(&rxf->mcast_pending_add_q)) { 909 mac = list_first_entry(&rxf->mcast_pending_add_q, 910 struct bna_mac, qe); 911 list_move_tail(&mac->qe, bna_mcam_mod_free_q(rxf->rx->bna)); 912 } 913 914 /* Schedule all entries in active_q for deletion */ 915 while (!list_empty(&rxf->mcast_active_q)) { 916 mac = list_first_entry(&rxf->mcast_active_q, 917 struct bna_mac, qe); 918 list_del(&mac->qe); 919 del_mac = bna_cam_mod_mac_get(bna_mcam_mod_del_q(rxf->rx->bna)); 920 memcpy(del_mac, mac, sizeof(*del_mac)); 921 list_add_tail(&del_mac->qe, &rxf->mcast_pending_del_q); 922 mac->handle = NULL; 923 list_add_tail(&mac->qe, bna_mcam_mod_free_q(rxf->rx->bna)); 924 need_hw_config = 1; 925 } 926 927 if (need_hw_config) 928 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 929 } 930 931 void 932 bna_rx_vlan_add(struct bna_rx *rx, int vlan_id) 933 { 934 struct bna_rxf *rxf = &rx->rxf; 935 int index = (vlan_id >> BFI_VLAN_WORD_SHIFT); 936 int bit = BIT(vlan_id & BFI_VLAN_WORD_MASK); 937 int group_id = (vlan_id >> BFI_VLAN_BLOCK_SHIFT); 938 939 rxf->vlan_filter_table[index] |= bit; 940 if (rxf->vlan_filter_status == BNA_STATUS_T_ENABLED) { 941 rxf->vlan_pending_bitmask |= BIT(group_id); 942 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 943 } 944 } 945 946 void 947 bna_rx_vlan_del(struct bna_rx *rx, int vlan_id) 948 { 949 struct bna_rxf *rxf = &rx->rxf; 950 int index = (vlan_id >> BFI_VLAN_WORD_SHIFT); 951 int bit = BIT(vlan_id & BFI_VLAN_WORD_MASK); 952 int group_id = (vlan_id >> BFI_VLAN_BLOCK_SHIFT); 953 954 rxf->vlan_filter_table[index] &= ~bit; 955 if (rxf->vlan_filter_status == BNA_STATUS_T_ENABLED) { 956 rxf->vlan_pending_bitmask |= BIT(group_id); 957 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 958 } 959 } 960 961 static int 962 bna_rxf_ucast_cfg_apply(struct bna_rxf *rxf) 963 { 964 struct bna_mac *mac = NULL; 965 966 /* Delete MAC addresses previousely added */ 967 if (!list_empty(&rxf->ucast_pending_del_q)) { 968 mac = list_first_entry(&rxf->ucast_pending_del_q, 969 struct bna_mac, qe); 970 bna_bfi_ucast_req(rxf, mac, BFI_ENET_H2I_MAC_UCAST_DEL_REQ); 971 list_move_tail(&mac->qe, bna_ucam_mod_del_q(rxf->rx->bna)); 972 return 1; 973 } 974 975 /* Set default unicast MAC */ 976 if (rxf->ucast_pending_set) { 977 rxf->ucast_pending_set = 0; 978 ether_addr_copy(rxf->ucast_active_mac.addr, 979 rxf->ucast_pending_mac->addr); 980 rxf->ucast_active_set = 1; 981 bna_bfi_ucast_req(rxf, &rxf->ucast_active_mac, 982 BFI_ENET_H2I_MAC_UCAST_SET_REQ); 983 return 1; 984 } 985 986 /* Add additional MAC entries */ 987 if (!list_empty(&rxf->ucast_pending_add_q)) { 988 mac = list_first_entry(&rxf->ucast_pending_add_q, 989 struct bna_mac, qe); 990 list_add_tail(&mac->qe, &rxf->ucast_active_q); 991 bna_bfi_ucast_req(rxf, mac, BFI_ENET_H2I_MAC_UCAST_ADD_REQ); 992 return 1; 993 } 994 995 return 0; 996 } 997 998 static int 999 bna_rxf_ucast_cfg_reset(struct bna_rxf *rxf, enum bna_cleanup_type cleanup) 1000 { 1001 struct bna_mac *mac; 1002 1003 /* Throw away delete pending ucast entries */ 1004 while (!list_empty(&rxf->ucast_pending_del_q)) { 1005 mac = list_first_entry(&rxf->ucast_pending_del_q, 1006 struct bna_mac, qe); 1007 if (cleanup == BNA_SOFT_CLEANUP) 1008 list_move_tail(&mac->qe, 1009 bna_ucam_mod_del_q(rxf->rx->bna)); 1010 else { 1011 bna_bfi_ucast_req(rxf, mac, 1012 BFI_ENET_H2I_MAC_UCAST_DEL_REQ); 1013 list_move_tail(&mac->qe, 1014 bna_ucam_mod_del_q(rxf->rx->bna)); 1015 return 1; 1016 } 1017 } 1018 1019 /* Move active ucast entries to pending_add_q */ 1020 while (!list_empty(&rxf->ucast_active_q)) { 1021 mac = list_first_entry(&rxf->ucast_active_q, 1022 struct bna_mac, qe); 1023 list_move_tail(&mac->qe, &rxf->ucast_pending_add_q); 1024 if (cleanup == BNA_HARD_CLEANUP) { 1025 bna_bfi_ucast_req(rxf, mac, 1026 BFI_ENET_H2I_MAC_UCAST_DEL_REQ); 1027 return 1; 1028 } 1029 } 1030 1031 if (rxf->ucast_active_set) { 1032 rxf->ucast_pending_set = 1; 1033 rxf->ucast_active_set = 0; 1034 if (cleanup == BNA_HARD_CLEANUP) { 1035 bna_bfi_ucast_req(rxf, &rxf->ucast_active_mac, 1036 BFI_ENET_H2I_MAC_UCAST_CLR_REQ); 1037 return 1; 1038 } 1039 } 1040 1041 return 0; 1042 } 1043 1044 static int 1045 bna_rxf_promisc_cfg_apply(struct bna_rxf *rxf) 1046 { 1047 struct bna *bna = rxf->rx->bna; 1048 1049 /* Enable/disable promiscuous mode */ 1050 if (is_promisc_enable(rxf->rxmode_pending, 1051 rxf->rxmode_pending_bitmask)) { 1052 /* move promisc configuration from pending -> active */ 1053 promisc_inactive(rxf->rxmode_pending, 1054 rxf->rxmode_pending_bitmask); 1055 rxf->rxmode_active |= BNA_RXMODE_PROMISC; 1056 bna_bfi_rx_promisc_req(rxf, BNA_STATUS_T_ENABLED); 1057 return 1; 1058 } else if (is_promisc_disable(rxf->rxmode_pending, 1059 rxf->rxmode_pending_bitmask)) { 1060 /* move promisc configuration from pending -> active */ 1061 promisc_inactive(rxf->rxmode_pending, 1062 rxf->rxmode_pending_bitmask); 1063 rxf->rxmode_active &= ~BNA_RXMODE_PROMISC; 1064 bna->promisc_rid = BFI_INVALID_RID; 1065 bna_bfi_rx_promisc_req(rxf, BNA_STATUS_T_DISABLED); 1066 return 1; 1067 } 1068 1069 return 0; 1070 } 1071 1072 static int 1073 bna_rxf_promisc_cfg_reset(struct bna_rxf *rxf, enum bna_cleanup_type cleanup) 1074 { 1075 struct bna *bna = rxf->rx->bna; 1076 1077 /* Clear pending promisc mode disable */ 1078 if (is_promisc_disable(rxf->rxmode_pending, 1079 rxf->rxmode_pending_bitmask)) { 1080 promisc_inactive(rxf->rxmode_pending, 1081 rxf->rxmode_pending_bitmask); 1082 rxf->rxmode_active &= ~BNA_RXMODE_PROMISC; 1083 bna->promisc_rid = BFI_INVALID_RID; 1084 if (cleanup == BNA_HARD_CLEANUP) { 1085 bna_bfi_rx_promisc_req(rxf, BNA_STATUS_T_DISABLED); 1086 return 1; 1087 } 1088 } 1089 1090 /* Move promisc mode config from active -> pending */ 1091 if (rxf->rxmode_active & BNA_RXMODE_PROMISC) { 1092 promisc_enable(rxf->rxmode_pending, 1093 rxf->rxmode_pending_bitmask); 1094 rxf->rxmode_active &= ~BNA_RXMODE_PROMISC; 1095 if (cleanup == BNA_HARD_CLEANUP) { 1096 bna_bfi_rx_promisc_req(rxf, BNA_STATUS_T_DISABLED); 1097 return 1; 1098 } 1099 } 1100 1101 return 0; 1102 } 1103 1104 static int 1105 bna_rxf_allmulti_cfg_apply(struct bna_rxf *rxf) 1106 { 1107 /* Enable/disable allmulti mode */ 1108 if (is_allmulti_enable(rxf->rxmode_pending, 1109 rxf->rxmode_pending_bitmask)) { 1110 /* move allmulti configuration from pending -> active */ 1111 allmulti_inactive(rxf->rxmode_pending, 1112 rxf->rxmode_pending_bitmask); 1113 rxf->rxmode_active |= BNA_RXMODE_ALLMULTI; 1114 bna_bfi_mcast_filter_req(rxf, BNA_STATUS_T_DISABLED); 1115 return 1; 1116 } else if (is_allmulti_disable(rxf->rxmode_pending, 1117 rxf->rxmode_pending_bitmask)) { 1118 /* move allmulti configuration from pending -> active */ 1119 allmulti_inactive(rxf->rxmode_pending, 1120 rxf->rxmode_pending_bitmask); 1121 rxf->rxmode_active &= ~BNA_RXMODE_ALLMULTI; 1122 bna_bfi_mcast_filter_req(rxf, BNA_STATUS_T_ENABLED); 1123 return 1; 1124 } 1125 1126 return 0; 1127 } 1128 1129 static int 1130 bna_rxf_allmulti_cfg_reset(struct bna_rxf *rxf, enum bna_cleanup_type cleanup) 1131 { 1132 /* Clear pending allmulti mode disable */ 1133 if (is_allmulti_disable(rxf->rxmode_pending, 1134 rxf->rxmode_pending_bitmask)) { 1135 allmulti_inactive(rxf->rxmode_pending, 1136 rxf->rxmode_pending_bitmask); 1137 rxf->rxmode_active &= ~BNA_RXMODE_ALLMULTI; 1138 if (cleanup == BNA_HARD_CLEANUP) { 1139 bna_bfi_mcast_filter_req(rxf, BNA_STATUS_T_ENABLED); 1140 return 1; 1141 } 1142 } 1143 1144 /* Move allmulti mode config from active -> pending */ 1145 if (rxf->rxmode_active & BNA_RXMODE_ALLMULTI) { 1146 allmulti_enable(rxf->rxmode_pending, 1147 rxf->rxmode_pending_bitmask); 1148 rxf->rxmode_active &= ~BNA_RXMODE_ALLMULTI; 1149 if (cleanup == BNA_HARD_CLEANUP) { 1150 bna_bfi_mcast_filter_req(rxf, BNA_STATUS_T_ENABLED); 1151 return 1; 1152 } 1153 } 1154 1155 return 0; 1156 } 1157 1158 static int 1159 bna_rxf_promisc_enable(struct bna_rxf *rxf) 1160 { 1161 struct bna *bna = rxf->rx->bna; 1162 int ret = 0; 1163 1164 if (is_promisc_enable(rxf->rxmode_pending, 1165 rxf->rxmode_pending_bitmask) || 1166 (rxf->rxmode_active & BNA_RXMODE_PROMISC)) { 1167 /* Do nothing if pending enable or already enabled */ 1168 } else if (is_promisc_disable(rxf->rxmode_pending, 1169 rxf->rxmode_pending_bitmask)) { 1170 /* Turn off pending disable command */ 1171 promisc_inactive(rxf->rxmode_pending, 1172 rxf->rxmode_pending_bitmask); 1173 } else { 1174 /* Schedule enable */ 1175 promisc_enable(rxf->rxmode_pending, 1176 rxf->rxmode_pending_bitmask); 1177 bna->promisc_rid = rxf->rx->rid; 1178 ret = 1; 1179 } 1180 1181 return ret; 1182 } 1183 1184 static int 1185 bna_rxf_promisc_disable(struct bna_rxf *rxf) 1186 { 1187 struct bna *bna = rxf->rx->bna; 1188 int ret = 0; 1189 1190 if (is_promisc_disable(rxf->rxmode_pending, 1191 rxf->rxmode_pending_bitmask) || 1192 (!(rxf->rxmode_active & BNA_RXMODE_PROMISC))) { 1193 /* Do nothing if pending disable or already disabled */ 1194 } else if (is_promisc_enable(rxf->rxmode_pending, 1195 rxf->rxmode_pending_bitmask)) { 1196 /* Turn off pending enable command */ 1197 promisc_inactive(rxf->rxmode_pending, 1198 rxf->rxmode_pending_bitmask); 1199 bna->promisc_rid = BFI_INVALID_RID; 1200 } else if (rxf->rxmode_active & BNA_RXMODE_PROMISC) { 1201 /* Schedule disable */ 1202 promisc_disable(rxf->rxmode_pending, 1203 rxf->rxmode_pending_bitmask); 1204 ret = 1; 1205 } 1206 1207 return ret; 1208 } 1209 1210 static int 1211 bna_rxf_allmulti_enable(struct bna_rxf *rxf) 1212 { 1213 int ret = 0; 1214 1215 if (is_allmulti_enable(rxf->rxmode_pending, 1216 rxf->rxmode_pending_bitmask) || 1217 (rxf->rxmode_active & BNA_RXMODE_ALLMULTI)) { 1218 /* Do nothing if pending enable or already enabled */ 1219 } else if (is_allmulti_disable(rxf->rxmode_pending, 1220 rxf->rxmode_pending_bitmask)) { 1221 /* Turn off pending disable command */ 1222 allmulti_inactive(rxf->rxmode_pending, 1223 rxf->rxmode_pending_bitmask); 1224 } else { 1225 /* Schedule enable */ 1226 allmulti_enable(rxf->rxmode_pending, 1227 rxf->rxmode_pending_bitmask); 1228 ret = 1; 1229 } 1230 1231 return ret; 1232 } 1233 1234 static int 1235 bna_rxf_allmulti_disable(struct bna_rxf *rxf) 1236 { 1237 int ret = 0; 1238 1239 if (is_allmulti_disable(rxf->rxmode_pending, 1240 rxf->rxmode_pending_bitmask) || 1241 (!(rxf->rxmode_active & BNA_RXMODE_ALLMULTI))) { 1242 /* Do nothing if pending disable or already disabled */ 1243 } else if (is_allmulti_enable(rxf->rxmode_pending, 1244 rxf->rxmode_pending_bitmask)) { 1245 /* Turn off pending enable command */ 1246 allmulti_inactive(rxf->rxmode_pending, 1247 rxf->rxmode_pending_bitmask); 1248 } else if (rxf->rxmode_active & BNA_RXMODE_ALLMULTI) { 1249 /* Schedule disable */ 1250 allmulti_disable(rxf->rxmode_pending, 1251 rxf->rxmode_pending_bitmask); 1252 ret = 1; 1253 } 1254 1255 return ret; 1256 } 1257 1258 static int 1259 bna_rxf_vlan_strip_cfg_apply(struct bna_rxf *rxf) 1260 { 1261 if (rxf->vlan_strip_pending) { 1262 rxf->vlan_strip_pending = false; 1263 bna_bfi_vlan_strip_enable(rxf); 1264 return 1; 1265 } 1266 1267 return 0; 1268 } 1269 1270 /* RX */ 1271 1272 #define BNA_GET_RXQS(qcfg) (((qcfg)->rxp_type == BNA_RXP_SINGLE) ? \ 1273 (qcfg)->num_paths : ((qcfg)->num_paths * 2)) 1274 1275 #define SIZE_TO_PAGES(size) (((size) >> PAGE_SHIFT) + ((((size) &\ 1276 (PAGE_SIZE - 1)) + (PAGE_SIZE - 1)) >> PAGE_SHIFT)) 1277 1278 #define call_rx_stop_cbfn(rx) \ 1279 do { \ 1280 if ((rx)->stop_cbfn) { \ 1281 void (*cbfn)(void *, struct bna_rx *); \ 1282 void *cbarg; \ 1283 cbfn = (rx)->stop_cbfn; \ 1284 cbarg = (rx)->stop_cbarg; \ 1285 (rx)->stop_cbfn = NULL; \ 1286 (rx)->stop_cbarg = NULL; \ 1287 cbfn(cbarg, rx); \ 1288 } \ 1289 } while (0) 1290 1291 #define call_rx_stall_cbfn(rx) \ 1292 do { \ 1293 if ((rx)->rx_stall_cbfn) \ 1294 (rx)->rx_stall_cbfn((rx)->bna->bnad, (rx)); \ 1295 } while (0) 1296 1297 #define bfi_enet_datapath_q_init(bfi_q, bna_qpt) \ 1298 do { \ 1299 struct bna_dma_addr cur_q_addr = \ 1300 *((struct bna_dma_addr *)((bna_qpt)->kv_qpt_ptr)); \ 1301 (bfi_q)->pg_tbl.a32.addr_lo = (bna_qpt)->hw_qpt_ptr.lsb; \ 1302 (bfi_q)->pg_tbl.a32.addr_hi = (bna_qpt)->hw_qpt_ptr.msb; \ 1303 (bfi_q)->first_entry.a32.addr_lo = cur_q_addr.lsb; \ 1304 (bfi_q)->first_entry.a32.addr_hi = cur_q_addr.msb; \ 1305 (bfi_q)->pages = htons((u16)(bna_qpt)->page_count); \ 1306 (bfi_q)->page_sz = htons((u16)(bna_qpt)->page_size);\ 1307 } while (0) 1308 1309 static void bna_bfi_rx_enet_start(struct bna_rx *rx); 1310 static void bna_rx_enet_stop(struct bna_rx *rx); 1311 static void bna_rx_mod_cb_rx_stopped(void *arg, struct bna_rx *rx); 1312 1313 bfa_fsm_state_decl(bna_rx, stopped, 1314 struct bna_rx, enum bna_rx_event); 1315 bfa_fsm_state_decl(bna_rx, start_wait, 1316 struct bna_rx, enum bna_rx_event); 1317 bfa_fsm_state_decl(bna_rx, start_stop_wait, 1318 struct bna_rx, enum bna_rx_event); 1319 bfa_fsm_state_decl(bna_rx, rxf_start_wait, 1320 struct bna_rx, enum bna_rx_event); 1321 bfa_fsm_state_decl(bna_rx, started, 1322 struct bna_rx, enum bna_rx_event); 1323 bfa_fsm_state_decl(bna_rx, rxf_stop_wait, 1324 struct bna_rx, enum bna_rx_event); 1325 bfa_fsm_state_decl(bna_rx, stop_wait, 1326 struct bna_rx, enum bna_rx_event); 1327 bfa_fsm_state_decl(bna_rx, cleanup_wait, 1328 struct bna_rx, enum bna_rx_event); 1329 bfa_fsm_state_decl(bna_rx, failed, 1330 struct bna_rx, enum bna_rx_event); 1331 bfa_fsm_state_decl(bna_rx, quiesce_wait, 1332 struct bna_rx, enum bna_rx_event); 1333 1334 static void bna_rx_sm_stopped_entry(struct bna_rx *rx) 1335 { 1336 call_rx_stop_cbfn(rx); 1337 } 1338 1339 static void bna_rx_sm_stopped(struct bna_rx *rx, 1340 enum bna_rx_event event) 1341 { 1342 switch (event) { 1343 case RX_E_START: 1344 bfa_fsm_set_state(rx, bna_rx_sm_start_wait); 1345 break; 1346 1347 case RX_E_STOP: 1348 call_rx_stop_cbfn(rx); 1349 break; 1350 1351 case RX_E_FAIL: 1352 /* no-op */ 1353 break; 1354 1355 default: 1356 bfa_sm_fault(event); 1357 break; 1358 } 1359 } 1360 1361 static void bna_rx_sm_start_wait_entry(struct bna_rx *rx) 1362 { 1363 bna_bfi_rx_enet_start(rx); 1364 } 1365 1366 static void 1367 bna_rx_sm_stop_wait_entry(struct bna_rx *rx) 1368 { 1369 } 1370 1371 static void 1372 bna_rx_sm_stop_wait(struct bna_rx *rx, enum bna_rx_event event) 1373 { 1374 switch (event) { 1375 case RX_E_FAIL: 1376 case RX_E_STOPPED: 1377 bfa_fsm_set_state(rx, bna_rx_sm_cleanup_wait); 1378 rx->rx_cleanup_cbfn(rx->bna->bnad, rx); 1379 break; 1380 1381 case RX_E_STARTED: 1382 bna_rx_enet_stop(rx); 1383 break; 1384 1385 default: 1386 bfa_sm_fault(event); 1387 break; 1388 } 1389 } 1390 1391 static void bna_rx_sm_start_wait(struct bna_rx *rx, 1392 enum bna_rx_event event) 1393 { 1394 switch (event) { 1395 case RX_E_STOP: 1396 bfa_fsm_set_state(rx, bna_rx_sm_start_stop_wait); 1397 break; 1398 1399 case RX_E_FAIL: 1400 bfa_fsm_set_state(rx, bna_rx_sm_stopped); 1401 break; 1402 1403 case RX_E_STARTED: 1404 bfa_fsm_set_state(rx, bna_rx_sm_rxf_start_wait); 1405 break; 1406 1407 default: 1408 bfa_sm_fault(event); 1409 break; 1410 } 1411 } 1412 1413 static void bna_rx_sm_rxf_start_wait_entry(struct bna_rx *rx) 1414 { 1415 rx->rx_post_cbfn(rx->bna->bnad, rx); 1416 bna_rxf_start(&rx->rxf); 1417 } 1418 1419 static void 1420 bna_rx_sm_rxf_stop_wait_entry(struct bna_rx *rx) 1421 { 1422 } 1423 1424 static void 1425 bna_rx_sm_rxf_stop_wait(struct bna_rx *rx, enum bna_rx_event event) 1426 { 1427 switch (event) { 1428 case RX_E_FAIL: 1429 bfa_fsm_set_state(rx, bna_rx_sm_cleanup_wait); 1430 bna_rxf_fail(&rx->rxf); 1431 call_rx_stall_cbfn(rx); 1432 rx->rx_cleanup_cbfn(rx->bna->bnad, rx); 1433 break; 1434 1435 case RX_E_RXF_STARTED: 1436 bna_rxf_stop(&rx->rxf); 1437 break; 1438 1439 case RX_E_RXF_STOPPED: 1440 bfa_fsm_set_state(rx, bna_rx_sm_stop_wait); 1441 call_rx_stall_cbfn(rx); 1442 bna_rx_enet_stop(rx); 1443 break; 1444 1445 default: 1446 bfa_sm_fault(event); 1447 break; 1448 } 1449 1450 } 1451 1452 static void 1453 bna_rx_sm_start_stop_wait_entry(struct bna_rx *rx) 1454 { 1455 } 1456 1457 static void 1458 bna_rx_sm_start_stop_wait(struct bna_rx *rx, enum bna_rx_event event) 1459 { 1460 switch (event) { 1461 case RX_E_FAIL: 1462 case RX_E_STOPPED: 1463 bfa_fsm_set_state(rx, bna_rx_sm_stopped); 1464 break; 1465 1466 case RX_E_STARTED: 1467 bna_rx_enet_stop(rx); 1468 break; 1469 1470 default: 1471 bfa_sm_fault(event); 1472 } 1473 } 1474 1475 static void 1476 bna_rx_sm_started_entry(struct bna_rx *rx) 1477 { 1478 struct bna_rxp *rxp; 1479 int is_regular = (rx->type == BNA_RX_T_REGULAR); 1480 1481 /* Start IB */ 1482 list_for_each_entry(rxp, &rx->rxp_q, qe) 1483 bna_ib_start(rx->bna, &rxp->cq.ib, is_regular); 1484 1485 bna_ethport_cb_rx_started(&rx->bna->ethport); 1486 } 1487 1488 static void 1489 bna_rx_sm_started(struct bna_rx *rx, enum bna_rx_event event) 1490 { 1491 switch (event) { 1492 case RX_E_STOP: 1493 bfa_fsm_set_state(rx, bna_rx_sm_rxf_stop_wait); 1494 bna_ethport_cb_rx_stopped(&rx->bna->ethport); 1495 bna_rxf_stop(&rx->rxf); 1496 break; 1497 1498 case RX_E_FAIL: 1499 bfa_fsm_set_state(rx, bna_rx_sm_failed); 1500 bna_ethport_cb_rx_stopped(&rx->bna->ethport); 1501 bna_rxf_fail(&rx->rxf); 1502 call_rx_stall_cbfn(rx); 1503 rx->rx_cleanup_cbfn(rx->bna->bnad, rx); 1504 break; 1505 1506 default: 1507 bfa_sm_fault(event); 1508 break; 1509 } 1510 } 1511 1512 static void bna_rx_sm_rxf_start_wait(struct bna_rx *rx, 1513 enum bna_rx_event event) 1514 { 1515 switch (event) { 1516 case RX_E_STOP: 1517 bfa_fsm_set_state(rx, bna_rx_sm_rxf_stop_wait); 1518 break; 1519 1520 case RX_E_FAIL: 1521 bfa_fsm_set_state(rx, bna_rx_sm_failed); 1522 bna_rxf_fail(&rx->rxf); 1523 call_rx_stall_cbfn(rx); 1524 rx->rx_cleanup_cbfn(rx->bna->bnad, rx); 1525 break; 1526 1527 case RX_E_RXF_STARTED: 1528 bfa_fsm_set_state(rx, bna_rx_sm_started); 1529 break; 1530 1531 default: 1532 bfa_sm_fault(event); 1533 break; 1534 } 1535 } 1536 1537 static void 1538 bna_rx_sm_cleanup_wait_entry(struct bna_rx *rx) 1539 { 1540 } 1541 1542 static void 1543 bna_rx_sm_cleanup_wait(struct bna_rx *rx, enum bna_rx_event event) 1544 { 1545 switch (event) { 1546 case RX_E_FAIL: 1547 case RX_E_RXF_STOPPED: 1548 /* No-op */ 1549 break; 1550 1551 case RX_E_CLEANUP_DONE: 1552 bfa_fsm_set_state(rx, bna_rx_sm_stopped); 1553 break; 1554 1555 default: 1556 bfa_sm_fault(event); 1557 break; 1558 } 1559 } 1560 1561 static void 1562 bna_rx_sm_failed_entry(struct bna_rx *rx) 1563 { 1564 } 1565 1566 static void 1567 bna_rx_sm_failed(struct bna_rx *rx, enum bna_rx_event event) 1568 { 1569 switch (event) { 1570 case RX_E_START: 1571 bfa_fsm_set_state(rx, bna_rx_sm_quiesce_wait); 1572 break; 1573 1574 case RX_E_STOP: 1575 bfa_fsm_set_state(rx, bna_rx_sm_cleanup_wait); 1576 break; 1577 1578 case RX_E_FAIL: 1579 case RX_E_RXF_STARTED: 1580 case RX_E_RXF_STOPPED: 1581 /* No-op */ 1582 break; 1583 1584 case RX_E_CLEANUP_DONE: 1585 bfa_fsm_set_state(rx, bna_rx_sm_stopped); 1586 break; 1587 1588 default: 1589 bfa_sm_fault(event); 1590 break; 1591 } } 1592 1593 static void 1594 bna_rx_sm_quiesce_wait_entry(struct bna_rx *rx) 1595 { 1596 } 1597 1598 static void 1599 bna_rx_sm_quiesce_wait(struct bna_rx *rx, enum bna_rx_event event) 1600 { 1601 switch (event) { 1602 case RX_E_STOP: 1603 bfa_fsm_set_state(rx, bna_rx_sm_cleanup_wait); 1604 break; 1605 1606 case RX_E_FAIL: 1607 bfa_fsm_set_state(rx, bna_rx_sm_failed); 1608 break; 1609 1610 case RX_E_CLEANUP_DONE: 1611 bfa_fsm_set_state(rx, bna_rx_sm_start_wait); 1612 break; 1613 1614 default: 1615 bfa_sm_fault(event); 1616 break; 1617 } 1618 } 1619 1620 static void 1621 bna_bfi_rx_enet_start(struct bna_rx *rx) 1622 { 1623 struct bfi_enet_rx_cfg_req *cfg_req = &rx->bfi_enet_cmd.cfg_req; 1624 struct bna_rxp *rxp = NULL; 1625 struct bna_rxq *q0 = NULL, *q1 = NULL; 1626 int i; 1627 1628 bfi_msgq_mhdr_set(cfg_req->mh, BFI_MC_ENET, 1629 BFI_ENET_H2I_RX_CFG_SET_REQ, 0, rx->rid); 1630 cfg_req->mh.num_entries = htons( 1631 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_rx_cfg_req))); 1632 1633 cfg_req->rx_cfg.frame_size = bna_enet_mtu_get(&rx->bna->enet); 1634 cfg_req->num_queue_sets = rx->num_paths; 1635 for (i = 0; i < rx->num_paths; i++) { 1636 rxp = rxp ? list_next_entry(rxp, qe) 1637 : list_first_entry(&rx->rxp_q, struct bna_rxp, qe); 1638 GET_RXQS(rxp, q0, q1); 1639 switch (rxp->type) { 1640 case BNA_RXP_SLR: 1641 case BNA_RXP_HDS: 1642 /* Small RxQ */ 1643 bfi_enet_datapath_q_init(&cfg_req->q_cfg[i].qs.q, 1644 &q1->qpt); 1645 cfg_req->q_cfg[i].qs.rx_buffer_size = 1646 htons((u16)q1->buffer_size); 1647 /* Fall through */ 1648 1649 case BNA_RXP_SINGLE: 1650 /* Large/Single RxQ */ 1651 bfi_enet_datapath_q_init(&cfg_req->q_cfg[i].ql.q, 1652 &q0->qpt); 1653 if (q0->multi_buffer) 1654 /* multi-buffer is enabled by allocating 1655 * a new rx with new set of resources. 1656 * q0->buffer_size should be initialized to 1657 * fragment size. 1658 */ 1659 cfg_req->rx_cfg.multi_buffer = 1660 BNA_STATUS_T_ENABLED; 1661 else 1662 q0->buffer_size = 1663 bna_enet_mtu_get(&rx->bna->enet); 1664 cfg_req->q_cfg[i].ql.rx_buffer_size = 1665 htons((u16)q0->buffer_size); 1666 break; 1667 1668 default: 1669 BUG_ON(1); 1670 } 1671 1672 bfi_enet_datapath_q_init(&cfg_req->q_cfg[i].cq.q, 1673 &rxp->cq.qpt); 1674 1675 cfg_req->q_cfg[i].ib.index_addr.a32.addr_lo = 1676 rxp->cq.ib.ib_seg_host_addr.lsb; 1677 cfg_req->q_cfg[i].ib.index_addr.a32.addr_hi = 1678 rxp->cq.ib.ib_seg_host_addr.msb; 1679 cfg_req->q_cfg[i].ib.intr.msix_index = 1680 htons((u16)rxp->cq.ib.intr_vector); 1681 } 1682 1683 cfg_req->ib_cfg.int_pkt_dma = BNA_STATUS_T_DISABLED; 1684 cfg_req->ib_cfg.int_enabled = BNA_STATUS_T_ENABLED; 1685 cfg_req->ib_cfg.int_pkt_enabled = BNA_STATUS_T_DISABLED; 1686 cfg_req->ib_cfg.continuous_coalescing = BNA_STATUS_T_DISABLED; 1687 cfg_req->ib_cfg.msix = (rxp->cq.ib.intr_type == BNA_INTR_T_MSIX) 1688 ? BNA_STATUS_T_ENABLED : 1689 BNA_STATUS_T_DISABLED; 1690 cfg_req->ib_cfg.coalescing_timeout = 1691 htonl((u32)rxp->cq.ib.coalescing_timeo); 1692 cfg_req->ib_cfg.inter_pkt_timeout = 1693 htonl((u32)rxp->cq.ib.interpkt_timeo); 1694 cfg_req->ib_cfg.inter_pkt_count = (u8)rxp->cq.ib.interpkt_count; 1695 1696 switch (rxp->type) { 1697 case BNA_RXP_SLR: 1698 cfg_req->rx_cfg.rxq_type = BFI_ENET_RXQ_LARGE_SMALL; 1699 break; 1700 1701 case BNA_RXP_HDS: 1702 cfg_req->rx_cfg.rxq_type = BFI_ENET_RXQ_HDS; 1703 cfg_req->rx_cfg.hds.type = rx->hds_cfg.hdr_type; 1704 cfg_req->rx_cfg.hds.force_offset = rx->hds_cfg.forced_offset; 1705 cfg_req->rx_cfg.hds.max_header_size = rx->hds_cfg.forced_offset; 1706 break; 1707 1708 case BNA_RXP_SINGLE: 1709 cfg_req->rx_cfg.rxq_type = BFI_ENET_RXQ_SINGLE; 1710 break; 1711 1712 default: 1713 BUG_ON(1); 1714 } 1715 cfg_req->rx_cfg.strip_vlan = rx->rxf.vlan_strip_status; 1716 1717 bfa_msgq_cmd_set(&rx->msgq_cmd, NULL, NULL, 1718 sizeof(struct bfi_enet_rx_cfg_req), &cfg_req->mh); 1719 bfa_msgq_cmd_post(&rx->bna->msgq, &rx->msgq_cmd); 1720 } 1721 1722 static void 1723 bna_bfi_rx_enet_stop(struct bna_rx *rx) 1724 { 1725 struct bfi_enet_req *req = &rx->bfi_enet_cmd.req; 1726 1727 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, 1728 BFI_ENET_H2I_RX_CFG_CLR_REQ, 0, rx->rid); 1729 req->mh.num_entries = htons( 1730 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_req))); 1731 bfa_msgq_cmd_set(&rx->msgq_cmd, NULL, NULL, sizeof(struct bfi_enet_req), 1732 &req->mh); 1733 bfa_msgq_cmd_post(&rx->bna->msgq, &rx->msgq_cmd); 1734 } 1735 1736 static void 1737 bna_rx_enet_stop(struct bna_rx *rx) 1738 { 1739 struct bna_rxp *rxp; 1740 1741 /* Stop IB */ 1742 list_for_each_entry(rxp, &rx->rxp_q, qe) 1743 bna_ib_stop(rx->bna, &rxp->cq.ib); 1744 1745 bna_bfi_rx_enet_stop(rx); 1746 } 1747 1748 static int 1749 bna_rx_res_check(struct bna_rx_mod *rx_mod, struct bna_rx_config *rx_cfg) 1750 { 1751 if ((rx_mod->rx_free_count == 0) || 1752 (rx_mod->rxp_free_count == 0) || 1753 (rx_mod->rxq_free_count == 0)) 1754 return 0; 1755 1756 if (rx_cfg->rxp_type == BNA_RXP_SINGLE) { 1757 if ((rx_mod->rxp_free_count < rx_cfg->num_paths) || 1758 (rx_mod->rxq_free_count < rx_cfg->num_paths)) 1759 return 0; 1760 } else { 1761 if ((rx_mod->rxp_free_count < rx_cfg->num_paths) || 1762 (rx_mod->rxq_free_count < (2 * rx_cfg->num_paths))) 1763 return 0; 1764 } 1765 1766 return 1; 1767 } 1768 1769 static struct bna_rxq * 1770 bna_rxq_get(struct bna_rx_mod *rx_mod) 1771 { 1772 struct bna_rxq *rxq = NULL; 1773 1774 rxq = list_first_entry(&rx_mod->rxq_free_q, struct bna_rxq, qe); 1775 list_del(&rxq->qe); 1776 rx_mod->rxq_free_count--; 1777 1778 return rxq; 1779 } 1780 1781 static void 1782 bna_rxq_put(struct bna_rx_mod *rx_mod, struct bna_rxq *rxq) 1783 { 1784 list_add_tail(&rxq->qe, &rx_mod->rxq_free_q); 1785 rx_mod->rxq_free_count++; 1786 } 1787 1788 static struct bna_rxp * 1789 bna_rxp_get(struct bna_rx_mod *rx_mod) 1790 { 1791 struct bna_rxp *rxp = NULL; 1792 1793 rxp = list_first_entry(&rx_mod->rxp_free_q, struct bna_rxp, qe); 1794 list_del(&rxp->qe); 1795 rx_mod->rxp_free_count--; 1796 1797 return rxp; 1798 } 1799 1800 static void 1801 bna_rxp_put(struct bna_rx_mod *rx_mod, struct bna_rxp *rxp) 1802 { 1803 list_add_tail(&rxp->qe, &rx_mod->rxp_free_q); 1804 rx_mod->rxp_free_count++; 1805 } 1806 1807 static struct bna_rx * 1808 bna_rx_get(struct bna_rx_mod *rx_mod, enum bna_rx_type type) 1809 { 1810 struct bna_rx *rx = NULL; 1811 1812 BUG_ON(list_empty(&rx_mod->rx_free_q)); 1813 if (type == BNA_RX_T_REGULAR) 1814 rx = list_first_entry(&rx_mod->rx_free_q, struct bna_rx, qe); 1815 else 1816 rx = list_last_entry(&rx_mod->rx_free_q, struct bna_rx, qe); 1817 1818 rx_mod->rx_free_count--; 1819 list_move_tail(&rx->qe, &rx_mod->rx_active_q); 1820 rx->type = type; 1821 1822 return rx; 1823 } 1824 1825 static void 1826 bna_rx_put(struct bna_rx_mod *rx_mod, struct bna_rx *rx) 1827 { 1828 struct list_head *qe; 1829 1830 list_for_each_prev(qe, &rx_mod->rx_free_q) 1831 if (((struct bna_rx *)qe)->rid < rx->rid) 1832 break; 1833 1834 list_add(&rx->qe, qe); 1835 rx_mod->rx_free_count++; 1836 } 1837 1838 static void 1839 bna_rxp_add_rxqs(struct bna_rxp *rxp, struct bna_rxq *q0, 1840 struct bna_rxq *q1) 1841 { 1842 switch (rxp->type) { 1843 case BNA_RXP_SINGLE: 1844 rxp->rxq.single.only = q0; 1845 rxp->rxq.single.reserved = NULL; 1846 break; 1847 case BNA_RXP_SLR: 1848 rxp->rxq.slr.large = q0; 1849 rxp->rxq.slr.small = q1; 1850 break; 1851 case BNA_RXP_HDS: 1852 rxp->rxq.hds.data = q0; 1853 rxp->rxq.hds.hdr = q1; 1854 break; 1855 default: 1856 break; 1857 } 1858 } 1859 1860 static void 1861 bna_rxq_qpt_setup(struct bna_rxq *rxq, 1862 struct bna_rxp *rxp, 1863 u32 page_count, 1864 u32 page_size, 1865 struct bna_mem_descr *qpt_mem, 1866 struct bna_mem_descr *swqpt_mem, 1867 struct bna_mem_descr *page_mem) 1868 { 1869 u8 *kva; 1870 u64 dma; 1871 struct bna_dma_addr bna_dma; 1872 int i; 1873 1874 rxq->qpt.hw_qpt_ptr.lsb = qpt_mem->dma.lsb; 1875 rxq->qpt.hw_qpt_ptr.msb = qpt_mem->dma.msb; 1876 rxq->qpt.kv_qpt_ptr = qpt_mem->kva; 1877 rxq->qpt.page_count = page_count; 1878 rxq->qpt.page_size = page_size; 1879 1880 rxq->rcb->sw_qpt = (void **) swqpt_mem->kva; 1881 rxq->rcb->sw_q = page_mem->kva; 1882 1883 kva = page_mem->kva; 1884 BNA_GET_DMA_ADDR(&page_mem->dma, dma); 1885 1886 for (i = 0; i < rxq->qpt.page_count; i++) { 1887 rxq->rcb->sw_qpt[i] = kva; 1888 kva += PAGE_SIZE; 1889 1890 BNA_SET_DMA_ADDR(dma, &bna_dma); 1891 ((struct bna_dma_addr *)rxq->qpt.kv_qpt_ptr)[i].lsb = 1892 bna_dma.lsb; 1893 ((struct bna_dma_addr *)rxq->qpt.kv_qpt_ptr)[i].msb = 1894 bna_dma.msb; 1895 dma += PAGE_SIZE; 1896 } 1897 } 1898 1899 static void 1900 bna_rxp_cqpt_setup(struct bna_rxp *rxp, 1901 u32 page_count, 1902 u32 page_size, 1903 struct bna_mem_descr *qpt_mem, 1904 struct bna_mem_descr *swqpt_mem, 1905 struct bna_mem_descr *page_mem) 1906 { 1907 u8 *kva; 1908 u64 dma; 1909 struct bna_dma_addr bna_dma; 1910 int i; 1911 1912 rxp->cq.qpt.hw_qpt_ptr.lsb = qpt_mem->dma.lsb; 1913 rxp->cq.qpt.hw_qpt_ptr.msb = qpt_mem->dma.msb; 1914 rxp->cq.qpt.kv_qpt_ptr = qpt_mem->kva; 1915 rxp->cq.qpt.page_count = page_count; 1916 rxp->cq.qpt.page_size = page_size; 1917 1918 rxp->cq.ccb->sw_qpt = (void **) swqpt_mem->kva; 1919 rxp->cq.ccb->sw_q = page_mem->kva; 1920 1921 kva = page_mem->kva; 1922 BNA_GET_DMA_ADDR(&page_mem->dma, dma); 1923 1924 for (i = 0; i < rxp->cq.qpt.page_count; i++) { 1925 rxp->cq.ccb->sw_qpt[i] = kva; 1926 kva += PAGE_SIZE; 1927 1928 BNA_SET_DMA_ADDR(dma, &bna_dma); 1929 ((struct bna_dma_addr *)rxp->cq.qpt.kv_qpt_ptr)[i].lsb = 1930 bna_dma.lsb; 1931 ((struct bna_dma_addr *)rxp->cq.qpt.kv_qpt_ptr)[i].msb = 1932 bna_dma.msb; 1933 dma += PAGE_SIZE; 1934 } 1935 } 1936 1937 static void 1938 bna_rx_mod_cb_rx_stopped(void *arg, struct bna_rx *rx) 1939 { 1940 struct bna_rx_mod *rx_mod = (struct bna_rx_mod *)arg; 1941 1942 bfa_wc_down(&rx_mod->rx_stop_wc); 1943 } 1944 1945 static void 1946 bna_rx_mod_cb_rx_stopped_all(void *arg) 1947 { 1948 struct bna_rx_mod *rx_mod = (struct bna_rx_mod *)arg; 1949 1950 if (rx_mod->stop_cbfn) 1951 rx_mod->stop_cbfn(&rx_mod->bna->enet); 1952 rx_mod->stop_cbfn = NULL; 1953 } 1954 1955 static void 1956 bna_rx_start(struct bna_rx *rx) 1957 { 1958 rx->rx_flags |= BNA_RX_F_ENET_STARTED; 1959 if (rx->rx_flags & BNA_RX_F_ENABLED) 1960 bfa_fsm_send_event(rx, RX_E_START); 1961 } 1962 1963 static void 1964 bna_rx_stop(struct bna_rx *rx) 1965 { 1966 rx->rx_flags &= ~BNA_RX_F_ENET_STARTED; 1967 if (rx->fsm == (bfa_fsm_t) bna_rx_sm_stopped) 1968 bna_rx_mod_cb_rx_stopped(&rx->bna->rx_mod, rx); 1969 else { 1970 rx->stop_cbfn = bna_rx_mod_cb_rx_stopped; 1971 rx->stop_cbarg = &rx->bna->rx_mod; 1972 bfa_fsm_send_event(rx, RX_E_STOP); 1973 } 1974 } 1975 1976 static void 1977 bna_rx_fail(struct bna_rx *rx) 1978 { 1979 /* Indicate Enet is not enabled, and failed */ 1980 rx->rx_flags &= ~BNA_RX_F_ENET_STARTED; 1981 bfa_fsm_send_event(rx, RX_E_FAIL); 1982 } 1983 1984 void 1985 bna_rx_mod_start(struct bna_rx_mod *rx_mod, enum bna_rx_type type) 1986 { 1987 struct bna_rx *rx; 1988 1989 rx_mod->flags |= BNA_RX_MOD_F_ENET_STARTED; 1990 if (type == BNA_RX_T_LOOPBACK) 1991 rx_mod->flags |= BNA_RX_MOD_F_ENET_LOOPBACK; 1992 1993 list_for_each_entry(rx, &rx_mod->rx_active_q, qe) 1994 if (rx->type == type) 1995 bna_rx_start(rx); 1996 } 1997 1998 void 1999 bna_rx_mod_stop(struct bna_rx_mod *rx_mod, enum bna_rx_type type) 2000 { 2001 struct bna_rx *rx; 2002 2003 rx_mod->flags &= ~BNA_RX_MOD_F_ENET_STARTED; 2004 rx_mod->flags &= ~BNA_RX_MOD_F_ENET_LOOPBACK; 2005 2006 rx_mod->stop_cbfn = bna_enet_cb_rx_stopped; 2007 2008 bfa_wc_init(&rx_mod->rx_stop_wc, bna_rx_mod_cb_rx_stopped_all, rx_mod); 2009 2010 list_for_each_entry(rx, &rx_mod->rx_active_q, qe) 2011 if (rx->type == type) { 2012 bfa_wc_up(&rx_mod->rx_stop_wc); 2013 bna_rx_stop(rx); 2014 } 2015 2016 bfa_wc_wait(&rx_mod->rx_stop_wc); 2017 } 2018 2019 void 2020 bna_rx_mod_fail(struct bna_rx_mod *rx_mod) 2021 { 2022 struct bna_rx *rx; 2023 2024 rx_mod->flags &= ~BNA_RX_MOD_F_ENET_STARTED; 2025 rx_mod->flags &= ~BNA_RX_MOD_F_ENET_LOOPBACK; 2026 2027 list_for_each_entry(rx, &rx_mod->rx_active_q, qe) 2028 bna_rx_fail(rx); 2029 } 2030 2031 void bna_rx_mod_init(struct bna_rx_mod *rx_mod, struct bna *bna, 2032 struct bna_res_info *res_info) 2033 { 2034 int index; 2035 struct bna_rx *rx_ptr; 2036 struct bna_rxp *rxp_ptr; 2037 struct bna_rxq *rxq_ptr; 2038 2039 rx_mod->bna = bna; 2040 rx_mod->flags = 0; 2041 2042 rx_mod->rx = (struct bna_rx *) 2043 res_info[BNA_MOD_RES_MEM_T_RX_ARRAY].res_u.mem_info.mdl[0].kva; 2044 rx_mod->rxp = (struct bna_rxp *) 2045 res_info[BNA_MOD_RES_MEM_T_RXP_ARRAY].res_u.mem_info.mdl[0].kva; 2046 rx_mod->rxq = (struct bna_rxq *) 2047 res_info[BNA_MOD_RES_MEM_T_RXQ_ARRAY].res_u.mem_info.mdl[0].kva; 2048 2049 /* Initialize the queues */ 2050 INIT_LIST_HEAD(&rx_mod->rx_free_q); 2051 rx_mod->rx_free_count = 0; 2052 INIT_LIST_HEAD(&rx_mod->rxq_free_q); 2053 rx_mod->rxq_free_count = 0; 2054 INIT_LIST_HEAD(&rx_mod->rxp_free_q); 2055 rx_mod->rxp_free_count = 0; 2056 INIT_LIST_HEAD(&rx_mod->rx_active_q); 2057 2058 /* Build RX queues */ 2059 for (index = 0; index < bna->ioceth.attr.num_rxp; index++) { 2060 rx_ptr = &rx_mod->rx[index]; 2061 2062 INIT_LIST_HEAD(&rx_ptr->rxp_q); 2063 rx_ptr->bna = NULL; 2064 rx_ptr->rid = index; 2065 rx_ptr->stop_cbfn = NULL; 2066 rx_ptr->stop_cbarg = NULL; 2067 2068 list_add_tail(&rx_ptr->qe, &rx_mod->rx_free_q); 2069 rx_mod->rx_free_count++; 2070 } 2071 2072 /* build RX-path queue */ 2073 for (index = 0; index < bna->ioceth.attr.num_rxp; index++) { 2074 rxp_ptr = &rx_mod->rxp[index]; 2075 list_add_tail(&rxp_ptr->qe, &rx_mod->rxp_free_q); 2076 rx_mod->rxp_free_count++; 2077 } 2078 2079 /* build RXQ queue */ 2080 for (index = 0; index < (bna->ioceth.attr.num_rxp * 2); index++) { 2081 rxq_ptr = &rx_mod->rxq[index]; 2082 list_add_tail(&rxq_ptr->qe, &rx_mod->rxq_free_q); 2083 rx_mod->rxq_free_count++; 2084 } 2085 } 2086 2087 void 2088 bna_rx_mod_uninit(struct bna_rx_mod *rx_mod) 2089 { 2090 rx_mod->bna = NULL; 2091 } 2092 2093 void 2094 bna_bfi_rx_enet_start_rsp(struct bna_rx *rx, struct bfi_msgq_mhdr *msghdr) 2095 { 2096 struct bfi_enet_rx_cfg_rsp *cfg_rsp = &rx->bfi_enet_cmd.cfg_rsp; 2097 struct bna_rxp *rxp = NULL; 2098 struct bna_rxq *q0 = NULL, *q1 = NULL; 2099 int i; 2100 2101 bfa_msgq_rsp_copy(&rx->bna->msgq, (u8 *)cfg_rsp, 2102 sizeof(struct bfi_enet_rx_cfg_rsp)); 2103 2104 rx->hw_id = cfg_rsp->hw_id; 2105 2106 for (i = 0, rxp = list_first_entry(&rx->rxp_q, struct bna_rxp, qe); 2107 i < rx->num_paths; i++, rxp = list_next_entry(rxp, qe)) { 2108 GET_RXQS(rxp, q0, q1); 2109 2110 /* Setup doorbells */ 2111 rxp->cq.ccb->i_dbell->doorbell_addr = 2112 rx->bna->pcidev.pci_bar_kva 2113 + ntohl(cfg_rsp->q_handles[i].i_dbell); 2114 rxp->hw_id = cfg_rsp->q_handles[i].hw_cqid; 2115 q0->rcb->q_dbell = 2116 rx->bna->pcidev.pci_bar_kva 2117 + ntohl(cfg_rsp->q_handles[i].ql_dbell); 2118 q0->hw_id = cfg_rsp->q_handles[i].hw_lqid; 2119 if (q1) { 2120 q1->rcb->q_dbell = 2121 rx->bna->pcidev.pci_bar_kva 2122 + ntohl(cfg_rsp->q_handles[i].qs_dbell); 2123 q1->hw_id = cfg_rsp->q_handles[i].hw_sqid; 2124 } 2125 2126 /* Initialize producer/consumer indexes */ 2127 (*rxp->cq.ccb->hw_producer_index) = 0; 2128 rxp->cq.ccb->producer_index = 0; 2129 q0->rcb->producer_index = q0->rcb->consumer_index = 0; 2130 if (q1) 2131 q1->rcb->producer_index = q1->rcb->consumer_index = 0; 2132 } 2133 2134 bfa_fsm_send_event(rx, RX_E_STARTED); 2135 } 2136 2137 void 2138 bna_bfi_rx_enet_stop_rsp(struct bna_rx *rx, struct bfi_msgq_mhdr *msghdr) 2139 { 2140 bfa_fsm_send_event(rx, RX_E_STOPPED); 2141 } 2142 2143 void 2144 bna_rx_res_req(struct bna_rx_config *q_cfg, struct bna_res_info *res_info) 2145 { 2146 u32 cq_size, hq_size, dq_size; 2147 u32 cpage_count, hpage_count, dpage_count; 2148 struct bna_mem_info *mem_info; 2149 u32 cq_depth; 2150 u32 hq_depth; 2151 u32 dq_depth; 2152 2153 dq_depth = q_cfg->q0_depth; 2154 hq_depth = ((q_cfg->rxp_type == BNA_RXP_SINGLE) ? 0 : q_cfg->q1_depth); 2155 cq_depth = roundup_pow_of_two(dq_depth + hq_depth); 2156 2157 cq_size = cq_depth * BFI_CQ_WI_SIZE; 2158 cq_size = ALIGN(cq_size, PAGE_SIZE); 2159 cpage_count = SIZE_TO_PAGES(cq_size); 2160 2161 dq_depth = roundup_pow_of_two(dq_depth); 2162 dq_size = dq_depth * BFI_RXQ_WI_SIZE; 2163 dq_size = ALIGN(dq_size, PAGE_SIZE); 2164 dpage_count = SIZE_TO_PAGES(dq_size); 2165 2166 if (BNA_RXP_SINGLE != q_cfg->rxp_type) { 2167 hq_depth = roundup_pow_of_two(hq_depth); 2168 hq_size = hq_depth * BFI_RXQ_WI_SIZE; 2169 hq_size = ALIGN(hq_size, PAGE_SIZE); 2170 hpage_count = SIZE_TO_PAGES(hq_size); 2171 } else 2172 hpage_count = 0; 2173 2174 res_info[BNA_RX_RES_MEM_T_CCB].res_type = BNA_RES_T_MEM; 2175 mem_info = &res_info[BNA_RX_RES_MEM_T_CCB].res_u.mem_info; 2176 mem_info->mem_type = BNA_MEM_T_KVA; 2177 mem_info->len = sizeof(struct bna_ccb); 2178 mem_info->num = q_cfg->num_paths; 2179 2180 res_info[BNA_RX_RES_MEM_T_RCB].res_type = BNA_RES_T_MEM; 2181 mem_info = &res_info[BNA_RX_RES_MEM_T_RCB].res_u.mem_info; 2182 mem_info->mem_type = BNA_MEM_T_KVA; 2183 mem_info->len = sizeof(struct bna_rcb); 2184 mem_info->num = BNA_GET_RXQS(q_cfg); 2185 2186 res_info[BNA_RX_RES_MEM_T_CQPT].res_type = BNA_RES_T_MEM; 2187 mem_info = &res_info[BNA_RX_RES_MEM_T_CQPT].res_u.mem_info; 2188 mem_info->mem_type = BNA_MEM_T_DMA; 2189 mem_info->len = cpage_count * sizeof(struct bna_dma_addr); 2190 mem_info->num = q_cfg->num_paths; 2191 2192 res_info[BNA_RX_RES_MEM_T_CSWQPT].res_type = BNA_RES_T_MEM; 2193 mem_info = &res_info[BNA_RX_RES_MEM_T_CSWQPT].res_u.mem_info; 2194 mem_info->mem_type = BNA_MEM_T_KVA; 2195 mem_info->len = cpage_count * sizeof(void *); 2196 mem_info->num = q_cfg->num_paths; 2197 2198 res_info[BNA_RX_RES_MEM_T_CQPT_PAGE].res_type = BNA_RES_T_MEM; 2199 mem_info = &res_info[BNA_RX_RES_MEM_T_CQPT_PAGE].res_u.mem_info; 2200 mem_info->mem_type = BNA_MEM_T_DMA; 2201 mem_info->len = PAGE_SIZE * cpage_count; 2202 mem_info->num = q_cfg->num_paths; 2203 2204 res_info[BNA_RX_RES_MEM_T_DQPT].res_type = BNA_RES_T_MEM; 2205 mem_info = &res_info[BNA_RX_RES_MEM_T_DQPT].res_u.mem_info; 2206 mem_info->mem_type = BNA_MEM_T_DMA; 2207 mem_info->len = dpage_count * sizeof(struct bna_dma_addr); 2208 mem_info->num = q_cfg->num_paths; 2209 2210 res_info[BNA_RX_RES_MEM_T_DSWQPT].res_type = BNA_RES_T_MEM; 2211 mem_info = &res_info[BNA_RX_RES_MEM_T_DSWQPT].res_u.mem_info; 2212 mem_info->mem_type = BNA_MEM_T_KVA; 2213 mem_info->len = dpage_count * sizeof(void *); 2214 mem_info->num = q_cfg->num_paths; 2215 2216 res_info[BNA_RX_RES_MEM_T_DPAGE].res_type = BNA_RES_T_MEM; 2217 mem_info = &res_info[BNA_RX_RES_MEM_T_DPAGE].res_u.mem_info; 2218 mem_info->mem_type = BNA_MEM_T_DMA; 2219 mem_info->len = PAGE_SIZE * dpage_count; 2220 mem_info->num = q_cfg->num_paths; 2221 2222 res_info[BNA_RX_RES_MEM_T_HQPT].res_type = BNA_RES_T_MEM; 2223 mem_info = &res_info[BNA_RX_RES_MEM_T_HQPT].res_u.mem_info; 2224 mem_info->mem_type = BNA_MEM_T_DMA; 2225 mem_info->len = hpage_count * sizeof(struct bna_dma_addr); 2226 mem_info->num = (hpage_count ? q_cfg->num_paths : 0); 2227 2228 res_info[BNA_RX_RES_MEM_T_HSWQPT].res_type = BNA_RES_T_MEM; 2229 mem_info = &res_info[BNA_RX_RES_MEM_T_HSWQPT].res_u.mem_info; 2230 mem_info->mem_type = BNA_MEM_T_KVA; 2231 mem_info->len = hpage_count * sizeof(void *); 2232 mem_info->num = (hpage_count ? q_cfg->num_paths : 0); 2233 2234 res_info[BNA_RX_RES_MEM_T_HPAGE].res_type = BNA_RES_T_MEM; 2235 mem_info = &res_info[BNA_RX_RES_MEM_T_HPAGE].res_u.mem_info; 2236 mem_info->mem_type = BNA_MEM_T_DMA; 2237 mem_info->len = PAGE_SIZE * hpage_count; 2238 mem_info->num = (hpage_count ? q_cfg->num_paths : 0); 2239 2240 res_info[BNA_RX_RES_MEM_T_IBIDX].res_type = BNA_RES_T_MEM; 2241 mem_info = &res_info[BNA_RX_RES_MEM_T_IBIDX].res_u.mem_info; 2242 mem_info->mem_type = BNA_MEM_T_DMA; 2243 mem_info->len = BFI_IBIDX_SIZE; 2244 mem_info->num = q_cfg->num_paths; 2245 2246 res_info[BNA_RX_RES_MEM_T_RIT].res_type = BNA_RES_T_MEM; 2247 mem_info = &res_info[BNA_RX_RES_MEM_T_RIT].res_u.mem_info; 2248 mem_info->mem_type = BNA_MEM_T_KVA; 2249 mem_info->len = BFI_ENET_RSS_RIT_MAX; 2250 mem_info->num = 1; 2251 2252 res_info[BNA_RX_RES_T_INTR].res_type = BNA_RES_T_INTR; 2253 res_info[BNA_RX_RES_T_INTR].res_u.intr_info.intr_type = BNA_INTR_T_MSIX; 2254 res_info[BNA_RX_RES_T_INTR].res_u.intr_info.num = q_cfg->num_paths; 2255 } 2256 2257 struct bna_rx * 2258 bna_rx_create(struct bna *bna, struct bnad *bnad, 2259 struct bna_rx_config *rx_cfg, 2260 const struct bna_rx_event_cbfn *rx_cbfn, 2261 struct bna_res_info *res_info, 2262 void *priv) 2263 { 2264 struct bna_rx_mod *rx_mod = &bna->rx_mod; 2265 struct bna_rx *rx; 2266 struct bna_rxp *rxp; 2267 struct bna_rxq *q0; 2268 struct bna_rxq *q1; 2269 struct bna_intr_info *intr_info; 2270 struct bna_mem_descr *hqunmap_mem; 2271 struct bna_mem_descr *dqunmap_mem; 2272 struct bna_mem_descr *ccb_mem; 2273 struct bna_mem_descr *rcb_mem; 2274 struct bna_mem_descr *cqpt_mem; 2275 struct bna_mem_descr *cswqpt_mem; 2276 struct bna_mem_descr *cpage_mem; 2277 struct bna_mem_descr *hqpt_mem; 2278 struct bna_mem_descr *dqpt_mem; 2279 struct bna_mem_descr *hsqpt_mem; 2280 struct bna_mem_descr *dsqpt_mem; 2281 struct bna_mem_descr *hpage_mem; 2282 struct bna_mem_descr *dpage_mem; 2283 u32 dpage_count, hpage_count; 2284 u32 hq_idx, dq_idx, rcb_idx; 2285 u32 cq_depth, i; 2286 u32 page_count; 2287 2288 if (!bna_rx_res_check(rx_mod, rx_cfg)) 2289 return NULL; 2290 2291 intr_info = &res_info[BNA_RX_RES_T_INTR].res_u.intr_info; 2292 ccb_mem = &res_info[BNA_RX_RES_MEM_T_CCB].res_u.mem_info.mdl[0]; 2293 rcb_mem = &res_info[BNA_RX_RES_MEM_T_RCB].res_u.mem_info.mdl[0]; 2294 dqunmap_mem = &res_info[BNA_RX_RES_MEM_T_UNMAPDQ].res_u.mem_info.mdl[0]; 2295 hqunmap_mem = &res_info[BNA_RX_RES_MEM_T_UNMAPHQ].res_u.mem_info.mdl[0]; 2296 cqpt_mem = &res_info[BNA_RX_RES_MEM_T_CQPT].res_u.mem_info.mdl[0]; 2297 cswqpt_mem = &res_info[BNA_RX_RES_MEM_T_CSWQPT].res_u.mem_info.mdl[0]; 2298 cpage_mem = &res_info[BNA_RX_RES_MEM_T_CQPT_PAGE].res_u.mem_info.mdl[0]; 2299 hqpt_mem = &res_info[BNA_RX_RES_MEM_T_HQPT].res_u.mem_info.mdl[0]; 2300 dqpt_mem = &res_info[BNA_RX_RES_MEM_T_DQPT].res_u.mem_info.mdl[0]; 2301 hsqpt_mem = &res_info[BNA_RX_RES_MEM_T_HSWQPT].res_u.mem_info.mdl[0]; 2302 dsqpt_mem = &res_info[BNA_RX_RES_MEM_T_DSWQPT].res_u.mem_info.mdl[0]; 2303 hpage_mem = &res_info[BNA_RX_RES_MEM_T_HPAGE].res_u.mem_info.mdl[0]; 2304 dpage_mem = &res_info[BNA_RX_RES_MEM_T_DPAGE].res_u.mem_info.mdl[0]; 2305 2306 page_count = res_info[BNA_RX_RES_MEM_T_CQPT_PAGE].res_u.mem_info.len / 2307 PAGE_SIZE; 2308 2309 dpage_count = res_info[BNA_RX_RES_MEM_T_DPAGE].res_u.mem_info.len / 2310 PAGE_SIZE; 2311 2312 hpage_count = res_info[BNA_RX_RES_MEM_T_HPAGE].res_u.mem_info.len / 2313 PAGE_SIZE; 2314 2315 rx = bna_rx_get(rx_mod, rx_cfg->rx_type); 2316 rx->bna = bna; 2317 rx->rx_flags = 0; 2318 INIT_LIST_HEAD(&rx->rxp_q); 2319 rx->stop_cbfn = NULL; 2320 rx->stop_cbarg = NULL; 2321 rx->priv = priv; 2322 2323 rx->rcb_setup_cbfn = rx_cbfn->rcb_setup_cbfn; 2324 rx->rcb_destroy_cbfn = rx_cbfn->rcb_destroy_cbfn; 2325 rx->ccb_setup_cbfn = rx_cbfn->ccb_setup_cbfn; 2326 rx->ccb_destroy_cbfn = rx_cbfn->ccb_destroy_cbfn; 2327 rx->rx_stall_cbfn = rx_cbfn->rx_stall_cbfn; 2328 /* Following callbacks are mandatory */ 2329 rx->rx_cleanup_cbfn = rx_cbfn->rx_cleanup_cbfn; 2330 rx->rx_post_cbfn = rx_cbfn->rx_post_cbfn; 2331 2332 if (rx->bna->rx_mod.flags & BNA_RX_MOD_F_ENET_STARTED) { 2333 switch (rx->type) { 2334 case BNA_RX_T_REGULAR: 2335 if (!(rx->bna->rx_mod.flags & 2336 BNA_RX_MOD_F_ENET_LOOPBACK)) 2337 rx->rx_flags |= BNA_RX_F_ENET_STARTED; 2338 break; 2339 case BNA_RX_T_LOOPBACK: 2340 if (rx->bna->rx_mod.flags & BNA_RX_MOD_F_ENET_LOOPBACK) 2341 rx->rx_flags |= BNA_RX_F_ENET_STARTED; 2342 break; 2343 } 2344 } 2345 2346 rx->num_paths = rx_cfg->num_paths; 2347 for (i = 0, hq_idx = 0, dq_idx = 0, rcb_idx = 0; 2348 i < rx->num_paths; i++) { 2349 rxp = bna_rxp_get(rx_mod); 2350 list_add_tail(&rxp->qe, &rx->rxp_q); 2351 rxp->type = rx_cfg->rxp_type; 2352 rxp->rx = rx; 2353 rxp->cq.rx = rx; 2354 2355 q0 = bna_rxq_get(rx_mod); 2356 if (BNA_RXP_SINGLE == rx_cfg->rxp_type) 2357 q1 = NULL; 2358 else 2359 q1 = bna_rxq_get(rx_mod); 2360 2361 if (1 == intr_info->num) 2362 rxp->vector = intr_info->idl[0].vector; 2363 else 2364 rxp->vector = intr_info->idl[i].vector; 2365 2366 /* Setup IB */ 2367 2368 rxp->cq.ib.ib_seg_host_addr.lsb = 2369 res_info[BNA_RX_RES_MEM_T_IBIDX].res_u.mem_info.mdl[i].dma.lsb; 2370 rxp->cq.ib.ib_seg_host_addr.msb = 2371 res_info[BNA_RX_RES_MEM_T_IBIDX].res_u.mem_info.mdl[i].dma.msb; 2372 rxp->cq.ib.ib_seg_host_addr_kva = 2373 res_info[BNA_RX_RES_MEM_T_IBIDX].res_u.mem_info.mdl[i].kva; 2374 rxp->cq.ib.intr_type = intr_info->intr_type; 2375 if (intr_info->intr_type == BNA_INTR_T_MSIX) 2376 rxp->cq.ib.intr_vector = rxp->vector; 2377 else 2378 rxp->cq.ib.intr_vector = BIT(rxp->vector); 2379 rxp->cq.ib.coalescing_timeo = rx_cfg->coalescing_timeo; 2380 rxp->cq.ib.interpkt_count = BFI_RX_INTERPKT_COUNT; 2381 rxp->cq.ib.interpkt_timeo = BFI_RX_INTERPKT_TIMEO; 2382 2383 bna_rxp_add_rxqs(rxp, q0, q1); 2384 2385 /* Setup large Q */ 2386 2387 q0->rx = rx; 2388 q0->rxp = rxp; 2389 2390 q0->rcb = (struct bna_rcb *) rcb_mem[rcb_idx].kva; 2391 q0->rcb->unmap_q = (void *)dqunmap_mem[dq_idx].kva; 2392 rcb_idx++; dq_idx++; 2393 q0->rcb->q_depth = rx_cfg->q0_depth; 2394 q0->q_depth = rx_cfg->q0_depth; 2395 q0->multi_buffer = rx_cfg->q0_multi_buf; 2396 q0->buffer_size = rx_cfg->q0_buf_size; 2397 q0->num_vecs = rx_cfg->q0_num_vecs; 2398 q0->rcb->rxq = q0; 2399 q0->rcb->bnad = bna->bnad; 2400 q0->rcb->id = 0; 2401 q0->rx_packets = q0->rx_bytes = 0; 2402 q0->rx_packets_with_error = q0->rxbuf_alloc_failed = 0; 2403 q0->rxbuf_map_failed = 0; 2404 2405 bna_rxq_qpt_setup(q0, rxp, dpage_count, PAGE_SIZE, 2406 &dqpt_mem[i], &dsqpt_mem[i], &dpage_mem[i]); 2407 2408 if (rx->rcb_setup_cbfn) 2409 rx->rcb_setup_cbfn(bnad, q0->rcb); 2410 2411 /* Setup small Q */ 2412 2413 if (q1) { 2414 q1->rx = rx; 2415 q1->rxp = rxp; 2416 2417 q1->rcb = (struct bna_rcb *) rcb_mem[rcb_idx].kva; 2418 q1->rcb->unmap_q = (void *)hqunmap_mem[hq_idx].kva; 2419 rcb_idx++; hq_idx++; 2420 q1->rcb->q_depth = rx_cfg->q1_depth; 2421 q1->q_depth = rx_cfg->q1_depth; 2422 q1->multi_buffer = BNA_STATUS_T_DISABLED; 2423 q1->num_vecs = 1; 2424 q1->rcb->rxq = q1; 2425 q1->rcb->bnad = bna->bnad; 2426 q1->rcb->id = 1; 2427 q1->buffer_size = (rx_cfg->rxp_type == BNA_RXP_HDS) ? 2428 rx_cfg->hds_config.forced_offset 2429 : rx_cfg->q1_buf_size; 2430 q1->rx_packets = q1->rx_bytes = 0; 2431 q1->rx_packets_with_error = q1->rxbuf_alloc_failed = 0; 2432 q1->rxbuf_map_failed = 0; 2433 2434 bna_rxq_qpt_setup(q1, rxp, hpage_count, PAGE_SIZE, 2435 &hqpt_mem[i], &hsqpt_mem[i], 2436 &hpage_mem[i]); 2437 2438 if (rx->rcb_setup_cbfn) 2439 rx->rcb_setup_cbfn(bnad, q1->rcb); 2440 } 2441 2442 /* Setup CQ */ 2443 2444 rxp->cq.ccb = (struct bna_ccb *) ccb_mem[i].kva; 2445 cq_depth = rx_cfg->q0_depth + 2446 ((rx_cfg->rxp_type == BNA_RXP_SINGLE) ? 2447 0 : rx_cfg->q1_depth); 2448 /* if multi-buffer is enabled sum of q0_depth 2449 * and q1_depth need not be a power of 2 2450 */ 2451 cq_depth = roundup_pow_of_two(cq_depth); 2452 rxp->cq.ccb->q_depth = cq_depth; 2453 rxp->cq.ccb->cq = &rxp->cq; 2454 rxp->cq.ccb->rcb[0] = q0->rcb; 2455 q0->rcb->ccb = rxp->cq.ccb; 2456 if (q1) { 2457 rxp->cq.ccb->rcb[1] = q1->rcb; 2458 q1->rcb->ccb = rxp->cq.ccb; 2459 } 2460 rxp->cq.ccb->hw_producer_index = 2461 (u32 *)rxp->cq.ib.ib_seg_host_addr_kva; 2462 rxp->cq.ccb->i_dbell = &rxp->cq.ib.door_bell; 2463 rxp->cq.ccb->intr_type = rxp->cq.ib.intr_type; 2464 rxp->cq.ccb->intr_vector = rxp->cq.ib.intr_vector; 2465 rxp->cq.ccb->rx_coalescing_timeo = 2466 rxp->cq.ib.coalescing_timeo; 2467 rxp->cq.ccb->pkt_rate.small_pkt_cnt = 0; 2468 rxp->cq.ccb->pkt_rate.large_pkt_cnt = 0; 2469 rxp->cq.ccb->bnad = bna->bnad; 2470 rxp->cq.ccb->id = i; 2471 2472 bna_rxp_cqpt_setup(rxp, page_count, PAGE_SIZE, 2473 &cqpt_mem[i], &cswqpt_mem[i], &cpage_mem[i]); 2474 2475 if (rx->ccb_setup_cbfn) 2476 rx->ccb_setup_cbfn(bnad, rxp->cq.ccb); 2477 } 2478 2479 rx->hds_cfg = rx_cfg->hds_config; 2480 2481 bna_rxf_init(&rx->rxf, rx, rx_cfg, res_info); 2482 2483 bfa_fsm_set_state(rx, bna_rx_sm_stopped); 2484 2485 rx_mod->rid_mask |= BIT(rx->rid); 2486 2487 return rx; 2488 } 2489 2490 void 2491 bna_rx_destroy(struct bna_rx *rx) 2492 { 2493 struct bna_rx_mod *rx_mod = &rx->bna->rx_mod; 2494 struct bna_rxq *q0 = NULL; 2495 struct bna_rxq *q1 = NULL; 2496 struct bna_rxp *rxp; 2497 struct list_head *qe; 2498 2499 bna_rxf_uninit(&rx->rxf); 2500 2501 while (!list_empty(&rx->rxp_q)) { 2502 rxp = list_first_entry(&rx->rxp_q, struct bna_rxp, qe); 2503 list_del(&rxp->qe); 2504 GET_RXQS(rxp, q0, q1); 2505 if (rx->rcb_destroy_cbfn) 2506 rx->rcb_destroy_cbfn(rx->bna->bnad, q0->rcb); 2507 q0->rcb = NULL; 2508 q0->rxp = NULL; 2509 q0->rx = NULL; 2510 bna_rxq_put(rx_mod, q0); 2511 2512 if (q1) { 2513 if (rx->rcb_destroy_cbfn) 2514 rx->rcb_destroy_cbfn(rx->bna->bnad, q1->rcb); 2515 q1->rcb = NULL; 2516 q1->rxp = NULL; 2517 q1->rx = NULL; 2518 bna_rxq_put(rx_mod, q1); 2519 } 2520 rxp->rxq.slr.large = NULL; 2521 rxp->rxq.slr.small = NULL; 2522 2523 if (rx->ccb_destroy_cbfn) 2524 rx->ccb_destroy_cbfn(rx->bna->bnad, rxp->cq.ccb); 2525 rxp->cq.ccb = NULL; 2526 rxp->rx = NULL; 2527 bna_rxp_put(rx_mod, rxp); 2528 } 2529 2530 list_for_each(qe, &rx_mod->rx_active_q) 2531 if (qe == &rx->qe) { 2532 list_del(&rx->qe); 2533 break; 2534 } 2535 2536 rx_mod->rid_mask &= ~BIT(rx->rid); 2537 2538 rx->bna = NULL; 2539 rx->priv = NULL; 2540 bna_rx_put(rx_mod, rx); 2541 } 2542 2543 void 2544 bna_rx_enable(struct bna_rx *rx) 2545 { 2546 if (rx->fsm != (bfa_sm_t)bna_rx_sm_stopped) 2547 return; 2548 2549 rx->rx_flags |= BNA_RX_F_ENABLED; 2550 if (rx->rx_flags & BNA_RX_F_ENET_STARTED) 2551 bfa_fsm_send_event(rx, RX_E_START); 2552 } 2553 2554 void 2555 bna_rx_disable(struct bna_rx *rx, enum bna_cleanup_type type, 2556 void (*cbfn)(void *, struct bna_rx *)) 2557 { 2558 if (type == BNA_SOFT_CLEANUP) { 2559 /* h/w should not be accessed. Treat we're stopped */ 2560 (*cbfn)(rx->bna->bnad, rx); 2561 } else { 2562 rx->stop_cbfn = cbfn; 2563 rx->stop_cbarg = rx->bna->bnad; 2564 2565 rx->rx_flags &= ~BNA_RX_F_ENABLED; 2566 2567 bfa_fsm_send_event(rx, RX_E_STOP); 2568 } 2569 } 2570 2571 void 2572 bna_rx_cleanup_complete(struct bna_rx *rx) 2573 { 2574 bfa_fsm_send_event(rx, RX_E_CLEANUP_DONE); 2575 } 2576 2577 void 2578 bna_rx_vlan_strip_enable(struct bna_rx *rx) 2579 { 2580 struct bna_rxf *rxf = &rx->rxf; 2581 2582 if (rxf->vlan_strip_status == BNA_STATUS_T_DISABLED) { 2583 rxf->vlan_strip_status = BNA_STATUS_T_ENABLED; 2584 rxf->vlan_strip_pending = true; 2585 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 2586 } 2587 } 2588 2589 void 2590 bna_rx_vlan_strip_disable(struct bna_rx *rx) 2591 { 2592 struct bna_rxf *rxf = &rx->rxf; 2593 2594 if (rxf->vlan_strip_status != BNA_STATUS_T_DISABLED) { 2595 rxf->vlan_strip_status = BNA_STATUS_T_DISABLED; 2596 rxf->vlan_strip_pending = true; 2597 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 2598 } 2599 } 2600 2601 enum bna_cb_status 2602 bna_rx_mode_set(struct bna_rx *rx, enum bna_rxmode new_mode, 2603 enum bna_rxmode bitmask) 2604 { 2605 struct bna_rxf *rxf = &rx->rxf; 2606 int need_hw_config = 0; 2607 2608 /* Error checks */ 2609 2610 if (is_promisc_enable(new_mode, bitmask)) { 2611 /* If promisc mode is already enabled elsewhere in the system */ 2612 if ((rx->bna->promisc_rid != BFI_INVALID_RID) && 2613 (rx->bna->promisc_rid != rxf->rx->rid)) 2614 goto err_return; 2615 2616 /* If default mode is already enabled in the system */ 2617 if (rx->bna->default_mode_rid != BFI_INVALID_RID) 2618 goto err_return; 2619 2620 /* Trying to enable promiscuous and default mode together */ 2621 if (is_default_enable(new_mode, bitmask)) 2622 goto err_return; 2623 } 2624 2625 if (is_default_enable(new_mode, bitmask)) { 2626 /* If default mode is already enabled elsewhere in the system */ 2627 if ((rx->bna->default_mode_rid != BFI_INVALID_RID) && 2628 (rx->bna->default_mode_rid != rxf->rx->rid)) { 2629 goto err_return; 2630 } 2631 2632 /* If promiscuous mode is already enabled in the system */ 2633 if (rx->bna->promisc_rid != BFI_INVALID_RID) 2634 goto err_return; 2635 } 2636 2637 /* Process the commands */ 2638 2639 if (is_promisc_enable(new_mode, bitmask)) { 2640 if (bna_rxf_promisc_enable(rxf)) 2641 need_hw_config = 1; 2642 } else if (is_promisc_disable(new_mode, bitmask)) { 2643 if (bna_rxf_promisc_disable(rxf)) 2644 need_hw_config = 1; 2645 } 2646 2647 if (is_allmulti_enable(new_mode, bitmask)) { 2648 if (bna_rxf_allmulti_enable(rxf)) 2649 need_hw_config = 1; 2650 } else if (is_allmulti_disable(new_mode, bitmask)) { 2651 if (bna_rxf_allmulti_disable(rxf)) 2652 need_hw_config = 1; 2653 } 2654 2655 /* Trigger h/w if needed */ 2656 2657 if (need_hw_config) { 2658 rxf->cam_fltr_cbfn = NULL; 2659 rxf->cam_fltr_cbarg = rx->bna->bnad; 2660 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 2661 } 2662 2663 return BNA_CB_SUCCESS; 2664 2665 err_return: 2666 return BNA_CB_FAIL; 2667 } 2668 2669 void 2670 bna_rx_vlanfilter_enable(struct bna_rx *rx) 2671 { 2672 struct bna_rxf *rxf = &rx->rxf; 2673 2674 if (rxf->vlan_filter_status == BNA_STATUS_T_DISABLED) { 2675 rxf->vlan_filter_status = BNA_STATUS_T_ENABLED; 2676 rxf->vlan_pending_bitmask = (u8)BFI_VLAN_BMASK_ALL; 2677 bfa_fsm_send_event(rxf, RXF_E_CONFIG); 2678 } 2679 } 2680 2681 void 2682 bna_rx_coalescing_timeo_set(struct bna_rx *rx, int coalescing_timeo) 2683 { 2684 struct bna_rxp *rxp; 2685 2686 list_for_each_entry(rxp, &rx->rxp_q, qe) { 2687 rxp->cq.ccb->rx_coalescing_timeo = coalescing_timeo; 2688 bna_ib_coalescing_timeo_set(&rxp->cq.ib, coalescing_timeo); 2689 } 2690 } 2691 2692 void 2693 bna_rx_dim_reconfig(struct bna *bna, const u32 vector[][BNA_BIAS_T_MAX]) 2694 { 2695 int i, j; 2696 2697 for (i = 0; i < BNA_LOAD_T_MAX; i++) 2698 for (j = 0; j < BNA_BIAS_T_MAX; j++) 2699 bna->rx_mod.dim_vector[i][j] = vector[i][j]; 2700 } 2701 2702 void 2703 bna_rx_dim_update(struct bna_ccb *ccb) 2704 { 2705 struct bna *bna = ccb->cq->rx->bna; 2706 u32 load, bias; 2707 u32 pkt_rt, small_rt, large_rt; 2708 u8 coalescing_timeo; 2709 2710 if ((ccb->pkt_rate.small_pkt_cnt == 0) && 2711 (ccb->pkt_rate.large_pkt_cnt == 0)) 2712 return; 2713 2714 /* Arrive at preconfigured coalescing timeo value based on pkt rate */ 2715 2716 small_rt = ccb->pkt_rate.small_pkt_cnt; 2717 large_rt = ccb->pkt_rate.large_pkt_cnt; 2718 2719 pkt_rt = small_rt + large_rt; 2720 2721 if (pkt_rt < BNA_PKT_RATE_10K) 2722 load = BNA_LOAD_T_LOW_4; 2723 else if (pkt_rt < BNA_PKT_RATE_20K) 2724 load = BNA_LOAD_T_LOW_3; 2725 else if (pkt_rt < BNA_PKT_RATE_30K) 2726 load = BNA_LOAD_T_LOW_2; 2727 else if (pkt_rt < BNA_PKT_RATE_40K) 2728 load = BNA_LOAD_T_LOW_1; 2729 else if (pkt_rt < BNA_PKT_RATE_50K) 2730 load = BNA_LOAD_T_HIGH_1; 2731 else if (pkt_rt < BNA_PKT_RATE_60K) 2732 load = BNA_LOAD_T_HIGH_2; 2733 else if (pkt_rt < BNA_PKT_RATE_80K) 2734 load = BNA_LOAD_T_HIGH_3; 2735 else 2736 load = BNA_LOAD_T_HIGH_4; 2737 2738 if (small_rt > (large_rt << 1)) 2739 bias = 0; 2740 else 2741 bias = 1; 2742 2743 ccb->pkt_rate.small_pkt_cnt = 0; 2744 ccb->pkt_rate.large_pkt_cnt = 0; 2745 2746 coalescing_timeo = bna->rx_mod.dim_vector[load][bias]; 2747 ccb->rx_coalescing_timeo = coalescing_timeo; 2748 2749 /* Set it to IB */ 2750 bna_ib_coalescing_timeo_set(&ccb->cq->ib, coalescing_timeo); 2751 } 2752 2753 const u32 bna_napi_dim_vector[BNA_LOAD_T_MAX][BNA_BIAS_T_MAX] = { 2754 {12, 12}, 2755 {6, 10}, 2756 {5, 10}, 2757 {4, 8}, 2758 {3, 6}, 2759 {3, 6}, 2760 {2, 4}, 2761 {1, 2}, 2762 }; 2763 2764 /* TX */ 2765 2766 #define call_tx_stop_cbfn(tx) \ 2767 do { \ 2768 if ((tx)->stop_cbfn) { \ 2769 void (*cbfn)(void *, struct bna_tx *); \ 2770 void *cbarg; \ 2771 cbfn = (tx)->stop_cbfn; \ 2772 cbarg = (tx)->stop_cbarg; \ 2773 (tx)->stop_cbfn = NULL; \ 2774 (tx)->stop_cbarg = NULL; \ 2775 cbfn(cbarg, (tx)); \ 2776 } \ 2777 } while (0) 2778 2779 static void bna_tx_mod_cb_tx_stopped(void *tx_mod, struct bna_tx *tx); 2780 static void bna_bfi_tx_enet_start(struct bna_tx *tx); 2781 static void bna_tx_enet_stop(struct bna_tx *tx); 2782 2783 enum bna_tx_event { 2784 TX_E_START = 1, 2785 TX_E_STOP = 2, 2786 TX_E_FAIL = 3, 2787 TX_E_STARTED = 4, 2788 TX_E_STOPPED = 5, 2789 TX_E_CLEANUP_DONE = 7, 2790 TX_E_BW_UPDATE = 8, 2791 }; 2792 2793 bfa_fsm_state_decl(bna_tx, stopped, struct bna_tx, enum bna_tx_event); 2794 bfa_fsm_state_decl(bna_tx, start_wait, struct bna_tx, enum bna_tx_event); 2795 bfa_fsm_state_decl(bna_tx, started, struct bna_tx, enum bna_tx_event); 2796 bfa_fsm_state_decl(bna_tx, stop_wait, struct bna_tx, enum bna_tx_event); 2797 bfa_fsm_state_decl(bna_tx, cleanup_wait, struct bna_tx, 2798 enum bna_tx_event); 2799 bfa_fsm_state_decl(bna_tx, prio_stop_wait, struct bna_tx, 2800 enum bna_tx_event); 2801 bfa_fsm_state_decl(bna_tx, prio_cleanup_wait, struct bna_tx, 2802 enum bna_tx_event); 2803 bfa_fsm_state_decl(bna_tx, failed, struct bna_tx, enum bna_tx_event); 2804 bfa_fsm_state_decl(bna_tx, quiesce_wait, struct bna_tx, 2805 enum bna_tx_event); 2806 2807 static void 2808 bna_tx_sm_stopped_entry(struct bna_tx *tx) 2809 { 2810 call_tx_stop_cbfn(tx); 2811 } 2812 2813 static void 2814 bna_tx_sm_stopped(struct bna_tx *tx, enum bna_tx_event event) 2815 { 2816 switch (event) { 2817 case TX_E_START: 2818 bfa_fsm_set_state(tx, bna_tx_sm_start_wait); 2819 break; 2820 2821 case TX_E_STOP: 2822 call_tx_stop_cbfn(tx); 2823 break; 2824 2825 case TX_E_FAIL: 2826 /* No-op */ 2827 break; 2828 2829 case TX_E_BW_UPDATE: 2830 /* No-op */ 2831 break; 2832 2833 default: 2834 bfa_sm_fault(event); 2835 } 2836 } 2837 2838 static void 2839 bna_tx_sm_start_wait_entry(struct bna_tx *tx) 2840 { 2841 bna_bfi_tx_enet_start(tx); 2842 } 2843 2844 static void 2845 bna_tx_sm_start_wait(struct bna_tx *tx, enum bna_tx_event event) 2846 { 2847 switch (event) { 2848 case TX_E_STOP: 2849 tx->flags &= ~BNA_TX_F_BW_UPDATED; 2850 bfa_fsm_set_state(tx, bna_tx_sm_stop_wait); 2851 break; 2852 2853 case TX_E_FAIL: 2854 tx->flags &= ~BNA_TX_F_BW_UPDATED; 2855 bfa_fsm_set_state(tx, bna_tx_sm_stopped); 2856 break; 2857 2858 case TX_E_STARTED: 2859 if (tx->flags & BNA_TX_F_BW_UPDATED) { 2860 tx->flags &= ~BNA_TX_F_BW_UPDATED; 2861 bfa_fsm_set_state(tx, bna_tx_sm_prio_stop_wait); 2862 } else 2863 bfa_fsm_set_state(tx, bna_tx_sm_started); 2864 break; 2865 2866 case TX_E_BW_UPDATE: 2867 tx->flags |= BNA_TX_F_BW_UPDATED; 2868 break; 2869 2870 default: 2871 bfa_sm_fault(event); 2872 } 2873 } 2874 2875 static void 2876 bna_tx_sm_started_entry(struct bna_tx *tx) 2877 { 2878 struct bna_txq *txq; 2879 int is_regular = (tx->type == BNA_TX_T_REGULAR); 2880 2881 list_for_each_entry(txq, &tx->txq_q, qe) { 2882 txq->tcb->priority = txq->priority; 2883 /* Start IB */ 2884 bna_ib_start(tx->bna, &txq->ib, is_regular); 2885 } 2886 tx->tx_resume_cbfn(tx->bna->bnad, tx); 2887 } 2888 2889 static void 2890 bna_tx_sm_started(struct bna_tx *tx, enum bna_tx_event event) 2891 { 2892 switch (event) { 2893 case TX_E_STOP: 2894 bfa_fsm_set_state(tx, bna_tx_sm_stop_wait); 2895 tx->tx_stall_cbfn(tx->bna->bnad, tx); 2896 bna_tx_enet_stop(tx); 2897 break; 2898 2899 case TX_E_FAIL: 2900 bfa_fsm_set_state(tx, bna_tx_sm_failed); 2901 tx->tx_stall_cbfn(tx->bna->bnad, tx); 2902 tx->tx_cleanup_cbfn(tx->bna->bnad, tx); 2903 break; 2904 2905 case TX_E_BW_UPDATE: 2906 bfa_fsm_set_state(tx, bna_tx_sm_prio_stop_wait); 2907 break; 2908 2909 default: 2910 bfa_sm_fault(event); 2911 } 2912 } 2913 2914 static void 2915 bna_tx_sm_stop_wait_entry(struct bna_tx *tx) 2916 { 2917 } 2918 2919 static void 2920 bna_tx_sm_stop_wait(struct bna_tx *tx, enum bna_tx_event event) 2921 { 2922 switch (event) { 2923 case TX_E_FAIL: 2924 case TX_E_STOPPED: 2925 bfa_fsm_set_state(tx, bna_tx_sm_cleanup_wait); 2926 tx->tx_cleanup_cbfn(tx->bna->bnad, tx); 2927 break; 2928 2929 case TX_E_STARTED: 2930 /** 2931 * We are here due to start_wait -> stop_wait transition on 2932 * TX_E_STOP event 2933 */ 2934 bna_tx_enet_stop(tx); 2935 break; 2936 2937 case TX_E_BW_UPDATE: 2938 /* No-op */ 2939 break; 2940 2941 default: 2942 bfa_sm_fault(event); 2943 } 2944 } 2945 2946 static void 2947 bna_tx_sm_cleanup_wait_entry(struct bna_tx *tx) 2948 { 2949 } 2950 2951 static void 2952 bna_tx_sm_cleanup_wait(struct bna_tx *tx, enum bna_tx_event event) 2953 { 2954 switch (event) { 2955 case TX_E_FAIL: 2956 case TX_E_BW_UPDATE: 2957 /* No-op */ 2958 break; 2959 2960 case TX_E_CLEANUP_DONE: 2961 bfa_fsm_set_state(tx, bna_tx_sm_stopped); 2962 break; 2963 2964 default: 2965 bfa_sm_fault(event); 2966 } 2967 } 2968 2969 static void 2970 bna_tx_sm_prio_stop_wait_entry(struct bna_tx *tx) 2971 { 2972 tx->tx_stall_cbfn(tx->bna->bnad, tx); 2973 bna_tx_enet_stop(tx); 2974 } 2975 2976 static void 2977 bna_tx_sm_prio_stop_wait(struct bna_tx *tx, enum bna_tx_event event) 2978 { 2979 switch (event) { 2980 case TX_E_STOP: 2981 bfa_fsm_set_state(tx, bna_tx_sm_stop_wait); 2982 break; 2983 2984 case TX_E_FAIL: 2985 bfa_fsm_set_state(tx, bna_tx_sm_failed); 2986 tx->tx_cleanup_cbfn(tx->bna->bnad, tx); 2987 break; 2988 2989 case TX_E_STOPPED: 2990 bfa_fsm_set_state(tx, bna_tx_sm_prio_cleanup_wait); 2991 break; 2992 2993 case TX_E_BW_UPDATE: 2994 /* No-op */ 2995 break; 2996 2997 default: 2998 bfa_sm_fault(event); 2999 } 3000 } 3001 3002 static void 3003 bna_tx_sm_prio_cleanup_wait_entry(struct bna_tx *tx) 3004 { 3005 tx->tx_cleanup_cbfn(tx->bna->bnad, tx); 3006 } 3007 3008 static void 3009 bna_tx_sm_prio_cleanup_wait(struct bna_tx *tx, enum bna_tx_event event) 3010 { 3011 switch (event) { 3012 case TX_E_STOP: 3013 bfa_fsm_set_state(tx, bna_tx_sm_cleanup_wait); 3014 break; 3015 3016 case TX_E_FAIL: 3017 bfa_fsm_set_state(tx, bna_tx_sm_failed); 3018 break; 3019 3020 case TX_E_BW_UPDATE: 3021 /* No-op */ 3022 break; 3023 3024 case TX_E_CLEANUP_DONE: 3025 bfa_fsm_set_state(tx, bna_tx_sm_start_wait); 3026 break; 3027 3028 default: 3029 bfa_sm_fault(event); 3030 } 3031 } 3032 3033 static void 3034 bna_tx_sm_failed_entry(struct bna_tx *tx) 3035 { 3036 } 3037 3038 static void 3039 bna_tx_sm_failed(struct bna_tx *tx, enum bna_tx_event event) 3040 { 3041 switch (event) { 3042 case TX_E_START: 3043 bfa_fsm_set_state(tx, bna_tx_sm_quiesce_wait); 3044 break; 3045 3046 case TX_E_STOP: 3047 bfa_fsm_set_state(tx, bna_tx_sm_cleanup_wait); 3048 break; 3049 3050 case TX_E_FAIL: 3051 /* No-op */ 3052 break; 3053 3054 case TX_E_CLEANUP_DONE: 3055 bfa_fsm_set_state(tx, bna_tx_sm_stopped); 3056 break; 3057 3058 default: 3059 bfa_sm_fault(event); 3060 } 3061 } 3062 3063 static void 3064 bna_tx_sm_quiesce_wait_entry(struct bna_tx *tx) 3065 { 3066 } 3067 3068 static void 3069 bna_tx_sm_quiesce_wait(struct bna_tx *tx, enum bna_tx_event event) 3070 { 3071 switch (event) { 3072 case TX_E_STOP: 3073 bfa_fsm_set_state(tx, bna_tx_sm_cleanup_wait); 3074 break; 3075 3076 case TX_E_FAIL: 3077 bfa_fsm_set_state(tx, bna_tx_sm_failed); 3078 break; 3079 3080 case TX_E_CLEANUP_DONE: 3081 bfa_fsm_set_state(tx, bna_tx_sm_start_wait); 3082 break; 3083 3084 case TX_E_BW_UPDATE: 3085 /* No-op */ 3086 break; 3087 3088 default: 3089 bfa_sm_fault(event); 3090 } 3091 } 3092 3093 static void 3094 bna_bfi_tx_enet_start(struct bna_tx *tx) 3095 { 3096 struct bfi_enet_tx_cfg_req *cfg_req = &tx->bfi_enet_cmd.cfg_req; 3097 struct bna_txq *txq = NULL; 3098 int i; 3099 3100 bfi_msgq_mhdr_set(cfg_req->mh, BFI_MC_ENET, 3101 BFI_ENET_H2I_TX_CFG_SET_REQ, 0, tx->rid); 3102 cfg_req->mh.num_entries = htons( 3103 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_tx_cfg_req))); 3104 3105 cfg_req->num_queues = tx->num_txq; 3106 for (i = 0; i < tx->num_txq; i++) { 3107 txq = txq ? list_next_entry(txq, qe) 3108 : list_first_entry(&tx->txq_q, struct bna_txq, qe); 3109 bfi_enet_datapath_q_init(&cfg_req->q_cfg[i].q.q, &txq->qpt); 3110 cfg_req->q_cfg[i].q.priority = txq->priority; 3111 3112 cfg_req->q_cfg[i].ib.index_addr.a32.addr_lo = 3113 txq->ib.ib_seg_host_addr.lsb; 3114 cfg_req->q_cfg[i].ib.index_addr.a32.addr_hi = 3115 txq->ib.ib_seg_host_addr.msb; 3116 cfg_req->q_cfg[i].ib.intr.msix_index = 3117 htons((u16)txq->ib.intr_vector); 3118 } 3119 3120 cfg_req->ib_cfg.int_pkt_dma = BNA_STATUS_T_ENABLED; 3121 cfg_req->ib_cfg.int_enabled = BNA_STATUS_T_ENABLED; 3122 cfg_req->ib_cfg.int_pkt_enabled = BNA_STATUS_T_DISABLED; 3123 cfg_req->ib_cfg.continuous_coalescing = BNA_STATUS_T_ENABLED; 3124 cfg_req->ib_cfg.msix = (txq->ib.intr_type == BNA_INTR_T_MSIX) 3125 ? BNA_STATUS_T_ENABLED : BNA_STATUS_T_DISABLED; 3126 cfg_req->ib_cfg.coalescing_timeout = 3127 htonl((u32)txq->ib.coalescing_timeo); 3128 cfg_req->ib_cfg.inter_pkt_timeout = 3129 htonl((u32)txq->ib.interpkt_timeo); 3130 cfg_req->ib_cfg.inter_pkt_count = (u8)txq->ib.interpkt_count; 3131 3132 cfg_req->tx_cfg.vlan_mode = BFI_ENET_TX_VLAN_WI; 3133 cfg_req->tx_cfg.vlan_id = htons((u16)tx->txf_vlan_id); 3134 cfg_req->tx_cfg.admit_tagged_frame = BNA_STATUS_T_ENABLED; 3135 cfg_req->tx_cfg.apply_vlan_filter = BNA_STATUS_T_DISABLED; 3136 3137 bfa_msgq_cmd_set(&tx->msgq_cmd, NULL, NULL, 3138 sizeof(struct bfi_enet_tx_cfg_req), &cfg_req->mh); 3139 bfa_msgq_cmd_post(&tx->bna->msgq, &tx->msgq_cmd); 3140 } 3141 3142 static void 3143 bna_bfi_tx_enet_stop(struct bna_tx *tx) 3144 { 3145 struct bfi_enet_req *req = &tx->bfi_enet_cmd.req; 3146 3147 bfi_msgq_mhdr_set(req->mh, BFI_MC_ENET, 3148 BFI_ENET_H2I_TX_CFG_CLR_REQ, 0, tx->rid); 3149 req->mh.num_entries = htons( 3150 bfi_msgq_num_cmd_entries(sizeof(struct bfi_enet_req))); 3151 bfa_msgq_cmd_set(&tx->msgq_cmd, NULL, NULL, sizeof(struct bfi_enet_req), 3152 &req->mh); 3153 bfa_msgq_cmd_post(&tx->bna->msgq, &tx->msgq_cmd); 3154 } 3155 3156 static void 3157 bna_tx_enet_stop(struct bna_tx *tx) 3158 { 3159 struct bna_txq *txq; 3160 3161 /* Stop IB */ 3162 list_for_each_entry(txq, &tx->txq_q, qe) 3163 bna_ib_stop(tx->bna, &txq->ib); 3164 3165 bna_bfi_tx_enet_stop(tx); 3166 } 3167 3168 static void 3169 bna_txq_qpt_setup(struct bna_txq *txq, int page_count, int page_size, 3170 struct bna_mem_descr *qpt_mem, 3171 struct bna_mem_descr *swqpt_mem, 3172 struct bna_mem_descr *page_mem) 3173 { 3174 u8 *kva; 3175 u64 dma; 3176 struct bna_dma_addr bna_dma; 3177 int i; 3178 3179 txq->qpt.hw_qpt_ptr.lsb = qpt_mem->dma.lsb; 3180 txq->qpt.hw_qpt_ptr.msb = qpt_mem->dma.msb; 3181 txq->qpt.kv_qpt_ptr = qpt_mem->kva; 3182 txq->qpt.page_count = page_count; 3183 txq->qpt.page_size = page_size; 3184 3185 txq->tcb->sw_qpt = (void **) swqpt_mem->kva; 3186 txq->tcb->sw_q = page_mem->kva; 3187 3188 kva = page_mem->kva; 3189 BNA_GET_DMA_ADDR(&page_mem->dma, dma); 3190 3191 for (i = 0; i < page_count; i++) { 3192 txq->tcb->sw_qpt[i] = kva; 3193 kva += PAGE_SIZE; 3194 3195 BNA_SET_DMA_ADDR(dma, &bna_dma); 3196 ((struct bna_dma_addr *)txq->qpt.kv_qpt_ptr)[i].lsb = 3197 bna_dma.lsb; 3198 ((struct bna_dma_addr *)txq->qpt.kv_qpt_ptr)[i].msb = 3199 bna_dma.msb; 3200 dma += PAGE_SIZE; 3201 } 3202 } 3203 3204 static struct bna_tx * 3205 bna_tx_get(struct bna_tx_mod *tx_mod, enum bna_tx_type type) 3206 { 3207 struct bna_tx *tx = NULL; 3208 3209 if (list_empty(&tx_mod->tx_free_q)) 3210 return NULL; 3211 if (type == BNA_TX_T_REGULAR) 3212 tx = list_first_entry(&tx_mod->tx_free_q, struct bna_tx, qe); 3213 else 3214 tx = list_last_entry(&tx_mod->tx_free_q, struct bna_tx, qe); 3215 list_del(&tx->qe); 3216 tx->type = type; 3217 3218 return tx; 3219 } 3220 3221 static void 3222 bna_tx_free(struct bna_tx *tx) 3223 { 3224 struct bna_tx_mod *tx_mod = &tx->bna->tx_mod; 3225 struct bna_txq *txq; 3226 struct list_head *qe; 3227 3228 while (!list_empty(&tx->txq_q)) { 3229 txq = list_first_entry(&tx->txq_q, struct bna_txq, qe); 3230 txq->tcb = NULL; 3231 txq->tx = NULL; 3232 list_move_tail(&txq->qe, &tx_mod->txq_free_q); 3233 } 3234 3235 list_for_each(qe, &tx_mod->tx_active_q) { 3236 if (qe == &tx->qe) { 3237 list_del(&tx->qe); 3238 break; 3239 } 3240 } 3241 3242 tx->bna = NULL; 3243 tx->priv = NULL; 3244 3245 list_for_each_prev(qe, &tx_mod->tx_free_q) 3246 if (((struct bna_tx *)qe)->rid < tx->rid) 3247 break; 3248 3249 list_add(&tx->qe, qe); 3250 } 3251 3252 static void 3253 bna_tx_start(struct bna_tx *tx) 3254 { 3255 tx->flags |= BNA_TX_F_ENET_STARTED; 3256 if (tx->flags & BNA_TX_F_ENABLED) 3257 bfa_fsm_send_event(tx, TX_E_START); 3258 } 3259 3260 static void 3261 bna_tx_stop(struct bna_tx *tx) 3262 { 3263 tx->stop_cbfn = bna_tx_mod_cb_tx_stopped; 3264 tx->stop_cbarg = &tx->bna->tx_mod; 3265 3266 tx->flags &= ~BNA_TX_F_ENET_STARTED; 3267 bfa_fsm_send_event(tx, TX_E_STOP); 3268 } 3269 3270 static void 3271 bna_tx_fail(struct bna_tx *tx) 3272 { 3273 tx->flags &= ~BNA_TX_F_ENET_STARTED; 3274 bfa_fsm_send_event(tx, TX_E_FAIL); 3275 } 3276 3277 void 3278 bna_bfi_tx_enet_start_rsp(struct bna_tx *tx, struct bfi_msgq_mhdr *msghdr) 3279 { 3280 struct bfi_enet_tx_cfg_rsp *cfg_rsp = &tx->bfi_enet_cmd.cfg_rsp; 3281 struct bna_txq *txq = NULL; 3282 int i; 3283 3284 bfa_msgq_rsp_copy(&tx->bna->msgq, (u8 *)cfg_rsp, 3285 sizeof(struct bfi_enet_tx_cfg_rsp)); 3286 3287 tx->hw_id = cfg_rsp->hw_id; 3288 3289 for (i = 0, txq = list_first_entry(&tx->txq_q, struct bna_txq, qe); 3290 i < tx->num_txq; i++, txq = list_next_entry(txq, qe)) { 3291 /* Setup doorbells */ 3292 txq->tcb->i_dbell->doorbell_addr = 3293 tx->bna->pcidev.pci_bar_kva 3294 + ntohl(cfg_rsp->q_handles[i].i_dbell); 3295 txq->tcb->q_dbell = 3296 tx->bna->pcidev.pci_bar_kva 3297 + ntohl(cfg_rsp->q_handles[i].q_dbell); 3298 txq->hw_id = cfg_rsp->q_handles[i].hw_qid; 3299 3300 /* Initialize producer/consumer indexes */ 3301 (*txq->tcb->hw_consumer_index) = 0; 3302 txq->tcb->producer_index = txq->tcb->consumer_index = 0; 3303 } 3304 3305 bfa_fsm_send_event(tx, TX_E_STARTED); 3306 } 3307 3308 void 3309 bna_bfi_tx_enet_stop_rsp(struct bna_tx *tx, struct bfi_msgq_mhdr *msghdr) 3310 { 3311 bfa_fsm_send_event(tx, TX_E_STOPPED); 3312 } 3313 3314 void 3315 bna_bfi_bw_update_aen(struct bna_tx_mod *tx_mod) 3316 { 3317 struct bna_tx *tx; 3318 3319 list_for_each_entry(tx, &tx_mod->tx_active_q, qe) 3320 bfa_fsm_send_event(tx, TX_E_BW_UPDATE); 3321 } 3322 3323 void 3324 bna_tx_res_req(int num_txq, int txq_depth, struct bna_res_info *res_info) 3325 { 3326 u32 q_size; 3327 u32 page_count; 3328 struct bna_mem_info *mem_info; 3329 3330 res_info[BNA_TX_RES_MEM_T_TCB].res_type = BNA_RES_T_MEM; 3331 mem_info = &res_info[BNA_TX_RES_MEM_T_TCB].res_u.mem_info; 3332 mem_info->mem_type = BNA_MEM_T_KVA; 3333 mem_info->len = sizeof(struct bna_tcb); 3334 mem_info->num = num_txq; 3335 3336 q_size = txq_depth * BFI_TXQ_WI_SIZE; 3337 q_size = ALIGN(q_size, PAGE_SIZE); 3338 page_count = q_size >> PAGE_SHIFT; 3339 3340 res_info[BNA_TX_RES_MEM_T_QPT].res_type = BNA_RES_T_MEM; 3341 mem_info = &res_info[BNA_TX_RES_MEM_T_QPT].res_u.mem_info; 3342 mem_info->mem_type = BNA_MEM_T_DMA; 3343 mem_info->len = page_count * sizeof(struct bna_dma_addr); 3344 mem_info->num = num_txq; 3345 3346 res_info[BNA_TX_RES_MEM_T_SWQPT].res_type = BNA_RES_T_MEM; 3347 mem_info = &res_info[BNA_TX_RES_MEM_T_SWQPT].res_u.mem_info; 3348 mem_info->mem_type = BNA_MEM_T_KVA; 3349 mem_info->len = page_count * sizeof(void *); 3350 mem_info->num = num_txq; 3351 3352 res_info[BNA_TX_RES_MEM_T_PAGE].res_type = BNA_RES_T_MEM; 3353 mem_info = &res_info[BNA_TX_RES_MEM_T_PAGE].res_u.mem_info; 3354 mem_info->mem_type = BNA_MEM_T_DMA; 3355 mem_info->len = PAGE_SIZE * page_count; 3356 mem_info->num = num_txq; 3357 3358 res_info[BNA_TX_RES_MEM_T_IBIDX].res_type = BNA_RES_T_MEM; 3359 mem_info = &res_info[BNA_TX_RES_MEM_T_IBIDX].res_u.mem_info; 3360 mem_info->mem_type = BNA_MEM_T_DMA; 3361 mem_info->len = BFI_IBIDX_SIZE; 3362 mem_info->num = num_txq; 3363 3364 res_info[BNA_TX_RES_INTR_T_TXCMPL].res_type = BNA_RES_T_INTR; 3365 res_info[BNA_TX_RES_INTR_T_TXCMPL].res_u.intr_info.intr_type = 3366 BNA_INTR_T_MSIX; 3367 res_info[BNA_TX_RES_INTR_T_TXCMPL].res_u.intr_info.num = num_txq; 3368 } 3369 3370 struct bna_tx * 3371 bna_tx_create(struct bna *bna, struct bnad *bnad, 3372 struct bna_tx_config *tx_cfg, 3373 const struct bna_tx_event_cbfn *tx_cbfn, 3374 struct bna_res_info *res_info, void *priv) 3375 { 3376 struct bna_intr_info *intr_info; 3377 struct bna_tx_mod *tx_mod = &bna->tx_mod; 3378 struct bna_tx *tx; 3379 struct bna_txq *txq; 3380 int page_count; 3381 int i; 3382 3383 intr_info = &res_info[BNA_TX_RES_INTR_T_TXCMPL].res_u.intr_info; 3384 page_count = (res_info[BNA_TX_RES_MEM_T_PAGE].res_u.mem_info.len) / 3385 PAGE_SIZE; 3386 3387 /** 3388 * Get resources 3389 */ 3390 3391 if ((intr_info->num != 1) && (intr_info->num != tx_cfg->num_txq)) 3392 return NULL; 3393 3394 /* Tx */ 3395 3396 tx = bna_tx_get(tx_mod, tx_cfg->tx_type); 3397 if (!tx) 3398 return NULL; 3399 tx->bna = bna; 3400 tx->priv = priv; 3401 3402 /* TxQs */ 3403 3404 INIT_LIST_HEAD(&tx->txq_q); 3405 for (i = 0; i < tx_cfg->num_txq; i++) { 3406 if (list_empty(&tx_mod->txq_free_q)) 3407 goto err_return; 3408 3409 txq = list_first_entry(&tx_mod->txq_free_q, struct bna_txq, qe); 3410 list_move_tail(&txq->qe, &tx->txq_q); 3411 txq->tx = tx; 3412 } 3413 3414 /* 3415 * Initialize 3416 */ 3417 3418 /* Tx */ 3419 3420 tx->tcb_setup_cbfn = tx_cbfn->tcb_setup_cbfn; 3421 tx->tcb_destroy_cbfn = tx_cbfn->tcb_destroy_cbfn; 3422 /* Following callbacks are mandatory */ 3423 tx->tx_stall_cbfn = tx_cbfn->tx_stall_cbfn; 3424 tx->tx_resume_cbfn = tx_cbfn->tx_resume_cbfn; 3425 tx->tx_cleanup_cbfn = tx_cbfn->tx_cleanup_cbfn; 3426 3427 list_add_tail(&tx->qe, &tx_mod->tx_active_q); 3428 3429 tx->num_txq = tx_cfg->num_txq; 3430 3431 tx->flags = 0; 3432 if (tx->bna->tx_mod.flags & BNA_TX_MOD_F_ENET_STARTED) { 3433 switch (tx->type) { 3434 case BNA_TX_T_REGULAR: 3435 if (!(tx->bna->tx_mod.flags & 3436 BNA_TX_MOD_F_ENET_LOOPBACK)) 3437 tx->flags |= BNA_TX_F_ENET_STARTED; 3438 break; 3439 case BNA_TX_T_LOOPBACK: 3440 if (tx->bna->tx_mod.flags & BNA_TX_MOD_F_ENET_LOOPBACK) 3441 tx->flags |= BNA_TX_F_ENET_STARTED; 3442 break; 3443 } 3444 } 3445 3446 /* TxQ */ 3447 3448 i = 0; 3449 list_for_each_entry(txq, &tx->txq_q, qe) { 3450 txq->tcb = (struct bna_tcb *) 3451 res_info[BNA_TX_RES_MEM_T_TCB].res_u.mem_info.mdl[i].kva; 3452 txq->tx_packets = 0; 3453 txq->tx_bytes = 0; 3454 3455 /* IB */ 3456 txq->ib.ib_seg_host_addr.lsb = 3457 res_info[BNA_TX_RES_MEM_T_IBIDX].res_u.mem_info.mdl[i].dma.lsb; 3458 txq->ib.ib_seg_host_addr.msb = 3459 res_info[BNA_TX_RES_MEM_T_IBIDX].res_u.mem_info.mdl[i].dma.msb; 3460 txq->ib.ib_seg_host_addr_kva = 3461 res_info[BNA_TX_RES_MEM_T_IBIDX].res_u.mem_info.mdl[i].kva; 3462 txq->ib.intr_type = intr_info->intr_type; 3463 txq->ib.intr_vector = (intr_info->num == 1) ? 3464 intr_info->idl[0].vector : 3465 intr_info->idl[i].vector; 3466 if (intr_info->intr_type == BNA_INTR_T_INTX) 3467 txq->ib.intr_vector = BIT(txq->ib.intr_vector); 3468 txq->ib.coalescing_timeo = tx_cfg->coalescing_timeo; 3469 txq->ib.interpkt_timeo = BFI_TX_INTERPKT_TIMEO; 3470 txq->ib.interpkt_count = BFI_TX_INTERPKT_COUNT; 3471 3472 /* TCB */ 3473 3474 txq->tcb->q_depth = tx_cfg->txq_depth; 3475 txq->tcb->unmap_q = (void *) 3476 res_info[BNA_TX_RES_MEM_T_UNMAPQ].res_u.mem_info.mdl[i].kva; 3477 txq->tcb->hw_consumer_index = 3478 (u32 *)txq->ib.ib_seg_host_addr_kva; 3479 txq->tcb->i_dbell = &txq->ib.door_bell; 3480 txq->tcb->intr_type = txq->ib.intr_type; 3481 txq->tcb->intr_vector = txq->ib.intr_vector; 3482 txq->tcb->txq = txq; 3483 txq->tcb->bnad = bnad; 3484 txq->tcb->id = i; 3485 3486 /* QPT, SWQPT, Pages */ 3487 bna_txq_qpt_setup(txq, page_count, PAGE_SIZE, 3488 &res_info[BNA_TX_RES_MEM_T_QPT].res_u.mem_info.mdl[i], 3489 &res_info[BNA_TX_RES_MEM_T_SWQPT].res_u.mem_info.mdl[i], 3490 &res_info[BNA_TX_RES_MEM_T_PAGE]. 3491 res_u.mem_info.mdl[i]); 3492 3493 /* Callback to bnad for setting up TCB */ 3494 if (tx->tcb_setup_cbfn) 3495 (tx->tcb_setup_cbfn)(bna->bnad, txq->tcb); 3496 3497 if (tx_cfg->num_txq == BFI_TX_MAX_PRIO) 3498 txq->priority = txq->tcb->id; 3499 else 3500 txq->priority = tx_mod->default_prio; 3501 3502 i++; 3503 } 3504 3505 tx->txf_vlan_id = 0; 3506 3507 bfa_fsm_set_state(tx, bna_tx_sm_stopped); 3508 3509 tx_mod->rid_mask |= BIT(tx->rid); 3510 3511 return tx; 3512 3513 err_return: 3514 bna_tx_free(tx); 3515 return NULL; 3516 } 3517 3518 void 3519 bna_tx_destroy(struct bna_tx *tx) 3520 { 3521 struct bna_txq *txq; 3522 3523 list_for_each_entry(txq, &tx->txq_q, qe) 3524 if (tx->tcb_destroy_cbfn) 3525 (tx->tcb_destroy_cbfn)(tx->bna->bnad, txq->tcb); 3526 3527 tx->bna->tx_mod.rid_mask &= ~BIT(tx->rid); 3528 bna_tx_free(tx); 3529 } 3530 3531 void 3532 bna_tx_enable(struct bna_tx *tx) 3533 { 3534 if (tx->fsm != (bfa_sm_t)bna_tx_sm_stopped) 3535 return; 3536 3537 tx->flags |= BNA_TX_F_ENABLED; 3538 3539 if (tx->flags & BNA_TX_F_ENET_STARTED) 3540 bfa_fsm_send_event(tx, TX_E_START); 3541 } 3542 3543 void 3544 bna_tx_disable(struct bna_tx *tx, enum bna_cleanup_type type, 3545 void (*cbfn)(void *, struct bna_tx *)) 3546 { 3547 if (type == BNA_SOFT_CLEANUP) { 3548 (*cbfn)(tx->bna->bnad, tx); 3549 return; 3550 } 3551 3552 tx->stop_cbfn = cbfn; 3553 tx->stop_cbarg = tx->bna->bnad; 3554 3555 tx->flags &= ~BNA_TX_F_ENABLED; 3556 3557 bfa_fsm_send_event(tx, TX_E_STOP); 3558 } 3559 3560 void 3561 bna_tx_cleanup_complete(struct bna_tx *tx) 3562 { 3563 bfa_fsm_send_event(tx, TX_E_CLEANUP_DONE); 3564 } 3565 3566 static void 3567 bna_tx_mod_cb_tx_stopped(void *arg, struct bna_tx *tx) 3568 { 3569 struct bna_tx_mod *tx_mod = (struct bna_tx_mod *)arg; 3570 3571 bfa_wc_down(&tx_mod->tx_stop_wc); 3572 } 3573 3574 static void 3575 bna_tx_mod_cb_tx_stopped_all(void *arg) 3576 { 3577 struct bna_tx_mod *tx_mod = (struct bna_tx_mod *)arg; 3578 3579 if (tx_mod->stop_cbfn) 3580 tx_mod->stop_cbfn(&tx_mod->bna->enet); 3581 tx_mod->stop_cbfn = NULL; 3582 } 3583 3584 void 3585 bna_tx_mod_init(struct bna_tx_mod *tx_mod, struct bna *bna, 3586 struct bna_res_info *res_info) 3587 { 3588 int i; 3589 3590 tx_mod->bna = bna; 3591 tx_mod->flags = 0; 3592 3593 tx_mod->tx = (struct bna_tx *) 3594 res_info[BNA_MOD_RES_MEM_T_TX_ARRAY].res_u.mem_info.mdl[0].kva; 3595 tx_mod->txq = (struct bna_txq *) 3596 res_info[BNA_MOD_RES_MEM_T_TXQ_ARRAY].res_u.mem_info.mdl[0].kva; 3597 3598 INIT_LIST_HEAD(&tx_mod->tx_free_q); 3599 INIT_LIST_HEAD(&tx_mod->tx_active_q); 3600 3601 INIT_LIST_HEAD(&tx_mod->txq_free_q); 3602 3603 for (i = 0; i < bna->ioceth.attr.num_txq; i++) { 3604 tx_mod->tx[i].rid = i; 3605 list_add_tail(&tx_mod->tx[i].qe, &tx_mod->tx_free_q); 3606 list_add_tail(&tx_mod->txq[i].qe, &tx_mod->txq_free_q); 3607 } 3608 3609 tx_mod->prio_map = BFI_TX_PRIO_MAP_ALL; 3610 tx_mod->default_prio = 0; 3611 tx_mod->iscsi_over_cee = BNA_STATUS_T_DISABLED; 3612 tx_mod->iscsi_prio = -1; 3613 } 3614 3615 void 3616 bna_tx_mod_uninit(struct bna_tx_mod *tx_mod) 3617 { 3618 tx_mod->bna = NULL; 3619 } 3620 3621 void 3622 bna_tx_mod_start(struct bna_tx_mod *tx_mod, enum bna_tx_type type) 3623 { 3624 struct bna_tx *tx; 3625 3626 tx_mod->flags |= BNA_TX_MOD_F_ENET_STARTED; 3627 if (type == BNA_TX_T_LOOPBACK) 3628 tx_mod->flags |= BNA_TX_MOD_F_ENET_LOOPBACK; 3629 3630 list_for_each_entry(tx, &tx_mod->tx_active_q, qe) 3631 if (tx->type == type) 3632 bna_tx_start(tx); 3633 } 3634 3635 void 3636 bna_tx_mod_stop(struct bna_tx_mod *tx_mod, enum bna_tx_type type) 3637 { 3638 struct bna_tx *tx; 3639 3640 tx_mod->flags &= ~BNA_TX_MOD_F_ENET_STARTED; 3641 tx_mod->flags &= ~BNA_TX_MOD_F_ENET_LOOPBACK; 3642 3643 tx_mod->stop_cbfn = bna_enet_cb_tx_stopped; 3644 3645 bfa_wc_init(&tx_mod->tx_stop_wc, bna_tx_mod_cb_tx_stopped_all, tx_mod); 3646 3647 list_for_each_entry(tx, &tx_mod->tx_active_q, qe) 3648 if (tx->type == type) { 3649 bfa_wc_up(&tx_mod->tx_stop_wc); 3650 bna_tx_stop(tx); 3651 } 3652 3653 bfa_wc_wait(&tx_mod->tx_stop_wc); 3654 } 3655 3656 void 3657 bna_tx_mod_fail(struct bna_tx_mod *tx_mod) 3658 { 3659 struct bna_tx *tx; 3660 3661 tx_mod->flags &= ~BNA_TX_MOD_F_ENET_STARTED; 3662 tx_mod->flags &= ~BNA_TX_MOD_F_ENET_LOOPBACK; 3663 3664 list_for_each_entry(tx, &tx_mod->tx_active_q, qe) 3665 bna_tx_fail(tx); 3666 } 3667 3668 void 3669 bna_tx_coalescing_timeo_set(struct bna_tx *tx, int coalescing_timeo) 3670 { 3671 struct bna_txq *txq; 3672 3673 list_for_each_entry(txq, &tx->txq_q, qe) 3674 bna_ib_coalescing_timeo_set(&txq->ib, coalescing_timeo); 3675 } 3676