|
|
@@ -1149,7 +1149,9 @@ int memory_failure(unsigned long pfn, int trapno, int flags)
|
|
|
}
|
|
|
|
|
|
if (!PageHuge(p) && PageTransHuge(hpage)) {
|
|
|
+ lock_page(hpage);
|
|
|
if (!PageAnon(hpage) || unlikely(split_huge_page(hpage))) {
|
|
|
+ unlock_page(hpage);
|
|
|
if (!PageAnon(hpage))
|
|
|
pr_err("MCE: %#lx: non anonymous thp\n", pfn);
|
|
|
else
|
|
|
@@ -1159,6 +1161,7 @@ int memory_failure(unsigned long pfn, int trapno, int flags)
|
|
|
put_hwpoison_page(p);
|
|
|
return -EBUSY;
|
|
|
}
|
|
|
+ unlock_page(hpage);
|
|
|
VM_BUG_ON_PAGE(!page_count(p), p);
|
|
|
hpage = compound_head(p);
|
|
|
}
|
|
|
@@ -1751,7 +1754,10 @@ int soft_offline_page(struct page *page, int flags)
|
|
|
return -EBUSY;
|
|
|
}
|
|
|
if (!PageHuge(page) && PageTransHuge(hpage)) {
|
|
|
- if (PageAnon(hpage) && unlikely(split_huge_page(hpage))) {
|
|
|
+ lock_page(page);
|
|
|
+ ret = split_huge_page(hpage);
|
|
|
+ unlock_page(page);
|
|
|
+ if (unlikely(ret)) {
|
|
|
pr_info("soft offline: %#lx: failed to split THP\n",
|
|
|
pfn);
|
|
|
if (flags & MF_COUNT_INCREASED)
|