Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp132604ybl; Thu, 29 Aug 2019 20:07:40 -0700 (PDT) X-Google-Smtp-Source: APXvYqzIKE3D2eHLnE9omPuxuz/yKFnh4pAXRUUXmpI3SiwmxCr/81WGgOqg/FnyjpG/J7OmL2vF X-Received: by 2002:a17:902:b604:: with SMTP id b4mr13054286pls.94.1567134460380; Thu, 29 Aug 2019 20:07:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567134460; cv=none; d=google.com; s=arc-20160816; b=qrXwzkSi4TtgupdU4fbrNpPahrxRd/TJ12PlZH35y/4lzqZ31jygdLug3C19KxM2u+ yjl6pIIznNh3sfirdacC0ARQI67AQ6SE21mGyQnivjirnLm/12yrLnZi5Y63bKp0pdLY TscyFYuUt1EFQSFmdG9yb5SrC9jpP7t6glbpNV1ieCG2qrjedjupnmlIL80MJIU4ea65 iShlqC8IthPl7UIoR1OMlJKrYvnyvkPrYrnMLWy7n8gB9UZ+4sVh3tXiYkSPBty7GpRg G6QRzzv5lo6G1LWdMacPMAuduIh1FRg4ihOXniEs3VVNPaKxzSxwQsrhB56AyzR+B4Yk Ft7g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=P7vQRVI5UD1/xcxqfUrPTlmNdr0gcGHeCjrwJUAm6Fs=; b=pe7lQ2GK35dWpGs2yG8fsWAhANkxaLYMRQ5WhN/jB9H36OYgXt63ZpYNZ3kDU6nR7V sfvu0uU+3dWN326/3N6/m19V75v14uIgp6jwE4i9nex9qKbdCCy+pkh2Rl3YX7/PAPue tdGhkVFuHscXB6fE88gLY/L/8EkzM24SA7GYST7FHUC+0kH440EBS5UOfNZdzPXWctyr xtisT1LdhxDVhfxP4avNmoCv5bln+bFN1XGX6GfI5LH7VvWeh6BuxPvWzqv/+20r15RA acmyVEv+jZ/ob7176k7m+5eeF0d/bf3J3FofPxsVlx5yJxfWwA52ijkRYZceKMj3IaBd wICw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=OTgzdxb3; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l70si3472615pge.446.2019.08.29.20.07.23; Thu, 29 Aug 2019 20:07:40 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=OTgzdxb3; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727392AbfH3DHS (ORCPT + 99 others); Thu, 29 Aug 2019 23:07:18 -0400 Received: from mail-qt1-f196.google.com ([209.85.160.196]:35881 "EHLO mail-qt1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727110AbfH3DHS (ORCPT ); Thu, 29 Aug 2019 23:07:18 -0400 Received: by mail-qt1-f196.google.com with SMTP id z4so6158848qtc.3 for ; Thu, 29 Aug 2019 20:07:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=P7vQRVI5UD1/xcxqfUrPTlmNdr0gcGHeCjrwJUAm6Fs=; b=OTgzdxb3fx1Y3NkbtL5/GsS0qDYldO2RciuAJlohK03CLqysGHMKlbzRH9nLK3EPNw x4Sd677Q2fe/SV7Z7ZkVySlGzp+Az46/J15mUev+9w5UQfkOdAP5IW3j3lUsr7LOvcPd 2uVQxoPFREYM/NfAK1Hn+hQJzAqY/NJM15I9s= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=P7vQRVI5UD1/xcxqfUrPTlmNdr0gcGHeCjrwJUAm6Fs=; b=CRK5fa9X+7+CGCKwzTdKl6fbjiV1Dl/WJ5tpuGS75QU3upzUN3Y+aQoE6KNH1ShJPu bGPYcSGTU29M4jBiNWrOJ3IBz/kT+dyLrVKPLqousmSpJEFoY67AFHfxYZfEzHjoLg/I q7X8nHqRQeA3zzSTnPZf4xOkLf3Ng8ImWkB3oGgkGd36oEvEom7BPwH2q2dl10niJOzL xgAearujjlIrBLOBG9JkdzX8/TZsOL4u0g0zjdcOOK7SFtmRSBGWWqxZIQZKyGmFbEpS aIFoKZPB0m9mWuU7V6sXA+vB5ko/Fgy6k5etF0Q2iOys2Db6hhqq/MfFfzjoGY0LsiZm txXg== X-Gm-Message-State: APjAAAVIMNro67D19XnmY3oWeF1rrbIPjsz773PFJ8lsztKAIOvjjrXr JbF/anT3EXWdvIEe2bgw4yqWsdN+wSFRQlMjtrD5yA== X-Received: by 2002:ad4:490c:: with SMTP id bh12mr8720502qvb.59.1567134437109; Thu, 29 Aug 2019 20:07:17 -0700 (PDT) MIME-Version: 1.0 References: <1566998177-2658-1-git-send-email-wgong@codeaurora.org> <1566998177-2658-3-git-send-email-wgong@codeaurora.org> In-Reply-To: <1566998177-2658-3-git-send-email-wgong@codeaurora.org> From: Nicolas Boichat Date: Fri, 30 Aug 2019 11:07:06 +0800 Message-ID: Subject: Re: [PATCH v3 2/8] ath10k: enable RX bundle receive for sdio To: Wen Gong Cc: ath10k@lists.infradead.org, "open list:NETWORKING DRIVERS (WIRELESS)" Content-Type: text/plain; charset="UTF-8" Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org On Thu, Aug 29, 2019 at 11:49 PM Wen Gong wrote: > > From: Alagu Sankar > > The existing implementation of initiating multiple sdio transfers for > receive bundling is slowing down the receive speed. Combining the > transfers using a bundle method would be ideal. > > The transmission utilization ratio for sdio bus for small packet is > slow, because the space and time cost for sdio bus is same for large > length packet and small length packet. So the speed of data for large > length packet is higher than small length. > > Test result of different length of data: > data packet(byte) cost time(us) calculated rate(Mbps) > 256 28 73 > 512 33 124 > 1024 35 234 > 1792 45 318 > 14336 168 682 > 28672 333 688 > 57344 660 695 > > Tested with QCA6174 SDIO with firmware > WLAN.RMH.4.4.1-00007-QCARMSWP-1. > > Signed-off-by: Alagu Sankar > Signed-off-by: Wen Gong > --- > v2: fix incorrect skb tail of rx bundle in ath10k_sdio_mbox_rx_process_packet > v3: change some code style > split fix incorrect skb tail of rx bundle to patch "adjust skb length in ath10k_sdio_mbox_rx_packet" > > drivers/net/wireless/ath/ath10k/sdio.c | 106 +++++++++++++++++++++------------ > drivers/net/wireless/ath/ath10k/sdio.h | 7 ++- > 2 files changed, 74 insertions(+), 39 deletions(-) > > diff --git a/drivers/net/wireless/ath/ath10k/sdio.c b/drivers/net/wireless/ath/ath10k/sdio.c > index 1127e44..23c998d 100644 > --- a/drivers/net/wireless/ath/ath10k/sdio.c > +++ b/drivers/net/wireless/ath/ath10k/sdio.c > @@ -24,6 +24,9 @@ > #include "trace.h" > #include "sdio.h" > > +#define ATH10K_SDIO_DMA_BUF_SIZE (32 * 1024) > +#define ATH10K_SDIO_VSG_BUF_SIZE (32 * 1024) > + > /* inlined helper functions */ > > static inline int ath10k_sdio_calc_txrx_padded_len(struct ath10k_sdio *ar_sdio, > @@ -484,11 +487,11 @@ static int ath10k_sdio_mbox_rx_process_packets(struct ath10k *ar, > return ret; > } > > -static int ath10k_sdio_mbox_alloc_pkt_bundle(struct ath10k *ar, > - struct ath10k_sdio_rx_data *rx_pkts, > - struct ath10k_htc_hdr *htc_hdr, > - size_t full_len, size_t act_len, > - size_t *bndl_cnt) > +static int ath10k_sdio_mbox_alloc_bundle(struct ath10k *ar, > + struct ath10k_sdio_rx_data *rx_pkts, > + struct ath10k_htc_hdr *htc_hdr, > + size_t full_len, size_t act_len, > + size_t *bndl_cnt) > { > int ret, i; > > @@ -529,6 +532,7 @@ static int ath10k_sdio_mbox_rx_alloc(struct ath10k *ar, > size_t full_len, act_len; > bool last_in_bundle; > int ret, i; > + int pkt_cnt = 0; > > if (n_lookaheads > ATH10K_SDIO_MAX_RX_MSGS) { > ath10k_warn(ar, > @@ -572,20 +576,22 @@ static int ath10k_sdio_mbox_rx_alloc(struct ath10k *ar, > */ > size_t bndl_cnt; > > - ret = ath10k_sdio_mbox_alloc_pkt_bundle(ar, > - &ar_sdio->rx_pkts[i], > - htc_hdr, > - full_len, > - act_len, > - &bndl_cnt); > + struct ath10k_sdio_rx_data *rx_pkts = > + &ar_sdio->rx_pkts[pkt_cnt]; > + > + ret = ath10k_sdio_mbox_alloc_bundle(ar, > + rx_pkts, > + htc_hdr, > + full_len, > + act_len, > + &bndl_cnt); > > if (ret) { > ath10k_warn(ar, "alloc_bundle error %d\n", ret); > goto err; > } > > - n_lookaheads += bndl_cnt; > - i += bndl_cnt; > + pkt_cnt += bndl_cnt; > /*Next buffer will be the last in the bundle */ > last_in_bundle = true; > } > @@ -597,7 +603,7 @@ static int ath10k_sdio_mbox_rx_alloc(struct ath10k *ar, > if (htc_hdr->flags & ATH10K_HTC_FLAGS_RECV_1MORE_BLOCK) > full_len += ATH10K_HIF_MBOX_BLOCK_SIZE; > > - ret = ath10k_sdio_mbox_alloc_rx_pkt(&ar_sdio->rx_pkts[i], > + ret = ath10k_sdio_mbox_alloc_rx_pkt(&ar_sdio->rx_pkts[pkt_cnt], > act_len, > full_len, > last_in_bundle, > @@ -606,9 +612,10 @@ static int ath10k_sdio_mbox_rx_alloc(struct ath10k *ar, > ath10k_warn(ar, "alloc_rx_pkt error %d\n", ret); > goto err; > } > + pkt_cnt++; > } > > - ar_sdio->n_rx_pkts = i; > + ar_sdio->n_rx_pkts = pkt_cnt; > > return 0; > > @@ -622,10 +629,10 @@ static int ath10k_sdio_mbox_rx_alloc(struct ath10k *ar, > return ret; > } > > -static int ath10k_sdio_mbox_rx_packet(struct ath10k *ar, > - struct ath10k_sdio_rx_data *pkt) > +static int ath10k_sdio_mbox_rx_fetch(struct ath10k *ar) > { > struct ath10k_sdio *ar_sdio = ath10k_sdio_priv(ar); > + struct ath10k_sdio_rx_data *pkt = &ar_sdio->rx_pkts[0]; > struct sk_buff *skb = pkt->skb; > struct ath10k_htc_hdr *htc_hdr; > int ret; > @@ -633,46 +640,62 @@ static int ath10k_sdio_mbox_rx_packet(struct ath10k *ar, > ret = ath10k_sdio_readsb(ar, ar_sdio->mbox_info.htc_addr, > skb->data, pkt->alloc_len); > > - if (!ret) { > - /* Update actual length. The original length may be incorrect, > - * as the FW will bundle multiple packets as long as their sizes > - * fit within the same aligned length (pkt->alloc_len). > - */ > - htc_hdr = (struct ath10k_htc_hdr *)skb->data; > - pkt->act_len = le16_to_cpu(htc_hdr->len) + sizeof(*htc_hdr); > - if (pkt->act_len <= pkt->alloc_len) { > - skb_put(skb, pkt->act_len); > - } else { > - ath10k_warn(ar, "rx packet too large (%zu > %zu)\n", > - pkt->act_len, pkt->alloc_len); > - ret = -EMSGSIZE; > - } > + if (ret) { > + ar_sdio->n_rx_pkts = 0; > + ath10k_sdio_mbox_free_rx_pkt(pkt); > + return ret; > } > > + htc_hdr = (struct ath10k_htc_hdr *)skb->data; > + pkt->act_len = le16_to_cpu(htc_hdr->len) + sizeof(*htc_hdr); > pkt->status = ret; > + skb_put(skb, pkt->act_len); > > return ret; > } > > -static int ath10k_sdio_mbox_rx_fetch(struct ath10k *ar) > +static int ath10k_sdio_mbox_rx_fetch_bundle(struct ath10k *ar) > { > struct ath10k_sdio *ar_sdio = ath10k_sdio_priv(ar); > + struct ath10k_sdio_rx_data *pkt; > + struct ath10k_htc_hdr *htc_hdr; > int ret, i; > + u32 pkt_offset, virt_pkt_len; > > + virt_pkt_len = 0; > for (i = 0; i < ar_sdio->n_rx_pkts; i++) { > - ret = ath10k_sdio_mbox_rx_packet(ar, > - &ar_sdio->rx_pkts[i]); > + virt_pkt_len += ar_sdio->rx_pkts[i].alloc_len; > + } > + > + if (virt_pkt_len < ATH10K_SDIO_DMA_BUF_SIZE) { > + ret = ath10k_sdio_readsb(ar, ar_sdio->mbox_info.htc_addr, > + ar_sdio->vsg_buffer, virt_pkt_len); > if (ret) > goto err; > + } else { > + ath10k_err(ar, "size exceeding limit %d\n", virt_pkt_len); Should you set err and goto err here? It seems like you're going to process garbage if this happens. > + } > + > + pkt_offset = 0; > + for (i = 0; i < ar_sdio->n_rx_pkts; i++) { > + pkt = &ar_sdio->rx_pkts[i]; > + htc_hdr = (struct ath10k_htc_hdr *)(ar_sdio->vsg_buffer + pkt_offset); > + pkt->act_len = le16_to_cpu(htc_hdr->len) + sizeof(*htc_hdr); > + > + skb_put_data(pkt->skb, htc_hdr, pkt->act_len); > + pkt->status = 0; > + pkt_offset += pkt->alloc_len; > } > > return 0; > > err: > /* Free all packets that was not successfully fetched. */ Well you're freeing everything, now. > - for (; i < ar_sdio->n_rx_pkts; i++) > + for (i = 0; i < ar_sdio->n_rx_pkts; i++) > ath10k_sdio_mbox_free_rx_pkt(&ar_sdio->rx_pkts[i]); > > + ar_sdio->n_rx_pkts = 0; > + > return ret; > } > > @@ -715,7 +738,10 @@ static int ath10k_sdio_mbox_rxmsg_pending_handler(struct ath10k *ar, > */ > *done = false; > > - ret = ath10k_sdio_mbox_rx_fetch(ar); > + if (ar_sdio->n_rx_pkts > 1) > + ret = ath10k_sdio_mbox_rx_fetch_bundle(ar); > + else > + ret = ath10k_sdio_mbox_rx_fetch(ar); > > /* Process fetched packets. This will potentially update > * n_lookaheads depending on if the packets contain lookahead > @@ -1123,7 +1149,7 @@ static int ath10k_sdio_bmi_get_rx_lookahead(struct ath10k *ar) > MBOX_HOST_INT_STATUS_ADDRESS, > &rx_word); > if (ret) { > - ath10k_warn(ar, "unable to read RX_LOOKAHEAD_VALID: %d\n", ret); > + ath10k_warn(ar, "unable to read rx_lookahd: %d\n", ret); > return ret; > } > > @@ -2018,6 +2044,12 @@ static int ath10k_sdio_probe(struct sdio_func *func, > goto err_core_destroy; > } > > + ar_sdio->vsg_buffer = devm_kmalloc(ar->dev, ATH10K_SDIO_VSG_BUF_SIZE, GFP_KERNEL); > + if (!ar_sdio->vsg_buffer) { > + ret = -ENOMEM; > + goto err_core_destroy; > + } > + > ar_sdio->irq_data.irq_en_reg = > devm_kzalloc(ar->dev, sizeof(struct ath10k_sdio_irq_enable_regs), > GFP_KERNEL); > diff --git a/drivers/net/wireless/ath/ath10k/sdio.h b/drivers/net/wireless/ath/ath10k/sdio.h > index b8c7ac0..4896eca 100644 > --- a/drivers/net/wireless/ath/ath10k/sdio.h > +++ b/drivers/net/wireless/ath/ath10k/sdio.h > @@ -138,8 +138,8 @@ struct ath10k_sdio_irq_proc_regs { > u8 rx_lookahead_valid; > u8 host_int_status2; > u8 gmbox_rx_avail; > - __le32 rx_lookahead[2]; > - __le32 rx_gmbox_lookahead_alias[2]; > + __le32 rx_lookahead[2 * ATH10K_HIF_MBOX_NUM_MAX]; > + __le32 int_status_enable; > }; > > struct ath10k_sdio_irq_enable_regs { > @@ -196,6 +196,9 @@ struct ath10k_sdio { > struct ath10k *ar; > struct ath10k_sdio_irq_data irq_data; > > + /* temporary buffer for sdio read */ > + u8 *vsg_buffer; > + > /* temporary buffer for BMI requests */ > u8 *bmi_buf; > > -- > 1.9.1 >