diff options
| author | 2021-10-21 08:27:39 +0300 | |
|---|---|---|
| committer | 2021-10-21 08:27:39 +0300 | |
| commit | 60dd57c7479418e2bc902143eb46a2fdcfeecbbb (patch) | |
| tree | ab6005faf6076a4c93fdfbcdccc1ff4bc044c8ec /mm/memory-failure.c | |
| parent | net/mlx5: Add priorities for counters in RDMA namespaces (diff) | |
| parent | RDMA/mlx5: Attach ndescs to mlx5_ib_mkey (diff) | |
| download | linux-dev-60dd57c7479418e2bc902143eb46a2fdcfeecbbb.tar.xz linux-dev-60dd57c7479418e2bc902143eb46a2fdcfeecbbb.zip | |
Merge brank 'mlx5_mkey' into rdma.git for-next
A small series to clean up the mlx5 mkey code across the mlx5_core and
InfiniBand.
* branch 'mlx5_mkey':
  RDMA/mlx5: Attach ndescs to mlx5_ib_mkey
  RDMA/mlx5: Move struct mlx5_core_mkey to mlx5_ib
  RDMA/mlx5: Replace struct mlx5_core_mkey by u32 key
  RDMA/mlx5: Remove pd from struct mlx5_core_mkey
  RDMA/mlx5: Remove size from struct mlx5_core_mkey
  RDMA/mlx5: Remove iova from struct mlx5_core_mkey
  Signed-off-by: Leon Romanovsky <leonro@nvidia.com>
Diffstat (limited to 'mm/memory-failure.c')
| -rw-r--r-- | mm/memory-failure.c | 12 | 
1 files changed, 6 insertions, 6 deletions
| diff --git a/mm/memory-failure.c b/mm/memory-failure.c index 54879c339024..3e6449f2102a 100644 --- a/mm/memory-failure.c +++ b/mm/memory-failure.c @@ -306,6 +306,7 @@ static unsigned long dev_pagemap_mapping_shift(struct page *page,  		struct vm_area_struct *vma)  {  	unsigned long address = vma_address(page, vma); +	unsigned long ret = 0;  	pgd_t *pgd;  	p4d_t *p4d;  	pud_t *pud; @@ -329,11 +330,10 @@ static unsigned long dev_pagemap_mapping_shift(struct page *page,  	if (pmd_devmap(*pmd))  		return PMD_SHIFT;  	pte = pte_offset_map(pmd, address); -	if (!pte_present(*pte)) -		return 0; -	if (pte_devmap(*pte)) -		return PAGE_SHIFT; -	return 0; +	if (pte_present(*pte) && pte_devmap(*pte)) +		ret = PAGE_SHIFT; +	pte_unmap(pte); +	return ret;  }  /* @@ -1126,7 +1126,7 @@ static int page_action(struct page_state *ps, struct page *p,   */  static inline bool HWPoisonHandlable(struct page *page)  { -	return PageLRU(page) || __PageMovable(page); +	return PageLRU(page) || __PageMovable(page) || is_free_buddy_page(page);  }  static int __get_hwpoison_page(struct page *page) | 
