|  | 
 | #include <linux/module.h> | 
 | #include <linux/notifier.h> | 
 | #include <linux/vmalloc.h> | 
 | #include <linux/kdebug.h> | 
 |  | 
 |  | 
 | static ATOMIC_NOTIFIER_HEAD(die_chain); | 
 |  | 
 | int notify_die(enum die_val val, const char *str, | 
 | 	       struct pt_regs *regs, long err, int trap, int sig) | 
 | { | 
 | 	struct die_args args = { | 
 | 		.regs		= regs, | 
 | 		.str		= str, | 
 | 		.err		= err, | 
 | 		.trapnr		= trap, | 
 | 		.signr		= sig, | 
 |  | 
 | 	}; | 
 |  | 
 | 	return atomic_notifier_call_chain(&die_chain, val, &args); | 
 | } | 
 |  | 
 | int register_die_notifier(struct notifier_block *nb) | 
 | { | 
 | 	vmalloc_sync_all(); | 
 | 	return atomic_notifier_chain_register(&die_chain, nb); | 
 | } | 
 | EXPORT_SYMBOL_GPL(register_die_notifier); | 
 |  | 
 | int unregister_die_notifier(struct notifier_block *nb) | 
 | { | 
 | 	return atomic_notifier_chain_unregister(&die_chain, nb); | 
 | } | 
 | EXPORT_SYMBOL_GPL(unregister_die_notifier); | 
 |  | 
 |  |