From owner-p4-projects@FreeBSD.ORG Wed Oct 31 22:20:07 2007 Return-Path: Delivered-To: p4-projects@freebsd.org Received: by hub.freebsd.org (Postfix, from userid 32767) id ED29316A420; Wed, 31 Oct 2007 22:20:06 +0000 (UTC) Delivered-To: perforce@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 8B42516A419 for ; Wed, 31 Oct 2007 22:20:06 +0000 (UTC) (envelope-from kmacy@freebsd.org) Received: from repoman.freebsd.org (repoman.freebsd.org [IPv6:2001:4f8:fff6::29]) by mx1.freebsd.org (Postfix) with ESMTP id 7210313C480 for ; Wed, 31 Oct 2007 22:20:06 +0000 (UTC) (envelope-from kmacy@freebsd.org) Received: from repoman.freebsd.org (localhost [127.0.0.1]) by repoman.freebsd.org (8.14.1/8.14.1) with ESMTP id l9VMK6IU039671 for ; Wed, 31 Oct 2007 22:20:06 GMT (envelope-from kmacy@freebsd.org) Received: (from perforce@localhost) by repoman.freebsd.org (8.14.1/8.14.1/Submit) id l9VMK6f2039668 for perforce@freebsd.org; Wed, 31 Oct 2007 22:20:06 GMT (envelope-from kmacy@freebsd.org) Date: Wed, 31 Oct 2007 22:20:06 GMT Message-Id: <200710312220.l9VMK6f2039668@repoman.freebsd.org> X-Authentication-Warning: repoman.freebsd.org: perforce set sender to kmacy@freebsd.org using -f From: Kip Macy To: Perforce Change Reviews Cc: Subject: PERFORCE change 128431 for review X-BeenThere: p4-projects@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: p4 projects tree changes List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 31 Oct 2007 22:20:07 -0000 http://perforce.freebsd.org/chv.cgi?CH=128431 Change 128431 by kmacy@kmacy:storage:toestack on 2007/10/31 22:19:17 - add sanity checks to write immediate - make sure rx_offload gets called for non-tunnelled packets Affected files ... .. //depot/projects/toestack/sys/dev/cxgb/cxgb_sge.c#8 edit Differences ... ==== //depot/projects/toestack/sys/dev/cxgb/cxgb_sge.c#8 (text+ko) ==== @@ -1501,6 +1501,11 @@ struct work_request_hdr *from = mtod(m, struct work_request_hdr *); struct work_request_hdr *to = (struct work_request_hdr *)d; + if (len > WR_LEN) + panic("len too big %d\n", len); + if (len < sizeof(*from)) + panic("len too small %d", len); + memcpy(&to[1], &from[1], len - sizeof(*from)); to->wr_hi = from->wr_hi | htonl(F_WR_SOP | F_WR_EOP | V_WR_BCNTLFLT(len & 7)); @@ -1508,6 +1513,8 @@ to->wr_lo = from->wr_lo | htonl(V_WR_GEN(gen) | V_WR_LEN((len + 7) / 8)); wr_gen2(d, gen); + + printf("m_freeing %p\n", m); m_freem(m); } @@ -1617,13 +1624,14 @@ if (__predict_false(ret)) { if (ret == 1) { mtx_unlock(&q->lock); + printf("no desc available\n"); + return (-1); } goto again; } - write_imm(&q->desc[q->pidx], m, m->m_len, q->gen); - + q->in_use++; if (++q->pidx >= q->size) { q->pidx = 0; @@ -2017,7 +2025,9 @@ struct mbuf *m_vec[TX_CLEAN_MAX_DESC]; bus_dma_segment_t segs[TX_MAX_SEGS]; int cleaned; - struct tx_sw_desc *stx = &q->sdesc[q->pidx]; + struct tx_sw_desc *stx; + + stx = &q->sdesc[q->pidx]; mtx_lock(&q->lock); if ((ret = busdma_map_mbufs(&m, q, stx, segs, &nsegs)) != 0) { @@ -2174,7 +2184,7 @@ adapter_t *adap = tdev2adap(tdev); struct sge_qset *qs = &adap->sge.qs[queue_set(m)]; - if (__predict_false(is_ctrl_pkt(m))) + if (__predict_false(is_ctrl_pkt(m))) return ctrl_xmit(adap, &qs->txq[TXQ_CTRL], m); return ofld_xmit(adap, &qs->txq[TXQ_OFLD], m); @@ -2205,9 +2215,9 @@ struct mbuf *m, struct mbuf *rx_gather[], unsigned int gather_idx) { + rq->offload_pkts++; m->m_pkthdr.header = mtod(m, void *); - rx_gather[gather_idx++] = m; if (gather_idx == RX_BUNDLE_SIZE) { cxgb_ofld_recv(tdev, rx_gather, RX_BUNDLE_SIZE); @@ -2788,7 +2798,8 @@ } #else struct mbuf *m = NULL; - + + DPRINTF("IMM DATA VALID opcode=0x%x rspq->cidx=%d\n", r->rss_hdr.opcode, rspq->cidx); if (rspq->rspq_mbuf == NULL) rspq->rspq_mbuf = m_gethdr(M_DONTWAIT, MT_DATA); else @@ -2802,11 +2813,13 @@ budget_left--; break; } - if (get_imm_packet(adap, r, rspq->rspq_mbuf, m, flags)) + if (get_imm_packet(adap, r, rspq->rspq_mbuf, m, flags)) { + eop = 1; + rspq->imm_data++; goto skip; - eop = 1; + } + #endif - rspq->imm_data++; } else if (r->len_cq) { int drop_thresh = eth ? SGE_RX_DROP_THRES : 0; @@ -2850,26 +2863,26 @@ refill_rspq(adap, rspq, rspq->credits); rspq->credits = 0; } - - if (eop) { + DPRINTF("eth=%d eop=%d flags=0x%x\n", eth, eop, flags); + + if (!eth && eop) { + rspq->rspq_mh.mh_head->m_pkthdr.csum_data = rss_csum; + /* + * XXX size mismatch + */ + m_set_priority(rspq->rspq_mh.mh_head, rss_hash); + + ngathered = rx_offload(&adap->tdev, rspq, + rspq->rspq_mh.mh_head, offload_mbufs, ngathered); + rspq->rspq_mh.mh_head = NULL; + } else if (eth && eop) { prefetch(mtod(rspq->rspq_mh.mh_head, uint8_t *)); prefetch(mtod(rspq->rspq_mh.mh_head, uint8_t *) + L1_CACHE_BYTES); - if (eth) { - t3_rx_eth_lro(adap, rspq, rspq->rspq_mh.mh_head, ethpad, - rss_hash, rss_csum, lro); + t3_rx_eth_lro(adap, rspq, rspq->rspq_mh.mh_head, ethpad, + rss_hash, rss_csum, lro); rspq->rspq_mh.mh_head = NULL; - } else { - rspq->rspq_mh.mh_head->m_pkthdr.csum_data = rss_csum; - /* - * XXX size mismatch - */ - m_set_priority(rspq->rspq_mh.mh_head, rss_hash); - - ngathered = rx_offload(&adap->tdev, rspq, - rspq->rspq_mh.mh_head, offload_mbufs, ngathered); - } } __refill_fl_lt(adap, &qs->fl[0], 32);