1 /****************************************************************************** 2 3 Copyright (c) 2013-2015, Intel Corporation 4 All rights reserved. 5 6 Redistribution and use in source and binary forms, with or without 7 modification, are permitted provided that the following conditions are met: 8 9 1. Redistributions of source code must retain the above copyright notice, 10 this list of conditions and the following disclaimer. 11 12 2. Redistributions in binary form must reproduce the above copyright 13 notice, this list of conditions and the following disclaimer in the 14 documentation and/or other materials provided with the distribution. 15 16 3. Neither the name of the Intel Corporation nor the names of its 17 contributors may be used to endorse or promote products derived from 18 this software without specific prior written permission. 19 20 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 21 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 24 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 25 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 26 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 27 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 28 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 29 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 30 POSSIBILITY OF SUCH DAMAGE. 31 32 ******************************************************************************/ 33 /*$FreeBSD$*/ 34 35 /* 36 ** IXL driver TX/RX Routines: 37 ** This was seperated to allow usage by 38 ** both the BASE and the VF drivers. 39 */ 40 41 #ifndef IXL_STANDALONE_BUILD 42 #include "opt_inet.h" 43 #include "opt_inet6.h" 44 #include "opt_rss.h" 45 #endif 46 47 #include "ixl.h" 48 49 #ifdef RSS 50 #include <net/rss_config.h> 51 #endif 52 53 /* Local Prototypes */ 54 static void ixl_rx_checksum(struct mbuf *, u32, u32, u8); 55 static void ixl_refresh_mbufs(struct ixl_queue *, int); 56 static int ixl_xmit(struct ixl_queue *, struct mbuf **); 57 static int ixl_tx_setup_offload(struct ixl_queue *, 58 struct mbuf *, u32 *, u32 *); 59 static bool ixl_tso_setup(struct ixl_queue *, struct mbuf *); 60 61 static __inline void ixl_rx_discard(struct rx_ring *, int); 62 static __inline void ixl_rx_input(struct rx_ring *, struct ifnet *, 63 struct mbuf *, u8); 64 65 #ifdef DEV_NETMAP 66 #include <dev/netmap/if_ixl_netmap.h> 67 #endif /* DEV_NETMAP */ 68 69 /* 70 ** Multiqueue Transmit driver 71 */ 72 int 73 ixl_mq_start(struct ifnet *ifp, struct mbuf *m) 74 { 75 struct ixl_vsi *vsi = ifp->if_softc; 76 struct ixl_queue *que; 77 struct tx_ring *txr; 78 int err, i; 79 #ifdef RSS 80 u32 bucket_id; 81 #endif 82 83 /* 84 ** Which queue to use: 85 ** 86 ** When doing RSS, map it to the same outbound 87 ** queue as the incoming flow would be mapped to. 88 ** If everything is setup correctly, it should be 89 ** the same bucket that the current CPU we're on is. 90 */ 91 if (M_HASHTYPE_GET(m) != M_HASHTYPE_NONE) { 92 #ifdef RSS 93 if (rss_hash2bucket(m->m_pkthdr.flowid, 94 M_HASHTYPE_GET(m), &bucket_id) == 0) { 95 i = bucket_id % vsi->num_queues; 96 } else 97 #endif 98 i = m->m_pkthdr.flowid % vsi->num_queues; 99 } else 100 i = curcpu % vsi->num_queues; 101 /* 102 ** This may not be perfect, but until something 103 ** better comes along it will keep from scheduling 104 ** on stalled queues. 105 */ 106 if (((1 << i) & vsi->active_queues) == 0) 107 i = ffsl(vsi->active_queues); 108 109 que = &vsi->queues[i]; 110 txr = &que->txr; 111 112 err = drbr_enqueue(ifp, txr->br, m); 113 if (err) 114 return (err); 115 if (IXL_TX_TRYLOCK(txr)) { 116 ixl_mq_start_locked(ifp, txr); 117 IXL_TX_UNLOCK(txr); 118 } else 119 taskqueue_enqueue(que->tq, &que->tx_task); 120 121 return (0); 122 } 123 124 int 125 ixl_mq_start_locked(struct ifnet *ifp, struct tx_ring *txr) 126 { 127 struct ixl_queue *que = txr->que; 128 struct ixl_vsi *vsi = que->vsi; 129 struct mbuf *next; 130 int err = 0; 131 132 133 if (((ifp->if_drv_flags & IFF_DRV_RUNNING) == 0) || 134 vsi->link_active == 0) 135 return (ENETDOWN); 136 137 /* Process the transmit queue */ 138 while ((next = drbr_peek(ifp, txr->br)) != NULL) { 139 if ((err = ixl_xmit(que, &next)) != 0) { 140 if (next == NULL) 141 drbr_advance(ifp, txr->br); 142 else 143 drbr_putback(ifp, txr->br, next); 144 break; 145 } 146 drbr_advance(ifp, txr->br); 147 /* Send a copy of the frame to the BPF listener */ 148 ETHER_BPF_MTAP(ifp, next); 149 if ((ifp->if_drv_flags & IFF_DRV_RUNNING) == 0) 150 break; 151 } 152 153 if (txr->avail < IXL_TX_CLEANUP_THRESHOLD) 154 ixl_txeof(que); 155 156 return (err); 157 } 158 159 /* 160 * Called from a taskqueue to drain queued transmit packets. 161 */ 162 void 163 ixl_deferred_mq_start(void *arg, int pending) 164 { 165 struct ixl_queue *que = arg; 166 struct tx_ring *txr = &que->txr; 167 struct ixl_vsi *vsi = que->vsi; 168 struct ifnet *ifp = vsi->ifp; 169 170 IXL_TX_LOCK(txr); 171 if (!drbr_empty(ifp, txr->br)) 172 ixl_mq_start_locked(ifp, txr); 173 IXL_TX_UNLOCK(txr); 174 } 175 176 /* 177 ** Flush all queue ring buffers 178 */ 179 void 180 ixl_qflush(struct ifnet *ifp) 181 { 182 struct ixl_vsi *vsi = ifp->if_softc; 183 184 for (int i = 0; i < vsi->num_queues; i++) { 185 struct ixl_queue *que = &vsi->queues[i]; 186 struct tx_ring *txr = &que->txr; 187 struct mbuf *m; 188 IXL_TX_LOCK(txr); 189 while ((m = buf_ring_dequeue_sc(txr->br)) != NULL) 190 m_freem(m); 191 IXL_TX_UNLOCK(txr); 192 } 193 if_qflush(ifp); 194 } 195 196 /* 197 ** Find mbuf chains passed to the driver 198 ** that are 'sparse', using more than 8 199 ** mbufs to deliver an mss-size chunk of data 200 */ 201 static inline bool 202 ixl_tso_detect_sparse(struct mbuf *mp) 203 { 204 struct mbuf *m; 205 int num = 0, mss; 206 bool ret = FALSE; 207 208 mss = mp->m_pkthdr.tso_segsz; 209 for (m = mp->m_next; m != NULL; m = m->m_next) { 210 num++; 211 mss -= m->m_len; 212 if (mss < 1) 213 break; 214 if (m->m_next == NULL) 215 break; 216 } 217 if (num > IXL_SPARSE_CHAIN) 218 ret = TRUE; 219 220 return (ret); 221 } 222 223 224 /********************************************************************* 225 * 226 * This routine maps the mbufs to tx descriptors, allowing the 227 * TX engine to transmit the packets. 228 * - return 0 on success, positive on failure 229 * 230 **********************************************************************/ 231 #define IXL_TXD_CMD (I40E_TX_DESC_CMD_EOP | I40E_TX_DESC_CMD_RS) 232 233 static int 234 ixl_xmit(struct ixl_queue *que, struct mbuf **m_headp) 235 { 236 struct ixl_vsi *vsi = que->vsi; 237 struct i40e_hw *hw = vsi->hw; 238 struct tx_ring *txr = &que->txr; 239 struct ixl_tx_buf *buf; 240 struct i40e_tx_desc *txd = NULL; 241 struct mbuf *m_head, *m; 242 int i, j, error, nsegs, maxsegs; 243 int first, last = 0; 244 u16 vtag = 0; 245 u32 cmd, off; 246 bus_dmamap_t map; 247 bus_dma_tag_t tag; 248 bus_dma_segment_t segs[IXL_MAX_TSO_SEGS]; 249 250 251 cmd = off = 0; 252 m_head = *m_headp; 253 254 /* 255 * Important to capture the first descriptor 256 * used because it will contain the index of 257 * the one we tell the hardware to report back 258 */ 259 first = txr->next_avail; 260 buf = &txr->buffers[first]; 261 map = buf->map; 262 tag = txr->tx_tag; 263 maxsegs = IXL_MAX_TX_SEGS; 264 265 if (m_head->m_pkthdr.csum_flags & CSUM_TSO) { 266 /* Use larger mapping for TSO */ 267 tag = txr->tso_tag; 268 maxsegs = IXL_MAX_TSO_SEGS; 269 if (ixl_tso_detect_sparse(m_head)) { 270 m = m_defrag(m_head, M_NOWAIT); 271 if (m == NULL) { 272 m_freem(*m_headp); 273 *m_headp = NULL; 274 return (ENOBUFS); 275 } 276 *m_headp = m; 277 } 278 } 279 280 /* 281 * Map the packet for DMA. 282 */ 283 error = bus_dmamap_load_mbuf_sg(tag, map, 284 *m_headp, segs, &nsegs, BUS_DMA_NOWAIT); 285 286 if (error == EFBIG) { 287 struct mbuf *m; 288 289 m = m_defrag(*m_headp, M_NOWAIT); 290 if (m == NULL) { 291 que->mbuf_defrag_failed++; 292 m_freem(*m_headp); 293 *m_headp = NULL; 294 return (ENOBUFS); 295 } 296 *m_headp = m; 297 298 /* Try it again */ 299 error = bus_dmamap_load_mbuf_sg(tag, map, 300 *m_headp, segs, &nsegs, BUS_DMA_NOWAIT); 301 302 if (error == ENOMEM) { 303 que->tx_dma_setup++; 304 return (error); 305 } else if (error != 0) { 306 que->tx_dma_setup++; 307 m_freem(*m_headp); 308 *m_headp = NULL; 309 return (error); 310 } 311 } else if (error == ENOMEM) { 312 que->tx_dma_setup++; 313 return (error); 314 } else if (error != 0) { 315 que->tx_dma_setup++; 316 m_freem(*m_headp); 317 *m_headp = NULL; 318 return (error); 319 } 320 321 /* Make certain there are enough descriptors */ 322 if (nsegs > txr->avail - 2) { 323 txr->no_desc++; 324 error = ENOBUFS; 325 goto xmit_fail; 326 } 327 m_head = *m_headp; 328 329 /* Set up the TSO/CSUM offload */ 330 if (m_head->m_pkthdr.csum_flags & CSUM_OFFLOAD) { 331 error = ixl_tx_setup_offload(que, m_head, &cmd, &off); 332 if (error) 333 goto xmit_fail; 334 } 335 336 cmd |= I40E_TX_DESC_CMD_ICRC; 337 /* Grab the VLAN tag */ 338 if (m_head->m_flags & M_VLANTAG) { 339 cmd |= I40E_TX_DESC_CMD_IL2TAG1; 340 vtag = htole16(m_head->m_pkthdr.ether_vtag); 341 } 342 343 i = txr->next_avail; 344 for (j = 0; j < nsegs; j++) { 345 bus_size_t seglen; 346 347 buf = &txr->buffers[i]; 348 buf->tag = tag; /* Keep track of the type tag */ 349 txd = &txr->base[i]; 350 seglen = segs[j].ds_len; 351 352 txd->buffer_addr = htole64(segs[j].ds_addr); 353 txd->cmd_type_offset_bsz = 354 htole64(I40E_TX_DESC_DTYPE_DATA 355 | ((u64)cmd << I40E_TXD_QW1_CMD_SHIFT) 356 | ((u64)off << I40E_TXD_QW1_OFFSET_SHIFT) 357 | ((u64)seglen << I40E_TXD_QW1_TX_BUF_SZ_SHIFT) 358 | ((u64)vtag << I40E_TXD_QW1_L2TAG1_SHIFT)); 359 360 last = i; /* descriptor that will get completion IRQ */ 361 362 if (++i == que->num_desc) 363 i = 0; 364 365 buf->m_head = NULL; 366 buf->eop_index = -1; 367 } 368 /* Set the last descriptor for report */ 369 txd->cmd_type_offset_bsz |= 370 htole64(((u64)IXL_TXD_CMD << I40E_TXD_QW1_CMD_SHIFT)); 371 txr->avail -= nsegs; 372 txr->next_avail = i; 373 374 buf->m_head = m_head; 375 /* Swap the dma map between the first and last descriptor */ 376 txr->buffers[first].map = buf->map; 377 buf->map = map; 378 bus_dmamap_sync(tag, map, BUS_DMASYNC_PREWRITE); 379 380 /* Set the index of the descriptor that will be marked done */ 381 buf = &txr->buffers[first]; 382 buf->eop_index = last; 383 384 bus_dmamap_sync(txr->dma.tag, txr->dma.map, 385 BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); 386 /* 387 * Advance the Transmit Descriptor Tail (Tdt), this tells the 388 * hardware that this frame is available to transmit. 389 */ 390 ++txr->total_packets; 391 wr32(hw, txr->tail, i); 392 393 /* Mark outstanding work */ 394 if (que->busy == 0) 395 que->busy = 1; 396 return (0); 397 398 xmit_fail: 399 bus_dmamap_unload(tag, buf->map); 400 return (error); 401 } 402 403 404 /********************************************************************* 405 * 406 * Allocate memory for tx_buffer structures. The tx_buffer stores all 407 * the information needed to transmit a packet on the wire. This is 408 * called only once at attach, setup is done every reset. 409 * 410 **********************************************************************/ 411 int 412 ixl_allocate_tx_data(struct ixl_queue *que) 413 { 414 struct tx_ring *txr = &que->txr; 415 struct ixl_vsi *vsi = que->vsi; 416 device_t dev = vsi->dev; 417 struct ixl_tx_buf *buf; 418 int error = 0; 419 420 /* 421 * Setup DMA descriptor areas. 422 */ 423 if ((error = bus_dma_tag_create(NULL, /* parent */ 424 1, 0, /* alignment, bounds */ 425 BUS_SPACE_MAXADDR, /* lowaddr */ 426 BUS_SPACE_MAXADDR, /* highaddr */ 427 NULL, NULL, /* filter, filterarg */ 428 IXL_TSO_SIZE, /* maxsize */ 429 IXL_MAX_TX_SEGS, /* nsegments */ 430 PAGE_SIZE, /* maxsegsize */ 431 0, /* flags */ 432 NULL, /* lockfunc */ 433 NULL, /* lockfuncarg */ 434 &txr->tx_tag))) { 435 device_printf(dev,"Unable to allocate TX DMA tag\n"); 436 goto fail; 437 } 438 439 /* Make a special tag for TSO */ 440 if ((error = bus_dma_tag_create(NULL, /* parent */ 441 1, 0, /* alignment, bounds */ 442 BUS_SPACE_MAXADDR, /* lowaddr */ 443 BUS_SPACE_MAXADDR, /* highaddr */ 444 NULL, NULL, /* filter, filterarg */ 445 IXL_TSO_SIZE, /* maxsize */ 446 IXL_MAX_TSO_SEGS, /* nsegments */ 447 PAGE_SIZE, /* maxsegsize */ 448 0, /* flags */ 449 NULL, /* lockfunc */ 450 NULL, /* lockfuncarg */ 451 &txr->tso_tag))) { 452 device_printf(dev,"Unable to allocate TX TSO DMA tag\n"); 453 goto fail; 454 } 455 456 if (!(txr->buffers = 457 (struct ixl_tx_buf *) malloc(sizeof(struct ixl_tx_buf) * 458 que->num_desc, M_DEVBUF, M_NOWAIT | M_ZERO))) { 459 device_printf(dev, "Unable to allocate tx_buffer memory\n"); 460 error = ENOMEM; 461 goto fail; 462 } 463 464 /* Create the descriptor buffer default dma maps */ 465 buf = txr->buffers; 466 for (int i = 0; i < que->num_desc; i++, buf++) { 467 buf->tag = txr->tx_tag; 468 error = bus_dmamap_create(buf->tag, 0, &buf->map); 469 if (error != 0) { 470 device_printf(dev, "Unable to create TX DMA map\n"); 471 goto fail; 472 } 473 } 474 fail: 475 return (error); 476 } 477 478 479 /********************************************************************* 480 * 481 * (Re)Initialize a queue transmit ring. 482 * - called by init, it clears the descriptor ring, 483 * and frees any stale mbufs 484 * 485 **********************************************************************/ 486 void 487 ixl_init_tx_ring(struct ixl_queue *que) 488 { 489 #ifdef DEV_NETMAP 490 struct netmap_adapter *na = NA(que->vsi->ifp); 491 struct netmap_slot *slot; 492 #endif /* DEV_NETMAP */ 493 struct tx_ring *txr = &que->txr; 494 struct ixl_tx_buf *buf; 495 496 /* Clear the old ring contents */ 497 IXL_TX_LOCK(txr); 498 499 #ifdef DEV_NETMAP 500 /* 501 * (under lock): if in netmap mode, do some consistency 502 * checks and set slot to entry 0 of the netmap ring. 503 */ 504 slot = netmap_reset(na, NR_TX, que->me, 0); 505 #endif /* DEV_NETMAP */ 506 507 bzero((void *)txr->base, 508 (sizeof(struct i40e_tx_desc)) * que->num_desc); 509 510 /* Reset indices */ 511 txr->next_avail = 0; 512 txr->next_to_clean = 0; 513 514 #ifdef IXL_FDIR 515 /* Initialize flow director */ 516 txr->atr_rate = ixl_atr_rate; 517 txr->atr_count = 0; 518 #endif 519 520 /* Free any existing tx mbufs. */ 521 buf = txr->buffers; 522 for (int i = 0; i < que->num_desc; i++, buf++) { 523 if (buf->m_head != NULL) { 524 bus_dmamap_sync(buf->tag, buf->map, 525 BUS_DMASYNC_POSTWRITE); 526 bus_dmamap_unload(buf->tag, buf->map); 527 m_freem(buf->m_head); 528 buf->m_head = NULL; 529 } 530 #ifdef DEV_NETMAP 531 /* 532 * In netmap mode, set the map for the packet buffer. 533 * NOTE: Some drivers (not this one) also need to set 534 * the physical buffer address in the NIC ring. 535 * netmap_idx_n2k() maps a nic index, i, into the corresponding 536 * netmap slot index, si 537 */ 538 if (slot) { 539 int si = netmap_idx_n2k(&na->tx_rings[que->me], i); 540 netmap_load_map(na, buf->tag, buf->map, NMB(na, slot + si)); 541 } 542 #endif /* DEV_NETMAP */ 543 /* Clear the EOP index */ 544 buf->eop_index = -1; 545 } 546 547 /* Set number of descriptors available */ 548 txr->avail = que->num_desc; 549 550 bus_dmamap_sync(txr->dma.tag, txr->dma.map, 551 BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); 552 IXL_TX_UNLOCK(txr); 553 } 554 555 556 /********************************************************************* 557 * 558 * Free transmit ring related data structures. 559 * 560 **********************************************************************/ 561 void 562 ixl_free_que_tx(struct ixl_queue *que) 563 { 564 struct tx_ring *txr = &que->txr; 565 struct ixl_tx_buf *buf; 566 567 INIT_DBG_IF(que->vsi->ifp, "queue %d: begin", que->me); 568 569 for (int i = 0; i < que->num_desc; i++) { 570 buf = &txr->buffers[i]; 571 if (buf->m_head != NULL) { 572 bus_dmamap_sync(buf->tag, buf->map, 573 BUS_DMASYNC_POSTWRITE); 574 bus_dmamap_unload(buf->tag, 575 buf->map); 576 m_freem(buf->m_head); 577 buf->m_head = NULL; 578 if (buf->map != NULL) { 579 bus_dmamap_destroy(buf->tag, 580 buf->map); 581 buf->map = NULL; 582 } 583 } else if (buf->map != NULL) { 584 bus_dmamap_unload(buf->tag, 585 buf->map); 586 bus_dmamap_destroy(buf->tag, 587 buf->map); 588 buf->map = NULL; 589 } 590 } 591 if (txr->br != NULL) 592 buf_ring_free(txr->br, M_DEVBUF); 593 if (txr->buffers != NULL) { 594 free(txr->buffers, M_DEVBUF); 595 txr->buffers = NULL; 596 } 597 if (txr->tx_tag != NULL) { 598 bus_dma_tag_destroy(txr->tx_tag); 599 txr->tx_tag = NULL; 600 } 601 if (txr->tso_tag != NULL) { 602 bus_dma_tag_destroy(txr->tso_tag); 603 txr->tso_tag = NULL; 604 } 605 606 INIT_DBG_IF(que->vsi->ifp, "queue %d: end", que->me); 607 return; 608 } 609 610 /********************************************************************* 611 * 612 * Setup descriptor for hw offloads 613 * 614 **********************************************************************/ 615 616 static int 617 ixl_tx_setup_offload(struct ixl_queue *que, 618 struct mbuf *mp, u32 *cmd, u32 *off) 619 { 620 struct ether_vlan_header *eh; 621 #ifdef INET 622 struct ip *ip = NULL; 623 #endif 624 struct tcphdr *th = NULL; 625 #ifdef INET6 626 struct ip6_hdr *ip6; 627 #endif 628 int elen, ip_hlen = 0, tcp_hlen; 629 u16 etype; 630 u8 ipproto = 0; 631 bool tso = FALSE; 632 633 634 /* Set up the TSO context descriptor if required */ 635 if (mp->m_pkthdr.csum_flags & CSUM_TSO) { 636 tso = ixl_tso_setup(que, mp); 637 if (tso) 638 ++que->tso; 639 else 640 return (ENXIO); 641 } 642 643 /* 644 * Determine where frame payload starts. 645 * Jump over vlan headers if already present, 646 * helpful for QinQ too. 647 */ 648 eh = mtod(mp, struct ether_vlan_header *); 649 if (eh->evl_encap_proto == htons(ETHERTYPE_VLAN)) { 650 etype = ntohs(eh->evl_proto); 651 elen = ETHER_HDR_LEN + ETHER_VLAN_ENCAP_LEN; 652 } else { 653 etype = ntohs(eh->evl_encap_proto); 654 elen = ETHER_HDR_LEN; 655 } 656 657 switch (etype) { 658 #ifdef INET 659 case ETHERTYPE_IP: 660 ip = (struct ip *)(mp->m_data + elen); 661 ip_hlen = ip->ip_hl << 2; 662 ipproto = ip->ip_p; 663 th = (struct tcphdr *)((caddr_t)ip + ip_hlen); 664 /* The IP checksum must be recalculated with TSO */ 665 if (tso) 666 *cmd |= I40E_TX_DESC_CMD_IIPT_IPV4_CSUM; 667 else 668 *cmd |= I40E_TX_DESC_CMD_IIPT_IPV4; 669 break; 670 #endif 671 #ifdef INET6 672 case ETHERTYPE_IPV6: 673 ip6 = (struct ip6_hdr *)(mp->m_data + elen); 674 ip_hlen = sizeof(struct ip6_hdr); 675 ipproto = ip6->ip6_nxt; 676 th = (struct tcphdr *)((caddr_t)ip6 + ip_hlen); 677 *cmd |= I40E_TX_DESC_CMD_IIPT_IPV6; 678 break; 679 #endif 680 default: 681 break; 682 } 683 684 *off |= (elen >> 1) << I40E_TX_DESC_LENGTH_MACLEN_SHIFT; 685 *off |= (ip_hlen >> 2) << I40E_TX_DESC_LENGTH_IPLEN_SHIFT; 686 687 switch (ipproto) { 688 case IPPROTO_TCP: 689 tcp_hlen = th->th_off << 2; 690 if (mp->m_pkthdr.csum_flags & (CSUM_TCP|CSUM_TCP_IPV6)) { 691 *cmd |= I40E_TX_DESC_CMD_L4T_EOFT_TCP; 692 *off |= (tcp_hlen >> 2) << 693 I40E_TX_DESC_LENGTH_L4_FC_LEN_SHIFT; 694 } 695 #ifdef IXL_FDIR 696 ixl_atr(que, th, etype); 697 #endif 698 break; 699 case IPPROTO_UDP: 700 if (mp->m_pkthdr.csum_flags & (CSUM_UDP|CSUM_UDP_IPV6)) { 701 *cmd |= I40E_TX_DESC_CMD_L4T_EOFT_UDP; 702 *off |= (sizeof(struct udphdr) >> 2) << 703 I40E_TX_DESC_LENGTH_L4_FC_LEN_SHIFT; 704 } 705 break; 706 707 case IPPROTO_SCTP: 708 if (mp->m_pkthdr.csum_flags & (CSUM_SCTP|CSUM_SCTP_IPV6)) { 709 *cmd |= I40E_TX_DESC_CMD_L4T_EOFT_SCTP; 710 *off |= (sizeof(struct sctphdr) >> 2) << 711 I40E_TX_DESC_LENGTH_L4_FC_LEN_SHIFT; 712 } 713 /* Fall Thru */ 714 default: 715 break; 716 } 717 718 return (0); 719 } 720 721 722 /********************************************************************** 723 * 724 * Setup context for hardware segmentation offload (TSO) 725 * 726 **********************************************************************/ 727 static bool 728 ixl_tso_setup(struct ixl_queue *que, struct mbuf *mp) 729 { 730 struct tx_ring *txr = &que->txr; 731 struct i40e_tx_context_desc *TXD; 732 struct ixl_tx_buf *buf; 733 u32 cmd, mss, type, tsolen; 734 u16 etype; 735 int idx, elen, ip_hlen, tcp_hlen; 736 struct ether_vlan_header *eh; 737 #ifdef INET 738 struct ip *ip; 739 #endif 740 #ifdef INET6 741 struct ip6_hdr *ip6; 742 #endif 743 #if defined(INET6) || defined(INET) 744 struct tcphdr *th; 745 #endif 746 u64 type_cmd_tso_mss; 747 748 /* 749 * Determine where frame payload starts. 750 * Jump over vlan headers if already present 751 */ 752 eh = mtod(mp, struct ether_vlan_header *); 753 if (eh->evl_encap_proto == htons(ETHERTYPE_VLAN)) { 754 elen = ETHER_HDR_LEN + ETHER_VLAN_ENCAP_LEN; 755 etype = eh->evl_proto; 756 } else { 757 elen = ETHER_HDR_LEN; 758 etype = eh->evl_encap_proto; 759 } 760 761 switch (ntohs(etype)) { 762 #ifdef INET6 763 case ETHERTYPE_IPV6: 764 ip6 = (struct ip6_hdr *)(mp->m_data + elen); 765 if (ip6->ip6_nxt != IPPROTO_TCP) 766 return (ENXIO); 767 ip_hlen = sizeof(struct ip6_hdr); 768 th = (struct tcphdr *)((caddr_t)ip6 + ip_hlen); 769 th->th_sum = in6_cksum_pseudo(ip6, 0, IPPROTO_TCP, 0); 770 tcp_hlen = th->th_off << 2; 771 break; 772 #endif 773 #ifdef INET 774 case ETHERTYPE_IP: 775 ip = (struct ip *)(mp->m_data + elen); 776 if (ip->ip_p != IPPROTO_TCP) 777 return (ENXIO); 778 ip->ip_sum = 0; 779 ip_hlen = ip->ip_hl << 2; 780 th = (struct tcphdr *)((caddr_t)ip + ip_hlen); 781 th->th_sum = in_pseudo(ip->ip_src.s_addr, 782 ip->ip_dst.s_addr, htons(IPPROTO_TCP)); 783 tcp_hlen = th->th_off << 2; 784 break; 785 #endif 786 default: 787 printf("%s: CSUM_TSO but no supported IP version (0x%04x)", 788 __func__, ntohs(etype)); 789 return FALSE; 790 } 791 792 /* Ensure we have at least the IP+TCP header in the first mbuf. */ 793 if (mp->m_len < elen + ip_hlen + sizeof(struct tcphdr)) 794 return FALSE; 795 796 idx = txr->next_avail; 797 buf = &txr->buffers[idx]; 798 TXD = (struct i40e_tx_context_desc *) &txr->base[idx]; 799 tsolen = mp->m_pkthdr.len - (elen + ip_hlen + tcp_hlen); 800 801 type = I40E_TX_DESC_DTYPE_CONTEXT; 802 cmd = I40E_TX_CTX_DESC_TSO; 803 mss = mp->m_pkthdr.tso_segsz; 804 805 type_cmd_tso_mss = ((u64)type << I40E_TXD_CTX_QW1_DTYPE_SHIFT) | 806 ((u64)cmd << I40E_TXD_CTX_QW1_CMD_SHIFT) | 807 ((u64)tsolen << I40E_TXD_CTX_QW1_TSO_LEN_SHIFT) | 808 ((u64)mss << I40E_TXD_CTX_QW1_MSS_SHIFT); 809 TXD->type_cmd_tso_mss = htole64(type_cmd_tso_mss); 810 811 TXD->tunneling_params = htole32(0); 812 buf->m_head = NULL; 813 buf->eop_index = -1; 814 815 if (++idx == que->num_desc) 816 idx = 0; 817 818 txr->avail--; 819 txr->next_avail = idx; 820 821 return TRUE; 822 } 823 824 /* 825 ** ixl_get_tx_head - Retrieve the value from the 826 ** location the HW records its HEAD index 827 */ 828 static inline u32 829 ixl_get_tx_head(struct ixl_queue *que) 830 { 831 struct tx_ring *txr = &que->txr; 832 void *head = &txr->base[que->num_desc]; 833 return LE32_TO_CPU(*(volatile __le32 *)head); 834 } 835 836 /********************************************************************** 837 * 838 * Examine each tx_buffer in the used queue. If the hardware is done 839 * processing the packet then free associated resources. The 840 * tx_buffer is put back on the free queue. 841 * 842 **********************************************************************/ 843 bool 844 ixl_txeof(struct ixl_queue *que) 845 { 846 struct tx_ring *txr = &que->txr; 847 u32 first, last, head, done, processed; 848 struct ixl_tx_buf *buf; 849 struct i40e_tx_desc *tx_desc, *eop_desc; 850 851 852 mtx_assert(&txr->mtx, MA_OWNED); 853 854 #ifdef DEV_NETMAP 855 // XXX todo: implement moderation 856 if (netmap_tx_irq(que->vsi->ifp, que->me)) 857 return FALSE; 858 #endif /* DEF_NETMAP */ 859 860 /* These are not the descriptors you seek, move along :) */ 861 if (txr->avail == que->num_desc) { 862 que->busy = 0; 863 return FALSE; 864 } 865 866 processed = 0; 867 first = txr->next_to_clean; 868 buf = &txr->buffers[first]; 869 tx_desc = (struct i40e_tx_desc *)&txr->base[first]; 870 last = buf->eop_index; 871 if (last == -1) 872 return FALSE; 873 eop_desc = (struct i40e_tx_desc *)&txr->base[last]; 874 875 /* Get the Head WB value */ 876 head = ixl_get_tx_head(que); 877 878 /* 879 ** Get the index of the first descriptor 880 ** BEYOND the EOP and call that 'done'. 881 ** I do this so the comparison in the 882 ** inner while loop below can be simple 883 */ 884 if (++last == que->num_desc) last = 0; 885 done = last; 886 887 bus_dmamap_sync(txr->dma.tag, txr->dma.map, 888 BUS_DMASYNC_POSTREAD); 889 /* 890 ** The HEAD index of the ring is written in a 891 ** defined location, this rather than a done bit 892 ** is what is used to keep track of what must be 893 ** 'cleaned'. 894 */ 895 while (first != head) { 896 /* We clean the range of the packet */ 897 while (first != done) { 898 ++txr->avail; 899 ++processed; 900 901 if (buf->m_head) { 902 txr->bytes += /* for ITR adjustment */ 903 buf->m_head->m_pkthdr.len; 904 txr->tx_bytes += /* for TX stats */ 905 buf->m_head->m_pkthdr.len; 906 bus_dmamap_sync(buf->tag, 907 buf->map, 908 BUS_DMASYNC_POSTWRITE); 909 bus_dmamap_unload(buf->tag, 910 buf->map); 911 m_freem(buf->m_head); 912 buf->m_head = NULL; 913 buf->map = NULL; 914 } 915 buf->eop_index = -1; 916 917 if (++first == que->num_desc) 918 first = 0; 919 920 buf = &txr->buffers[first]; 921 tx_desc = &txr->base[first]; 922 } 923 ++txr->packets; 924 /* See if there is more work now */ 925 last = buf->eop_index; 926 if (last != -1) { 927 eop_desc = &txr->base[last]; 928 /* Get next done point */ 929 if (++last == que->num_desc) last = 0; 930 done = last; 931 } else 932 break; 933 } 934 bus_dmamap_sync(txr->dma.tag, txr->dma.map, 935 BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); 936 937 txr->next_to_clean = first; 938 939 940 /* 941 ** Hang detection, we know there's 942 ** work outstanding or the first return 943 ** would have been taken, so indicate an 944 ** unsuccessful pass, in local_timer if 945 ** the value is too great the queue will 946 ** be considered hung. If anything has been 947 ** cleaned then reset the state. 948 */ 949 if ((processed == 0) && (que->busy != IXL_QUEUE_HUNG)) 950 ++que->busy; 951 952 if (processed) 953 que->busy = 1; /* Note this turns off HUNG */ 954 955 /* 956 * If there are no pending descriptors, clear the timeout. 957 */ 958 if (txr->avail == que->num_desc) { 959 que->busy = 0; 960 return FALSE; 961 } 962 963 return TRUE; 964 } 965 966 /********************************************************************* 967 * 968 * Refresh mbuf buffers for RX descriptor rings 969 * - now keeps its own state so discards due to resource 970 * exhaustion are unnecessary, if an mbuf cannot be obtained 971 * it just returns, keeping its placeholder, thus it can simply 972 * be recalled to try again. 973 * 974 **********************************************************************/ 975 static void 976 ixl_refresh_mbufs(struct ixl_queue *que, int limit) 977 { 978 struct ixl_vsi *vsi = que->vsi; 979 struct rx_ring *rxr = &que->rxr; 980 bus_dma_segment_t hseg[1]; 981 bus_dma_segment_t pseg[1]; 982 struct ixl_rx_buf *buf; 983 struct mbuf *mh, *mp; 984 int i, j, nsegs, error; 985 bool refreshed = FALSE; 986 987 i = j = rxr->next_refresh; 988 /* Control the loop with one beyond */ 989 if (++j == que->num_desc) 990 j = 0; 991 992 while (j != limit) { 993 buf = &rxr->buffers[i]; 994 if (rxr->hdr_split == FALSE) 995 goto no_split; 996 997 if (buf->m_head == NULL) { 998 mh = m_gethdr(M_NOWAIT, MT_DATA); 999 if (mh == NULL) 1000 goto update; 1001 } else 1002 mh = buf->m_head; 1003 1004 mh->m_pkthdr.len = mh->m_len = MHLEN; 1005 mh->m_len = MHLEN; 1006 mh->m_flags |= M_PKTHDR; 1007 /* Get the memory mapping */ 1008 error = bus_dmamap_load_mbuf_sg(rxr->htag, 1009 buf->hmap, mh, hseg, &nsegs, BUS_DMA_NOWAIT); 1010 if (error != 0) { 1011 printf("Refresh mbufs: hdr dmamap load" 1012 " failure - %d\n", error); 1013 m_free(mh); 1014 buf->m_head = NULL; 1015 goto update; 1016 } 1017 buf->m_head = mh; 1018 bus_dmamap_sync(rxr->htag, buf->hmap, 1019 BUS_DMASYNC_PREREAD); 1020 rxr->base[i].read.hdr_addr = 1021 htole64(hseg[0].ds_addr); 1022 1023 no_split: 1024 if (buf->m_pack == NULL) { 1025 mp = m_getjcl(M_NOWAIT, MT_DATA, 1026 M_PKTHDR, rxr->mbuf_sz); 1027 if (mp == NULL) 1028 goto update; 1029 } else 1030 mp = buf->m_pack; 1031 1032 mp->m_pkthdr.len = mp->m_len = rxr->mbuf_sz; 1033 /* Get the memory mapping */ 1034 error = bus_dmamap_load_mbuf_sg(rxr->ptag, 1035 buf->pmap, mp, pseg, &nsegs, BUS_DMA_NOWAIT); 1036 if (error != 0) { 1037 printf("Refresh mbufs: payload dmamap load" 1038 " failure - %d\n", error); 1039 m_free(mp); 1040 buf->m_pack = NULL; 1041 goto update; 1042 } 1043 buf->m_pack = mp; 1044 bus_dmamap_sync(rxr->ptag, buf->pmap, 1045 BUS_DMASYNC_PREREAD); 1046 rxr->base[i].read.pkt_addr = 1047 htole64(pseg[0].ds_addr); 1048 /* Used only when doing header split */ 1049 rxr->base[i].read.hdr_addr = 0; 1050 1051 refreshed = TRUE; 1052 /* Next is precalculated */ 1053 i = j; 1054 rxr->next_refresh = i; 1055 if (++j == que->num_desc) 1056 j = 0; 1057 } 1058 update: 1059 if (refreshed) /* Update hardware tail index */ 1060 wr32(vsi->hw, rxr->tail, rxr->next_refresh); 1061 return; 1062 } 1063 1064 1065 /********************************************************************* 1066 * 1067 * Allocate memory for rx_buffer structures. Since we use one 1068 * rx_buffer per descriptor, the maximum number of rx_buffer's 1069 * that we'll need is equal to the number of receive descriptors 1070 * that we've defined. 1071 * 1072 **********************************************************************/ 1073 int 1074 ixl_allocate_rx_data(struct ixl_queue *que) 1075 { 1076 struct rx_ring *rxr = &que->rxr; 1077 struct ixl_vsi *vsi = que->vsi; 1078 device_t dev = vsi->dev; 1079 struct ixl_rx_buf *buf; 1080 int i, bsize, error; 1081 1082 bsize = sizeof(struct ixl_rx_buf) * que->num_desc; 1083 if (!(rxr->buffers = 1084 (struct ixl_rx_buf *) malloc(bsize, 1085 M_DEVBUF, M_NOWAIT | M_ZERO))) { 1086 device_printf(dev, "Unable to allocate rx_buffer memory\n"); 1087 error = ENOMEM; 1088 return (error); 1089 } 1090 1091 if ((error = bus_dma_tag_create(NULL, /* parent */ 1092 1, 0, /* alignment, bounds */ 1093 BUS_SPACE_MAXADDR, /* lowaddr */ 1094 BUS_SPACE_MAXADDR, /* highaddr */ 1095 NULL, NULL, /* filter, filterarg */ 1096 MSIZE, /* maxsize */ 1097 1, /* nsegments */ 1098 MSIZE, /* maxsegsize */ 1099 0, /* flags */ 1100 NULL, /* lockfunc */ 1101 NULL, /* lockfuncarg */ 1102 &rxr->htag))) { 1103 device_printf(dev, "Unable to create RX DMA htag\n"); 1104 return (error); 1105 } 1106 1107 if ((error = bus_dma_tag_create(NULL, /* parent */ 1108 1, 0, /* alignment, bounds */ 1109 BUS_SPACE_MAXADDR, /* lowaddr */ 1110 BUS_SPACE_MAXADDR, /* highaddr */ 1111 NULL, NULL, /* filter, filterarg */ 1112 MJUM16BYTES, /* maxsize */ 1113 1, /* nsegments */ 1114 MJUM16BYTES, /* maxsegsize */ 1115 0, /* flags */ 1116 NULL, /* lockfunc */ 1117 NULL, /* lockfuncarg */ 1118 &rxr->ptag))) { 1119 device_printf(dev, "Unable to create RX DMA ptag\n"); 1120 return (error); 1121 } 1122 1123 for (i = 0; i < que->num_desc; i++) { 1124 buf = &rxr->buffers[i]; 1125 error = bus_dmamap_create(rxr->htag, 1126 BUS_DMA_NOWAIT, &buf->hmap); 1127 if (error) { 1128 device_printf(dev, "Unable to create RX head map\n"); 1129 break; 1130 } 1131 error = bus_dmamap_create(rxr->ptag, 1132 BUS_DMA_NOWAIT, &buf->pmap); 1133 if (error) { 1134 device_printf(dev, "Unable to create RX pkt map\n"); 1135 break; 1136 } 1137 } 1138 1139 return (error); 1140 } 1141 1142 1143 /********************************************************************* 1144 * 1145 * (Re)Initialize the queue receive ring and its buffers. 1146 * 1147 **********************************************************************/ 1148 int 1149 ixl_init_rx_ring(struct ixl_queue *que) 1150 { 1151 struct rx_ring *rxr = &que->rxr; 1152 struct ixl_vsi *vsi = que->vsi; 1153 #if defined(INET6) || defined(INET) 1154 struct ifnet *ifp = vsi->ifp; 1155 struct lro_ctrl *lro = &rxr->lro; 1156 #endif 1157 struct ixl_rx_buf *buf; 1158 bus_dma_segment_t pseg[1], hseg[1]; 1159 int rsize, nsegs, error = 0; 1160 #ifdef DEV_NETMAP 1161 struct netmap_adapter *na = NA(que->vsi->ifp); 1162 struct netmap_slot *slot; 1163 #endif /* DEV_NETMAP */ 1164 1165 IXL_RX_LOCK(rxr); 1166 #ifdef DEV_NETMAP 1167 /* same as in ixl_init_tx_ring() */ 1168 slot = netmap_reset(na, NR_RX, que->me, 0); 1169 #endif /* DEV_NETMAP */ 1170 /* Clear the ring contents */ 1171 rsize = roundup2(que->num_desc * 1172 sizeof(union i40e_rx_desc), DBA_ALIGN); 1173 bzero((void *)rxr->base, rsize); 1174 /* Cleanup any existing buffers */ 1175 for (int i = 0; i < que->num_desc; i++) { 1176 buf = &rxr->buffers[i]; 1177 if (buf->m_head != NULL) { 1178 bus_dmamap_sync(rxr->htag, buf->hmap, 1179 BUS_DMASYNC_POSTREAD); 1180 bus_dmamap_unload(rxr->htag, buf->hmap); 1181 buf->m_head->m_flags |= M_PKTHDR; 1182 m_freem(buf->m_head); 1183 } 1184 if (buf->m_pack != NULL) { 1185 bus_dmamap_sync(rxr->ptag, buf->pmap, 1186 BUS_DMASYNC_POSTREAD); 1187 bus_dmamap_unload(rxr->ptag, buf->pmap); 1188 buf->m_pack->m_flags |= M_PKTHDR; 1189 m_freem(buf->m_pack); 1190 } 1191 buf->m_head = NULL; 1192 buf->m_pack = NULL; 1193 } 1194 1195 /* header split is off */ 1196 rxr->hdr_split = FALSE; 1197 1198 /* Now replenish the mbufs */ 1199 for (int j = 0; j != que->num_desc; ++j) { 1200 struct mbuf *mh, *mp; 1201 1202 buf = &rxr->buffers[j]; 1203 #ifdef DEV_NETMAP 1204 /* 1205 * In netmap mode, fill the map and set the buffer 1206 * address in the NIC ring, considering the offset 1207 * between the netmap and NIC rings (see comment in 1208 * ixgbe_setup_transmit_ring() ). No need to allocate 1209 * an mbuf, so end the block with a continue; 1210 */ 1211 if (slot) { 1212 int sj = netmap_idx_n2k(&na->rx_rings[que->me], j); 1213 uint64_t paddr; 1214 void *addr; 1215 1216 addr = PNMB(na, slot + sj, &paddr); 1217 netmap_load_map(na, rxr->dma.tag, buf->pmap, addr); 1218 /* Update descriptor and the cached value */ 1219 rxr->base[j].read.pkt_addr = htole64(paddr); 1220 rxr->base[j].read.hdr_addr = 0; 1221 continue; 1222 } 1223 #endif /* DEV_NETMAP */ 1224 /* 1225 ** Don't allocate mbufs if not 1226 ** doing header split, its wasteful 1227 */ 1228 if (rxr->hdr_split == FALSE) 1229 goto skip_head; 1230 1231 /* First the header */ 1232 buf->m_head = m_gethdr(M_NOWAIT, MT_DATA); 1233 if (buf->m_head == NULL) { 1234 error = ENOBUFS; 1235 goto fail; 1236 } 1237 m_adj(buf->m_head, ETHER_ALIGN); 1238 mh = buf->m_head; 1239 mh->m_len = mh->m_pkthdr.len = MHLEN; 1240 mh->m_flags |= M_PKTHDR; 1241 /* Get the memory mapping */ 1242 error = bus_dmamap_load_mbuf_sg(rxr->htag, 1243 buf->hmap, buf->m_head, hseg, 1244 &nsegs, BUS_DMA_NOWAIT); 1245 if (error != 0) /* Nothing elegant to do here */ 1246 goto fail; 1247 bus_dmamap_sync(rxr->htag, 1248 buf->hmap, BUS_DMASYNC_PREREAD); 1249 /* Update descriptor */ 1250 rxr->base[j].read.hdr_addr = htole64(hseg[0].ds_addr); 1251 1252 skip_head: 1253 /* Now the payload cluster */ 1254 buf->m_pack = m_getjcl(M_NOWAIT, MT_DATA, 1255 M_PKTHDR, rxr->mbuf_sz); 1256 if (buf->m_pack == NULL) { 1257 error = ENOBUFS; 1258 goto fail; 1259 } 1260 mp = buf->m_pack; 1261 mp->m_pkthdr.len = mp->m_len = rxr->mbuf_sz; 1262 /* Get the memory mapping */ 1263 error = bus_dmamap_load_mbuf_sg(rxr->ptag, 1264 buf->pmap, mp, pseg, 1265 &nsegs, BUS_DMA_NOWAIT); 1266 if (error != 0) 1267 goto fail; 1268 bus_dmamap_sync(rxr->ptag, 1269 buf->pmap, BUS_DMASYNC_PREREAD); 1270 /* Update descriptor */ 1271 rxr->base[j].read.pkt_addr = htole64(pseg[0].ds_addr); 1272 rxr->base[j].read.hdr_addr = 0; 1273 } 1274 1275 1276 /* Setup our descriptor indices */ 1277 rxr->next_check = 0; 1278 rxr->next_refresh = 0; 1279 rxr->lro_enabled = FALSE; 1280 rxr->split = 0; 1281 rxr->bytes = 0; 1282 rxr->discard = FALSE; 1283 1284 wr32(vsi->hw, rxr->tail, que->num_desc - 1); 1285 ixl_flush(vsi->hw); 1286 1287 #if defined(INET6) || defined(INET) 1288 /* 1289 ** Now set up the LRO interface: 1290 */ 1291 if (ifp->if_capenable & IFCAP_LRO) { 1292 int err = tcp_lro_init(lro); 1293 if (err) { 1294 if_printf(ifp, "queue %d: LRO Initialization failed!\n", que->me); 1295 goto fail; 1296 } 1297 INIT_DBG_IF(ifp, "queue %d: RX Soft LRO Initialized", que->me); 1298 rxr->lro_enabled = TRUE; 1299 lro->ifp = vsi->ifp; 1300 } 1301 #endif 1302 1303 bus_dmamap_sync(rxr->dma.tag, rxr->dma.map, 1304 BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); 1305 1306 fail: 1307 IXL_RX_UNLOCK(rxr); 1308 return (error); 1309 } 1310 1311 1312 /********************************************************************* 1313 * 1314 * Free station receive ring data structures 1315 * 1316 **********************************************************************/ 1317 void 1318 ixl_free_que_rx(struct ixl_queue *que) 1319 { 1320 struct rx_ring *rxr = &que->rxr; 1321 struct ixl_rx_buf *buf; 1322 1323 INIT_DBG_IF(que->vsi->ifp, "queue %d: begin", que->me); 1324 1325 /* Cleanup any existing buffers */ 1326 if (rxr->buffers != NULL) { 1327 for (int i = 0; i < que->num_desc; i++) { 1328 buf = &rxr->buffers[i]; 1329 if (buf->m_head != NULL) { 1330 bus_dmamap_sync(rxr->htag, buf->hmap, 1331 BUS_DMASYNC_POSTREAD); 1332 bus_dmamap_unload(rxr->htag, buf->hmap); 1333 buf->m_head->m_flags |= M_PKTHDR; 1334 m_freem(buf->m_head); 1335 } 1336 if (buf->m_pack != NULL) { 1337 bus_dmamap_sync(rxr->ptag, buf->pmap, 1338 BUS_DMASYNC_POSTREAD); 1339 bus_dmamap_unload(rxr->ptag, buf->pmap); 1340 buf->m_pack->m_flags |= M_PKTHDR; 1341 m_freem(buf->m_pack); 1342 } 1343 buf->m_head = NULL; 1344 buf->m_pack = NULL; 1345 if (buf->hmap != NULL) { 1346 bus_dmamap_destroy(rxr->htag, buf->hmap); 1347 buf->hmap = NULL; 1348 } 1349 if (buf->pmap != NULL) { 1350 bus_dmamap_destroy(rxr->ptag, buf->pmap); 1351 buf->pmap = NULL; 1352 } 1353 } 1354 if (rxr->buffers != NULL) { 1355 free(rxr->buffers, M_DEVBUF); 1356 rxr->buffers = NULL; 1357 } 1358 } 1359 1360 if (rxr->htag != NULL) { 1361 bus_dma_tag_destroy(rxr->htag); 1362 rxr->htag = NULL; 1363 } 1364 if (rxr->ptag != NULL) { 1365 bus_dma_tag_destroy(rxr->ptag); 1366 rxr->ptag = NULL; 1367 } 1368 1369 INIT_DBG_IF(que->vsi->ifp, "queue %d: end", que->me); 1370 return; 1371 } 1372 1373 static __inline void 1374 ixl_rx_input(struct rx_ring *rxr, struct ifnet *ifp, struct mbuf *m, u8 ptype) 1375 { 1376 1377 #if defined(INET6) || defined(INET) 1378 /* 1379 * ATM LRO is only for IPv4/TCP packets and TCP checksum of the packet 1380 * should be computed by hardware. Also it should not have VLAN tag in 1381 * ethernet header. 1382 */ 1383 if (rxr->lro_enabled && 1384 (ifp->if_capenable & IFCAP_VLAN_HWTAGGING) != 0 && 1385 (m->m_pkthdr.csum_flags & (CSUM_DATA_VALID | CSUM_PSEUDO_HDR)) == 1386 (CSUM_DATA_VALID | CSUM_PSEUDO_HDR)) { 1387 /* 1388 * Send to the stack if: 1389 ** - LRO not enabled, or 1390 ** - no LRO resources, or 1391 ** - lro enqueue fails 1392 */ 1393 if (rxr->lro.lro_cnt != 0) 1394 if (tcp_lro_rx(&rxr->lro, m, 0) == 0) 1395 return; 1396 } 1397 #endif 1398 IXL_RX_UNLOCK(rxr); 1399 (*ifp->if_input)(ifp, m); 1400 IXL_RX_LOCK(rxr); 1401 } 1402 1403 1404 static __inline void 1405 ixl_rx_discard(struct rx_ring *rxr, int i) 1406 { 1407 struct ixl_rx_buf *rbuf; 1408 1409 rbuf = &rxr->buffers[i]; 1410 1411 if (rbuf->fmp != NULL) {/* Partial chain ? */ 1412 rbuf->fmp->m_flags |= M_PKTHDR; 1413 m_freem(rbuf->fmp); 1414 rbuf->fmp = NULL; 1415 } 1416 1417 /* 1418 ** With advanced descriptors the writeback 1419 ** clobbers the buffer addrs, so its easier 1420 ** to just free the existing mbufs and take 1421 ** the normal refresh path to get new buffers 1422 ** and mapping. 1423 */ 1424 if (rbuf->m_head) { 1425 m_free(rbuf->m_head); 1426 rbuf->m_head = NULL; 1427 } 1428 1429 if (rbuf->m_pack) { 1430 m_free(rbuf->m_pack); 1431 rbuf->m_pack = NULL; 1432 } 1433 1434 return; 1435 } 1436 1437 #ifdef RSS 1438 /* 1439 ** i40e_ptype_to_hash: parse the packet type 1440 ** to determine the appropriate hash. 1441 */ 1442 static inline int 1443 ixl_ptype_to_hash(u8 ptype) 1444 { 1445 struct i40e_rx_ptype_decoded decoded; 1446 u8 ex = 0; 1447 1448 decoded = decode_rx_desc_ptype(ptype); 1449 ex = decoded.outer_frag; 1450 1451 if (!decoded.known) 1452 return M_HASHTYPE_OPAQUE; 1453 1454 if (decoded.outer_ip == I40E_RX_PTYPE_OUTER_L2) 1455 return M_HASHTYPE_OPAQUE; 1456 1457 /* Note: anything that gets to this point is IP */ 1458 if (decoded.outer_ip_ver == I40E_RX_PTYPE_OUTER_IPV6) { 1459 switch (decoded.inner_prot) { 1460 case I40E_RX_PTYPE_INNER_PROT_TCP: 1461 if (ex) 1462 return M_HASHTYPE_RSS_TCP_IPV6_EX; 1463 else 1464 return M_HASHTYPE_RSS_TCP_IPV6; 1465 case I40E_RX_PTYPE_INNER_PROT_UDP: 1466 if (ex) 1467 return M_HASHTYPE_RSS_UDP_IPV6_EX; 1468 else 1469 return M_HASHTYPE_RSS_UDP_IPV6; 1470 default: 1471 if (ex) 1472 return M_HASHTYPE_RSS_IPV6_EX; 1473 else 1474 return M_HASHTYPE_RSS_IPV6; 1475 } 1476 } 1477 if (decoded.outer_ip_ver == I40E_RX_PTYPE_OUTER_IPV4) { 1478 switch (decoded.inner_prot) { 1479 case I40E_RX_PTYPE_INNER_PROT_TCP: 1480 return M_HASHTYPE_RSS_TCP_IPV4; 1481 case I40E_RX_PTYPE_INNER_PROT_UDP: 1482 if (ex) 1483 return M_HASHTYPE_RSS_UDP_IPV4_EX; 1484 else 1485 return M_HASHTYPE_RSS_UDP_IPV4; 1486 default: 1487 return M_HASHTYPE_RSS_IPV4; 1488 } 1489 } 1490 /* We should never get here!! */ 1491 return M_HASHTYPE_OPAQUE; 1492 } 1493 #endif /* RSS */ 1494 1495 /********************************************************************* 1496 * 1497 * This routine executes in interrupt context. It replenishes 1498 * the mbufs in the descriptor and sends data which has been 1499 * dma'ed into host memory to upper layer. 1500 * 1501 * We loop at most count times if count is > 0, or until done if 1502 * count < 0. 1503 * 1504 * Return TRUE for more work, FALSE for all clean. 1505 *********************************************************************/ 1506 bool 1507 ixl_rxeof(struct ixl_queue *que, int count) 1508 { 1509 struct ixl_vsi *vsi = que->vsi; 1510 struct rx_ring *rxr = &que->rxr; 1511 struct ifnet *ifp = vsi->ifp; 1512 #if defined(INET6) || defined(INET) 1513 struct lro_ctrl *lro = &rxr->lro; 1514 #endif 1515 int i, nextp, processed = 0; 1516 union i40e_rx_desc *cur; 1517 struct ixl_rx_buf *rbuf, *nbuf; 1518 1519 1520 IXL_RX_LOCK(rxr); 1521 1522 #ifdef DEV_NETMAP 1523 if (netmap_rx_irq(ifp, que->me, &count)) { 1524 IXL_RX_UNLOCK(rxr); 1525 return (FALSE); 1526 } 1527 #endif /* DEV_NETMAP */ 1528 1529 for (i = rxr->next_check; count != 0;) { 1530 struct mbuf *sendmp, *mh, *mp; 1531 u32 rsc, status, error; 1532 u16 hlen, plen, vtag; 1533 u64 qword; 1534 u8 ptype; 1535 bool eop; 1536 1537 /* Sync the ring. */ 1538 bus_dmamap_sync(rxr->dma.tag, rxr->dma.map, 1539 BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE); 1540 1541 cur = &rxr->base[i]; 1542 qword = le64toh(cur->wb.qword1.status_error_len); 1543 status = (qword & I40E_RXD_QW1_STATUS_MASK) 1544 >> I40E_RXD_QW1_STATUS_SHIFT; 1545 error = (qword & I40E_RXD_QW1_ERROR_MASK) 1546 >> I40E_RXD_QW1_ERROR_SHIFT; 1547 plen = (qword & I40E_RXD_QW1_LENGTH_PBUF_MASK) 1548 >> I40E_RXD_QW1_LENGTH_PBUF_SHIFT; 1549 hlen = (qword & I40E_RXD_QW1_LENGTH_HBUF_MASK) 1550 >> I40E_RXD_QW1_LENGTH_HBUF_SHIFT; 1551 ptype = (qword & I40E_RXD_QW1_PTYPE_MASK) 1552 >> I40E_RXD_QW1_PTYPE_SHIFT; 1553 1554 if ((status & (1 << I40E_RX_DESC_STATUS_DD_SHIFT)) == 0) { 1555 ++rxr->not_done; 1556 break; 1557 } 1558 if ((ifp->if_drv_flags & IFF_DRV_RUNNING) == 0) 1559 break; 1560 1561 count--; 1562 sendmp = NULL; 1563 nbuf = NULL; 1564 rsc = 0; 1565 cur->wb.qword1.status_error_len = 0; 1566 rbuf = &rxr->buffers[i]; 1567 mh = rbuf->m_head; 1568 mp = rbuf->m_pack; 1569 eop = (status & (1 << I40E_RX_DESC_STATUS_EOF_SHIFT)); 1570 if (status & (1 << I40E_RX_DESC_STATUS_L2TAG1P_SHIFT)) 1571 vtag = le16toh(cur->wb.qword0.lo_dword.l2tag1); 1572 else 1573 vtag = 0; 1574 1575 /* 1576 ** Make sure bad packets are discarded, 1577 ** note that only EOP descriptor has valid 1578 ** error results. 1579 */ 1580 if (eop && (error & (1 << I40E_RX_DESC_ERROR_RXE_SHIFT))) { 1581 rxr->discarded++; 1582 ixl_rx_discard(rxr, i); 1583 goto next_desc; 1584 } 1585 1586 /* Prefetch the next buffer */ 1587 if (!eop) { 1588 nextp = i + 1; 1589 if (nextp == que->num_desc) 1590 nextp = 0; 1591 nbuf = &rxr->buffers[nextp]; 1592 prefetch(nbuf); 1593 } 1594 1595 /* 1596 ** The header mbuf is ONLY used when header 1597 ** split is enabled, otherwise we get normal 1598 ** behavior, ie, both header and payload 1599 ** are DMA'd into the payload buffer. 1600 ** 1601 ** Rather than using the fmp/lmp global pointers 1602 ** we now keep the head of a packet chain in the 1603 ** buffer struct and pass this along from one 1604 ** descriptor to the next, until we get EOP. 1605 */ 1606 if (rxr->hdr_split && (rbuf->fmp == NULL)) { 1607 if (hlen > IXL_RX_HDR) 1608 hlen = IXL_RX_HDR; 1609 mh->m_len = hlen; 1610 mh->m_flags |= M_PKTHDR; 1611 mh->m_next = NULL; 1612 mh->m_pkthdr.len = mh->m_len; 1613 /* Null buf pointer so it is refreshed */ 1614 rbuf->m_head = NULL; 1615 /* 1616 ** Check the payload length, this 1617 ** could be zero if its a small 1618 ** packet. 1619 */ 1620 if (plen > 0) { 1621 mp->m_len = plen; 1622 mp->m_next = NULL; 1623 mp->m_flags &= ~M_PKTHDR; 1624 mh->m_next = mp; 1625 mh->m_pkthdr.len += mp->m_len; 1626 /* Null buf pointer so it is refreshed */ 1627 rbuf->m_pack = NULL; 1628 rxr->split++; 1629 } 1630 /* 1631 ** Now create the forward 1632 ** chain so when complete 1633 ** we wont have to. 1634 */ 1635 if (eop == 0) { 1636 /* stash the chain head */ 1637 nbuf->fmp = mh; 1638 /* Make forward chain */ 1639 if (plen) 1640 mp->m_next = nbuf->m_pack; 1641 else 1642 mh->m_next = nbuf->m_pack; 1643 } else { 1644 /* Singlet, prepare to send */ 1645 sendmp = mh; 1646 if (vtag) { 1647 sendmp->m_pkthdr.ether_vtag = vtag; 1648 sendmp->m_flags |= M_VLANTAG; 1649 } 1650 } 1651 } else { 1652 /* 1653 ** Either no header split, or a 1654 ** secondary piece of a fragmented 1655 ** split packet. 1656 */ 1657 mp->m_len = plen; 1658 /* 1659 ** See if there is a stored head 1660 ** that determines what we are 1661 */ 1662 sendmp = rbuf->fmp; 1663 rbuf->m_pack = rbuf->fmp = NULL; 1664 1665 if (sendmp != NULL) /* secondary frag */ 1666 sendmp->m_pkthdr.len += mp->m_len; 1667 else { 1668 /* first desc of a non-ps chain */ 1669 sendmp = mp; 1670 sendmp->m_flags |= M_PKTHDR; 1671 sendmp->m_pkthdr.len = mp->m_len; 1672 if (vtag) { 1673 sendmp->m_pkthdr.ether_vtag = vtag; 1674 sendmp->m_flags |= M_VLANTAG; 1675 } 1676 } 1677 /* Pass the head pointer on */ 1678 if (eop == 0) { 1679 nbuf->fmp = sendmp; 1680 sendmp = NULL; 1681 mp->m_next = nbuf->m_pack; 1682 } 1683 } 1684 ++processed; 1685 /* Sending this frame? */ 1686 if (eop) { 1687 sendmp->m_pkthdr.rcvif = ifp; 1688 /* gather stats */ 1689 rxr->rx_packets++; 1690 rxr->rx_bytes += sendmp->m_pkthdr.len; 1691 /* capture data for dynamic ITR adjustment */ 1692 rxr->packets++; 1693 rxr->bytes += sendmp->m_pkthdr.len; 1694 if ((ifp->if_capenable & IFCAP_RXCSUM) != 0) 1695 ixl_rx_checksum(sendmp, status, error, ptype); 1696 #ifdef RSS 1697 sendmp->m_pkthdr.flowid = 1698 le32toh(cur->wb.qword0.hi_dword.rss); 1699 M_HASHTYPE_SET(sendmp, ixl_ptype_to_hash(ptype)); 1700 #else 1701 sendmp->m_pkthdr.flowid = que->msix; 1702 M_HASHTYPE_SET(sendmp, M_HASHTYPE_OPAQUE); 1703 #endif 1704 } 1705 next_desc: 1706 bus_dmamap_sync(rxr->dma.tag, rxr->dma.map, 1707 BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); 1708 1709 /* Advance our pointers to the next descriptor. */ 1710 if (++i == que->num_desc) 1711 i = 0; 1712 1713 /* Now send to the stack or do LRO */ 1714 if (sendmp != NULL) { 1715 rxr->next_check = i; 1716 ixl_rx_input(rxr, ifp, sendmp, ptype); 1717 i = rxr->next_check; 1718 } 1719 1720 /* Every 8 descriptors we go to refresh mbufs */ 1721 if (processed == 8) { 1722 ixl_refresh_mbufs(que, i); 1723 processed = 0; 1724 } 1725 } 1726 1727 /* Refresh any remaining buf structs */ 1728 if (ixl_rx_unrefreshed(que)) 1729 ixl_refresh_mbufs(que, i); 1730 1731 rxr->next_check = i; 1732 1733 #if defined(INET6) || defined(INET) 1734 /* 1735 * Flush any outstanding LRO work 1736 */ 1737 tcp_lro_flush_all(lro); 1738 #endif 1739 1740 IXL_RX_UNLOCK(rxr); 1741 return (FALSE); 1742 } 1743 1744 1745 /********************************************************************* 1746 * 1747 * Verify that the hardware indicated that the checksum is valid. 1748 * Inform the stack about the status of checksum so that stack 1749 * doesn't spend time verifying the checksum. 1750 * 1751 *********************************************************************/ 1752 static void 1753 ixl_rx_checksum(struct mbuf * mp, u32 status, u32 error, u8 ptype) 1754 { 1755 struct i40e_rx_ptype_decoded decoded; 1756 1757 decoded = decode_rx_desc_ptype(ptype); 1758 1759 /* Errors? */ 1760 if (error & ((1 << I40E_RX_DESC_ERROR_IPE_SHIFT) | 1761 (1 << I40E_RX_DESC_ERROR_L4E_SHIFT))) { 1762 mp->m_pkthdr.csum_flags = 0; 1763 return; 1764 } 1765 1766 /* IPv6 with extension headers likely have bad csum */ 1767 if (decoded.outer_ip == I40E_RX_PTYPE_OUTER_IP && 1768 decoded.outer_ip_ver == I40E_RX_PTYPE_OUTER_IPV6) 1769 if (status & 1770 (1 << I40E_RX_DESC_STATUS_IPV6EXADD_SHIFT)) { 1771 mp->m_pkthdr.csum_flags = 0; 1772 return; 1773 } 1774 1775 1776 /* IP Checksum Good */ 1777 mp->m_pkthdr.csum_flags = CSUM_IP_CHECKED; 1778 mp->m_pkthdr.csum_flags |= CSUM_IP_VALID; 1779 1780 if (status & (1 << I40E_RX_DESC_STATUS_L3L4P_SHIFT)) { 1781 mp->m_pkthdr.csum_flags |= 1782 (CSUM_DATA_VALID | CSUM_PSEUDO_HDR); 1783 mp->m_pkthdr.csum_data |= htons(0xffff); 1784 } 1785 return; 1786 } 1787 1788 #if __FreeBSD_version >= 1100000 1789 uint64_t 1790 ixl_get_counter(if_t ifp, ift_counter cnt) 1791 { 1792 struct ixl_vsi *vsi; 1793 1794 vsi = if_getsoftc(ifp); 1795 1796 switch (cnt) { 1797 case IFCOUNTER_IPACKETS: 1798 return (vsi->ipackets); 1799 case IFCOUNTER_IERRORS: 1800 return (vsi->ierrors); 1801 case IFCOUNTER_OPACKETS: 1802 return (vsi->opackets); 1803 case IFCOUNTER_OERRORS: 1804 return (vsi->oerrors); 1805 case IFCOUNTER_COLLISIONS: 1806 /* Collisions are by standard impossible in 40G/10G Ethernet */ 1807 return (0); 1808 case IFCOUNTER_IBYTES: 1809 return (vsi->ibytes); 1810 case IFCOUNTER_OBYTES: 1811 return (vsi->obytes); 1812 case IFCOUNTER_IMCASTS: 1813 return (vsi->imcasts); 1814 case IFCOUNTER_OMCASTS: 1815 return (vsi->omcasts); 1816 case IFCOUNTER_IQDROPS: 1817 return (vsi->iqdrops); 1818 case IFCOUNTER_OQDROPS: 1819 return (vsi->oqdrops); 1820 case IFCOUNTER_NOPROTO: 1821 return (vsi->noproto); 1822 default: 1823 return (if_get_counter_default(ifp, cnt)); 1824 } 1825 } 1826 #endif 1827 1828