Power management fix for 5.5-rc8
Prevent the kernel from crashing during resume from hibernation if free pages contain leftover data from the restore kernel and init_on_free is set (Alexander Potapenko). -----BEGIN PGP SIGNATURE----- iQJGBAABCAAwFiEE4fcc61cGeeHD/fCwgsRv/nhiVHEFAl4psjQSHHJqd0Byand5 c29ja2kubmV0AAoJEILEb/54YlRxpOcP/1UTGUr+VdGfBBjG5WlgCY0Jrd50Y78b RoVNDR/NvSVSuIs44AgrnfyQiz2Y8jG6qY1iSAbIXmFl37/4+kGhkNmd6pV/xFUc TdZZotFwFlRQjmeQxxH0kNXuAY6nJ2RwELWrjXqM8PuNjNKIEpfS+0fSaWexHqIm MDArxcDHkvZU5SnnRQM+LkT/EmbEheB7tgm7vGGqMLsSKc0gUsBmVCURe/lLAH5o EUKX4FI2jCy+LlmSdZ3EDjf1cstm3YXLiegTLSq1Jh3mFHXkFTwJMmidiz21qXJh Hc4r3iG0NZ37J8HXpwuq++KlhvNbhHJz+ZgC1IYls16RNYh5mUzxtMHWdSyyqlrW +z8gBVUyeJUYos5Kjb/NKSt43gnz7Uhy0UVbQXD66hgajXe71CQZQq/D5CMeTdJL jWNaeGYnhskz3IW2vnrs9Ucf6RHHWezXk51kVsyJXadiLhTdOv7DKahDKVwC/Hvf kyN1W0F5PZpF50yYmnhJgqDfxkGBNKpwXxTAGk6X0WQFaWeh/2FkX045UdJzBbHu fa1taTM/5RfPlbWq0wLPeHHSP4M2I0ndeWXZk88vUwwMfm9Wo+FNBhgs/EZfeuKD 16sVMsX0r7R1bG+hEj+mvNeLWqfgz7MpGludCkV1dHIDkn2esxx6JqaWxR/UnLHb D3fZM/cKGdpY =kDFG -----END PGP SIGNATURE----- Merge tag 'pm-5.5-rc8' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm Pull power management fix from Rafael Wysocki: "Prevent the kernel from crashing during resume from hibernation if free pages contain leftover data from the restore kernel and init_on_free is set (Alexander Potapenko)" * tag 'pm-5.5-rc8' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: PM: hibernate: fix crashes with init_on_free=1
This commit is contained in:
commit
3a83c8c81c
@ -1147,24 +1147,24 @@ void free_basic_memory_bitmaps(void)
|
|||||||
|
|
||||||
void clear_free_pages(void)
|
void clear_free_pages(void)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_PAGE_POISONING_ZERO
|
|
||||||
struct memory_bitmap *bm = free_pages_map;
|
struct memory_bitmap *bm = free_pages_map;
|
||||||
unsigned long pfn;
|
unsigned long pfn;
|
||||||
|
|
||||||
if (WARN_ON(!(free_pages_map)))
|
if (WARN_ON(!(free_pages_map)))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
memory_bm_position_reset(bm);
|
if (IS_ENABLED(CONFIG_PAGE_POISONING_ZERO) || want_init_on_free()) {
|
||||||
pfn = memory_bm_next_pfn(bm);
|
memory_bm_position_reset(bm);
|
||||||
while (pfn != BM_END_OF_MAP) {
|
|
||||||
if (pfn_valid(pfn))
|
|
||||||
clear_highpage(pfn_to_page(pfn));
|
|
||||||
|
|
||||||
pfn = memory_bm_next_pfn(bm);
|
pfn = memory_bm_next_pfn(bm);
|
||||||
|
while (pfn != BM_END_OF_MAP) {
|
||||||
|
if (pfn_valid(pfn))
|
||||||
|
clear_highpage(pfn_to_page(pfn));
|
||||||
|
|
||||||
|
pfn = memory_bm_next_pfn(bm);
|
||||||
|
}
|
||||||
|
memory_bm_position_reset(bm);
|
||||||
|
pr_info("free pages cleared after restore\n");
|
||||||
}
|
}
|
||||||
memory_bm_position_reset(bm);
|
|
||||||
pr_info("free pages cleared after restore\n");
|
|
||||||
#endif /* PAGE_POISONING_ZERO */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user