From patchwork Wed Dec 6 12:31:13 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Hemant Agrawal X-Patchwork-Id: 120821 Delivered-To: patch@linaro.org Received: by 10.140.22.227 with SMTP id 90csp6995379qgn; Wed, 6 Dec 2017 04:32:22 -0800 (PST) X-Google-Smtp-Source: AGs4zMZH+xDADvPhPTHV0vbgTij5+hQUea2r/mUUoFDcRVzDMdUuoLBJyPLmbWBxlqjFL0BA+JxM X-Received: by 10.28.131.73 with SMTP id f70mr8975059wmd.137.1512563542727; Wed, 06 Dec 2017 04:32:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1512563542; cv=none; d=google.com; s=arc-20160816; b=Iqc9YmXVyffgvXzCeclINZEtjWQsWrtbGFodOlFth6CYK8ULXs5MQQZTpMnZu0wKTr W60+0KBMluosd1F7yICrYJ5j4GgGP+1gTL0NsiHuOTjSaVSC8waPB8Nk18U1G9jo9Jan 7BMIst5xKxNCFZ2ZG3Lrl+nun9FR2DUPF/nkb51U7IEqfz1ow3kAE0Ref8713ebyXIv7 com15WoO4lQem/dx0UF7QSkM/XjcV8N84kPEyq6YWlwVMtqoWcqnfrcqXmb9NAhA22/G unyU+Lr4OaVcjuv7So5GOhyFpNRp5M6rDXlDChW8JlyEZtDLQV7faW8lkWhtqCtSt0sJ BbEQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:subject:spamdiagnosticmetadata :spamdiagnosticoutput:mime-version:references:in-reply-to:message-id :date:cc:to:from:arc-authentication-results; bh=hEQ0l0QmeXtfXngzs8ddvfjnBX1RAvC/iOB0Ah4i4Bo=; b=B7sICm9WfAXTFwxztpPooHod6au6V/9cIQJ3TO+1DKE0IwG3GHm6Law4nvgu0YDx+I 85EriWLEjHCDgB/PP+fAI9cPU6AP+uny1Ji+LCAlFHZCRIgLVZRbczi3lgSjxqeam7j8 KUyxAX/K5uau9RJIrQN8j04wxNw0zUMIHd3HBf0iyEUQiS6hznfMw8BpfhN3D/6ouLU6 TEk06SZ4tesbBXSIaylW8xbymsQefl4LCMhqkoRNRFMfx5oLKNc3T1LLyRvdOzk5Ko1/ LMceKm+EF5NW21qH7kZqvlImPdKs/9i01fxpiZS4FzGKeR4WRNpMxkPqPMh/ltdVuEQZ 9bDg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of dev-bounces@dpdk.org designates 92.243.14.124 as permitted sender) smtp.mailfrom=dev-bounces@dpdk.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from dpdk.org (dpdk.org. [92.243.14.124]) by mx.google.com with ESMTP id i11si1888303wmb.138.2017.12.06.04.32.22; Wed, 06 Dec 2017 04:32:22 -0800 (PST) Received-SPF: pass (google.com: domain of dev-bounces@dpdk.org designates 92.243.14.124 as permitted sender) client-ip=92.243.14.124; Authentication-Results: mx.google.com; spf=pass (google.com: domain of dev-bounces@dpdk.org designates 92.243.14.124 as permitted sender) smtp.mailfrom=dev-bounces@dpdk.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id C4AA37CEA; Wed, 6 Dec 2017 13:32:17 +0100 (CET) Received: from NAM01-BY2-obe.outbound.protection.outlook.com (mail-by2nam01on0086.outbound.protection.outlook.com [104.47.34.86]) by dpdk.org (Postfix) with ESMTP id 7A612E5D for ; Wed, 6 Dec 2017 13:32:14 +0100 (CET) Received: from CY4PR03CA0013.namprd03.prod.outlook.com (2603:10b6:903:33::23) by SN2PR03MB2365.namprd03.prod.outlook.com (2603:10b6:804:e::16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.302.9; Wed, 6 Dec 2017 12:32:13 +0000 Received: from BN1BFFO11FD045.protection.gbl (2a01:111:f400:7c10::1:173) by CY4PR03CA0013.outlook.office365.com (2603:10b6:903:33::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.20.302.9 via Frontend Transport; Wed, 6 Dec 2017 12:32:13 +0000 Authentication-Results: spf=fail (sender IP is 192.88.168.50) smtp.mailfrom=nxp.com; dpdk.org; dkim=none (message not signed) header.d=none;dpdk.org; dmarc=fail action=none header.from=nxp.com; Received-SPF: Fail (protection.outlook.com: domain of nxp.com does not designate 192.88.168.50 as permitted sender) receiver=protection.outlook.com; client-ip=192.88.168.50; helo=tx30smr01.am.freescale.net; Received: from tx30smr01.am.freescale.net (192.88.168.50) by BN1BFFO11FD045.mail.protection.outlook.com (10.58.145.0) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.20.239.4 via Frontend Transport; Wed, 6 Dec 2017 12:32:12 +0000 Received: from bf-netperf1.ap.freescale.net (bf-netperf1.ap.freescale.net [10.232.134.28]) by tx30smr01.am.freescale.net (8.14.3/8.14.0) with ESMTP id vB6CW66D004419; Wed, 6 Dec 2017 05:32:09 -0700 From: Hemant Agrawal To: CC: Date: Wed, 6 Dec 2017 18:01:13 +0530 Message-ID: <1512563473-19969-2-git-send-email-hemant.agrawal@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1512563473-19969-1-git-send-email-hemant.agrawal@nxp.com> References: <1512563473-19969-1-git-send-email-hemant.agrawal@nxp.com> X-EOPAttributedMessage: 0 X-Matching-Connectors: 131570371336770757; (91ab9b29-cfa4-454e-5278-08d120cd25b8); () X-Forefront-Antispam-Report: CIP:192.88.168.50; IPV:NLI; CTRY:US; EFV:NLI; SFV:NSPM; SFS:(10009020)(336005)(39860400002)(376002)(346002)(39380400002)(2980300002)(1110001)(1109001)(339900001)(199004)(189003)(8676002)(77096006)(8936002)(50226002)(68736007)(53936002)(47776003)(50466002)(16586007)(4326008)(48376002)(36756003)(5660300001)(498600001)(316002)(2950100002)(2351001)(356003)(6666003)(106466001)(33646002)(6916009)(81166006)(305945005)(105606002)(104016004)(85426001)(86362001)(97736004)(51416003)(76176011)(2906002)(81156014); DIR:OUT; SFP:1101; SCL:1; SRVR:SN2PR03MB2365; H:tx30smr01.am.freescale.net; FPR:; SPF:Fail; PTR:InfoDomainNonexistent; A:1; MX:1; LANG:en; X-Microsoft-Exchange-Diagnostics: 1; BN1BFFO11FD045; 1:NoDnmzGX0gaVefed3Q9O3WHQ1aQbRuMHMYvyGbFmVAXZD0SNX26ma/6ILUAuY/j/euEvAz2XR6d7ZsbKvWBX0EngCxapIsG88PB207SyiqN2cFoOu4uCBo60aSM4xzOP MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 7e8d06aa-29c1-4a24-3366-08d53ca560f3 X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(5600026)(4604075)(4534020)(4628075)(201703131517081)(2017052603286); SRVR:SN2PR03MB2365; X-Microsoft-Exchange-Diagnostics: 1; SN2PR03MB2365; 3:V6Y+ZyfR/z+kqmveh80EUm0Gy+SLfAqG4XpII8vD3ZDimN+gRKS6mTP+BMkIHzMpQgIfCpcc4QcYzmmWRuGv0hcDHkucxpHOuBN4uvgOpMeSg8Hp0+a3tSe+b/CsIIf9jKFz3UgPzJBz/sPDT+GZbyD0cbdWOL86ElG+IUgPkulQtijc6eKUvr9rc0Dylsh4Psegb6GZzAdnRSvadjOvZQjHHbtfoAXWg1sduXNU3/U4r277wzCrEs9HIFndQ+K9jNwweJX9SYNO9fJRKmHOQYNUsfe0sI2qRHRYUKrD8EpBVcorXcVIRba809pl/oVtZMt0cvW9gf2/BBofczjzHphb9DJO+JVeVi+a+3XAzZ4=; 25:mAcU/f544u1m2BMfFRwKAE2cxpaqUvEorinzsDIP4r39HMh1hYWSn7da/SfezWgWLfnCLFA/KAFoAdUD5KUjuMBlnJnSdmWiy3G/7ptSdJg6WscZMRS42Dye/qU18fTcMNr4S6LfEdCjTfEGjDiuW0nheaZJcTBBo0QxFKxjDVd2MxFTrlPZ4sbVq/u19aAYrfElSB266071zxXSxvrh38LvJZ2O+ViH16IVP2vgTiCeuI2cFGghUqIq/KnS/ouumoFDy/QLukiJJKWSKvToiFGO+MX/WSFZeWnHrxRJKpNVRR4gu1G5o/gVTKvlEmGJIGiTollSQQukz2irMmDTSQ== X-MS-TrafficTypeDiagnostic: SN2PR03MB2365: X-Microsoft-Exchange-Diagnostics: 1; SN2PR03MB2365; 31:fmXJIjDOasXq4yYkuxwBBaLOmM7SP2Q3Nj6F3S98LcCVuvsCv4r+I/JzCJRyjvpAPm1dygbQ0cihQTctc/oUAtcEx+Jp75j8nXaTmLlGOnRnl0zc06GPSYmRMTFJ7SyMMRoX6h02K051I0Mv3MLc8OhrFMroZdKjtEsIBu3jqL5l8Xkx5RRMP6GT0l/kOXeVmkx2A5wJxwSOPYrTCkq/cF8GcS8OiLS5FhvPW701+1U=; 4:hhv2ON338JZZvkzc1cjy4HWH2Vol3mj1w1A5I4XgV5y7PAyYZYpxnaNidzx01kUkGpocWePQz0L81uX5NUryP/iFckWU0JxR7QE73jorXmjrhy90Wfudthc3c+jSsfjPi2mWucEOKXuayf4WhGQOwY+uLCHN3rjfaX8n3KcFcs7VXnc3MQSbf0aitArNhac7qDdw7ct0n+DmN++cKbLj68niulGQGeLK/EEagdez2Gnl0TlSdU9vPFq+MLwe1ylxxPckMpXyuNNGj6lrxa1EauST/e6APP+y5sdB2vm4zDnKs26gGtiSm/GteOlPFYTe X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(185117386973197); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(6095135)(2401047)(8121501046)(5005006)(3231022)(10201501046)(3002001)(93006095)(93001095)(6055026)(6096035)(201703131430075)(201703131433075)(201703131448075)(201703161259150)(201703151042153)(20161123563025)(20161123559100)(20161123565025)(20161123556025)(20161123561025)(201708071742011); SRVR:SN2PR03MB2365; BCL:0; PCL:0; RULEID:(100000803101)(100110400095)(400006); SRVR:SN2PR03MB2365; X-Forefront-PRVS: 05134F8B4F X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; SN2PR03MB2365; 23:tWV1cKtprbkkNJOo3gZ7Vwk8LOGpsWu/K0iH8sTAQ?= 5PJmMgCqxBi+MgsCqkwGR29VAsIKuLkdlz0jl0dA37Q7HrBIQaPq1BbVVT4c+SPqoMcfll5f97nx/5qqDoEFRx+CE+lJpLAC+pXdpVRZE1U2gNl+QIW+Qr5Eqx7X/kaS9crj2T0O1fYETnUeI5WAWew4guW+pApePeK7q3zBJMPnwhzW8e6cIdPJd84imTyrWgI4NUiDgcFHlxMu54aj/djoz/dkSSVDUo1UQkquGpfjsUHbR+Uoh3vNbPhpyeMDDB0DvU1mIzbAGl3cT6jcTjgmcHM6QzQtAbMMy5HS6OkFAukGezg4YNfLxmzmNkkWi1Hv0iYEzf2JRzJtwJgYL0Qt6twMbv08CVzhX9aHAadHoxu2LJCRfesmOGd0QPTUIfk3zJqUs/ZRNSK6zkjMt96RTfa45oYUHylzWfviBZJcz1ePyjRrji7o4YDRQags7YMD+09oqa9PYSC0B6q4yFihAsEXYWTJh+laUArzk7LNx2ReU+FmWS7G1Vc4vgt9PAJfxMcYPyvGUW0399n29FpdbpTerTLTFgxkjBlZSiwbq9rGXOlkjDsj0wX2DBOVNk/Ay3COHpEuK/f8xEczSc4YXkgAr4Gka+qwDVDT4Aba2mRzu2mNd+k3G6Q1XY4VtXATYi/QdyPEfiNyVgM/95ASLAOxqxyH9AxQG5sPMOVTxIwl+RJP3klV6So+xkWyXXqQWq+iZiSdjuverV9eD/zf8h6SpJcG8mg7V0iMJQ5KI0xUiP7wVOgKcwvDHWVqPEQXUMqTTXT97blnJdERluNEwwKAAjK6xjWih0jyJqNFX4Rt5rcPUY28UwehCHktR2TT3M3d5q5SXy1Pkxd96NCH13IrYQyF8lDbcu4zxqh9ijfnUswHFRUL0Y1bCyAAhPn8XNnl48NF+yk3vsGzsDwpZCHoxwtMo31j8LkDPZ0rPj5XQN+JaWouen+sTs8xUsDp6FLhPL2joHOlsvQ7+F6UYOBYic2IP3+1Ix6MyVihIxUiZJEJsmoUEjdVQT83RE= X-Microsoft-Exchange-Diagnostics: 1; SN2PR03MB2365; 6:pxFwKeSXqcorj6NzkkMHIME9Fbb0xHI2OJpBRSdmEEEJELHacvXtYeWfPiHNUktuaCQAXGQiNYODCDJ4PZbWKFKMSDmbHJRDo3G0OTVlGlLpdr514Y4FZKJPvC20xf2dr3ucXyyvs3Uy2II35UVnS1iHKGmb1PqWFYwDFL28Q4aUI504Zm5a/6BSV0y7dt6fFfOic+OeuNenR2lrGPdo9hFL+9EcHOqQv8jxQtuiPDucN/+teXrPFKH5ELQWUt2cSsx4p0jBIoZ0j/owtzwjlhFgUo0DAfm2R1asA+7zb5KPxOfahdvAFZko+Q9MykoAvFOmIIBI7mVYI47KU920lqwxHJ8SyNRNvha79XsI41g=; 5:QC5pdkswlZZd+s2KQe9V3Q1WzsNIjRWu9gRuWGCY3ACeRpDCsHMIXIuVMktaSBsq3wUX6uAxf+ZiciAZctqSaJj1ycLApkRfoYt5AGYHXitZ5v706dAByb/tDVH5nCtjJQ0ktQTpPWPRkoui9Ee/hf0Nd0qoiCt4YbxAT+TTPGs=; 24:6dhL7oKZfarghPPD0tVTAHfeQubLiucb7jFPrXT3VFe3wXgOWlwvhRk+Aj9qyeYu6qoSvThQiKdKtGlAfJWWlPiagXbNx0cfzzB36kC55VA=; 7:L/qSch/QO9/dr2Z+t0c240IqjVfsTYW3tLocoVTLrKPAgvYn3rCJmFoxaGvBhJGzVzqdIdh7ZHvZewbjrRquuAbb9FqI+FXVauTPieGSdoIhgWi0fpDhhsf7qwR6b/j4H8od+4qMxU/76iabqN8BxNtHg6UvZ+cZ5P4r9wY3ist5zeo8EtVxkN17gAKm4AUK1DnK1mmquJESo9hazb8V2VrEvjDMXSIHKG148EP8/NxVWFFzMAERlLrzLs2EEDWD SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-MS-Exchange-CrossTenant-OriginalArrivalTime: 06 Dec 2017 12:32:12.7254 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 7e8d06aa-29c1-4a24-3366-08d53ca560f3 X-MS-Exchange-CrossTenant-Id: 5afe0b00-7697-4969-b663-5eab37d5f47e X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=5afe0b00-7697-4969-b663-5eab37d5f47e; Ip=[192.88.168.50]; Helo=[tx30smr01.am.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN2PR03MB2365 Subject: [dpdk-dev] [PATCH 2/2] mempool/dpaa: optimize phy to virt conversion X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" If the allocation is from a single memzone, optimize the phy-virt address conversions. Signed-off-by: Hemant Agrawal --- drivers/mempool/dpaa/dpaa_mempool.c | 18 +++++++++++++++--- drivers/mempool/dpaa/dpaa_mempool.h | 9 +++++++++ 2 files changed, 24 insertions(+), 3 deletions(-) -- 2.7.4 diff --git a/drivers/mempool/dpaa/dpaa_mempool.c b/drivers/mempool/dpaa/dpaa_mempool.c index f5ee80f..ac3e4ac 100644 --- a/drivers/mempool/dpaa/dpaa_mempool.c +++ b/drivers/mempool/dpaa/dpaa_mempool.c @@ -99,6 +99,7 @@ dpaa_mbuf_create_pool(struct rte_mempool *mp) rte_dpaa_bpid_info[bpid].meta_data_size = sizeof(struct rte_mbuf) + rte_pktmbuf_priv_size(mp); rte_dpaa_bpid_info[bpid].dpaa_ops_index = mp->ops_index; + rte_dpaa_bpid_info[bpid].ptov_off = 0; bp_info = rte_malloc(NULL, sizeof(struct dpaa_bp_info), @@ -171,9 +172,20 @@ dpaa_mbuf_free_bulk(struct rte_mempool *pool, } while (i < n) { + uint64_t phy = rte_mempool_virt2iova(obj_table[i]); + + if (unlikely(!bp_info->ptov_off)) { + /* buffers are not from multiple memzones */ + if (!(bp_info->mp->flags & MEMPOOL_F_MULTI_MEMZONE)) { + bp_info->ptov_off + = (uint64_t)obj_table[i] - phy; + rte_dpaa_bpid_info[bp_info->bpid].ptov_off + = bp_info->ptov_off; + } + } + dpaa_buf_free(bp_info, - (uint64_t)rte_mempool_virt2iova(obj_table[i]) + - bp_info->meta_data_size); + (uint64_t)phy + bp_info->meta_data_size); i = i + 1; } @@ -241,7 +253,7 @@ dpaa_mbuf_alloc_bulk(struct rte_mempool *pool, * i.e. first buffer is valid, remaining 6 buffers * may be null. */ - bufaddr = (void *)rte_dpaa_mem_ptov(bufs[i].addr); + bufaddr = DPAA_MEMPOOL_PTOV(bp_info, bufs[i].addr); m[n] = (struct rte_mbuf *)((char *)bufaddr - bp_info->meta_data_size); DPAA_MEMPOOL_DPDEBUG("Paddr (%p), FD (%p) from BMAN", diff --git a/drivers/mempool/dpaa/dpaa_mempool.h b/drivers/mempool/dpaa/dpaa_mempool.h index 6795859..8160af6 100644 --- a/drivers/mempool/dpaa/dpaa_mempool.h +++ b/drivers/mempool/dpaa/dpaa_mempool.h @@ -61,8 +61,17 @@ struct dpaa_bp_info { uint32_t size; uint32_t meta_data_size; int32_t dpaa_ops_index; + int64_t ptov_off; }; +static inline void * +DPAA_MEMPOOL_PTOV(struct dpaa_bp_info *bp_info, uint64_t addr) +{ + if (bp_info->ptov_off) + return ((void *)(addr + bp_info->ptov_off)); + return rte_dpaa_mem_ptov(addr); +} + #define DPAA_MEMPOOL_TO_POOL_INFO(__mp) \ ((struct dpaa_bp_info *)__mp->pool_data)