reactor_printk.c 1003 B

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) 2019-2022 Red Hat, Inc. Daniel Bristot de Oliveira <[email protected]>
  4. *
  5. * Printk RV reactor:
  6. * Prints the exception msg to the kernel message log.
  7. */
  8. #include <linux/ftrace.h>
  9. #include <linux/tracepoint.h>
  10. #include <linux/kernel.h>
  11. #include <linux/module.h>
  12. #include <linux/init.h>
  13. #include <linux/rv.h>
  14. static void rv_printk_reaction(char *msg)
  15. {
  16. printk_deferred(msg);
  17. }
  18. static struct rv_reactor rv_printk = {
  19. .name = "printk",
  20. .description = "prints the exception msg to the kernel message log.",
  21. .react = rv_printk_reaction
  22. };
  23. static int __init register_react_printk(void)
  24. {
  25. rv_register_reactor(&rv_printk);
  26. return 0;
  27. }
  28. static void __exit unregister_react_printk(void)
  29. {
  30. rv_unregister_reactor(&rv_printk);
  31. }
  32. module_init(register_react_printk);
  33. module_exit(unregister_react_printk);
  34. MODULE_LICENSE("GPL");
  35. MODULE_AUTHOR("Daniel Bristot de Oliveira");
  36. MODULE_DESCRIPTION("printk rv reactor: printk if an exception is hit.");