| 
									
										
										
										
											2010-05-26 14:43:36 -07:00
										 |  |  | #include <linux/kernel.h>
 | 
					
						
							|  |  |  | #include <linux/module.h>
 | 
					
						
							| 
									
										
										
										
											2012-07-30 14:43:03 -07:00
										 |  |  | #include <linux/cpu.h>
 | 
					
						
							| 
									
										
										
										
											2010-05-26 14:43:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-30 14:43:03 -07:00
										 |  |  | #include "notifier-error-inject.h"
 | 
					
						
							| 
									
										
										
										
											2010-05-26 14:43:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-30 14:43:03 -07:00
										 |  |  | static int priority; | 
					
						
							| 
									
										
										
										
											2010-05-26 14:43:36 -07:00
										 |  |  | module_param(priority, int, 0); | 
					
						
							|  |  |  | MODULE_PARM_DESC(priority, "specify cpu notifier priority"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-30 14:43:03 -07:00
										 |  |  | 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) }, | 
					
						
							|  |  |  | 		{} | 
					
						
							| 
									
										
										
										
											2010-05-26 14:43:36 -07:00
										 |  |  | 	} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-30 14:43:03 -07:00
										 |  |  | static struct dentry *dir; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-26 14:43:36 -07:00
										 |  |  | static int err_inject_init(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-07-30 14:43:03 -07:00
										 |  |  | 	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); | 
					
						
							| 
									
										
										
										
											2010-05-26 14:43:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-30 14:43:03 -07:00
										 |  |  | 	return err; | 
					
						
							| 
									
										
										
										
											2010-05-26 14:43:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void err_inject_exit(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-07-30 14:43:03 -07:00
										 |  |  | 	unregister_hotcpu_notifier(&cpu_notifier_err_inject.nb); | 
					
						
							|  |  |  | 	debugfs_remove_recursive(dir); | 
					
						
							| 
									
										
										
										
											2010-05-26 14:43:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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>"); |