]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/blame - releases/4.12.14/net-mlx5e-fix-dangling-page-pointer-on-dma-mapping-error.patch
4.14-stable patches
[thirdparty/kernel/stable-queue.git] / releases / 4.12.14 / net-mlx5e-fix-dangling-page-pointer-on-dma-mapping-error.patch
CommitLineData
9ac87053
GKH
1From foo@baz Thu Sep 14 23:20:23 PDT 2017
2From: Eran Ben Elisha <eranbe@mellanox.com>
3Date: Wed, 16 Aug 2017 14:37:11 +0300
4Subject: net/mlx5e: Fix dangling page pointer on DMA mapping error
5
6From: Eran Ben Elisha <eranbe@mellanox.com>
7
8
9[ Upstream commit 0556ce72ab16156af6c94cdc7964e4310acc97c0 ]
10
11Function mlx5e_dealloc_rx_wqe is using page pointer value as an
12indication to valid DMA mapping. In case that the mapping failed, we
13released the page but kept the dangling pointer. Store the page pointer
14only after the DMA mapping passed to avoid invalid page DMA unmap.
15
16Fixes: bc77b240b3c5 ("net/mlx5e: Add fragmented memory support for RX multi packet WQE")
17Signed-off-by: Eran Ben Elisha <eranbe@mellanox.com>
18Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
19Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
20---
21 drivers/net/ethernet/mellanox/mlx5/core/en_rx.c | 2 +-
22 1 file changed, 1 insertion(+), 1 deletion(-)
23
24--- a/drivers/net/ethernet/mellanox/mlx5/core/en_rx.c
25+++ b/drivers/net/ethernet/mellanox/mlx5/core/en_rx.c
26@@ -216,13 +216,13 @@ static inline int mlx5e_page_alloc_mappe
27 if (unlikely(!page))
28 return -ENOMEM;
29
30- dma_info->page = page;
31 dma_info->addr = dma_map_page(rq->pdev, page, 0,
32 RQ_PAGE_SIZE(rq), rq->buff.map_dir);
33 if (unlikely(dma_mapping_error(rq->pdev, dma_info->addr))) {
34 put_page(page);
35 return -ENOMEM;
36 }
37+ dma_info->page = page;
38
39 return 0;
40 }