Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp5573724ybp; Tue, 8 Oct 2019 05:12:19 -0700 (PDT) X-Google-Smtp-Source: APXvYqwwYN3hwsRCRnQTdoHMRAMh129iCHT4YHJyhesmhEOy4B9cIVoX0owvMypJswP7Cm8XO2fg X-Received: by 2002:a50:d2d4:: with SMTP id q20mr33972965edg.172.1570536739479; Tue, 08 Oct 2019 05:12:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570536739; cv=none; d=google.com; s=arc-20160816; b=qyxBl4rbO+OWbw1mk/PNJ1D+5ApKsTHjHNZQJCRPq8IdYauHeagZdx7l6yrWVl46I0 Ms9qpdJnZrzsFYiM0W6Uoe3RChviJKt2/EP2kozDhZ0X+zQ2/JxzMlTrsudCp7ZbeapL NG+vQvRdee2vtZh79dV1ZE+1p/Cbj6cHO0P5ePqRhVk/SL3l4AzncY4B+W1HE19lGFNn 5C9merWSsre7V2HHM+SbYp56D8BMOstPL5qHqc+G2+vFy/Q5NtJZmqg/4+vG4FIeqC74 3m/lzcltu2HqfHVzWBXbhm+m7KXhO5pPkooytt/uAkAwnQ/OAkrr+WM7T4IwvBxeKkLF 9p4g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:reply-to:references:in-reply-to :message-id:date:subject:cc:to:from; bh=7vIGwUR4JxxYHaT7Z6H2g4j7LCKdcv19RiBC7sROk5U=; b=KaVRRtxWbOS46Ix6W0vbMbi3juSVjR8RpYZP0EvsaDN6bqG5ErkGKQbsCWW4w6579k r935FizNw2tdryKkAGhcm2DKc3I3cvS3i++aM7xH2PKDRyajvlM+gFR11pQA9bfALww/ kYR0jei5C81EZwLaic8Pfo/GpRJPJQIHy8BAGIMHxZKHizjFIjXx33cu8rzkDlHmDIKh GEYR7C6Wo6A5qTQkA6N5+il/MsWKnn3H5ktbhIW/a+aNUyB+1VtHhsUruWy5/8AslMot /inocc5UrdndsqQKJXMaz1zkWpoF7n1IwqhxDk/WOqNGkD1L5VcPf3xzYHZh1NmpLiCu nqCw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r3si7480569ejs.415.2019.10.08.05.11.56; Tue, 08 Oct 2019 05:12:19 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731118AbfJHMLZ (ORCPT + 99 others); Tue, 8 Oct 2019 08:11:25 -0400 Received: from inva020.nxp.com ([92.121.34.13]:54166 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731099AbfJHMLY (ORCPT ); Tue, 8 Oct 2019 08:11:24 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id D44221A0158; Tue, 8 Oct 2019 14:11:20 +0200 (CEST) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id C53621A002E; Tue, 8 Oct 2019 14:11:20 +0200 (CEST) Received: from fsr-fed2164-101.ea.freescale.net (fsr-fed2164-101.ea.freescale.net [10.171.82.91]) by inva024.eu-rdc02.nxp.com (Postfix) with ESMTP id 79183205DB; Tue, 8 Oct 2019 14:11:20 +0200 (CEST) From: Madalin Bucur To: davem@davemloft.net, netdev@vger.kernel.org Cc: roy.pledge@nxp.com, laurentiu.tudor@nxp.com, linux-kernel@vger.kernel.org, Madalin Bucur Subject: [PATCH 12/20] dpaa_eth: use fd information in dpaa_cleanup_tx_fd() Date: Tue, 8 Oct 2019 15:10:33 +0300 Message-Id: <1570536641-25104-13-git-send-email-madalin.bucur@nxp.com> X-Mailer: git-send-email 2.1.0 In-Reply-To: <1570536641-25104-1-git-send-email-madalin.bucur@nxp.com> References: <1570536641-25104-1-git-send-email-madalin.bucur@nxp.com> Reply-to: madalin.bucur@nxp.com X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Instead of reading skb fields, use information from the DPAA frame descriptor. Signed-off-by: Madalin Bucur --- drivers/net/ethernet/freescale/dpaa/dpaa_eth.c | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c b/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c index d4601e31261e..20f0062afdec 100644 --- a/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c +++ b/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c @@ -1588,13 +1588,10 @@ static struct sk_buff *dpaa_cleanup_tx_fd(const struct dpaa_priv *priv, void *vaddr = phys_to_virt(addr); const struct qm_sg_entry *sgt; struct sk_buff *skb; - int nr_frags, i; u64 ns; - - skb = *(struct sk_buff **)vaddr; + int i; if (unlikely(qm_fd_get_format(fd) == qm_fd_sg)) { - nr_frags = skb_shinfo(skb)->nr_frags; dma_unmap_single(priv->tx_dma_dev, addr, qm_fd_get_offset(fd) + DPAA_SGT_SIZE, dma_dir); @@ -1609,7 +1606,8 @@ static struct sk_buff *dpaa_cleanup_tx_fd(const struct dpaa_priv *priv, qm_sg_entry_get_len(&sgt[0]), dma_dir); /* remaining pages were mapped with skb_frag_dma_map() */ - for (i = 1; i <= nr_frags; i++) { + for (i = 1; (i < DPAA_SGT_MAX_ENTRIES) && + !qm_sg_entry_is_final(&sgt[i - 1]); i++) { WARN_ON(qm_sg_entry_is_ext(&sgt[i])); dma_unmap_page(priv->tx_dma_dev, qm_sg_addr(&sgt[i]), @@ -1617,9 +1615,12 @@ static struct sk_buff *dpaa_cleanup_tx_fd(const struct dpaa_priv *priv, } } else { dma_unmap_single(priv->tx_dma_dev, addr, - skb_tail_pointer(skb) - (u8 *)vaddr, dma_dir); + priv->tx_headroom + qm_fd_get_length(fd), + dma_dir); } + skb = *(struct sk_buff **)vaddr; + /* DMA unmapping is required before accessing the HW provided info */ if (ts && priv->tx_tstamp && skb_shinfo(skb)->tx_flags & SKBTX_HW_TSTAMP) { -- 2.1.0