diff options
Diffstat (limited to 'mm/memory-failure.c')
| -rw-r--r-- | mm/memory-failure.c | 36 | 
1 files changed, 17 insertions, 19 deletions
diff --git a/mm/memory-failure.c b/mm/memory-failure.c index c0bb186bba62..5d880d4eb9a2 100644 --- a/mm/memory-failure.c +++ b/mm/memory-failure.c @@ -1057,27 +1057,25 @@ static bool hwpoison_user_mappings(struct page *p, unsigned long pfn,  	if (!PageHuge(hpage)) {  		unmap_success = try_to_unmap(hpage, ttu);  	} else { -		/* -		 * For hugetlb pages, try_to_unmap could potentially call -		 * huge_pmd_unshare.  Because of this, take semaphore in -		 * write mode here and set TTU_RMAP_LOCKED to indicate we -		 * have taken the lock at this higer level. -		 * -		 * Note that the call to hugetlb_page_mapping_lock_write -		 * is necessary even if mapping is already set.  It handles -		 * ugliness of potentially having to drop page lock to obtain -		 * i_mmap_rwsem. -		 */ -		mapping = hugetlb_page_mapping_lock_write(hpage); - -		if (mapping) { -			unmap_success = try_to_unmap(hpage, +		if (!PageAnon(hpage)) { +			/* +			 * For hugetlb pages in shared mappings, try_to_unmap +			 * could potentially call huge_pmd_unshare.  Because of +			 * this, take semaphore in write mode here and set +			 * TTU_RMAP_LOCKED to indicate we have taken the lock +			 * at this higer level. +			 */ +			mapping = hugetlb_page_mapping_lock_write(hpage); +			if (mapping) { +				unmap_success = try_to_unmap(hpage,  						     ttu|TTU_RMAP_LOCKED); -			i_mmap_unlock_write(mapping); +				i_mmap_unlock_write(mapping); +			} else { +				pr_info("Memory failure: %#lx: could not lock mapping for mapped huge page\n", pfn); +				unmap_success = false; +			}  		} else { -			pr_info("Memory failure: %#lx: could not find mapping for mapped huge page\n", -				pfn); -			unmap_success = false; +			unmap_success = try_to_unmap(hpage, ttu);  		}  	}  	if (!unmap_success)  | 
