home *** CD-ROM | disk | FTP | other *** search
/ PC Welt 2006 November (DVD) / PCWELT_11_2006.ISO / casper / filesystem.squashfs / usr / src / linux-headers-2.6.17-6 / include / asm-ia64 / kdebug.h < prev    next >
Encoding:
C/C++ Source or Header  |  2006-08-11  |  2.3 KB  |  90 lines

  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.  
  31. struct pt_regs;
  32.  
  33. struct die_args {
  34.     struct pt_regs *regs;
  35.     const char *str;
  36.     long err;
  37.     int trapnr;
  38.     int signr;
  39. };
  40.  
  41. extern int register_die_notifier(struct notifier_block *);
  42. extern int unregister_die_notifier(struct notifier_block *);
  43. extern struct atomic_notifier_head ia64die_chain;
  44.  
  45. enum die_val {
  46.     DIE_BREAK = 1,
  47.     DIE_FAULT,
  48.     DIE_OOPS,
  49.     DIE_PAGE_FAULT,
  50.     DIE_MACHINE_HALT,
  51.     DIE_MACHINE_RESTART,
  52.     DIE_MCA_MONARCH_ENTER,
  53.     DIE_MCA_MONARCH_PROCESS,
  54.     DIE_MCA_MONARCH_LEAVE,
  55.     DIE_MCA_SLAVE_ENTER,
  56.     DIE_MCA_SLAVE_PROCESS,
  57.     DIE_MCA_SLAVE_LEAVE,
  58.     DIE_MCA_RENDZVOUS_ENTER,
  59.     DIE_MCA_RENDZVOUS_PROCESS,
  60.     DIE_MCA_RENDZVOUS_LEAVE,
  61.     DIE_MCA_NEW_TIMEOUT,
  62.     DIE_INIT_ENTER,
  63.     DIE_INIT_MONARCH_ENTER,
  64.     DIE_INIT_MONARCH_PROCESS,
  65.     DIE_INIT_MONARCH_LEAVE,
  66.     DIE_INIT_SLAVE_ENTER,
  67.     DIE_INIT_SLAVE_PROCESS,
  68.     DIE_INIT_SLAVE_LEAVE,
  69.     DIE_KDEBUG_ENTER,
  70.     DIE_KDEBUG_LEAVE,
  71.     DIE_KDUMP_ENTER,
  72.     DIE_KDUMP_LEAVE,
  73. };
  74.  
  75. static inline int notify_die(enum die_val val, char *str, struct pt_regs *regs,
  76.                  long err, int trap, int sig)
  77. {
  78.     struct die_args args = {
  79.         .regs   = regs,
  80.         .str    = str,
  81.         .err    = err,
  82.         .trapnr = trap,
  83.         .signr  = sig
  84.     };
  85.  
  86.     return atomic_notifier_call_chain(&ia64die_chain, val, &args);
  87. }
  88.  
  89. #endif
  90.