Skip to content
Snippets Groups Projects
  • Akinobu Mita's avatar
    f5a9f52e
    cpu: rewrite cpu-notifier-error-inject module · f5a9f52e
    Akinobu Mita authored
    
    Rewrite existing cpu-notifier-error-inject module to use debugfs based new
    framework.
    
    This change removes cpu_up_prepare_error and cpu_down_prepare_error module
    parameters which were used to specify error code to be injected.  We could
    keep these module parameters for backward compatibility by module_param_cb
    but it seems overkill for this module.
    
    This provides the ability to inject artifical errors to CPU notifier chain
    callbacks.  It is controlled through debugfs interface under
    /sys/kernel/debug/notifier-error-inject/cpu
    
    If the notifier call chain should be failed with some events notified,
    write the error code to "actions/<notifier event>/error".
    
    Example1: inject CPU offline error (-1 == -EPERM)
    
    	# cd /sys/kernel/debug/notifier-error-inject/cpu
    	# echo -1 > actions/CPU_DOWN_PREPARE/error
    	# echo 0 > /sys/devices/system/cpu/cpu1/online
    	bash: echo: write error: Operation not permitted
    
    Example2: inject CPU online error (-2 == -ENOENT)
    
    	# cd /sys/kernel/debug/notifier-error-inject/cpu
    	# echo -2 > actions/CPU_UP_PREPARE/error
    	# echo 1 > /sys/devices/system/cpu/cpu1/online
    	bash: echo: write error: No such file or directory
    
    Signed-off-by: default avatarAkinobu Mita <akinobu.mita@gmail.com>
    Cc: Pavel Machek <pavel@ucw.cz>
    Cc: "Rafael J. Wysocki" <rjw@sisk.pl>
    Cc: Greg KH <greg@kroah.com>
    Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
    Cc: Paul Mackerras <paulus@samba.org>
    Cc: Michael Ellerman <michael@ellerman.id.au>
    Cc: Dave Jones <davej@redhat.com>
    Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
    Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
    f5a9f52e
    History
    cpu: rewrite cpu-notifier-error-inject module
    Akinobu Mita authored
    
    Rewrite existing cpu-notifier-error-inject module to use debugfs based new
    framework.
    
    This change removes cpu_up_prepare_error and cpu_down_prepare_error module
    parameters which were used to specify error code to be injected.  We could
    keep these module parameters for backward compatibility by module_param_cb
    but it seems overkill for this module.
    
    This provides the ability to inject artifical errors to CPU notifier chain
    callbacks.  It is controlled through debugfs interface under
    /sys/kernel/debug/notifier-error-inject/cpu
    
    If the notifier call chain should be failed with some events notified,
    write the error code to "actions/<notifier event>/error".
    
    Example1: inject CPU offline error (-1 == -EPERM)
    
    	# cd /sys/kernel/debug/notifier-error-inject/cpu
    	# echo -1 > actions/CPU_DOWN_PREPARE/error
    	# echo 0 > /sys/devices/system/cpu/cpu1/online
    	bash: echo: write error: Operation not permitted
    
    Example2: inject CPU online error (-2 == -ENOENT)
    
    	# cd /sys/kernel/debug/notifier-error-inject/cpu
    	# echo -2 > actions/CPU_UP_PREPARE/error
    	# echo 1 > /sys/devices/system/cpu/cpu1/online
    	bash: echo: write error: No such file or directory
    
    Signed-off-by: default avatarAkinobu Mita <akinobu.mita@gmail.com>
    Cc: Pavel Machek <pavel@ucw.cz>
    Cc: "Rafael J. Wysocki" <rjw@sisk.pl>
    Cc: Greg KH <greg@kroah.com>
    Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
    Cc: Paul Mackerras <paulus@samba.org>
    Cc: Michael Ellerman <michael@ellerman.id.au>
    Cc: Dave Jones <davej@redhat.com>
    Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
    Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
cpu-notifier-error-inject.c 1.18 KiB
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/cpu.h>

#include "notifier-error-inject.h"

static int priority;
module_param(priority, int, 0);
MODULE_PARM_DESC(priority, "specify cpu notifier priority");

static struct notifier_err_inject cpu_notifier_err_inject = {
	.actions = {
		{ NOTIFIER_ERR_INJECT_ACTION(CPU_UP_PREPARE) },
		{ NOTIFIER_ERR_INJECT_ACTION(CPU_UP_PREPARE_FROZEN) },
		{ NOTIFIER_ERR_INJECT_ACTION(CPU_DOWN_PREPARE) },
		{ NOTIFIER_ERR_INJECT_ACTION(CPU_DOWN_PREPARE_FROZEN) },
		{}
	}
};

static struct dentry *dir;

static int err_inject_init(void)
{
	int err;

	dir = notifier_err_inject_init("cpu", notifier_err_inject_dir,
					&cpu_notifier_err_inject, priority);
	if (IS_ERR(dir))
		return PTR_ERR(dir);

	err = register_hotcpu_notifier(&cpu_notifier_err_inject.nb);
	if (err)
		debugfs_remove_recursive(dir);

	return err;
}

static void err_inject_exit(void)
{
	unregister_hotcpu_notifier(&cpu_notifier_err_inject.nb);
	debugfs_remove_recursive(dir);
}

module_init(err_inject_init);
module_exit(err_inject_exit);

MODULE_DESCRIPTION("CPU notifier error injection module");
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Akinobu Mita <akinobu.mita@gmail.com>");