HWPOISON: add page flags filter
When specified, only poison pages if ((page_flags & mask) == value). - corrupt-filter-flags-mask - corrupt-filter-flags-value This allows stress testing of many kinds of pages. Strictly speaking, the buddy pages requires taking zone lock, to avoid setting PG_hwpoison on a "was buddy but now allocated to someone" page. However we can just do nothing because we set PG_locked in the beginning, this prevents the page allocator from allocating it to someone. (It will BUG() on the unexpected PG_locked, which is fine for hwpoison testing.) [AK: Add select PROC_PAGE_MONITOR to satisfy dependency] CC: Nick Piggin <npiggin@suse.de> Signed-off-by: Wu Fengguang <fengguang.wu@intel.com> Signed-off-by: Andi Kleen <ak@linux.intel.com>
This commit is contained in:

gecommit door
Andi Kleen

bovenliggende
1a9b5b7fe0
commit
478c5ffc0b
@@ -102,6 +102,16 @@ static int pfn_inject_init(void)
|
||||
if (!dentry)
|
||||
goto fail;
|
||||
|
||||
dentry = debugfs_create_u64("corrupt-filter-flags-mask", 0600,
|
||||
hwpoison_dir, &hwpoison_filter_flags_mask);
|
||||
if (!dentry)
|
||||
goto fail;
|
||||
|
||||
dentry = debugfs_create_u64("corrupt-filter-flags-value", 0600,
|
||||
hwpoison_dir, &hwpoison_filter_flags_value);
|
||||
if (!dentry)
|
||||
goto fail;
|
||||
|
||||
return 0;
|
||||
fail:
|
||||
pfn_inject_exit();
|
||||
|
Verwijs in nieuw issue
Block a user