kdebug.h 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. #ifndef _IA64_KDEBUG_H
  2. #define _IA64_KDEBUG_H 1
  3. /*
  4. * include/asm-ia64/kdebug.h
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, write to the Free Software
  18. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  19. *
  20. * Copyright (C) Intel Corporation, 2005
  21. *
  22. * 2005-Apr Rusty Lynch <rusty.lynch@intel.com> and Anil S Keshavamurthy
  23. * <anil.s.keshavamurthy@intel.com> adopted from
  24. * include/asm-x86_64/kdebug.h
  25. *
  26. * 2005-Oct Keith Owens <kaos@sgi.com>. Expand notify_die to cover more
  27. * events.
  28. */
  29. #include <linux/notifier.h>
  30. struct pt_regs;
  31. struct die_args {
  32. struct pt_regs *regs;
  33. const char *str;
  34. long err;
  35. int trapnr;
  36. int signr;
  37. };
  38. extern int register_die_notifier(struct notifier_block *);
  39. extern int unregister_die_notifier(struct notifier_block *);
  40. extern int register_page_fault_notifier(struct notifier_block *);
  41. extern int unregister_page_fault_notifier(struct notifier_block *);
  42. extern struct atomic_notifier_head ia64die_chain;
  43. enum die_val {
  44. DIE_BREAK = 1,
  45. DIE_FAULT,
  46. DIE_OOPS,
  47. DIE_PAGE_FAULT,
  48. DIE_MACHINE_HALT,
  49. DIE_MACHINE_RESTART,
  50. DIE_MCA_MONARCH_ENTER,
  51. DIE_MCA_MONARCH_PROCESS,
  52. DIE_MCA_MONARCH_LEAVE,
  53. DIE_MCA_SLAVE_ENTER,
  54. DIE_MCA_SLAVE_PROCESS,
  55. DIE_MCA_SLAVE_LEAVE,
  56. DIE_MCA_RENDZVOUS_ENTER,
  57. DIE_MCA_RENDZVOUS_PROCESS,
  58. DIE_MCA_RENDZVOUS_LEAVE,
  59. DIE_MCA_NEW_TIMEOUT,
  60. DIE_INIT_ENTER,
  61. DIE_INIT_MONARCH_ENTER,
  62. DIE_INIT_MONARCH_PROCESS,
  63. DIE_INIT_MONARCH_LEAVE,
  64. DIE_INIT_SLAVE_ENTER,
  65. DIE_INIT_SLAVE_PROCESS,
  66. DIE_INIT_SLAVE_LEAVE,
  67. DIE_KDEBUG_ENTER,
  68. DIE_KDEBUG_LEAVE,
  69. DIE_KDUMP_ENTER,
  70. DIE_KDUMP_LEAVE,
  71. };
  72. static inline int notify_die(enum die_val val, char *str, struct pt_regs *regs,
  73. long err, int trap, int sig)
  74. {
  75. struct die_args args = {
  76. .regs = regs,
  77. .str = str,
  78. .err = err,
  79. .trapnr = trap,
  80. .signr = sig
  81. };
  82. return atomic_notifier_call_chain(&ia64die_chain, val, &args);
  83. }
  84. #endif