Commit | Line | Data |
---|---|---|
45d607ed RA |
1 | /* |
2 | * hvc_console.h | |
3 | * Copyright (C) 2005 IBM Corporation | |
4 | * | |
5 | * Author(s): | |
6 | * Ryan S. Arnold <rsa@us.ibm.com> | |
7 | * | |
8 | * hvc_console header information: | |
b8b572e1 | 9 | * moved here from arch/powerpc/include/asm/hvconsole.h |
45d607ed RA |
10 | * and drivers/char/hvc_console.c |
11 | * | |
12 | * This program is free software; you can redistribute it and/or modify | |
13 | * it under the terms of the GNU General Public License as published by | |
14 | * the Free Software Foundation; either version 2 of the License, or | |
15 | * (at your option) any later version. | |
16 | * | |
17 | * This program is distributed in the hope that it will be useful, | |
18 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
20 | * GNU General Public License for more details. | |
21 | * | |
22 | * You should have received a copy of the GNU General Public License | |
23 | * along with this program; if not, write to the Free Software | |
24 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
25 | */ | |
26 | ||
27 | #ifndef HVC_CONSOLE_H | |
28 | #define HVC_CONSOLE_H | |
611e097d | 29 | #include <linux/kref.h> |
febde371 | 30 | #include <linux/tty.h> |
254be490 | 31 | #include <linux/spinlock.h> |
45d607ed RA |
32 | |
33 | /* | |
34 | * This is the max number of console adapters that can/will be found as | |
35 | * console devices on first stage console init. Any number beyond this range | |
36 | * can't be used as a console device but is still a valid tty device. | |
37 | */ | |
38 | #define MAX_NR_HVC_CONSOLES 16 | |
39 | ||
40 | /* | |
41 | * The Linux TTY code does not support dynamic addition of tty derived devices | |
42 | * so we need to know how many tty devices we might need when space is allocated | |
43 | * for the tty device. Since this driver supports hotplug of vty adapters we | |
44 | * need to make sure we have enough allocated. | |
45 | */ | |
46 | #define HVC_ALLOC_TTY_ADAPTERS 8 | |
47 | ||
611e097d | 48 | struct hvc_struct { |
f3d9f250 | 49 | struct tty_port port; |
611e097d CB |
50 | spinlock_t lock; |
51 | int index; | |
611e097d CB |
52 | int do_wakeup; |
53 | char *outbuf; | |
54 | int outbuf_size; | |
55 | int n_outbuf; | |
56 | uint32_t vtermno; | |
b5113068 | 57 | const struct hv_ops *ops; |
611e097d CB |
58 | int irq_requested; |
59 | int data; | |
febde371 HB |
60 | struct winsize ws; |
61 | struct work_struct tty_resize; | |
611e097d | 62 | struct list_head next; |
611e097d | 63 | }; |
45d607ed RA |
64 | |
65 | /* implemented by a low level driver */ | |
66 | struct hv_ops { | |
67 | int (*get_chars)(uint32_t vtermno, char *buf, int count); | |
68 | int (*put_chars)(uint32_t vtermno, const char *buf, int count); | |
45d607ed | 69 | |
fc362e2e | 70 | /* Callbacks for notification. Called in open, close and hangup */ |
611e097d CB |
71 | int (*notifier_add)(struct hvc_struct *hp, int irq); |
72 | void (*notifier_del)(struct hvc_struct *hp, int irq); | |
fc362e2e | 73 | void (*notifier_hangup)(struct hvc_struct *hp, int irq); |
4d2bb3f5 BH |
74 | |
75 | /* tiocmget/set implementation */ | |
76 | int (*tiocmget)(struct hvc_struct *hp); | |
77 | int (*tiocmset)(struct hvc_struct *hp, unsigned int set, unsigned int clear); | |
33e745a1 HB |
78 | |
79 | /* Callbacks to handle tty ports */ | |
80 | void (*dtr_rts)(struct hvc_struct *hp, int raise); | |
611e097d | 81 | }; |
45d607ed RA |
82 | |
83 | /* Register a vterm and a slot index for use as a console (console_init) */ | |
b5113068 RR |
84 | extern int hvc_instantiate(uint32_t vtermno, int index, |
85 | const struct hv_ops *ops); | |
45d607ed RA |
86 | |
87 | /* register a vterm for hvc tty operation (module_init or hotplug add) */ | |
119ea109 AS |
88 | extern struct hvc_struct * hvc_alloc(uint32_t vtermno, int data, |
89 | const struct hv_ops *ops, int outbuf_size); | |
611e097d | 90 | /* remove a vterm from hvc tty operation (module_exit or hotplug remove) */ |
934752d8 | 91 | extern int hvc_remove(struct hvc_struct *hp); |
45d607ed | 92 | |
611e097d CB |
93 | /* data available */ |
94 | int hvc_poll(struct hvc_struct *hp); | |
95 | void hvc_kick(void); | |
96 | ||
febde371 | 97 | /* Resize hvc tty terminal window */ |
254be490 HB |
98 | extern void __hvc_resize(struct hvc_struct *hp, struct winsize ws); |
99 | ||
100 | static inline void hvc_resize(struct hvc_struct *hp, struct winsize ws) | |
101 | { | |
102 | unsigned long flags; | |
103 | ||
104 | spin_lock_irqsave(&hp->lock, flags); | |
105 | __hvc_resize(hp, ws); | |
106 | spin_unlock_irqrestore(&hp->lock, flags); | |
107 | } | |
febde371 | 108 | |
611e097d CB |
109 | /* default notifier for irq based notification */ |
110 | extern int notifier_add_irq(struct hvc_struct *hp, int data); | |
111 | extern void notifier_del_irq(struct hvc_struct *hp, int data); | |
fc362e2e | 112 | extern void notifier_hangup_irq(struct hvc_struct *hp, int data); |
611e097d | 113 | |
1c8950ff ME |
114 | |
115 | #if defined(CONFIG_XMON) && defined(CONFIG_SMP) | |
116 | #include <asm/xmon.h> | |
117 | #else | |
118 | static inline int cpus_are_in_xmon(void) | |
119 | { | |
120 | return 0; | |
121 | } | |
122 | #endif | |
123 | ||
45d607ed | 124 | #endif // HVC_CONSOLE_H |