locks: fix setlease methods to free passed-in lock
[linux-2.6/linux-acpi-2.6/ibm-acpi-2.6.git] / include / linux / sysrq.h
blob387fa7d05c982b758942f83395e328949324fc1a
1 /* -*- linux-c -*-
3 * $Id: sysrq.h,v 1.3 1997/07/17 11:54:33 mj Exp $
5 * Linux Magic System Request Key Hacks
7 * (c) 1997 Martin Mares <mj@atrey.karlin.mff.cuni.cz>
9 * (c) 2000 Crutcher Dunnavant <crutcher+kernel@datastacks.com>
10 * overhauled to use key registration
11 * based upon discusions in irc://irc.openprojects.net/#kernelnewbies
14 #ifndef _LINUX_SYSRQ_H
15 #define _LINUX_SYSRQ_H
17 #include <linux/errno.h>
18 #include <linux/types.h>
20 /* Possible values of bitmask for enabling sysrq functions */
21 /* 0x0001 is reserved for enable everything */
22 #define SYSRQ_ENABLE_LOG 0x0002
23 #define SYSRQ_ENABLE_KEYBOARD 0x0004
24 #define SYSRQ_ENABLE_DUMP 0x0008
25 #define SYSRQ_ENABLE_SYNC 0x0010
26 #define SYSRQ_ENABLE_REMOUNT 0x0020
27 #define SYSRQ_ENABLE_SIGNAL 0x0040
28 #define SYSRQ_ENABLE_BOOT 0x0080
29 #define SYSRQ_ENABLE_RTNICE 0x0100
31 struct sysrq_key_op {
32 void (*handler)(int);
33 char *help_msg;
34 char *action_msg;
35 int enable_mask;
38 #ifdef CONFIG_MAGIC_SYSRQ
40 /* Generic SysRq interface -- you may call it from any device driver, supplying
41 * ASCII code of the key, pointer to registers and kbd/tty structs (if they
42 * are available -- else NULL's).
45 void handle_sysrq(int key);
46 void __handle_sysrq(int key, bool check_mask);
47 int register_sysrq_key(int key, struct sysrq_key_op *op);
48 int unregister_sysrq_key(int key, struct sysrq_key_op *op);
49 struct sysrq_key_op *__sysrq_get_key_op(int key);
51 int sysrq_toggle_support(int enable_mask);
53 #else
55 static inline void handle_sysrq(int key)
59 static inline void __handle_sysrq(int key, bool check_mask)
63 static inline int register_sysrq_key(int key, struct sysrq_key_op *op)
65 return -EINVAL;
68 static inline int unregister_sysrq_key(int key, struct sysrq_key_op *op)
70 return -EINVAL;
73 #endif
75 #endif /* _LINUX_SYSRQ_H */