vt: add an event interface
[safe/jmp/linux-2.6] / include / linux / vt.h
1 #ifndef _LINUX_VT_H
2 #define _LINUX_VT_H
3
4 #ifdef __KERNEL__
5 struct notifier_block;
6
7 struct vt_notifier_param {
8         struct vc_data *vc;     /* VC on which the update happened */
9         unsigned int c;         /* Printed char */
10 };
11
12 extern int register_vt_notifier(struct notifier_block *nb);
13 extern int unregister_vt_notifier(struct notifier_block *nb);
14 #endif
15
16 /*
17  * These constants are also useful for user-level apps (e.g., VC
18  * resizing).
19  */
20 #define MIN_NR_CONSOLES 1       /* must be at least 1 */
21 #define MAX_NR_CONSOLES 63      /* serial lines start at 64 */
22 #define MAX_NR_USER_CONSOLES 63 /* must be root to allocate above this */
23                 /* Note: the ioctl VT_GETSTATE does not work for
24                    consoles 16 and higher (since it returns a short) */
25
26 /* 0x56 is 'V', to avoid collision with termios and kd */
27
28 #define VT_OPENQRY      0x5600  /* find available vt */
29
30 struct vt_mode {
31         char mode;              /* vt mode */
32         char waitv;             /* if set, hang on writes if not active */
33         short relsig;           /* signal to raise on release req */
34         short acqsig;           /* signal to raise on acquisition */
35         short frsig;            /* unused (set to 0) */
36 };
37 #define VT_GETMODE      0x5601  /* get mode of active vt */
38 #define VT_SETMODE      0x5602  /* set mode of active vt */
39 #define         VT_AUTO         0x00    /* auto vt switching */
40 #define         VT_PROCESS      0x01    /* process controls switching */
41 #define         VT_ACKACQ       0x02    /* acknowledge switch */
42
43 struct vt_stat {
44         unsigned short v_active;        /* active vt */
45         unsigned short v_signal;        /* signal to send */
46         unsigned short v_state;         /* vt bitmask */
47 };
48 #define VT_GETSTATE     0x5603  /* get global vt state info */
49 #define VT_SENDSIG      0x5604  /* signal to send to bitmask of vts */
50
51 #define VT_RELDISP      0x5605  /* release display */
52
53 #define VT_ACTIVATE     0x5606  /* make vt active */
54 #define VT_WAITACTIVE   0x5607  /* wait for vt active */
55 #define VT_DISALLOCATE  0x5608  /* free memory associated to vt */
56
57 struct vt_sizes {
58         unsigned short v_rows;          /* number of rows */
59         unsigned short v_cols;          /* number of columns */
60         unsigned short v_scrollsize;    /* number of lines of scrollback */
61 };
62 #define VT_RESIZE       0x5609  /* set kernel's idea of screensize */
63
64 struct vt_consize {
65         unsigned short v_rows;  /* number of rows */
66         unsigned short v_cols;  /* number of columns */
67         unsigned short v_vlin;  /* number of pixel rows on screen */
68         unsigned short v_clin;  /* number of pixel rows per character */
69         unsigned short v_vcol;  /* number of pixel columns on screen */
70         unsigned short v_ccol;  /* number of pixel columns per character */
71 };
72 #define VT_RESIZEX      0x560A  /* set kernel's idea of screensize + more */
73 #define VT_LOCKSWITCH   0x560B  /* disallow vt switching */
74 #define VT_UNLOCKSWITCH 0x560C  /* allow vt switching */
75 #define VT_GETHIFONTMASK 0x560D  /* return hi font mask */
76
77 struct vt_event {
78         unsigned int event;
79 #define VT_EVENT_SWITCH         0x0001  /* Console switch */
80 #define VT_EVENT_BLANK          0x0002  /* Screen blank */
81 #define VT_EVENT_UNBLANK        0x0004  /* Screen unblank */
82 #define VT_EVENT_RESIZE         0x0008  /* Resize display */
83 #define VT_MAX_EVENT            0x000F
84         unsigned int old;               /* Old console */
85         unsigned int new;               /* New console (if changing) */
86         unsigned int pad[4];            /* Padding for expansion */
87 };
88
89 #define VT_WAITEVENT    0x560E  /* Wait for an event */
90
91 #endif /* _LINUX_VT_H */