forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
HWPOISON: Add simple debugfs interface to inject hwpoison on arbitary…
… PFNs Useful for some testing scenarios, although specific testing is often done better through MADV_POISON This can be done with the x86 level MCE injector too, but this interface allows it to do independently from low level x86 changes. v2: Add module license (Haicheng Li) Signed-off-by: Andi Kleen <[email protected]>
- Loading branch information
Andi Kleen
authored and
Andi Kleen
committed
Sep 16, 2009
1 parent
9893e49
commit cae681f
Showing
3 changed files
with
46 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
/* Inject a hwpoison memory failure on a arbitary pfn */ | ||
#include <linux/module.h> | ||
#include <linux/debugfs.h> | ||
#include <linux/kernel.h> | ||
#include <linux/mm.h> | ||
|
||
static struct dentry *hwpoison_dir, *corrupt_pfn; | ||
|
||
static int hwpoison_inject(void *data, u64 val) | ||
{ | ||
if (!capable(CAP_SYS_ADMIN)) | ||
return -EPERM; | ||
printk(KERN_INFO "Injecting memory failure at pfn %Lx\n", val); | ||
return __memory_failure(val, 18, 0); | ||
} | ||
|
||
DEFINE_SIMPLE_ATTRIBUTE(hwpoison_fops, NULL, hwpoison_inject, "%lli\n"); | ||
|
||
static void pfn_inject_exit(void) | ||
{ | ||
if (hwpoison_dir) | ||
debugfs_remove_recursive(hwpoison_dir); | ||
} | ||
|
||
static int pfn_inject_init(void) | ||
{ | ||
hwpoison_dir = debugfs_create_dir("hwpoison", NULL); | ||
if (hwpoison_dir == NULL) | ||
return -ENOMEM; | ||
corrupt_pfn = debugfs_create_file("corrupt-pfn", 0600, hwpoison_dir, | ||
NULL, &hwpoison_fops); | ||
if (corrupt_pfn == NULL) { | ||
pfn_inject_exit(); | ||
return -ENOMEM; | ||
} | ||
return 0; | ||
} | ||
|
||
module_init(pfn_inject_init); | ||
module_exit(pfn_inject_exit); | ||
MODULE_LICENSE("GPL"); |