Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp308180pxf; Thu, 25 Mar 2021 04:46:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyGjZeOp0Pfg96GgsjR80pSIcCobsvkBGkRa5eb+ZIe7uEac1LV1DsXkmeeOdY8Ubyn5JP6 X-Received: by 2002:a05:6402:12cf:: with SMTP id k15mr8379562edx.192.1616672760118; Thu, 25 Mar 2021 04:46:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616672760; cv=none; d=google.com; s=arc-20160816; b=K+E78RmMb3v5aXud0GgaecNHP4o6ZbNflns1RK71nFbz/6hEwMU8RgF81qUco/XieF 9tkB243Y+jo/cCIvcG8qPTOyBtKjcpApxmdAWBFZ1jrZk35KmiUXt/C5/UtAMiNXV+Q2 lanQLaLTQIRVdNJyzQ3lOxCCeUqU2PMYYua0W9vhd+fpbbgibbTPio8ysf9ABg/CRpd/ BCIDYJDFXe5tHTwQF6GospjHrdBsDp4ggacvpbej8su1SKE1jtlXydF0XyzsJlntT1U7 f0d9xVdXW4qMbwJW8ymAIrq3/Yr4EegI5jnWfr6GrAh3PjgCPqk3uNlFmIQTOkQSsCp6 ZcTA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=0lf0sNHObCfd6BEP92lUEs52BT9Jye9nhCD8MZ7FOuk=; b=BEAZUhl8RpkEkIm6dMETl/pZdE7DXBq6VSMmMdQCDnvLocNW0hnoQlWgjd+yk/O7JI 6or3oSsOGJ7qMpbJ+yxLz4Nf+HPdWJVXPnB7YDQP18p2ZSfzZoQX/3ZpW0Gu5xaqm7I2 1vfPGCUTkG4nwz66MCM3M8aR2BZdmOtkXIcQBcgF0a0+3K2dVpDXcwi0FB6nuFrkag2Y lApBOsRPnDnmFIGv5l1tOnZkJpPRafIBkFHMAmdscW15Ar73bktUfvBhVtzj8vaQ8RVt v8KkVVpyTpUvqqLrRb9+Z+oVXeN+aNR54+/4STAyI42tCgmxprD7Tx3GNzLQBMYNkTJq pQkA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r25si4115865ejs.195.2021.03.25.04.45.37; Thu, 25 Mar 2021 04:46:00 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231220AbhCYLoi (ORCPT + 99 others); Thu, 25 Mar 2021 07:44:38 -0400 Received: from outbound-smtp63.blacknight.com ([46.22.136.252]:41019 "EHLO outbound-smtp63.blacknight.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231185AbhCYLoC (ORCPT ); Thu, 25 Mar 2021 07:44:02 -0400 Received: from mail.blacknight.com (pemlinmail01.blacknight.ie [81.17.254.10]) by outbound-smtp63.blacknight.com (Postfix) with ESMTPS id 88101FA825 for ; Thu, 25 Mar 2021 11:44:01 +0000 (GMT) Received: (qmail 19650 invoked from network); 25 Mar 2021 11:44:01 -0000 Received: from unknown (HELO stampy.112glenside.lan) (mgorman@techsingularity.net@[84.203.22.4]) by 81.17.254.9 with ESMTPA; 25 Mar 2021 11:44:01 -0000 From: Mel Gorman To: Andrew Morton Cc: Chuck Lever , Jesper Dangaard Brouer , Christoph Hellwig , Alexander Duyck , Vlastimil Babka , Matthew Wilcox , Ilias Apalodimas , LKML , Linux-Net , Linux-MM , Linux-NFS , Mel Gorman Subject: [PATCH 8/9] net: page_pool: refactor dma_map into own function page_pool_dma_map Date: Thu, 25 Mar 2021 11:42:27 +0000 Message-Id: <20210325114228.27719-9-mgorman@techsingularity.net> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20210325114228.27719-1-mgorman@techsingularity.net> References: <20210325114228.27719-1-mgorman@techsingularity.net> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jesper Dangaard Brouer In preparation for next patch, move the dma mapping into its own function, as this will make it easier to follow the changes. [ilias.apalodimas: make page_pool_dma_map return boolean] Signed-off-by: Jesper Dangaard Brouer Reviewed-by: Ilias Apalodimas Signed-off-by: Mel Gorman --- net/core/page_pool.c | 45 +++++++++++++++++++++++++------------------- 1 file changed, 26 insertions(+), 19 deletions(-) diff --git a/net/core/page_pool.c b/net/core/page_pool.c index ad8b0707af04..40e1b2beaa6c 100644 --- a/net/core/page_pool.c +++ b/net/core/page_pool.c @@ -180,14 +180,37 @@ static void page_pool_dma_sync_for_device(struct page_pool *pool, pool->p.dma_dir); } +static bool page_pool_dma_map(struct page_pool *pool, struct page *page) +{ + dma_addr_t dma; + + /* Setup DMA mapping: use 'struct page' area for storing DMA-addr + * since dma_addr_t can be either 32 or 64 bits and does not always fit + * into page private data (i.e 32bit cpu with 64bit DMA caps) + * This mapping is kept for lifetime of page, until leaving pool. + */ + dma = dma_map_page_attrs(pool->p.dev, page, 0, + (PAGE_SIZE << pool->p.order), + pool->p.dma_dir, DMA_ATTR_SKIP_CPU_SYNC); + if (dma_mapping_error(pool->p.dev, dma)) + return false; + + page->dma_addr = dma; + + if (pool->p.flags & PP_FLAG_DMA_SYNC_DEV) + page_pool_dma_sync_for_device(pool, page, pool->p.max_len); + + return true; +} + /* slow path */ noinline static struct page *__page_pool_alloc_pages_slow(struct page_pool *pool, gfp_t _gfp) { + unsigned int pp_flags = pool->p.flags; struct page *page; gfp_t gfp = _gfp; - dma_addr_t dma; /* We could always set __GFP_COMP, and avoid this branch, as * prep_new_page() can handle order-0 with __GFP_COMP. @@ -211,30 +234,14 @@ static struct page *__page_pool_alloc_pages_slow(struct page_pool *pool, if (!page) return NULL; - if (!(pool->p.flags & PP_FLAG_DMA_MAP)) - goto skip_dma_map; - - /* Setup DMA mapping: use 'struct page' area for storing DMA-addr - * since dma_addr_t can be either 32 or 64 bits and does not always fit - * into page private data (i.e 32bit cpu with 64bit DMA caps) - * This mapping is kept for lifetime of page, until leaving pool. - */ - dma = dma_map_page_attrs(pool->p.dev, page, 0, - (PAGE_SIZE << pool->p.order), - pool->p.dma_dir, DMA_ATTR_SKIP_CPU_SYNC); - if (dma_mapping_error(pool->p.dev, dma)) { + if ((pp_flags & PP_FLAG_DMA_MAP) && + unlikely(!page_pool_dma_map(pool, page))) { put_page(page); return NULL; } - page->dma_addr = dma; - if (pool->p.flags & PP_FLAG_DMA_SYNC_DEV) - page_pool_dma_sync_for_device(pool, page, pool->p.max_len); - -skip_dma_map: /* Track how many pages are held 'in-flight' */ pool->pages_state_hold_cnt++; - trace_page_pool_state_hold(pool, page, pool->pages_state_hold_cnt); /* When page just alloc'ed is should/must have refcnt 1. */ -- 2.26.2