diff options
Diffstat (limited to 'net/core/page_pool.c')
| -rw-r--r-- | net/core/page_pool.c | 22 | 
1 files changed, 14 insertions, 8 deletions
diff --git a/net/core/page_pool.c b/net/core/page_pool.c index 43a932cb609b..5b2252c6d49b 100644 --- a/net/core/page_pool.c +++ b/net/core/page_pool.c @@ -136,17 +136,19 @@ static struct page *__page_pool_alloc_pages_slow(struct page_pool *pool,  	if (!(pool->p.flags & PP_FLAG_DMA_MAP))  		goto skip_dma_map; -	/* Setup DMA mapping: use page->private for DMA-addr +	/* 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(pool->p.dev, page, 0, -			   (PAGE_SIZE << pool->p.order), -			   pool->p.dma_dir); +	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)) {  		put_page(page);  		return NULL;  	} -	set_page_private(page, dma); /* page->private = dma; */ +	page->dma_addr = dma;  skip_dma_map:  	/* When page just alloc'ed is should/must have refcnt 1. */ @@ -175,13 +177,17 @@ EXPORT_SYMBOL(page_pool_alloc_pages);  static void __page_pool_clean_page(struct page_pool *pool,  				   struct page *page)  { +	dma_addr_t dma; +  	if (!(pool->p.flags & PP_FLAG_DMA_MAP))  		return; +	dma = page->dma_addr;  	/* DMA unmap */ -	dma_unmap_page(pool->p.dev, page_private(page), -		       PAGE_SIZE << pool->p.order, pool->p.dma_dir); -	set_page_private(page, 0); +	dma_unmap_page_attrs(pool->p.dev, dma, +			     PAGE_SIZE << pool->p.order, pool->p.dma_dir, +			     DMA_ATTR_SKIP_CPU_SYNC); +	page->dma_addr = 0;  }  /* Return a page to the page allocator, cleaning up our state */  |