blob: e4dce87095410f8f648137ecb992927a6630c483 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/drivers/char/tty_io.c
3 *
4 * Copyright (C) 1991, 1992 Linus Torvalds
5 */
6
7/*
8 * 'tty_io.c' gives an orthogonal feeling to tty's, be they consoles
9 * or rs-channels. It also implements echoing, cooked mode etc.
10 *
11 * Kill-line thanks to John T Kohl, who also corrected VMIN = VTIME = 0.
12 *
13 * Modified by Theodore Ts'o, 9/14/92, to dynamically allocate the
14 * tty_struct and tty_queue structures. Previously there was an array
15 * of 256 tty_struct's which was statically allocated, and the
16 * tty_queue structures were allocated at boot time. Both are now
17 * dynamically allocated only when the tty is open.
18 *
19 * Also restructured routines so that there is more of a separation
20 * between the high-level tty routines (tty_io.c and tty_ioctl.c) and
21 * the low-level tty routines (serial.c, pty.c, console.c). This
Alan Cox37bdfb02008-02-08 04:18:47 -080022 * makes for cleaner and more compact code. -TYT, 9/17/92
Linus Torvalds1da177e2005-04-16 15:20:36 -070023 *
24 * Modified by Fred N. van Kempen, 01/29/93, to add line disciplines
25 * which can be dynamically activated and de-activated by the line
26 * discipline handling modules (like SLIP).
27 *
28 * NOTE: pay no attention to the line discipline code (yet); its
29 * interface is still subject to change in this version...
30 * -- TYT, 1/31/92
31 *
32 * Added functionality to the OPOST tty handling. No delays, but all
33 * other bits should be there.
34 * -- Nick Holloway <alfie@dcs.warwick.ac.uk>, 27th May 1993.
35 *
36 * Rewrote canonical mode and added more termios flags.
37 * -- julian@uhunix.uhcc.hawaii.edu (J. Cowley), 13Jan94
38 *
39 * Reorganized FASYNC support so mouse code can share it.
40 * -- ctm@ardi.com, 9Sep95
41 *
42 * New TIOCLINUX variants added.
43 * -- mj@k332.feld.cvut.cz, 19-Nov-95
Alan Cox37bdfb02008-02-08 04:18:47 -080044 *
Linus Torvalds1da177e2005-04-16 15:20:36 -070045 * Restrict vt switching via ioctl()
46 * -- grif@cs.ucr.edu, 5-Dec-95
47 *
48 * Move console and virtual terminal code to more appropriate files,
49 * implement CONFIG_VT and generalize console device interface.
50 * -- Marko Kohtala <Marko.Kohtala@hut.fi>, March 97
51 *
52 * Rewrote init_dev and release_dev to eliminate races.
53 * -- Bill Hawes <whawes@star.net>, June 97
54 *
55 * Added devfs support.
56 * -- C. Scott Ananian <cananian@alumni.princeton.edu>, 13-Jan-1998
57 *
58 * Added support for a Unix98-style ptmx device.
59 * -- C. Scott Ananian <cananian@alumni.princeton.edu>, 14-Jan-1998
60 *
61 * Reduced memory usage for older ARM systems
62 * -- Russell King <rmk@arm.linux.org.uk>
63 *
64 * Move do_SAK() into process context. Less stack use in devfs functions.
Alan Cox37bdfb02008-02-08 04:18:47 -080065 * alloc_tty_struct() always uses kmalloc()
66 * -- Andrew Morton <andrewm@uow.edu.eu> 17Mar01
Linus Torvalds1da177e2005-04-16 15:20:36 -070067 */
68
Linus Torvalds1da177e2005-04-16 15:20:36 -070069#include <linux/types.h>
70#include <linux/major.h>
71#include <linux/errno.h>
72#include <linux/signal.h>
73#include <linux/fcntl.h>
74#include <linux/sched.h>
75#include <linux/interrupt.h>
76#include <linux/tty.h>
77#include <linux/tty_driver.h>
78#include <linux/tty_flip.h>
79#include <linux/devpts_fs.h>
80#include <linux/file.h>
Al Viro9f3acc32008-04-24 07:44:08 -040081#include <linux/fdtable.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070082#include <linux/console.h>
83#include <linux/timer.h>
84#include <linux/ctype.h>
85#include <linux/kd.h>
86#include <linux/mm.h>
87#include <linux/string.h>
88#include <linux/slab.h>
89#include <linux/poll.h>
90#include <linux/proc_fs.h>
91#include <linux/init.h>
92#include <linux/module.h>
93#include <linux/smp_lock.h>
94#include <linux/device.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070095#include <linux/wait.h>
96#include <linux/bitops.h>
Domen Puncerb20f3ae2005-06-25 14:58:42 -070097#include <linux/delay.h>
Alan Coxa352def2008-07-16 21:53:12 +010098#include <linux/seq_file.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070099
Alan Coxa352def2008-07-16 21:53:12 +0100100#include <linux/uaccess.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -0700101#include <asm/system.h>
102
103#include <linux/kbd_kern.h>
104#include <linux/vt_kern.h>
105#include <linux/selection.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -0700106
107#include <linux/kmod.h>
Pavel Emelyanovb4888932007-10-18 23:40:14 -0700108#include <linux/nsproxy.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -0700109
110#undef TTY_DEBUG_HANGUP
111
112#define TTY_PARANOIA_CHECK 1
113#define CHECK_TTY_COUNT 1
114
Alan Coxedc6afc2006-12-08 02:38:44 -0800115struct ktermios tty_std_termios = { /* for the benefit of tty drivers */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700116 .c_iflag = ICRNL | IXON,
117 .c_oflag = OPOST | ONLCR,
118 .c_cflag = B38400 | CS8 | CREAD | HUPCL,
119 .c_lflag = ISIG | ICANON | ECHO | ECHOE | ECHOK |
120 ECHOCTL | ECHOKE | IEXTEN,
Alan Coxedc6afc2006-12-08 02:38:44 -0800121 .c_cc = INIT_C_CC,
122 .c_ispeed = 38400,
123 .c_ospeed = 38400
Linus Torvalds1da177e2005-04-16 15:20:36 -0700124};
125
126EXPORT_SYMBOL(tty_std_termios);
127
128/* This list gets poked at by procfs and various bits of boot up code. This
129 could do with some rationalisation such as pulling the tty proc function
130 into this file */
Alan Cox37bdfb02008-02-08 04:18:47 -0800131
Linus Torvalds1da177e2005-04-16 15:20:36 -0700132LIST_HEAD(tty_drivers); /* linked list of tty drivers */
133
Peter Zijlstra24ec8392006-12-08 02:36:04 -0800134/* Mutex to protect creating and releasing a tty. This is shared with
Linus Torvalds1da177e2005-04-16 15:20:36 -0700135 vt.c for deeply disgusting hack reasons */
Ingo Molnar70522e12006-03-23 03:00:31 -0800136DEFINE_MUTEX(tty_mutex);
Alan Coxde2a84f2006-09-29 02:00:57 -0700137EXPORT_SYMBOL(tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700138
139#ifdef CONFIG_UNIX98_PTYS
140extern struct tty_driver *ptm_driver; /* Unix98 pty masters; for /dev/ptmx */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700141static int ptmx_open(struct inode *, struct file *);
142#endif
143
Linus Torvalds1da177e2005-04-16 15:20:36 -0700144static void initialize_tty_struct(struct tty_struct *tty);
145
146static ssize_t tty_read(struct file *, char __user *, size_t, loff_t *);
147static ssize_t tty_write(struct file *, const char __user *, size_t, loff_t *);
Alan Cox37bdfb02008-02-08 04:18:47 -0800148ssize_t redirected_tty_write(struct file *, const char __user *,
149 size_t, loff_t *);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700150static unsigned int tty_poll(struct file *, poll_table *);
151static int tty_open(struct inode *, struct file *);
152static int tty_release(struct inode *, struct file *);
Alan Cox04f378b2008-04-30 00:53:29 -0700153long tty_ioctl(struct file *file, unsigned int cmd, unsigned long arg);
Paul Fulghume10cc1d2007-05-10 22:22:50 -0700154#ifdef CONFIG_COMPAT
Alan Cox37bdfb02008-02-08 04:18:47 -0800155static long tty_compat_ioctl(struct file *file, unsigned int cmd,
Paul Fulghume10cc1d2007-05-10 22:22:50 -0700156 unsigned long arg);
157#else
158#define tty_compat_ioctl NULL
159#endif
Alan Cox37bdfb02008-02-08 04:18:47 -0800160static int tty_fasync(int fd, struct file *filp, int on);
Christoph Hellwigd5698c22007-02-10 01:46:46 -0800161static void release_tty(struct tty_struct *tty, int idx);
Eric W. Biederman2a65f1d2007-05-08 00:26:53 -0700162static void __proc_set_tty(struct task_struct *tsk, struct tty_struct *tty);
Eric W. Biederman98a27ba2007-05-08 00:26:56 -0700163static void proc_set_tty(struct task_struct *tsk, struct tty_struct *tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700164
Alan Coxaf9b8972006-08-27 01:24:01 -0700165/**
166 * alloc_tty_struct - allocate a tty object
167 *
168 * Return a new empty tty structure. The data fields have not
169 * been initialized in any way but has been zeroed
170 *
171 * Locking: none
Alan Coxaf9b8972006-08-27 01:24:01 -0700172 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700173
174static struct tty_struct *alloc_tty_struct(void)
175{
Alan Cox1266b1e2006-09-29 02:00:40 -0700176 return kzalloc(sizeof(struct tty_struct), GFP_KERNEL);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700177}
178
Alan Cox33f0f882006-01-09 20:54:13 -0800179static void tty_buffer_free_all(struct tty_struct *);
180
Alan Coxaf9b8972006-08-27 01:24:01 -0700181/**
182 * free_tty_struct - free a disused tty
183 * @tty: tty struct to free
184 *
185 * Free the write buffers, tty queue and tty memory itself.
186 *
187 * Locking: none. Must be called after tty is definitely unused
188 */
189
Linus Torvalds1da177e2005-04-16 15:20:36 -0700190static inline void free_tty_struct(struct tty_struct *tty)
191{
192 kfree(tty->write_buf);
Alan Cox33f0f882006-01-09 20:54:13 -0800193 tty_buffer_free_all(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700194 kfree(tty);
195}
196
197#define TTY_NUMBER(tty) ((tty)->index + (tty)->driver->name_base)
198
Alan Coxaf9b8972006-08-27 01:24:01 -0700199/**
200 * tty_name - return tty naming
201 * @tty: tty structure
202 * @buf: buffer for output
203 *
204 * Convert a tty structure into a name. The name reflects the kernel
205 * naming policy and if udev is in use may not reflect user space
206 *
207 * Locking: none
208 */
209
Linus Torvalds1da177e2005-04-16 15:20:36 -0700210char *tty_name(struct tty_struct *tty, char *buf)
211{
212 if (!tty) /* Hmm. NULL pointer. That's fun. */
213 strcpy(buf, "NULL tty");
214 else
215 strcpy(buf, tty->name);
216 return buf;
217}
218
219EXPORT_SYMBOL(tty_name);
220
Andrew Mortond769a662005-05-05 16:15:50 -0700221int tty_paranoia_check(struct tty_struct *tty, struct inode *inode,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700222 const char *routine)
223{
224#ifdef TTY_PARANOIA_CHECK
225 if (!tty) {
226 printk(KERN_WARNING
227 "null TTY for (%d:%d) in %s\n",
228 imajor(inode), iminor(inode), routine);
229 return 1;
230 }
231 if (tty->magic != TTY_MAGIC) {
232 printk(KERN_WARNING
233 "bad magic number for tty struct (%d:%d) in %s\n",
234 imajor(inode), iminor(inode), routine);
235 return 1;
236 }
237#endif
238 return 0;
239}
240
241static int check_tty_count(struct tty_struct *tty, const char *routine)
242{
243#ifdef CHECK_TTY_COUNT
244 struct list_head *p;
245 int count = 0;
Alan Cox37bdfb02008-02-08 04:18:47 -0800246
Linus Torvalds1da177e2005-04-16 15:20:36 -0700247 file_list_lock();
248 list_for_each(p, &tty->tty_files) {
249 count++;
250 }
251 file_list_unlock();
252 if (tty->driver->type == TTY_DRIVER_TYPE_PTY &&
253 tty->driver->subtype == PTY_TYPE_SLAVE &&
254 tty->link && tty->link->count)
255 count++;
256 if (tty->count != count) {
257 printk(KERN_WARNING "Warning: dev (%s) tty->count(%d) "
258 "!= #fd's(%d) in %s\n",
259 tty->name, tty->count, count, routine);
260 return count;
Peter Zijlstra24ec8392006-12-08 02:36:04 -0800261 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700262#endif
263 return 0;
264}
265
266/*
Alan Cox33f0f882006-01-09 20:54:13 -0800267 * Tty buffer allocation management
268 */
269
Alan Cox01da5fd2006-08-27 01:24:02 -0700270/**
271 * tty_buffer_free_all - free buffers used by a tty
272 * @tty: tty to free from
273 *
274 * Remove all the buffers pending on a tty whether queued with data
275 * or in the free ring. Must be called when the tty is no longer in use
276 *
277 * Locking: none
278 */
279
Alan Cox33f0f882006-01-09 20:54:13 -0800280static void tty_buffer_free_all(struct tty_struct *tty)
281{
282 struct tty_buffer *thead;
Alan Cox37bdfb02008-02-08 04:18:47 -0800283 while ((thead = tty->buf.head) != NULL) {
Alan Cox33f0f882006-01-09 20:54:13 -0800284 tty->buf.head = thead->next;
285 kfree(thead);
286 }
Alan Cox37bdfb02008-02-08 04:18:47 -0800287 while ((thead = tty->buf.free) != NULL) {
Alan Cox33f0f882006-01-09 20:54:13 -0800288 tty->buf.free = thead->next;
289 kfree(thead);
290 }
291 tty->buf.tail = NULL;
Alan Cox01da5fd2006-08-27 01:24:02 -0700292 tty->buf.memory_used = 0;
Alan Cox33f0f882006-01-09 20:54:13 -0800293}
294
Alan Cox01da5fd2006-08-27 01:24:02 -0700295/**
296 * tty_buffer_init - prepare a tty buffer structure
297 * @tty: tty to initialise
298 *
299 * Set up the initial state of the buffer management for a tty device.
300 * Must be called before the other tty buffer functions are used.
301 *
302 * Locking: none
303 */
304
Alan Cox33f0f882006-01-09 20:54:13 -0800305static void tty_buffer_init(struct tty_struct *tty)
306{
Paul Fulghum808249c2006-02-03 03:04:41 -0800307 spin_lock_init(&tty->buf.lock);
Alan Cox33f0f882006-01-09 20:54:13 -0800308 tty->buf.head = NULL;
309 tty->buf.tail = NULL;
310 tty->buf.free = NULL;
Alan Cox01da5fd2006-08-27 01:24:02 -0700311 tty->buf.memory_used = 0;
Alan Cox33f0f882006-01-09 20:54:13 -0800312}
313
Alan Cox01da5fd2006-08-27 01:24:02 -0700314/**
315 * tty_buffer_alloc - allocate a tty buffer
316 * @tty: tty device
317 * @size: desired size (characters)
318 *
319 * Allocate a new tty buffer to hold the desired number of characters.
320 * Return NULL if out of memory or the allocation would exceed the
321 * per device queue
322 *
323 * Locking: Caller must hold tty->buf.lock
324 */
325
326static struct tty_buffer *tty_buffer_alloc(struct tty_struct *tty, size_t size)
Alan Cox33f0f882006-01-09 20:54:13 -0800327{
Alan Cox01da5fd2006-08-27 01:24:02 -0700328 struct tty_buffer *p;
329
330 if (tty->buf.memory_used + size > 65536)
331 return NULL;
332 p = kmalloc(sizeof(struct tty_buffer) + 2 * size, GFP_ATOMIC);
Alan Cox37bdfb02008-02-08 04:18:47 -0800333 if (p == NULL)
Alan Cox33f0f882006-01-09 20:54:13 -0800334 return NULL;
335 p->used = 0;
336 p->size = size;
337 p->next = NULL;
Paul Fulghum8977d922006-02-10 01:51:14 -0800338 p->commit = 0;
339 p->read = 0;
Alan Cox33f0f882006-01-09 20:54:13 -0800340 p->char_buf_ptr = (char *)(p->data);
341 p->flag_buf_ptr = (unsigned char *)p->char_buf_ptr + size;
Alan Cox01da5fd2006-08-27 01:24:02 -0700342 tty->buf.memory_used += size;
Alan Cox33f0f882006-01-09 20:54:13 -0800343 return p;
344}
345
Alan Cox01da5fd2006-08-27 01:24:02 -0700346/**
347 * tty_buffer_free - free a tty buffer
348 * @tty: tty owning the buffer
349 * @b: the buffer to free
350 *
351 * Free a tty buffer, or add it to the free list according to our
352 * internal strategy
353 *
354 * Locking: Caller must hold tty->buf.lock
355 */
Alan Cox33f0f882006-01-09 20:54:13 -0800356
357static void tty_buffer_free(struct tty_struct *tty, struct tty_buffer *b)
358{
359 /* Dumb strategy for now - should keep some stats */
Alan Cox01da5fd2006-08-27 01:24:02 -0700360 tty->buf.memory_used -= b->size;
361 WARN_ON(tty->buf.memory_used < 0);
362
Alan Cox37bdfb02008-02-08 04:18:47 -0800363 if (b->size >= 512)
Alan Cox33f0f882006-01-09 20:54:13 -0800364 kfree(b);
365 else {
366 b->next = tty->buf.free;
367 tty->buf.free = b;
368 }
369}
370
Alan Cox01da5fd2006-08-27 01:24:02 -0700371/**
Alan Cox42fd5522007-08-10 13:01:05 -0700372 * __tty_buffer_flush - flush full tty buffers
373 * @tty: tty to flush
374 *
375 * flush all the buffers containing receive data. Caller must
376 * hold the buffer lock and must have ensured no parallel flush to
377 * ldisc is running.
378 *
379 * Locking: Caller must hold tty->buf.lock
380 */
381
382static void __tty_buffer_flush(struct tty_struct *tty)
383{
384 struct tty_buffer *thead;
385
Alan Cox37bdfb02008-02-08 04:18:47 -0800386 while ((thead = tty->buf.head) != NULL) {
Alan Cox42fd5522007-08-10 13:01:05 -0700387 tty->buf.head = thead->next;
388 tty_buffer_free(tty, thead);
389 }
390 tty->buf.tail = NULL;
391}
392
393/**
Paul Fulghumc5c34d42007-05-12 10:36:55 -0700394 * tty_buffer_flush - flush full tty buffers
395 * @tty: tty to flush
396 *
Alan Cox42fd5522007-08-10 13:01:05 -0700397 * flush all the buffers containing receive data. If the buffer is
398 * being processed by flush_to_ldisc then we defer the processing
399 * to that function
Paul Fulghumc5c34d42007-05-12 10:36:55 -0700400 *
401 * Locking: none
402 */
403
404static void tty_buffer_flush(struct tty_struct *tty)
405{
Paul Fulghumc5c34d42007-05-12 10:36:55 -0700406 unsigned long flags;
Paul Fulghumc5c34d42007-05-12 10:36:55 -0700407 spin_lock_irqsave(&tty->buf.lock, flags);
Alan Cox42fd5522007-08-10 13:01:05 -0700408
409 /* If the data is being pushed to the tty layer then we can't
410 process it here. Instead set a flag and the flush_to_ldisc
411 path will process the flush request before it exits */
412 if (test_bit(TTY_FLUSHING, &tty->flags)) {
413 set_bit(TTY_FLUSHPENDING, &tty->flags);
414 spin_unlock_irqrestore(&tty->buf.lock, flags);
415 wait_event(tty->read_wait,
416 test_bit(TTY_FLUSHPENDING, &tty->flags) == 0);
417 return;
418 } else
419 __tty_buffer_flush(tty);
Paul Fulghumc5c34d42007-05-12 10:36:55 -0700420 spin_unlock_irqrestore(&tty->buf.lock, flags);
421}
422
423/**
Alan Cox01da5fd2006-08-27 01:24:02 -0700424 * tty_buffer_find - find a free tty buffer
425 * @tty: tty owning the buffer
426 * @size: characters wanted
427 *
428 * Locate an existing suitable tty buffer or if we are lacking one then
429 * allocate a new one. We round our buffers off in 256 character chunks
430 * to get better allocation behaviour.
431 *
432 * Locking: Caller must hold tty->buf.lock
433 */
434
Alan Cox33f0f882006-01-09 20:54:13 -0800435static struct tty_buffer *tty_buffer_find(struct tty_struct *tty, size_t size)
436{
437 struct tty_buffer **tbh = &tty->buf.free;
Alan Cox37bdfb02008-02-08 04:18:47 -0800438 while ((*tbh) != NULL) {
Alan Cox33f0f882006-01-09 20:54:13 -0800439 struct tty_buffer *t = *tbh;
Alan Cox37bdfb02008-02-08 04:18:47 -0800440 if (t->size >= size) {
Alan Cox33f0f882006-01-09 20:54:13 -0800441 *tbh = t->next;
442 t->next = NULL;
443 t->used = 0;
Paul Fulghum8977d922006-02-10 01:51:14 -0800444 t->commit = 0;
445 t->read = 0;
Alan Cox01da5fd2006-08-27 01:24:02 -0700446 tty->buf.memory_used += t->size;
Alan Cox33f0f882006-01-09 20:54:13 -0800447 return t;
448 }
449 tbh = &((*tbh)->next);
450 }
451 /* Round the buffer size out */
Alan Cox37bdfb02008-02-08 04:18:47 -0800452 size = (size + 0xFF) & ~0xFF;
Alan Cox01da5fd2006-08-27 01:24:02 -0700453 return tty_buffer_alloc(tty, size);
Alan Cox33f0f882006-01-09 20:54:13 -0800454 /* Should possibly check if this fails for the largest buffer we
455 have queued and recycle that ? */
456}
457
Alan Cox01da5fd2006-08-27 01:24:02 -0700458/**
459 * tty_buffer_request_room - grow tty buffer if needed
460 * @tty: tty structure
461 * @size: size desired
462 *
463 * Make at least size bytes of linear space available for the tty
464 * buffer. If we fail return the size we managed to find.
465 *
466 * Locking: Takes tty->buf.lock
467 */
Alan Cox33f0f882006-01-09 20:54:13 -0800468int tty_buffer_request_room(struct tty_struct *tty, size_t size)
469{
Paul Fulghum808249c2006-02-03 03:04:41 -0800470 struct tty_buffer *b, *n;
471 int left;
472 unsigned long flags;
473
474 spin_lock_irqsave(&tty->buf.lock, flags);
Alan Cox33f0f882006-01-09 20:54:13 -0800475
476 /* OPTIMISATION: We could keep a per tty "zero" sized buffer to
477 remove this conditional if its worth it. This would be invisible
478 to the callers */
Paul Fulghum33b37a32006-06-28 04:26:49 -0700479 if ((b = tty->buf.tail) != NULL)
Alan Cox33f0f882006-01-09 20:54:13 -0800480 left = b->size - b->used;
Paul Fulghum33b37a32006-06-28 04:26:49 -0700481 else
Paul Fulghum808249c2006-02-03 03:04:41 -0800482 left = 0;
483
484 if (left < size) {
485 /* This is the slow path - looking for new buffers to use */
486 if ((n = tty_buffer_find(tty, size)) != NULL) {
487 if (b != NULL) {
488 b->next = n;
Paul Fulghum8977d922006-02-10 01:51:14 -0800489 b->commit = b->used;
Paul Fulghum808249c2006-02-03 03:04:41 -0800490 } else
491 tty->buf.head = n;
492 tty->buf.tail = n;
Paul Fulghum808249c2006-02-03 03:04:41 -0800493 } else
494 size = left;
495 }
496
497 spin_unlock_irqrestore(&tty->buf.lock, flags);
Alan Cox33f0f882006-01-09 20:54:13 -0800498 return size;
499}
Alan Cox33f0f882006-01-09 20:54:13 -0800500EXPORT_SYMBOL_GPL(tty_buffer_request_room);
501
Alan Coxaf9b8972006-08-27 01:24:01 -0700502/**
503 * tty_insert_flip_string - Add characters to the tty buffer
504 * @tty: tty structure
505 * @chars: characters
506 * @size: size
507 *
508 * Queue a series of bytes to the tty buffering. All the characters
509 * passed are marked as without error. Returns the number added.
510 *
511 * Locking: Called functions may take tty->buf.lock
512 */
513
Andrew Mortone1a25092006-04-10 22:54:05 -0700514int tty_insert_flip_string(struct tty_struct *tty, const unsigned char *chars,
515 size_t size)
Alan Cox33f0f882006-01-09 20:54:13 -0800516{
517 int copied = 0;
518 do {
519 int space = tty_buffer_request_room(tty, size - copied);
520 struct tty_buffer *tb = tty->buf.tail;
521 /* If there is no space then tb may be NULL */
Alan Cox37bdfb02008-02-08 04:18:47 -0800522 if (unlikely(space == 0))
Alan Cox33f0f882006-01-09 20:54:13 -0800523 break;
524 memcpy(tb->char_buf_ptr + tb->used, chars, space);
525 memset(tb->flag_buf_ptr + tb->used, TTY_NORMAL, space);
526 tb->used += space;
527 copied += space;
528 chars += space;
Alexey Dobriyan527063b2006-09-29 01:59:50 -0700529 /* There is a small chance that we need to split the data over
530 several buffers. If this is the case we must loop */
531 } while (unlikely(size > copied));
Alan Cox33f0f882006-01-09 20:54:13 -0800532 return copied;
533}
Andrew Mortonee37df72006-03-31 02:30:35 -0800534EXPORT_SYMBOL(tty_insert_flip_string);
Alan Cox33f0f882006-01-09 20:54:13 -0800535
Alan Coxaf9b8972006-08-27 01:24:01 -0700536/**
537 * tty_insert_flip_string_flags - Add characters to the tty buffer
538 * @tty: tty structure
539 * @chars: characters
540 * @flags: flag bytes
541 * @size: size
542 *
543 * Queue a series of bytes to the tty buffering. For each character
544 * the flags array indicates the status of the character. Returns the
545 * number added.
546 *
547 * Locking: Called functions may take tty->buf.lock
548 */
549
Andrew Mortone1a25092006-04-10 22:54:05 -0700550int tty_insert_flip_string_flags(struct tty_struct *tty,
551 const unsigned char *chars, const char *flags, size_t size)
Alan Cox33f0f882006-01-09 20:54:13 -0800552{
553 int copied = 0;
554 do {
555 int space = tty_buffer_request_room(tty, size - copied);
556 struct tty_buffer *tb = tty->buf.tail;
557 /* If there is no space then tb may be NULL */
Alan Cox37bdfb02008-02-08 04:18:47 -0800558 if (unlikely(space == 0))
Alan Cox33f0f882006-01-09 20:54:13 -0800559 break;
560 memcpy(tb->char_buf_ptr + tb->used, chars, space);
561 memcpy(tb->flag_buf_ptr + tb->used, flags, space);
562 tb->used += space;
563 copied += space;
564 chars += space;
565 flags += space;
Alexey Dobriyan527063b2006-09-29 01:59:50 -0700566 /* There is a small chance that we need to split the data over
567 several buffers. If this is the case we must loop */
568 } while (unlikely(size > copied));
Alan Cox33f0f882006-01-09 20:54:13 -0800569 return copied;
570}
Tobias Powalowskiff4547f2006-05-22 22:35:28 -0700571EXPORT_SYMBOL(tty_insert_flip_string_flags);
Alan Cox33f0f882006-01-09 20:54:13 -0800572
Alan Coxaf9b8972006-08-27 01:24:01 -0700573/**
574 * tty_schedule_flip - push characters to ldisc
575 * @tty: tty to push from
576 *
577 * Takes any pending buffers and transfers their ownership to the
578 * ldisc side of the queue. It then schedules those characters for
579 * processing by the line discipline.
580 *
581 * Locking: Takes tty->buf.lock
582 */
583
Andrew Mortone1a25092006-04-10 22:54:05 -0700584void tty_schedule_flip(struct tty_struct *tty)
585{
586 unsigned long flags;
587 spin_lock_irqsave(&tty->buf.lock, flags);
Paul Fulghum33b37a32006-06-28 04:26:49 -0700588 if (tty->buf.tail != NULL)
Andrew Mortone1a25092006-04-10 22:54:05 -0700589 tty->buf.tail->commit = tty->buf.tail->used;
Andrew Mortone1a25092006-04-10 22:54:05 -0700590 spin_unlock_irqrestore(&tty->buf.lock, flags);
591 schedule_delayed_work(&tty->buf.work, 1);
592}
593EXPORT_SYMBOL(tty_schedule_flip);
Alan Cox33f0f882006-01-09 20:54:13 -0800594
Alan Coxaf9b8972006-08-27 01:24:01 -0700595/**
596 * tty_prepare_flip_string - make room for characters
597 * @tty: tty
598 * @chars: return pointer for character write area
599 * @size: desired size
600 *
Alan Cox33f0f882006-01-09 20:54:13 -0800601 * Prepare a block of space in the buffer for data. Returns the length
602 * available and buffer pointer to the space which is now allocated and
603 * accounted for as ready for normal characters. This is used for drivers
604 * that need their own block copy routines into the buffer. There is no
605 * guarantee the buffer is a DMA target!
Alan Coxaf9b8972006-08-27 01:24:01 -0700606 *
607 * Locking: May call functions taking tty->buf.lock
Alan Cox33f0f882006-01-09 20:54:13 -0800608 */
609
Alan Cox37bdfb02008-02-08 04:18:47 -0800610int tty_prepare_flip_string(struct tty_struct *tty, unsigned char **chars,
611 size_t size)
Alan Cox33f0f882006-01-09 20:54:13 -0800612{
613 int space = tty_buffer_request_room(tty, size);
Paul Fulghum808249c2006-02-03 03:04:41 -0800614 if (likely(space)) {
615 struct tty_buffer *tb = tty->buf.tail;
616 *chars = tb->char_buf_ptr + tb->used;
617 memset(tb->flag_buf_ptr + tb->used, TTY_NORMAL, space);
618 tb->used += space;
619 }
Alan Cox33f0f882006-01-09 20:54:13 -0800620 return space;
621}
622
623EXPORT_SYMBOL_GPL(tty_prepare_flip_string);
624
Alan Coxaf9b8972006-08-27 01:24:01 -0700625/**
626 * tty_prepare_flip_string_flags - make room for characters
627 * @tty: tty
628 * @chars: return pointer for character write area
629 * @flags: return pointer for status flag write area
630 * @size: desired size
631 *
Alan Cox33f0f882006-01-09 20:54:13 -0800632 * Prepare a block of space in the buffer for data. Returns the length
633 * available and buffer pointer to the space which is now allocated and
634 * accounted for as ready for characters. This is used for drivers
635 * that need their own block copy routines into the buffer. There is no
636 * guarantee the buffer is a DMA target!
Alan Coxaf9b8972006-08-27 01:24:01 -0700637 *
638 * Locking: May call functions taking tty->buf.lock
Alan Cox33f0f882006-01-09 20:54:13 -0800639 */
640
Alan Cox37bdfb02008-02-08 04:18:47 -0800641int tty_prepare_flip_string_flags(struct tty_struct *tty,
642 unsigned char **chars, char **flags, size_t size)
Alan Cox33f0f882006-01-09 20:54:13 -0800643{
644 int space = tty_buffer_request_room(tty, size);
Paul Fulghum808249c2006-02-03 03:04:41 -0800645 if (likely(space)) {
646 struct tty_buffer *tb = tty->buf.tail;
647 *chars = tb->char_buf_ptr + tb->used;
648 *flags = tb->flag_buf_ptr + tb->used;
649 tb->used += space;
650 }
Alan Cox33f0f882006-01-09 20:54:13 -0800651 return space;
652}
653
654EXPORT_SYMBOL_GPL(tty_prepare_flip_string_flags);
655
656
657
Alan Coxaf9b8972006-08-27 01:24:01 -0700658/**
Alan Coxaf9b8972006-08-27 01:24:01 -0700659 * get_tty_driver - find device of a tty
660 * @dev_t: device identifier
661 * @index: returns the index of the tty
662 *
663 * This routine returns a tty driver structure, given a device number
664 * and also passes back the index number.
665 *
666 * Locking: caller must hold tty_mutex
Linus Torvalds1da177e2005-04-16 15:20:36 -0700667 */
Alan Coxaf9b8972006-08-27 01:24:01 -0700668
Linus Torvalds1da177e2005-04-16 15:20:36 -0700669static struct tty_driver *get_tty_driver(dev_t device, int *index)
670{
671 struct tty_driver *p;
672
673 list_for_each_entry(p, &tty_drivers, tty_drivers) {
674 dev_t base = MKDEV(p->major, p->minor_start);
675 if (device < base || device >= base + p->num)
676 continue;
677 *index = device - base;
678 return p;
679 }
680 return NULL;
681}
682
Jason Wesself2d937f2008-04-17 20:05:37 +0200683#ifdef CONFIG_CONSOLE_POLL
684
685/**
686 * tty_find_polling_driver - find device of a polled tty
687 * @name: name string to match
688 * @line: pointer to resulting tty line nr
689 *
690 * This routine returns a tty driver structure, given a name
691 * and the condition that the tty driver is capable of polled
692 * operation.
693 */
694struct tty_driver *tty_find_polling_driver(char *name, int *line)
695{
696 struct tty_driver *p, *res = NULL;
697 int tty_line = 0;
Jason Wessel0dca0fd2008-09-26 10:36:42 -0500698 int len;
Jason Wesself2d937f2008-04-17 20:05:37 +0200699 char *str;
700
Jason Wessel0dca0fd2008-09-26 10:36:42 -0500701 for (str = name; *str; str++)
702 if ((*str >= '0' && *str <= '9') || *str == ',')
703 break;
704 if (!*str)
705 return NULL;
706
707 len = str - name;
708 tty_line = simple_strtoul(str, &str, 10);
709
Jason Wesself2d937f2008-04-17 20:05:37 +0200710 mutex_lock(&tty_mutex);
711 /* Search through the tty devices to look for a match */
712 list_for_each_entry(p, &tty_drivers, tty_drivers) {
Jason Wessel0dca0fd2008-09-26 10:36:42 -0500713 if (strncmp(name, p->name, len) != 0)
714 continue;
Jason Wesself2d937f2008-04-17 20:05:37 +0200715 if (*str == ',')
716 str++;
717 if (*str == '\0')
Harvey Harrison8da56302008-04-28 14:13:20 -0700718 str = NULL;
Jason Wesself2d937f2008-04-17 20:05:37 +0200719
Alan Coxf34d7a52008-04-30 00:54:13 -0700720 if (tty_line >= 0 && tty_line <= p->num && p->ops &&
721 p->ops->poll_init && !p->ops->poll_init(p, tty_line, str)) {
Jason Wesself2d937f2008-04-17 20:05:37 +0200722 res = p;
723 *line = tty_line;
724 break;
725 }
726 }
727 mutex_unlock(&tty_mutex);
728
729 return res;
730}
731EXPORT_SYMBOL_GPL(tty_find_polling_driver);
732#endif
733
Alan Coxaf9b8972006-08-27 01:24:01 -0700734/**
735 * tty_check_change - check for POSIX terminal changes
736 * @tty: tty to check
737 *
738 * If we try to write to, or set the state of, a terminal and we're
739 * not in the foreground, send a SIGTTOU. If the signal is blocked or
740 * ignored, go ahead and perform the operation. (POSIX 7.2)
741 *
Alan Cox978e5952008-04-30 00:53:59 -0700742 * Locking: ctrl_lock
Linus Torvalds1da177e2005-04-16 15:20:36 -0700743 */
Alan Coxaf9b8972006-08-27 01:24:01 -0700744
Alan Cox37bdfb02008-02-08 04:18:47 -0800745int tty_check_change(struct tty_struct *tty)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700746{
Alan Cox47f86832008-04-30 00:53:30 -0700747 unsigned long flags;
748 int ret = 0;
749
Linus Torvalds1da177e2005-04-16 15:20:36 -0700750 if (current->signal->tty != tty)
751 return 0;
Alan Cox47f86832008-04-30 00:53:30 -0700752
753 spin_lock_irqsave(&tty->ctrl_lock, flags);
754
Eric W. Biedermanab521dc2007-02-12 00:53:00 -0800755 if (!tty->pgrp) {
756 printk(KERN_WARNING "tty_check_change: tty->pgrp == NULL!\n");
Andrew Morton9ffee4c2008-05-14 16:05:58 -0700757 goto out_unlock;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700758 }
Eric W. Biedermanab521dc2007-02-12 00:53:00 -0800759 if (task_pgrp(current) == tty->pgrp)
Andrew Morton9ffee4c2008-05-14 16:05:58 -0700760 goto out_unlock;
761 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700762 if (is_ignored(SIGTTOU))
Alan Cox47f86832008-04-30 00:53:30 -0700763 goto out;
764 if (is_current_pgrp_orphaned()) {
765 ret = -EIO;
766 goto out;
767 }
Oleg Nesterov040b6362007-06-01 00:46:53 -0700768 kill_pgrp(task_pgrp(current), SIGTTOU, 1);
769 set_thread_flag(TIF_SIGPENDING);
Alan Cox47f86832008-04-30 00:53:30 -0700770 ret = -ERESTARTSYS;
771out:
Andrew Morton9ffee4c2008-05-14 16:05:58 -0700772 return ret;
773out_unlock:
Alan Cox47f86832008-04-30 00:53:30 -0700774 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
775 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700776}
777
778EXPORT_SYMBOL(tty_check_change);
779
Alan Cox37bdfb02008-02-08 04:18:47 -0800780static ssize_t hung_up_tty_read(struct file *file, char __user *buf,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700781 size_t count, loff_t *ppos)
782{
783 return 0;
784}
785
Alan Cox37bdfb02008-02-08 04:18:47 -0800786static ssize_t hung_up_tty_write(struct file *file, const char __user *buf,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700787 size_t count, loff_t *ppos)
788{
789 return -EIO;
790}
791
792/* No kernel lock held - none needed ;) */
Alan Cox37bdfb02008-02-08 04:18:47 -0800793static unsigned int hung_up_tty_poll(struct file *filp, poll_table *wait)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700794{
795 return POLLIN | POLLOUT | POLLERR | POLLHUP | POLLRDNORM | POLLWRNORM;
796}
797
Alan Cox04f378b2008-04-30 00:53:29 -0700798static long hung_up_tty_ioctl(struct file *file, unsigned int cmd,
799 unsigned long arg)
Paul Fulghum38ad2ed2007-06-16 10:15:55 -0700800{
801 return cmd == TIOCSPGRP ? -ENOTTY : -EIO;
802}
803
Alan Cox37bdfb02008-02-08 04:18:47 -0800804static long hung_up_tty_compat_ioctl(struct file *file,
Paul Fulghum38ad2ed2007-06-16 10:15:55 -0700805 unsigned int cmd, unsigned long arg)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700806{
807 return cmd == TIOCSPGRP ? -ENOTTY : -EIO;
808}
809
Arjan van de Ven62322d22006-07-03 00:24:21 -0700810static const struct file_operations tty_fops = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700811 .llseek = no_llseek,
812 .read = tty_read,
813 .write = tty_write,
814 .poll = tty_poll,
Alan Cox04f378b2008-04-30 00:53:29 -0700815 .unlocked_ioctl = tty_ioctl,
Paul Fulghume10cc1d2007-05-10 22:22:50 -0700816 .compat_ioctl = tty_compat_ioctl,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700817 .open = tty_open,
818 .release = tty_release,
819 .fasync = tty_fasync,
820};
821
822#ifdef CONFIG_UNIX98_PTYS
Arjan van de Ven62322d22006-07-03 00:24:21 -0700823static const struct file_operations ptmx_fops = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700824 .llseek = no_llseek,
825 .read = tty_read,
826 .write = tty_write,
827 .poll = tty_poll,
Alan Cox04f378b2008-04-30 00:53:29 -0700828 .unlocked_ioctl = tty_ioctl,
Paul Fulghume10cc1d2007-05-10 22:22:50 -0700829 .compat_ioctl = tty_compat_ioctl,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700830 .open = ptmx_open,
831 .release = tty_release,
832 .fasync = tty_fasync,
833};
834#endif
835
Arjan van de Ven62322d22006-07-03 00:24:21 -0700836static const struct file_operations console_fops = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700837 .llseek = no_llseek,
838 .read = tty_read,
839 .write = redirected_tty_write,
840 .poll = tty_poll,
Alan Cox04f378b2008-04-30 00:53:29 -0700841 .unlocked_ioctl = tty_ioctl,
Paul Fulghume10cc1d2007-05-10 22:22:50 -0700842 .compat_ioctl = tty_compat_ioctl,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700843 .open = tty_open,
844 .release = tty_release,
845 .fasync = tty_fasync,
846};
847
Arjan van de Ven62322d22006-07-03 00:24:21 -0700848static const struct file_operations hung_up_tty_fops = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700849 .llseek = no_llseek,
850 .read = hung_up_tty_read,
851 .write = hung_up_tty_write,
852 .poll = hung_up_tty_poll,
Alan Cox04f378b2008-04-30 00:53:29 -0700853 .unlocked_ioctl = hung_up_tty_ioctl,
Paul Fulghum38ad2ed2007-06-16 10:15:55 -0700854 .compat_ioctl = hung_up_tty_compat_ioctl,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700855 .release = tty_release,
856};
857
858static DEFINE_SPINLOCK(redirect_lock);
859static struct file *redirect;
860
861/**
862 * tty_wakeup - request more data
863 * @tty: terminal
864 *
865 * Internal and external helper for wakeups of tty. This function
866 * informs the line discipline if present that the driver is ready
867 * to receive more output data.
868 */
Alan Cox37bdfb02008-02-08 04:18:47 -0800869
Linus Torvalds1da177e2005-04-16 15:20:36 -0700870void tty_wakeup(struct tty_struct *tty)
871{
872 struct tty_ldisc *ld;
Alan Cox37bdfb02008-02-08 04:18:47 -0800873
Linus Torvalds1da177e2005-04-16 15:20:36 -0700874 if (test_bit(TTY_DO_WRITE_WAKEUP, &tty->flags)) {
875 ld = tty_ldisc_ref(tty);
Alan Cox37bdfb02008-02-08 04:18:47 -0800876 if (ld) {
Alan Coxa352def2008-07-16 21:53:12 +0100877 if (ld->ops->write_wakeup)
878 ld->ops->write_wakeup(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700879 tty_ldisc_deref(ld);
880 }
881 }
882 wake_up_interruptible(&tty->write_wait);
883}
884
885EXPORT_SYMBOL_GPL(tty_wakeup);
886
887/**
888 * tty_ldisc_flush - flush line discipline queue
889 * @tty: tty
890 *
891 * Flush the line discipline queue (if any) for this tty. If there
892 * is no line discipline active this is a no-op.
893 */
Alan Cox37bdfb02008-02-08 04:18:47 -0800894
Linus Torvalds1da177e2005-04-16 15:20:36 -0700895void tty_ldisc_flush(struct tty_struct *tty)
896{
897 struct tty_ldisc *ld = tty_ldisc_ref(tty);
Alan Cox37bdfb02008-02-08 04:18:47 -0800898 if (ld) {
Alan Coxa352def2008-07-16 21:53:12 +0100899 if (ld->ops->flush_buffer)
900 ld->ops->flush_buffer(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700901 tty_ldisc_deref(ld);
902 }
Paul Fulghumc5c34d42007-05-12 10:36:55 -0700903 tty_buffer_flush(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700904}
905
906EXPORT_SYMBOL_GPL(tty_ldisc_flush);
Alan Coxedc6afc2006-12-08 02:38:44 -0800907
908/**
909 * tty_reset_termios - reset terminal state
910 * @tty: tty to reset
911 *
912 * Restore a terminal to the driver default state
913 */
914
915static void tty_reset_termios(struct tty_struct *tty)
916{
917 mutex_lock(&tty->termios_mutex);
918 *tty->termios = tty->driver->init_termios;
919 tty->termios->c_ispeed = tty_termios_input_baud_rate(tty->termios);
920 tty->termios->c_ospeed = tty_termios_baud_rate(tty->termios);
921 mutex_unlock(&tty->termios_mutex);
922}
Alan Cox37bdfb02008-02-08 04:18:47 -0800923
Alan Coxaf9b8972006-08-27 01:24:01 -0700924/**
925 * do_tty_hangup - actual handler for hangup events
David Howells65f27f32006-11-22 14:55:48 +0000926 * @work: tty device
Alan Coxaf9b8972006-08-27 01:24:01 -0700927 *
Alan Cox1bad8792008-07-22 23:38:04 +0100928 * This can be called by the "eventd" kernel thread. That is process
Alan Coxaf9b8972006-08-27 01:24:01 -0700929 * synchronous but doesn't hold any locks, so we need to make sure we
930 * have the appropriate locks for what we're doing.
931 *
932 * The hangup event clears any pending redirections onto the hung up
933 * device. It ensures future writes will error and it does the needed
934 * line discipline hangup and signal delivery. The tty object itself
935 * remains intact.
936 *
937 * Locking:
938 * BKL
Peter Zijlstra24ec8392006-12-08 02:36:04 -0800939 * redirect lock for undoing redirection
940 * file list lock for manipulating list of ttys
941 * tty_ldisc_lock from called functions
942 * termios_mutex resetting termios data
943 * tasklist_lock to walk task list for hangup event
944 * ->siglock to protect ->signal/->sighand
Linus Torvalds1da177e2005-04-16 15:20:36 -0700945 */
David Howells65f27f32006-11-22 14:55:48 +0000946static void do_tty_hangup(struct work_struct *work)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700947{
David Howells65f27f32006-11-22 14:55:48 +0000948 struct tty_struct *tty =
949 container_of(work, struct tty_struct, hangup_work);
Alan Cox37bdfb02008-02-08 04:18:47 -0800950 struct file *cons_filp = NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700951 struct file *filp, *f = NULL;
952 struct task_struct *p;
953 struct tty_ldisc *ld;
954 int closecount = 0, n;
Alan Cox47f86832008-04-30 00:53:30 -0700955 unsigned long flags;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700956
957 if (!tty)
958 return;
959
960 /* inuse_filps is protected by the single kernel lock */
961 lock_kernel();
962
963 spin_lock(&redirect_lock);
964 if (redirect && redirect->private_data == tty) {
965 f = redirect;
966 redirect = NULL;
967 }
968 spin_unlock(&redirect_lock);
Alan Cox37bdfb02008-02-08 04:18:47 -0800969
Linus Torvalds1da177e2005-04-16 15:20:36 -0700970 check_tty_count(tty, "do_tty_hangup");
971 file_list_lock();
972 /* This breaks for file handles being sent over AF_UNIX sockets ? */
Eric Dumazet2f512012005-10-30 15:02:16 -0800973 list_for_each_entry(filp, &tty->tty_files, f_u.fu_list) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700974 if (filp->f_op->write == redirected_tty_write)
975 cons_filp = filp;
976 if (filp->f_op->write != tty_write)
977 continue;
978 closecount++;
979 tty_fasync(-1, filp, 0); /* can't block */
980 filp->f_op = &hung_up_tty_fops;
981 }
982 file_list_unlock();
Alan Cox37bdfb02008-02-08 04:18:47 -0800983 /*
984 * FIXME! What are the locking issues here? This may me overdoing
985 * things... This question is especially important now that we've
986 * removed the irqlock.
987 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700988 ld = tty_ldisc_ref(tty);
Alan Cox37bdfb02008-02-08 04:18:47 -0800989 if (ld != NULL) {
990 /* We may have no line discipline at this point */
Alan Coxa352def2008-07-16 21:53:12 +0100991 if (ld->ops->flush_buffer)
992 ld->ops->flush_buffer(tty);
Alan Coxf34d7a52008-04-30 00:54:13 -0700993 tty_driver_flush_buffer(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700994 if ((test_bit(TTY_DO_WRITE_WAKEUP, &tty->flags)) &&
Alan Coxa352def2008-07-16 21:53:12 +0100995 ld->ops->write_wakeup)
996 ld->ops->write_wakeup(tty);
997 if (ld->ops->hangup)
998 ld->ops->hangup(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700999 }
Alan Cox37bdfb02008-02-08 04:18:47 -08001000 /*
1001 * FIXME: Once we trust the LDISC code better we can wait here for
1002 * ldisc completion and fix the driver call race
1003 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001004 wake_up_interruptible(&tty->write_wait);
1005 wake_up_interruptible(&tty->read_wait);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001006 /*
1007 * Shutdown the current line discipline, and reset it to
1008 * N_TTY.
1009 */
1010 if (tty->driver->flags & TTY_DRIVER_RESET_TERMIOS)
Alan Coxedc6afc2006-12-08 02:38:44 -08001011 tty_reset_termios(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001012 /* Defer ldisc switch */
1013 /* tty_deferred_ldisc_switch(N_TTY);
Alan Cox37bdfb02008-02-08 04:18:47 -08001014
Linus Torvalds1da177e2005-04-16 15:20:36 -07001015 This should get done automatically when the port closes and
1016 tty_release is called */
Alan Cox37bdfb02008-02-08 04:18:47 -08001017
Linus Torvalds1da177e2005-04-16 15:20:36 -07001018 read_lock(&tasklist_lock);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001019 if (tty->session) {
1020 do_each_pid_task(tty->session, PIDTYPE_SID, p) {
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001021 spin_lock_irq(&p->sighand->siglock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001022 if (p->signal->tty == tty)
1023 p->signal->tty = NULL;
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001024 if (!p->signal->leader) {
1025 spin_unlock_irq(&p->sighand->siglock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001026 continue;
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001027 }
1028 __group_send_sig_info(SIGHUP, SEND_SIG_PRIV, p);
1029 __group_send_sig_info(SIGCONT, SEND_SIG_PRIV, p);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001030 put_pid(p->signal->tty_old_pgrp); /* A noop */
Alan Cox47f86832008-04-30 00:53:30 -07001031 spin_lock_irqsave(&tty->ctrl_lock, flags);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001032 if (tty->pgrp)
1033 p->signal->tty_old_pgrp = get_pid(tty->pgrp);
Alan Cox47f86832008-04-30 00:53:30 -07001034 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001035 spin_unlock_irq(&p->sighand->siglock);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001036 } while_each_pid_task(tty->session, PIDTYPE_SID, p);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001037 }
1038 read_unlock(&tasklist_lock);
1039
Alan Cox47f86832008-04-30 00:53:30 -07001040 spin_lock_irqsave(&tty->ctrl_lock, flags);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001041 tty->flags = 0;
Eric W. Biedermand9c1e9a2007-03-18 12:45:44 -06001042 put_pid(tty->session);
1043 put_pid(tty->pgrp);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001044 tty->session = NULL;
1045 tty->pgrp = NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001046 tty->ctrl_status = 0;
Alan Cox47f86832008-04-30 00:53:30 -07001047 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
1048
Linus Torvalds1da177e2005-04-16 15:20:36 -07001049 /*
Alan Cox37bdfb02008-02-08 04:18:47 -08001050 * If one of the devices matches a console pointer, we
1051 * cannot just call hangup() because that will cause
1052 * tty->count and state->count to go out of sync.
1053 * So we just call close() the right number of times.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001054 */
1055 if (cons_filp) {
Alan Coxf34d7a52008-04-30 00:54:13 -07001056 if (tty->ops->close)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001057 for (n = 0; n < closecount; n++)
Alan Coxf34d7a52008-04-30 00:54:13 -07001058 tty->ops->close(tty, cons_filp);
1059 } else if (tty->ops->hangup)
1060 (tty->ops->hangup)(tty);
Alan Cox37bdfb02008-02-08 04:18:47 -08001061 /*
1062 * We don't want to have driver/ldisc interactions beyond
1063 * the ones we did here. The driver layer expects no
1064 * calls after ->hangup() from the ldisc side. However we
1065 * can't yet guarantee all that.
1066 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001067 set_bit(TTY_HUPPED, &tty->flags);
1068 if (ld) {
1069 tty_ldisc_enable(tty);
1070 tty_ldisc_deref(ld);
1071 }
1072 unlock_kernel();
1073 if (f)
1074 fput(f);
1075}
1076
Alan Coxaf9b8972006-08-27 01:24:01 -07001077/**
1078 * tty_hangup - trigger a hangup event
1079 * @tty: tty to hangup
1080 *
1081 * A carrier loss (virtual or otherwise) has occurred on this like
1082 * schedule a hangup sequence to run after this event.
1083 */
1084
Alan Cox37bdfb02008-02-08 04:18:47 -08001085void tty_hangup(struct tty_struct *tty)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001086{
1087#ifdef TTY_DEBUG_HANGUP
1088 char buf[64];
Linus Torvalds1da177e2005-04-16 15:20:36 -07001089 printk(KERN_DEBUG "%s hangup...\n", tty_name(tty, buf));
1090#endif
1091 schedule_work(&tty->hangup_work);
1092}
1093
1094EXPORT_SYMBOL(tty_hangup);
1095
Alan Coxaf9b8972006-08-27 01:24:01 -07001096/**
1097 * tty_vhangup - process vhangup
1098 * @tty: tty to hangup
1099 *
1100 * The user has asked via system call for the terminal to be hung up.
1101 * We do this synchronously so that when the syscall returns the process
Robert P. J. Day3a4fa0a2007-10-19 23:10:43 +02001102 * is complete. That guarantee is necessary for security reasons.
Alan Coxaf9b8972006-08-27 01:24:01 -07001103 */
1104
Alan Cox37bdfb02008-02-08 04:18:47 -08001105void tty_vhangup(struct tty_struct *tty)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001106{
1107#ifdef TTY_DEBUG_HANGUP
1108 char buf[64];
1109
1110 printk(KERN_DEBUG "%s vhangup...\n", tty_name(tty, buf));
1111#endif
David Howells65f27f32006-11-22 14:55:48 +00001112 do_tty_hangup(&tty->hangup_work);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001113}
Alan Cox37bdfb02008-02-08 04:18:47 -08001114
Linus Torvalds1da177e2005-04-16 15:20:36 -07001115EXPORT_SYMBOL(tty_vhangup);
1116
Alan Coxaf9b8972006-08-27 01:24:01 -07001117/**
1118 * tty_hung_up_p - was tty hung up
1119 * @filp: file pointer of tty
1120 *
1121 * Return true if the tty has been subject to a vhangup or a carrier
1122 * loss
1123 */
1124
Alan Cox37bdfb02008-02-08 04:18:47 -08001125int tty_hung_up_p(struct file *filp)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001126{
1127 return (filp->f_op == &hung_up_tty_fops);
1128}
1129
1130EXPORT_SYMBOL(tty_hung_up_p);
1131
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001132static void session_clear_tty(struct pid *session)
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001133{
1134 struct task_struct *p;
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001135 do_each_pid_task(session, PIDTYPE_SID, p) {
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001136 proc_clear_tty(p);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001137 } while_each_pid_task(session, PIDTYPE_SID, p);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001138}
1139
Alan Coxaf9b8972006-08-27 01:24:01 -07001140/**
1141 * disassociate_ctty - disconnect controlling tty
1142 * @on_exit: true if exiting so need to "hang up" the session
Linus Torvalds1da177e2005-04-16 15:20:36 -07001143 *
Alan Coxaf9b8972006-08-27 01:24:01 -07001144 * This function is typically called only by the session leader, when
1145 * it wants to disassociate itself from its controlling tty.
1146 *
1147 * It performs the following functions:
Linus Torvalds1da177e2005-04-16 15:20:36 -07001148 * (1) Sends a SIGHUP and SIGCONT to the foreground process group
1149 * (2) Clears the tty from being controlling the session
1150 * (3) Clears the controlling tty for all processes in the
1151 * session group.
1152 *
Alan Coxaf9b8972006-08-27 01:24:01 -07001153 * The argument on_exit is set to 1 if called when a process is
1154 * exiting; it is 0 if called by the ioctl TIOCNOTTY.
1155 *
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001156 * Locking:
Alan Coxaf9b8972006-08-27 01:24:01 -07001157 * BKL is taken for hysterical raisins
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001158 * tty_mutex is taken to protect tty
1159 * ->siglock is taken to protect ->signal/->sighand
1160 * tasklist_lock is taken to walk process list for sessions
1161 * ->siglock is taken to protect ->signal/->sighand
Linus Torvalds1da177e2005-04-16 15:20:36 -07001162 */
Alan Coxaf9b8972006-08-27 01:24:01 -07001163
Linus Torvalds1da177e2005-04-16 15:20:36 -07001164void disassociate_ctty(int on_exit)
1165{
1166 struct tty_struct *tty;
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001167 struct pid *tty_pgrp = NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001168
Linus Torvalds1da177e2005-04-16 15:20:36 -07001169
Ingo Molnar70522e12006-03-23 03:00:31 -08001170 mutex_lock(&tty_mutex);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001171 tty = get_current_tty();
Linus Torvalds1da177e2005-04-16 15:20:36 -07001172 if (tty) {
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001173 tty_pgrp = get_pid(tty->pgrp);
Alan Cox04f378b2008-04-30 00:53:29 -07001174 lock_kernel();
Christian Borntraeger000b9152008-08-11 09:02:49 +01001175 mutex_unlock(&tty_mutex);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001176 /* XXX: here we race, there is nothing protecting tty */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001177 if (on_exit && tty->driver->type != TTY_DRIVER_TYPE_PTY)
1178 tty_vhangup(tty);
Alan Cox04f378b2008-04-30 00:53:29 -07001179 unlock_kernel();
Eric W. Biederman680a9672007-02-12 00:52:52 -08001180 } else if (on_exit) {
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001181 struct pid *old_pgrp;
Eric W. Biederman680a9672007-02-12 00:52:52 -08001182 spin_lock_irq(&current->sighand->siglock);
1183 old_pgrp = current->signal->tty_old_pgrp;
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001184 current->signal->tty_old_pgrp = NULL;
Eric W. Biederman680a9672007-02-12 00:52:52 -08001185 spin_unlock_irq(&current->sighand->siglock);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001186 if (old_pgrp) {
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001187 kill_pgrp(old_pgrp, SIGHUP, on_exit);
1188 kill_pgrp(old_pgrp, SIGCONT, on_exit);
1189 put_pid(old_pgrp);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001190 }
Ingo Molnar70522e12006-03-23 03:00:31 -08001191 mutex_unlock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001192 return;
1193 }
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001194 if (tty_pgrp) {
1195 kill_pgrp(tty_pgrp, SIGHUP, on_exit);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001196 if (!on_exit)
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001197 kill_pgrp(tty_pgrp, SIGCONT, on_exit);
1198 put_pid(tty_pgrp);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001199 }
1200
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001201 spin_lock_irq(&current->sighand->siglock);
Eric W. Biederman2a65f1d2007-05-08 00:26:53 -07001202 put_pid(current->signal->tty_old_pgrp);
Randy Dunlap23cac8d2007-02-20 13:58:05 -08001203 current->signal->tty_old_pgrp = NULL;
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001204 spin_unlock_irq(&current->sighand->siglock);
1205
1206 mutex_lock(&tty_mutex);
1207 /* It is possible that do_tty_hangup has free'd this tty */
1208 tty = get_current_tty();
1209 if (tty) {
Alan Cox47f86832008-04-30 00:53:30 -07001210 unsigned long flags;
1211 spin_lock_irqsave(&tty->ctrl_lock, flags);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001212 put_pid(tty->session);
1213 put_pid(tty->pgrp);
1214 tty->session = NULL;
1215 tty->pgrp = NULL;
Alan Cox47f86832008-04-30 00:53:30 -07001216 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08001217 } else {
1218#ifdef TTY_DEBUG_HANGUP
1219 printk(KERN_DEBUG "error attempted to write to tty [0x%p]"
1220 " = NULL", tty);
1221#endif
1222 }
1223 mutex_unlock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001224
1225 /* Now clear signal->tty under the lock */
1226 read_lock(&tasklist_lock);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08001227 session_clear_tty(task_session(current));
Linus Torvalds1da177e2005-04-16 15:20:36 -07001228 read_unlock(&tasklist_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001229}
1230
Eric W. Biederman98a27ba2007-05-08 00:26:56 -07001231/**
1232 *
1233 * no_tty - Ensure the current process does not have a controlling tty
1234 */
1235void no_tty(void)
1236{
1237 struct task_struct *tsk = current;
Alan Cox04f378b2008-04-30 00:53:29 -07001238 lock_kernel();
Eric W. Biederman98a27ba2007-05-08 00:26:56 -07001239 if (tsk->signal->leader)
1240 disassociate_ctty(0);
Alan Cox04f378b2008-04-30 00:53:29 -07001241 unlock_kernel();
Eric W. Biederman98a27ba2007-05-08 00:26:56 -07001242 proc_clear_tty(tsk);
1243}
1244
Alan Coxaf9b8972006-08-27 01:24:01 -07001245
1246/**
Robert P. J. Daybeb7dd82007-05-09 07:14:03 +02001247 * stop_tty - propagate flow control
Alan Coxaf9b8972006-08-27 01:24:01 -07001248 * @tty: tty to stop
1249 *
1250 * Perform flow control to the driver. For PTY/TTY pairs we
Robert P. J. Daybeb7dd82007-05-09 07:14:03 +02001251 * must also propagate the TIOCKPKT status. May be called
Alan Coxaf9b8972006-08-27 01:24:01 -07001252 * on an already stopped device and will not re-call the driver
1253 * method.
1254 *
1255 * This functionality is used by both the line disciplines for
1256 * halting incoming flow and by the driver. It may therefore be
1257 * called from any context, may be under the tty atomic_write_lock
1258 * but not always.
1259 *
1260 * Locking:
Alan Cox04f378b2008-04-30 00:53:29 -07001261 * Uses the tty control lock internally
Alan Coxaf9b8972006-08-27 01:24:01 -07001262 */
1263
Linus Torvalds1da177e2005-04-16 15:20:36 -07001264void stop_tty(struct tty_struct *tty)
1265{
Alan Cox04f378b2008-04-30 00:53:29 -07001266 unsigned long flags;
1267 spin_lock_irqsave(&tty->ctrl_lock, flags);
1268 if (tty->stopped) {
1269 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001270 return;
Alan Cox04f378b2008-04-30 00:53:29 -07001271 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001272 tty->stopped = 1;
1273 if (tty->link && tty->link->packet) {
1274 tty->ctrl_status &= ~TIOCPKT_START;
1275 tty->ctrl_status |= TIOCPKT_STOP;
1276 wake_up_interruptible(&tty->link->read_wait);
1277 }
Alan Cox04f378b2008-04-30 00:53:29 -07001278 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
Alan Coxf34d7a52008-04-30 00:54:13 -07001279 if (tty->ops->stop)
1280 (tty->ops->stop)(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001281}
1282
1283EXPORT_SYMBOL(stop_tty);
1284
Alan Coxaf9b8972006-08-27 01:24:01 -07001285/**
Robert P. J. Daybeb7dd82007-05-09 07:14:03 +02001286 * start_tty - propagate flow control
Alan Coxaf9b8972006-08-27 01:24:01 -07001287 * @tty: tty to start
1288 *
1289 * Start a tty that has been stopped if at all possible. Perform
Robert P. J. Day3a4fa0a2007-10-19 23:10:43 +02001290 * any necessary wakeups and propagate the TIOCPKT status. If this
Alan Coxaf9b8972006-08-27 01:24:01 -07001291 * is the tty was previous stopped and is being started then the
1292 * driver start method is invoked and the line discipline woken.
1293 *
1294 * Locking:
Alan Cox04f378b2008-04-30 00:53:29 -07001295 * ctrl_lock
Alan Coxaf9b8972006-08-27 01:24:01 -07001296 */
1297
Linus Torvalds1da177e2005-04-16 15:20:36 -07001298void start_tty(struct tty_struct *tty)
1299{
Alan Cox04f378b2008-04-30 00:53:29 -07001300 unsigned long flags;
1301 spin_lock_irqsave(&tty->ctrl_lock, flags);
1302 if (!tty->stopped || tty->flow_stopped) {
1303 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001304 return;
Alan Cox04f378b2008-04-30 00:53:29 -07001305 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001306 tty->stopped = 0;
1307 if (tty->link && tty->link->packet) {
1308 tty->ctrl_status &= ~TIOCPKT_STOP;
1309 tty->ctrl_status |= TIOCPKT_START;
1310 wake_up_interruptible(&tty->link->read_wait);
1311 }
Alan Cox04f378b2008-04-30 00:53:29 -07001312 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
Alan Coxf34d7a52008-04-30 00:54:13 -07001313 if (tty->ops->start)
1314 (tty->ops->start)(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001315 /* If we have a running line discipline it may need kicking */
1316 tty_wakeup(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001317}
1318
1319EXPORT_SYMBOL(start_tty);
1320
Alan Coxaf9b8972006-08-27 01:24:01 -07001321/**
1322 * tty_read - read method for tty device files
1323 * @file: pointer to tty file
1324 * @buf: user buffer
1325 * @count: size of user buffer
1326 * @ppos: unused
1327 *
1328 * Perform the read system call function on this terminal device. Checks
1329 * for hung up devices before calling the line discipline method.
1330 *
1331 * Locking:
Alan Cox47f86832008-04-30 00:53:30 -07001332 * Locks the line discipline internally while needed. Multiple
1333 * read calls may be outstanding in parallel.
Alan Coxaf9b8972006-08-27 01:24:01 -07001334 */
1335
Alan Cox37bdfb02008-02-08 04:18:47 -08001336static ssize_t tty_read(struct file *file, char __user *buf, size_t count,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001337 loff_t *ppos)
1338{
1339 int i;
Alan Cox37bdfb02008-02-08 04:18:47 -08001340 struct tty_struct *tty;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001341 struct inode *inode;
1342 struct tty_ldisc *ld;
1343
1344 tty = (struct tty_struct *)file->private_data;
Josef Sipeka7113a92006-12-08 02:36:55 -08001345 inode = file->f_path.dentry->d_inode;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001346 if (tty_paranoia_check(tty, inode, "tty_read"))
1347 return -EIO;
1348 if (!tty || (test_bit(TTY_IO_ERROR, &tty->flags)))
1349 return -EIO;
1350
1351 /* We want to wait for the line discipline to sort out in this
1352 situation */
1353 ld = tty_ldisc_ref_wait(tty);
Alan Coxa352def2008-07-16 21:53:12 +01001354 if (ld->ops->read)
1355 i = (ld->ops->read)(tty, file, buf, count);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001356 else
1357 i = -EIO;
1358 tty_ldisc_deref(ld);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001359 if (i > 0)
1360 inode->i_atime = current_fs_time(inode->i_sb);
1361 return i;
1362}
1363
Alan Cox9c1729d2007-07-15 23:39:43 -07001364void tty_write_unlock(struct tty_struct *tty)
1365{
1366 mutex_unlock(&tty->atomic_write_lock);
1367 wake_up_interruptible(&tty->write_wait);
1368}
1369
1370int tty_write_lock(struct tty_struct *tty, int ndelay)
1371{
1372 if (!mutex_trylock(&tty->atomic_write_lock)) {
1373 if (ndelay)
1374 return -EAGAIN;
1375 if (mutex_lock_interruptible(&tty->atomic_write_lock))
1376 return -ERESTARTSYS;
1377 }
1378 return 0;
1379}
1380
Linus Torvalds1da177e2005-04-16 15:20:36 -07001381/*
1382 * Split writes up in sane blocksizes to avoid
1383 * denial-of-service type attacks
1384 */
1385static inline ssize_t do_tty_write(
1386 ssize_t (*write)(struct tty_struct *, struct file *, const unsigned char *, size_t),
1387 struct tty_struct *tty,
1388 struct file *file,
1389 const char __user *buf,
1390 size_t count)
1391{
Alan Cox9c1729d2007-07-15 23:39:43 -07001392 ssize_t ret, written = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001393 unsigned int chunk;
Alan Cox37bdfb02008-02-08 04:18:47 -08001394
Alan Cox9c1729d2007-07-15 23:39:43 -07001395 ret = tty_write_lock(tty, file->f_flags & O_NDELAY);
1396 if (ret < 0)
1397 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001398
1399 /*
1400 * We chunk up writes into a temporary buffer. This
1401 * simplifies low-level drivers immensely, since they
1402 * don't have locking issues and user mode accesses.
1403 *
1404 * But if TTY_NO_WRITE_SPLIT is set, we should use a
1405 * big chunk-size..
1406 *
1407 * The default chunk-size is 2kB, because the NTTY
1408 * layer has problems with bigger chunks. It will
1409 * claim to be able to handle more characters than
1410 * it actually does.
Alan Coxaf9b8972006-08-27 01:24:01 -07001411 *
1412 * FIXME: This can probably go away now except that 64K chunks
1413 * are too likely to fail unless switched to vmalloc...
Linus Torvalds1da177e2005-04-16 15:20:36 -07001414 */
1415 chunk = 2048;
1416 if (test_bit(TTY_NO_WRITE_SPLIT, &tty->flags))
1417 chunk = 65536;
1418 if (count < chunk)
1419 chunk = count;
1420
Ingo Molnar70522e12006-03-23 03:00:31 -08001421 /* write_buf/write_cnt is protected by the atomic_write_lock mutex */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001422 if (tty->write_cnt < chunk) {
1423 unsigned char *buf;
1424
1425 if (chunk < 1024)
1426 chunk = 1024;
1427
1428 buf = kmalloc(chunk, GFP_KERNEL);
1429 if (!buf) {
Alan Cox9c1729d2007-07-15 23:39:43 -07001430 ret = -ENOMEM;
1431 goto out;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001432 }
1433 kfree(tty->write_buf);
1434 tty->write_cnt = chunk;
1435 tty->write_buf = buf;
1436 }
1437
1438 /* Do the write .. */
1439 for (;;) {
1440 size_t size = count;
1441 if (size > chunk)
1442 size = chunk;
1443 ret = -EFAULT;
1444 if (copy_from_user(tty->write_buf, buf, size))
1445 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001446 ret = write(tty, file, tty->write_buf, size);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001447 if (ret <= 0)
1448 break;
1449 written += ret;
1450 buf += ret;
1451 count -= ret;
1452 if (!count)
1453 break;
1454 ret = -ERESTARTSYS;
1455 if (signal_pending(current))
1456 break;
1457 cond_resched();
1458 }
1459 if (written) {
Josef Sipeka7113a92006-12-08 02:36:55 -08001460 struct inode *inode = file->f_path.dentry->d_inode;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001461 inode->i_mtime = current_fs_time(inode->i_sb);
1462 ret = written;
1463 }
Alan Cox9c1729d2007-07-15 23:39:43 -07001464out:
1465 tty_write_unlock(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001466 return ret;
1467}
1468
1469
Alan Coxaf9b8972006-08-27 01:24:01 -07001470/**
1471 * tty_write - write method for tty device file
1472 * @file: tty file pointer
1473 * @buf: user data to write
1474 * @count: bytes to write
1475 * @ppos: unused
1476 *
1477 * Write data to a tty device via the line discipline.
1478 *
1479 * Locking:
1480 * Locks the line discipline as required
1481 * Writes to the tty driver are serialized by the atomic_write_lock
1482 * and are then processed in chunks to the device. The line discipline
1483 * write method will not be involked in parallel for each device
1484 * The line discipline write method is called under the big
1485 * kernel lock for historical reasons. New code should not rely on this.
1486 */
1487
Alan Cox37bdfb02008-02-08 04:18:47 -08001488static ssize_t tty_write(struct file *file, const char __user *buf,
1489 size_t count, loff_t *ppos)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001490{
Alan Cox37bdfb02008-02-08 04:18:47 -08001491 struct tty_struct *tty;
Josef Sipeka7113a92006-12-08 02:36:55 -08001492 struct inode *inode = file->f_path.dentry->d_inode;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001493 ssize_t ret;
1494 struct tty_ldisc *ld;
Alan Cox37bdfb02008-02-08 04:18:47 -08001495
Linus Torvalds1da177e2005-04-16 15:20:36 -07001496 tty = (struct tty_struct *)file->private_data;
1497 if (tty_paranoia_check(tty, inode, "tty_write"))
1498 return -EIO;
Alan Coxf34d7a52008-04-30 00:54:13 -07001499 if (!tty || !tty->ops->write ||
Alan Cox37bdfb02008-02-08 04:18:47 -08001500 (test_bit(TTY_IO_ERROR, &tty->flags)))
1501 return -EIO;
Alan Coxf34d7a52008-04-30 00:54:13 -07001502 /* Short term debug to catch buggy drivers */
1503 if (tty->ops->write_room == NULL)
1504 printk(KERN_ERR "tty driver %s lacks a write_room method.\n",
1505 tty->driver->name);
Alan Cox37bdfb02008-02-08 04:18:47 -08001506 ld = tty_ldisc_ref_wait(tty);
Alan Coxa352def2008-07-16 21:53:12 +01001507 if (!ld->ops->write)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001508 ret = -EIO;
1509 else
Alan Coxa352def2008-07-16 21:53:12 +01001510 ret = do_tty_write(ld->ops->write, tty, file, buf, count);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001511 tty_ldisc_deref(ld);
1512 return ret;
1513}
1514
Alan Cox37bdfb02008-02-08 04:18:47 -08001515ssize_t redirected_tty_write(struct file *file, const char __user *buf,
1516 size_t count, loff_t *ppos)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001517{
1518 struct file *p = NULL;
1519
1520 spin_lock(&redirect_lock);
1521 if (redirect) {
1522 get_file(redirect);
1523 p = redirect;
1524 }
1525 spin_unlock(&redirect_lock);
1526
1527 if (p) {
1528 ssize_t res;
1529 res = vfs_write(p, buf, count, &p->f_pos);
1530 fput(p);
1531 return res;
1532 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001533 return tty_write(file, buf, count, ppos);
1534}
1535
Alan Cox6f670482008-07-16 21:53:41 +01001536void tty_port_init(struct tty_port *port)
1537{
1538 memset(port, 0, sizeof(*port));
1539 init_waitqueue_head(&port->open_wait);
1540 init_waitqueue_head(&port->close_wait);
1541 mutex_init(&port->mutex);
Alan Cox44b7d1b2008-07-16 21:57:18 +01001542 port->close_delay = (50 * HZ) / 100;
1543 port->closing_wait = (3000 * HZ) / 100;
Alan Cox6f670482008-07-16 21:53:41 +01001544}
1545EXPORT_SYMBOL(tty_port_init);
1546
1547int tty_port_alloc_xmit_buf(struct tty_port *port)
1548{
1549 /* We may sleep in get_zeroed_page() */
1550 mutex_lock(&port->mutex);
1551 if (port->xmit_buf == NULL)
1552 port->xmit_buf = (unsigned char *)get_zeroed_page(GFP_KERNEL);
1553 mutex_unlock(&port->mutex);
1554 if (port->xmit_buf == NULL)
1555 return -ENOMEM;
1556 return 0;
1557}
1558EXPORT_SYMBOL(tty_port_alloc_xmit_buf);
1559
1560void tty_port_free_xmit_buf(struct tty_port *port)
1561{
1562 mutex_lock(&port->mutex);
1563 if (port->xmit_buf != NULL) {
1564 free_page((unsigned long)port->xmit_buf);
1565 port->xmit_buf = NULL;
1566 }
1567 mutex_unlock(&port->mutex);
1568}
1569EXPORT_SYMBOL(tty_port_free_xmit_buf);
1570
1571
Linus Torvalds1da177e2005-04-16 15:20:36 -07001572static char ptychar[] = "pqrstuvwxyzabcde";
1573
Alan Coxaf9b8972006-08-27 01:24:01 -07001574/**
1575 * pty_line_name - generate name for a pty
1576 * @driver: the tty driver in use
1577 * @index: the minor number
1578 * @p: output buffer of at least 6 bytes
1579 *
1580 * Generate a name from a driver reference and write it to the output
1581 * buffer.
1582 *
1583 * Locking: None
1584 */
1585static void pty_line_name(struct tty_driver *driver, int index, char *p)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001586{
1587 int i = index + driver->name_base;
1588 /* ->name is initialized to "ttyp", but "tty" is expected */
1589 sprintf(p, "%s%c%x",
Alan Cox37bdfb02008-02-08 04:18:47 -08001590 driver->subtype == PTY_TYPE_SLAVE ? "tty" : driver->name,
1591 ptychar[i >> 4 & 0xf], i & 0xf);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001592}
1593
Alan Coxaf9b8972006-08-27 01:24:01 -07001594/**
1595 * pty_line_name - generate name for a tty
1596 * @driver: the tty driver in use
1597 * @index: the minor number
1598 * @p: output buffer of at least 7 bytes
1599 *
1600 * Generate a name from a driver reference and write it to the output
1601 * buffer.
1602 *
1603 * Locking: None
1604 */
1605static void tty_line_name(struct tty_driver *driver, int index, char *p)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001606{
1607 sprintf(p, "%s%d", driver->name, index + driver->name_base);
1608}
1609
Alan Coxaf9b8972006-08-27 01:24:01 -07001610/**
1611 * init_dev - initialise a tty device
1612 * @driver: tty driver we are opening a device on
1613 * @idx: device index
1614 * @tty: returned tty structure
1615 *
1616 * Prepare a tty device. This may not be a "new" clean device but
1617 * could also be an active device. The pty drivers require special
1618 * handling because of this.
1619 *
1620 * Locking:
1621 * The function is called under the tty_mutex, which
1622 * protects us from the tty struct or driver itself going away.
1623 *
1624 * On exit the tty device has the line discipline attached and
1625 * a reference count of 1. If a pair was created for pty/tty use
1626 * and the other was a pty master then it too has a reference count of 1.
1627 *
Linus Torvalds1da177e2005-04-16 15:20:36 -07001628 * WSH 06/09/97: Rewritten to remove races and properly clean up after a
Ingo Molnar70522e12006-03-23 03:00:31 -08001629 * failed open. The new code protects the open with a mutex, so it's
1630 * really quite straightforward. The mutex locking can probably be
Linus Torvalds1da177e2005-04-16 15:20:36 -07001631 * relaxed for the (most common) case of reopening a tty.
1632 */
Alan Coxaf9b8972006-08-27 01:24:01 -07001633
Linus Torvalds1da177e2005-04-16 15:20:36 -07001634static int init_dev(struct tty_driver *driver, int idx,
1635 struct tty_struct **ret_tty)
1636{
1637 struct tty_struct *tty, *o_tty;
Alan Coxedc6afc2006-12-08 02:38:44 -08001638 struct ktermios *tp, **tp_loc, *o_tp, **o_tp_loc;
1639 struct ktermios *ltp, **ltp_loc, *o_ltp, **o_ltp_loc;
Alan Coxaf9b8972006-08-27 01:24:01 -07001640 int retval = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001641
1642 /* check whether we're reopening an existing tty */
1643 if (driver->flags & TTY_DRIVER_DEVPTS_MEM) {
1644 tty = devpts_get_tty(idx);
Aristeu Sergio Rozanski Filho5a39e8c2007-02-28 20:13:53 -08001645 /*
1646 * If we don't have a tty here on a slave open, it's because
1647 * the master already started the close process and there's
1648 * no relation between devpts file and tty anymore.
1649 */
1650 if (!tty && driver->subtype == PTY_TYPE_SLAVE) {
1651 retval = -EIO;
1652 goto end_init;
1653 }
1654 /*
1655 * It's safe from now on because init_dev() is called with
1656 * tty_mutex held and release_dev() won't change tty->count
1657 * or tty->flags without having to grab tty_mutex
1658 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001659 if (tty && driver->subtype == PTY_TYPE_MASTER)
1660 tty = tty->link;
1661 } else {
1662 tty = driver->ttys[idx];
1663 }
1664 if (tty) goto fast_track;
1665
1666 /*
1667 * First time open is complex, especially for PTY devices.
1668 * This code guarantees that either everything succeeds and the
1669 * TTY is ready for operation, or else the table slots are vacated
Alan Cox37bdfb02008-02-08 04:18:47 -08001670 * and the allocated memory released. (Except that the termios
Linus Torvalds1da177e2005-04-16 15:20:36 -07001671 * and locked termios may be retained.)
1672 */
1673
1674 if (!try_module_get(driver->owner)) {
1675 retval = -ENODEV;
1676 goto end_init;
1677 }
1678
1679 o_tty = NULL;
1680 tp = o_tp = NULL;
1681 ltp = o_ltp = NULL;
1682
1683 tty = alloc_tty_struct();
Alan Cox37bdfb02008-02-08 04:18:47 -08001684 if (!tty)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001685 goto fail_no_mem;
1686 initialize_tty_struct(tty);
1687 tty->driver = driver;
Alan Coxf34d7a52008-04-30 00:54:13 -07001688 tty->ops = driver->ops;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001689 tty->index = idx;
1690 tty_line_name(driver, idx, tty->name);
1691
1692 if (driver->flags & TTY_DRIVER_DEVPTS_MEM) {
1693 tp_loc = &tty->termios;
1694 ltp_loc = &tty->termios_locked;
1695 } else {
1696 tp_loc = &driver->termios[idx];
1697 ltp_loc = &driver->termios_locked[idx];
1698 }
1699
1700 if (!*tp_loc) {
Jesper Juhlabcb1ff32007-08-24 02:28:42 +02001701 tp = kmalloc(sizeof(struct ktermios), GFP_KERNEL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001702 if (!tp)
1703 goto free_mem_out;
1704 *tp = driver->init_termios;
1705 }
1706
1707 if (!*ltp_loc) {
Jean Delvare506eb992007-07-15 23:40:14 -07001708 ltp = kzalloc(sizeof(struct ktermios), GFP_KERNEL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001709 if (!ltp)
1710 goto free_mem_out;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001711 }
1712
1713 if (driver->type == TTY_DRIVER_TYPE_PTY) {
1714 o_tty = alloc_tty_struct();
1715 if (!o_tty)
1716 goto free_mem_out;
1717 initialize_tty_struct(o_tty);
1718 o_tty->driver = driver->other;
Alan Coxf34d7a52008-04-30 00:54:13 -07001719 o_tty->ops = driver->ops;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001720 o_tty->index = idx;
1721 tty_line_name(driver->other, idx, o_tty->name);
1722
1723 if (driver->flags & TTY_DRIVER_DEVPTS_MEM) {
1724 o_tp_loc = &o_tty->termios;
1725 o_ltp_loc = &o_tty->termios_locked;
1726 } else {
1727 o_tp_loc = &driver->other->termios[idx];
1728 o_ltp_loc = &driver->other->termios_locked[idx];
1729 }
1730
1731 if (!*o_tp_loc) {
Jesper Juhlabcb1ff32007-08-24 02:28:42 +02001732 o_tp = kmalloc(sizeof(struct ktermios), GFP_KERNEL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001733 if (!o_tp)
1734 goto free_mem_out;
1735 *o_tp = driver->other->init_termios;
1736 }
1737
1738 if (!*o_ltp_loc) {
Jean Delvare506eb992007-07-15 23:40:14 -07001739 o_ltp = kzalloc(sizeof(struct ktermios), GFP_KERNEL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001740 if (!o_ltp)
1741 goto free_mem_out;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001742 }
1743
1744 /*
1745 * Everything allocated ... set up the o_tty structure.
1746 */
Alan Cox37bdfb02008-02-08 04:18:47 -08001747 if (!(driver->other->flags & TTY_DRIVER_DEVPTS_MEM))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001748 driver->other->ttys[idx] = o_tty;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001749 if (!*o_tp_loc)
1750 *o_tp_loc = o_tp;
1751 if (!*o_ltp_loc)
1752 *o_ltp_loc = o_ltp;
1753 o_tty->termios = *o_tp_loc;
1754 o_tty->termios_locked = *o_ltp_loc;
1755 driver->other->refcount++;
1756 if (driver->subtype == PTY_TYPE_MASTER)
1757 o_tty->count++;
1758
1759 /* Establish the links in both directions */
1760 tty->link = o_tty;
1761 o_tty->link = tty;
1762 }
1763
Alan Cox37bdfb02008-02-08 04:18:47 -08001764 /*
Linus Torvalds1da177e2005-04-16 15:20:36 -07001765 * All structures have been allocated, so now we install them.
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001766 * Failures after this point use release_tty to clean up, so
Linus Torvalds1da177e2005-04-16 15:20:36 -07001767 * there's no need to null out the local pointers.
1768 */
Alan Cox37bdfb02008-02-08 04:18:47 -08001769 if (!(driver->flags & TTY_DRIVER_DEVPTS_MEM))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001770 driver->ttys[idx] = tty;
Alan Cox37bdfb02008-02-08 04:18:47 -08001771
Linus Torvalds1da177e2005-04-16 15:20:36 -07001772 if (!*tp_loc)
1773 *tp_loc = tp;
1774 if (!*ltp_loc)
1775 *ltp_loc = ltp;
1776 tty->termios = *tp_loc;
1777 tty->termios_locked = *ltp_loc;
Alan Coxedc6afc2006-12-08 02:38:44 -08001778 /* Compatibility until drivers always set this */
1779 tty->termios->c_ispeed = tty_termios_input_baud_rate(tty->termios);
1780 tty->termios->c_ospeed = tty_termios_baud_rate(tty->termios);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001781 driver->refcount++;
1782 tty->count++;
1783
Alan Cox37bdfb02008-02-08 04:18:47 -08001784 /*
Linus Torvalds1da177e2005-04-16 15:20:36 -07001785 * Structures all installed ... call the ldisc open routines.
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001786 * If we fail here just call release_tty to clean up. No need
1787 * to decrement the use counts, as release_tty doesn't care.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001788 */
1789
Alan Cox01e1abb2008-07-22 11:16:55 +01001790 retval = tty_ldisc_setup(tty, o_tty);
1791
1792 if (retval)
1793 goto release_mem_out;
1794 goto success;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001795
1796 /*
1797 * This fast open can be used if the tty is already open.
1798 * No memory is allocated, and the only failures are from
1799 * attempting to open a closing tty or attempting multiple
1800 * opens on a pty master.
1801 */
1802fast_track:
1803 if (test_bit(TTY_CLOSING, &tty->flags)) {
1804 retval = -EIO;
1805 goto end_init;
1806 }
1807 if (driver->type == TTY_DRIVER_TYPE_PTY &&
1808 driver->subtype == PTY_TYPE_MASTER) {
1809 /*
Alan Cox37bdfb02008-02-08 04:18:47 -08001810 * special case for PTY masters: only one open permitted,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001811 * and the slave side open count is incremented as well.
1812 */
1813 if (tty->count) {
1814 retval = -EIO;
1815 goto end_init;
1816 }
1817 tty->link->count++;
1818 }
1819 tty->count++;
1820 tty->driver = driver; /* N.B. why do this every time?? */
1821
1822 /* FIXME */
Alan Cox37bdfb02008-02-08 04:18:47 -08001823 if (!test_bit(TTY_LDISC, &tty->flags))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001824 printk(KERN_ERR "init_dev but no ldisc\n");
1825success:
1826 *ret_tty = tty;
Alan Cox37bdfb02008-02-08 04:18:47 -08001827
Ingo Molnar70522e12006-03-23 03:00:31 -08001828 /* All paths come through here to release the mutex */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001829end_init:
1830 return retval;
1831
1832 /* Release locally allocated memory ... nothing placed in slots */
1833free_mem_out:
Jesper Juhl735d5662005-11-07 01:01:29 -08001834 kfree(o_tp);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001835 if (o_tty)
1836 free_tty_struct(o_tty);
Jesper Juhl735d5662005-11-07 01:01:29 -08001837 kfree(ltp);
1838 kfree(tp);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001839 free_tty_struct(tty);
1840
1841fail_no_mem:
1842 module_put(driver->owner);
1843 retval = -ENOMEM;
1844 goto end_init;
1845
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001846 /* call the tty release_tty routine to clean out this slot */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001847release_mem_out:
Akinobu Mita40509142006-09-29 02:01:27 -07001848 if (printk_ratelimit())
1849 printk(KERN_INFO "init_dev: ldisc open failed, "
1850 "clearing slot %d\n", idx);
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001851 release_tty(tty, idx);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001852 goto end_init;
1853}
1854
Alan Coxaf9b8972006-08-27 01:24:01 -07001855/**
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001856 * release_one_tty - release tty structure memory
Alan Coxaf9b8972006-08-27 01:24:01 -07001857 *
1858 * Releases memory associated with a tty structure, and clears out the
1859 * driver table slots. This function is called when a device is no longer
1860 * in use. It also gets called when setup of a device fails.
1861 *
1862 * Locking:
1863 * tty_mutex - sometimes only
1864 * takes the file list lock internally when working on the list
1865 * of ttys that the driver keeps.
1866 * FIXME: should we require tty_mutex is held here ??
Linus Torvalds1da177e2005-04-16 15:20:36 -07001867 */
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001868static void release_one_tty(struct tty_struct *tty, int idx)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001869{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001870 int devpts = tty->driver->flags & TTY_DRIVER_DEVPTS_MEM;
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001871 struct ktermios *tp;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001872
1873 if (!devpts)
1874 tty->driver->ttys[idx] = NULL;
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001875
Linus Torvalds1da177e2005-04-16 15:20:36 -07001876 if (tty->driver->flags & TTY_DRIVER_RESET_TERMIOS) {
1877 tp = tty->termios;
1878 if (!devpts)
1879 tty->driver->termios[idx] = NULL;
1880 kfree(tp);
1881
1882 tp = tty->termios_locked;
1883 if (!devpts)
1884 tty->driver->termios_locked[idx] = NULL;
1885 kfree(tp);
1886 }
1887
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001888
Linus Torvalds1da177e2005-04-16 15:20:36 -07001889 tty->magic = 0;
1890 tty->driver->refcount--;
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001891
Linus Torvalds1da177e2005-04-16 15:20:36 -07001892 file_list_lock();
1893 list_del_init(&tty->tty_files);
1894 file_list_unlock();
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001895
Linus Torvalds1da177e2005-04-16 15:20:36 -07001896 free_tty_struct(tty);
1897}
1898
Christoph Hellwigd5698c22007-02-10 01:46:46 -08001899/**
1900 * release_tty - release tty structure memory
1901 *
1902 * Release both @tty and a possible linked partner (think pty pair),
1903 * and decrement the refcount of the backing module.
1904 *
1905 * Locking:
1906 * tty_mutex - sometimes only
1907 * takes the file list lock internally when working on the list
1908 * of ttys that the driver keeps.
1909 * FIXME: should we require tty_mutex is held here ??
1910 */
1911static void release_tty(struct tty_struct *tty, int idx)
1912{
1913 struct tty_driver *driver = tty->driver;
1914
1915 if (tty->link)
1916 release_one_tty(tty->link, idx);
1917 release_one_tty(tty, idx);
1918 module_put(driver->owner);
1919}
1920
Linus Torvalds1da177e2005-04-16 15:20:36 -07001921/*
1922 * Even releasing the tty structures is a tricky business.. We have
1923 * to be very careful that the structures are all released at the
1924 * same time, as interrupts might otherwise get the wrong pointers.
1925 *
1926 * WSH 09/09/97: rewritten to avoid some nasty race conditions that could
1927 * lead to double frees or releasing memory still in use.
1928 */
Alan Cox37bdfb02008-02-08 04:18:47 -08001929static void release_dev(struct file *filp)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001930{
1931 struct tty_struct *tty, *o_tty;
1932 int pty_master, tty_closing, o_tty_closing, do_sleep;
Paul Fulghum14a62832006-04-10 22:54:19 -07001933 int devpts;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001934 int idx;
1935 char buf[64];
Alan Cox37bdfb02008-02-08 04:18:47 -08001936
Linus Torvalds1da177e2005-04-16 15:20:36 -07001937 tty = (struct tty_struct *)filp->private_data;
Alan Cox37bdfb02008-02-08 04:18:47 -08001938 if (tty_paranoia_check(tty, filp->f_path.dentry->d_inode,
1939 "release_dev"))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001940 return;
1941
1942 check_tty_count(tty, "release_dev");
1943
1944 tty_fasync(-1, filp, 0);
1945
1946 idx = tty->index;
1947 pty_master = (tty->driver->type == TTY_DRIVER_TYPE_PTY &&
1948 tty->driver->subtype == PTY_TYPE_MASTER);
1949 devpts = (tty->driver->flags & TTY_DRIVER_DEVPTS_MEM) != 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001950 o_tty = tty->link;
1951
1952#ifdef TTY_PARANOIA_CHECK
1953 if (idx < 0 || idx >= tty->driver->num) {
1954 printk(KERN_DEBUG "release_dev: bad idx when trying to "
1955 "free (%s)\n", tty->name);
1956 return;
1957 }
1958 if (!(tty->driver->flags & TTY_DRIVER_DEVPTS_MEM)) {
1959 if (tty != tty->driver->ttys[idx]) {
1960 printk(KERN_DEBUG "release_dev: driver.table[%d] not tty "
1961 "for (%s)\n", idx, tty->name);
1962 return;
1963 }
1964 if (tty->termios != tty->driver->termios[idx]) {
1965 printk(KERN_DEBUG "release_dev: driver.termios[%d] not termios "
1966 "for (%s)\n",
1967 idx, tty->name);
1968 return;
1969 }
1970 if (tty->termios_locked != tty->driver->termios_locked[idx]) {
1971 printk(KERN_DEBUG "release_dev: driver.termios_locked[%d] not "
1972 "termios_locked for (%s)\n",
1973 idx, tty->name);
1974 return;
1975 }
1976 }
1977#endif
1978
1979#ifdef TTY_DEBUG_HANGUP
1980 printk(KERN_DEBUG "release_dev of %s (tty count=%d)...",
1981 tty_name(tty, buf), tty->count);
1982#endif
1983
1984#ifdef TTY_PARANOIA_CHECK
1985 if (tty->driver->other &&
1986 !(tty->driver->flags & TTY_DRIVER_DEVPTS_MEM)) {
1987 if (o_tty != tty->driver->other->ttys[idx]) {
1988 printk(KERN_DEBUG "release_dev: other->table[%d] "
1989 "not o_tty for (%s)\n",
1990 idx, tty->name);
1991 return;
1992 }
1993 if (o_tty->termios != tty->driver->other->termios[idx]) {
1994 printk(KERN_DEBUG "release_dev: other->termios[%d] "
1995 "not o_termios for (%s)\n",
1996 idx, tty->name);
1997 return;
1998 }
Alan Cox37bdfb02008-02-08 04:18:47 -08001999 if (o_tty->termios_locked !=
Linus Torvalds1da177e2005-04-16 15:20:36 -07002000 tty->driver->other->termios_locked[idx]) {
2001 printk(KERN_DEBUG "release_dev: other->termios_locked["
2002 "%d] not o_termios_locked for (%s)\n",
2003 idx, tty->name);
2004 return;
2005 }
2006 if (o_tty->link != tty) {
2007 printk(KERN_DEBUG "release_dev: bad pty pointers\n");
2008 return;
2009 }
2010 }
2011#endif
Alan Coxf34d7a52008-04-30 00:54:13 -07002012 if (tty->ops->close)
2013 tty->ops->close(tty, filp);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002014
2015 /*
2016 * Sanity check: if tty->count is going to zero, there shouldn't be
2017 * any waiters on tty->read_wait or tty->write_wait. We test the
2018 * wait queues and kick everyone out _before_ actually starting to
2019 * close. This ensures that we won't block while releasing the tty
2020 * structure.
2021 *
2022 * The test for the o_tty closing is necessary, since the master and
2023 * slave sides may close in any order. If the slave side closes out
2024 * first, its count will be one, since the master side holds an open.
2025 * Thus this test wouldn't be triggered at the time the slave closes,
2026 * so we do it now.
2027 *
2028 * Note that it's possible for the tty to be opened again while we're
2029 * flushing out waiters. By recalculating the closing flags before
2030 * each iteration we avoid any problems.
2031 */
2032 while (1) {
2033 /* Guard against races with tty->count changes elsewhere and
2034 opens on /dev/tty */
Alan Cox37bdfb02008-02-08 04:18:47 -08002035
Ingo Molnar70522e12006-03-23 03:00:31 -08002036 mutex_lock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002037 tty_closing = tty->count <= 1;
2038 o_tty_closing = o_tty &&
2039 (o_tty->count <= (pty_master ? 1 : 0));
Linus Torvalds1da177e2005-04-16 15:20:36 -07002040 do_sleep = 0;
2041
2042 if (tty_closing) {
2043 if (waitqueue_active(&tty->read_wait)) {
2044 wake_up(&tty->read_wait);
2045 do_sleep++;
2046 }
2047 if (waitqueue_active(&tty->write_wait)) {
2048 wake_up(&tty->write_wait);
2049 do_sleep++;
2050 }
2051 }
2052 if (o_tty_closing) {
2053 if (waitqueue_active(&o_tty->read_wait)) {
2054 wake_up(&o_tty->read_wait);
2055 do_sleep++;
2056 }
2057 if (waitqueue_active(&o_tty->write_wait)) {
2058 wake_up(&o_tty->write_wait);
2059 do_sleep++;
2060 }
2061 }
2062 if (!do_sleep)
2063 break;
2064
2065 printk(KERN_WARNING "release_dev: %s: read/write wait queue "
2066 "active!\n", tty_name(tty, buf));
Ingo Molnar70522e12006-03-23 03:00:31 -08002067 mutex_unlock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002068 schedule();
Alan Cox37bdfb02008-02-08 04:18:47 -08002069 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07002070
2071 /*
Alan Cox37bdfb02008-02-08 04:18:47 -08002072 * The closing flags are now consistent with the open counts on
2073 * both sides, and we've completed the last operation that could
Linus Torvalds1da177e2005-04-16 15:20:36 -07002074 * block, so it's safe to proceed with closing.
2075 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002076 if (pty_master) {
2077 if (--o_tty->count < 0) {
2078 printk(KERN_WARNING "release_dev: bad pty slave count "
2079 "(%d) for %s\n",
2080 o_tty->count, tty_name(o_tty, buf));
2081 o_tty->count = 0;
2082 }
2083 }
2084 if (--tty->count < 0) {
2085 printk(KERN_WARNING "release_dev: bad tty->count (%d) for %s\n",
2086 tty->count, tty_name(tty, buf));
2087 tty->count = 0;
2088 }
Alan Cox37bdfb02008-02-08 04:18:47 -08002089
Linus Torvalds1da177e2005-04-16 15:20:36 -07002090 /*
2091 * We've decremented tty->count, so we need to remove this file
2092 * descriptor off the tty->tty_files list; this serves two
2093 * purposes:
2094 * - check_tty_count sees the correct number of file descriptors
2095 * associated with this tty.
2096 * - do_tty_hangup no longer sees this file descriptor as
2097 * something that needs to be handled for hangups.
2098 */
2099 file_kill(filp);
2100 filp->private_data = NULL;
2101
2102 /*
2103 * Perform some housekeeping before deciding whether to return.
2104 *
2105 * Set the TTY_CLOSING flag if this was the last open. In the
2106 * case of a pty we may have to wait around for the other side
2107 * to close, and TTY_CLOSING makes sure we can't be reopened.
2108 */
Alan Cox37bdfb02008-02-08 04:18:47 -08002109 if (tty_closing)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002110 set_bit(TTY_CLOSING, &tty->flags);
Alan Cox37bdfb02008-02-08 04:18:47 -08002111 if (o_tty_closing)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002112 set_bit(TTY_CLOSING, &o_tty->flags);
2113
2114 /*
2115 * If _either_ side is closing, make sure there aren't any
2116 * processes that still think tty or o_tty is their controlling
2117 * tty.
2118 */
2119 if (tty_closing || o_tty_closing) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002120 read_lock(&tasklist_lock);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002121 session_clear_tty(tty->session);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002122 if (o_tty)
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002123 session_clear_tty(o_tty->session);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002124 read_unlock(&tasklist_lock);
2125 }
2126
Ingo Molnar70522e12006-03-23 03:00:31 -08002127 mutex_unlock(&tty_mutex);
Paul Fulghumda965822006-02-14 13:53:00 -08002128
Linus Torvalds1da177e2005-04-16 15:20:36 -07002129 /* check whether both sides are closing ... */
2130 if (!tty_closing || (o_tty && !o_tty_closing))
2131 return;
Alan Cox37bdfb02008-02-08 04:18:47 -08002132
Linus Torvalds1da177e2005-04-16 15:20:36 -07002133#ifdef TTY_DEBUG_HANGUP
2134 printk(KERN_DEBUG "freeing tty structure...");
2135#endif
2136 /*
Alan Cox01e1abb2008-07-22 11:16:55 +01002137 * Ask the line discipline code to release its structures
Linus Torvalds1da177e2005-04-16 15:20:36 -07002138 */
Alan Cox01e1abb2008-07-22 11:16:55 +01002139 tty_ldisc_release(tty, o_tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002140 /*
Christoph Hellwigd5698c22007-02-10 01:46:46 -08002141 * The release_tty function takes care of the details of clearing
Linus Torvalds1da177e2005-04-16 15:20:36 -07002142 * the slots and preserving the termios structure.
2143 */
Christoph Hellwigd5698c22007-02-10 01:46:46 -08002144 release_tty(tty, idx);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002145
Linus Torvalds1da177e2005-04-16 15:20:36 -07002146 /* Make this pty number available for reallocation */
Sukadev Bhattiprolu718a9162008-04-30 00:54:21 -07002147 if (devpts)
2148 devpts_kill_index(idx);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002149}
2150
Alan Coxaf9b8972006-08-27 01:24:01 -07002151/**
2152 * tty_open - open a tty device
2153 * @inode: inode of device file
2154 * @filp: file pointer to tty
Linus Torvalds1da177e2005-04-16 15:20:36 -07002155 *
Alan Coxaf9b8972006-08-27 01:24:01 -07002156 * tty_open and tty_release keep up the tty count that contains the
2157 * number of opens done on a tty. We cannot use the inode-count, as
2158 * different inodes might point to the same tty.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002159 *
Alan Coxaf9b8972006-08-27 01:24:01 -07002160 * Open-counting is needed for pty masters, as well as for keeping
2161 * track of serial lines: DTR is dropped when the last close happens.
2162 * (This is not done solely through tty->count, now. - Ted 1/27/92)
2163 *
2164 * The termios state of a pty is reset on first open so that
2165 * settings don't persist across reuse.
2166 *
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002167 * Locking: tty_mutex protects tty, get_tty_driver and init_dev work.
2168 * tty->count should protect the rest.
2169 * ->siglock protects ->signal/->sighand
Linus Torvalds1da177e2005-04-16 15:20:36 -07002170 */
Alan Coxaf9b8972006-08-27 01:24:01 -07002171
Jonathan Corbet39d95b92008-05-16 09:10:50 -06002172static int __tty_open(struct inode *inode, struct file *filp)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002173{
2174 struct tty_struct *tty;
2175 int noctty, retval;
2176 struct tty_driver *driver;
2177 int index;
2178 dev_t device = inode->i_rdev;
2179 unsigned short saved_flags = filp->f_flags;
2180
2181 nonseekable_open(inode, filp);
Alan Cox37bdfb02008-02-08 04:18:47 -08002182
Linus Torvalds1da177e2005-04-16 15:20:36 -07002183retry_open:
2184 noctty = filp->f_flags & O_NOCTTY;
2185 index = -1;
2186 retval = 0;
Alan Cox37bdfb02008-02-08 04:18:47 -08002187
Ingo Molnar70522e12006-03-23 03:00:31 -08002188 mutex_lock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002189
Alan Cox37bdfb02008-02-08 04:18:47 -08002190 if (device == MKDEV(TTYAUX_MAJOR, 0)) {
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002191 tty = get_current_tty();
2192 if (!tty) {
Ingo Molnar70522e12006-03-23 03:00:31 -08002193 mutex_unlock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002194 return -ENXIO;
2195 }
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002196 driver = tty->driver;
2197 index = tty->index;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002198 filp->f_flags |= O_NONBLOCK; /* Don't let /dev/tty block */
2199 /* noctty = 1; */
2200 goto got_driver;
2201 }
2202#ifdef CONFIG_VT
Alan Cox37bdfb02008-02-08 04:18:47 -08002203 if (device == MKDEV(TTY_MAJOR, 0)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002204 extern struct tty_driver *console_driver;
2205 driver = console_driver;
2206 index = fg_console;
2207 noctty = 1;
2208 goto got_driver;
2209 }
2210#endif
Alan Cox37bdfb02008-02-08 04:18:47 -08002211 if (device == MKDEV(TTYAUX_MAJOR, 1)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002212 driver = console_device(&index);
2213 if (driver) {
2214 /* Don't let /dev/console block */
2215 filp->f_flags |= O_NONBLOCK;
2216 noctty = 1;
2217 goto got_driver;
2218 }
Ingo Molnar70522e12006-03-23 03:00:31 -08002219 mutex_unlock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002220 return -ENODEV;
2221 }
2222
2223 driver = get_tty_driver(device, &index);
2224 if (!driver) {
Ingo Molnar70522e12006-03-23 03:00:31 -08002225 mutex_unlock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002226 return -ENODEV;
2227 }
2228got_driver:
2229 retval = init_dev(driver, index, &tty);
Ingo Molnar70522e12006-03-23 03:00:31 -08002230 mutex_unlock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002231 if (retval)
2232 return retval;
2233
2234 filp->private_data = tty;
2235 file_move(filp, &tty->tty_files);
2236 check_tty_count(tty, "tty_open");
2237 if (tty->driver->type == TTY_DRIVER_TYPE_PTY &&
2238 tty->driver->subtype == PTY_TYPE_MASTER)
2239 noctty = 1;
2240#ifdef TTY_DEBUG_HANGUP
2241 printk(KERN_DEBUG "opening %s...", tty->name);
2242#endif
2243 if (!retval) {
Alan Coxf34d7a52008-04-30 00:54:13 -07002244 if (tty->ops->open)
2245 retval = tty->ops->open(tty, filp);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002246 else
2247 retval = -ENODEV;
2248 }
2249 filp->f_flags = saved_flags;
2250
Alan Cox37bdfb02008-02-08 04:18:47 -08002251 if (!retval && test_bit(TTY_EXCLUSIVE, &tty->flags) &&
2252 !capable(CAP_SYS_ADMIN))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002253 retval = -EBUSY;
2254
2255 if (retval) {
2256#ifdef TTY_DEBUG_HANGUP
2257 printk(KERN_DEBUG "error %d in opening %s...", retval,
2258 tty->name);
2259#endif
2260 release_dev(filp);
2261 if (retval != -ERESTARTSYS)
2262 return retval;
2263 if (signal_pending(current))
2264 return retval;
2265 schedule();
2266 /*
2267 * Need to reset f_op in case a hangup happened.
2268 */
2269 if (filp->f_op == &hung_up_tty_fops)
2270 filp->f_op = &tty_fops;
2271 goto retry_open;
2272 }
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002273
2274 mutex_lock(&tty_mutex);
2275 spin_lock_irq(&current->sighand->siglock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002276 if (!noctty &&
2277 current->signal->leader &&
2278 !current->signal->tty &&
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08002279 tty->session == NULL)
Eric W. Biederman2a65f1d2007-05-08 00:26:53 -07002280 __proc_set_tty(current, tty);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002281 spin_unlock_irq(&current->sighand->siglock);
2282 mutex_unlock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002283 return 0;
2284}
2285
Jonathan Corbet39d95b92008-05-16 09:10:50 -06002286/* BKL pushdown: scary code avoidance wrapper */
2287static int tty_open(struct inode *inode, struct file *filp)
2288{
2289 int ret;
2290
2291 lock_kernel();
2292 ret = __tty_open(inode, filp);
2293 unlock_kernel();
2294 return ret;
2295}
2296
2297
2298
Linus Torvalds1da177e2005-04-16 15:20:36 -07002299#ifdef CONFIG_UNIX98_PTYS
Alan Coxaf9b8972006-08-27 01:24:01 -07002300/**
2301 * ptmx_open - open a unix 98 pty master
2302 * @inode: inode of device file
2303 * @filp: file pointer to tty
2304 *
2305 * Allocate a unix98 pty master device from the ptmx driver.
2306 *
2307 * Locking: tty_mutex protects theinit_dev work. tty->count should
Alan Cox37bdfb02008-02-08 04:18:47 -08002308 * protect the rest.
Alan Coxaf9b8972006-08-27 01:24:01 -07002309 * allocated_ptys_lock handles the list of free pty numbers
2310 */
2311
Jonathan Corbet39d95b92008-05-16 09:10:50 -06002312static int __ptmx_open(struct inode *inode, struct file *filp)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002313{
2314 struct tty_struct *tty;
2315 int retval;
2316 int index;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002317
2318 nonseekable_open(inode, filp);
2319
2320 /* find a device that is not in use. */
Sukadev Bhattiprolu718a9162008-04-30 00:54:21 -07002321 index = devpts_new_index();
2322 if (index < 0)
2323 return index;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002324
Ingo Molnar70522e12006-03-23 03:00:31 -08002325 mutex_lock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002326 retval = init_dev(ptm_driver, index, &tty);
Ingo Molnar70522e12006-03-23 03:00:31 -08002327 mutex_unlock(&tty_mutex);
Alan Cox37bdfb02008-02-08 04:18:47 -08002328
Linus Torvalds1da177e2005-04-16 15:20:36 -07002329 if (retval)
2330 goto out;
2331
2332 set_bit(TTY_PTY_LOCK, &tty->flags); /* LOCK THE SLAVE */
2333 filp->private_data = tty;
2334 file_move(filp, &tty->tty_files);
2335
Sukadev Bhattiprolu4f8f9d62008-04-30 00:54:20 -07002336 retval = devpts_pty_new(tty->link);
2337 if (retval)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002338 goto out1;
2339
Hiroshi Shimamoto86a96532008-04-30 00:54:20 -07002340 check_tty_count(tty, "ptmx_open");
Alan Coxf34d7a52008-04-30 00:54:13 -07002341 retval = ptm_driver->ops->open(tty, filp);
Miloslav Trmac41126222008-04-18 13:30:14 -07002342 if (!retval)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002343 return 0;
2344out1:
2345 release_dev(filp);
Paul Fulghum9453a5a2006-04-10 22:54:18 -07002346 return retval;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002347out:
Sukadev Bhattiprolu718a9162008-04-30 00:54:21 -07002348 devpts_kill_index(index);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002349 return retval;
2350}
Jonathan Corbet39d95b92008-05-16 09:10:50 -06002351
2352static int ptmx_open(struct inode *inode, struct file *filp)
2353{
2354 int ret;
2355
2356 lock_kernel();
2357 ret = __ptmx_open(inode, filp);
2358 unlock_kernel();
2359 return ret;
2360}
Linus Torvalds1da177e2005-04-16 15:20:36 -07002361#endif
2362
Alan Coxaf9b8972006-08-27 01:24:01 -07002363/**
2364 * tty_release - vfs callback for close
2365 * @inode: inode of tty
2366 * @filp: file pointer for handle to tty
2367 *
2368 * Called the last time each file handle is closed that references
2369 * this tty. There may however be several such references.
2370 *
2371 * Locking:
2372 * Takes bkl. See release_dev
2373 */
2374
Alan Cox37bdfb02008-02-08 04:18:47 -08002375static int tty_release(struct inode *inode, struct file *filp)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002376{
2377 lock_kernel();
2378 release_dev(filp);
2379 unlock_kernel();
2380 return 0;
2381}
2382
Alan Coxaf9b8972006-08-27 01:24:01 -07002383/**
2384 * tty_poll - check tty status
2385 * @filp: file being polled
2386 * @wait: poll wait structures to update
2387 *
2388 * Call the line discipline polling method to obtain the poll
2389 * status of the device.
2390 *
2391 * Locking: locks called line discipline but ldisc poll method
2392 * may be re-entered freely by other callers.
2393 */
2394
Alan Cox37bdfb02008-02-08 04:18:47 -08002395static unsigned int tty_poll(struct file *filp, poll_table *wait)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002396{
Alan Cox37bdfb02008-02-08 04:18:47 -08002397 struct tty_struct *tty;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002398 struct tty_ldisc *ld;
2399 int ret = 0;
2400
2401 tty = (struct tty_struct *)filp->private_data;
Josef Sipeka7113a92006-12-08 02:36:55 -08002402 if (tty_paranoia_check(tty, filp->f_path.dentry->d_inode, "tty_poll"))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002403 return 0;
Alan Cox37bdfb02008-02-08 04:18:47 -08002404
Linus Torvalds1da177e2005-04-16 15:20:36 -07002405 ld = tty_ldisc_ref_wait(tty);
Alan Coxa352def2008-07-16 21:53:12 +01002406 if (ld->ops->poll)
2407 ret = (ld->ops->poll)(tty, filp, wait);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002408 tty_ldisc_deref(ld);
2409 return ret;
2410}
2411
Alan Cox37bdfb02008-02-08 04:18:47 -08002412static int tty_fasync(int fd, struct file *filp, int on)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002413{
Alan Cox37bdfb02008-02-08 04:18:47 -08002414 struct tty_struct *tty;
Alan Cox47f86832008-04-30 00:53:30 -07002415 unsigned long flags;
Jonathan Corbet5d1e3232008-06-19 16:04:53 -06002416 int retval = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002417
Jonathan Corbet5d1e3232008-06-19 16:04:53 -06002418 lock_kernel();
Linus Torvalds1da177e2005-04-16 15:20:36 -07002419 tty = (struct tty_struct *)filp->private_data;
Josef Sipeka7113a92006-12-08 02:36:55 -08002420 if (tty_paranoia_check(tty, filp->f_path.dentry->d_inode, "tty_fasync"))
Jonathan Corbet5d1e3232008-06-19 16:04:53 -06002421 goto out;
Alan Cox37bdfb02008-02-08 04:18:47 -08002422
Linus Torvalds1da177e2005-04-16 15:20:36 -07002423 retval = fasync_helper(fd, filp, on, &tty->fasync);
2424 if (retval <= 0)
Jonathan Corbet5d1e3232008-06-19 16:04:53 -06002425 goto out;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002426
2427 if (on) {
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08002428 enum pid_type type;
2429 struct pid *pid;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002430 if (!waitqueue_active(&tty->read_wait))
2431 tty->minimum_to_wake = 1;
Alan Cox47f86832008-04-30 00:53:30 -07002432 spin_lock_irqsave(&tty->ctrl_lock, flags);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08002433 if (tty->pgrp) {
2434 pid = tty->pgrp;
2435 type = PIDTYPE_PGID;
2436 } else {
2437 pid = task_pid(current);
2438 type = PIDTYPE_PID;
2439 }
Alan Cox47f86832008-04-30 00:53:30 -07002440 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08002441 retval = __f_setown(filp, pid, type, 0);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002442 if (retval)
Jonathan Corbet5d1e3232008-06-19 16:04:53 -06002443 goto out;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002444 } else {
2445 if (!tty->fasync && !waitqueue_active(&tty->read_wait))
2446 tty->minimum_to_wake = N_TTY_BUF_SIZE;
2447 }
Jonathan Corbet5d1e3232008-06-19 16:04:53 -06002448 retval = 0;
2449out:
2450 unlock_kernel();
2451 return retval;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002452}
2453
Alan Coxaf9b8972006-08-27 01:24:01 -07002454/**
2455 * tiocsti - fake input character
2456 * @tty: tty to fake input into
2457 * @p: pointer to character
2458 *
Robert P. J. Day3a4fa0a2007-10-19 23:10:43 +02002459 * Fake input to a tty device. Does the necessary locking and
Alan Coxaf9b8972006-08-27 01:24:01 -07002460 * input management.
2461 *
2462 * FIXME: does not honour flow control ??
2463 *
2464 * Locking:
2465 * Called functions take tty_ldisc_lock
2466 * current->signal->tty check is safe without locks
Alan Cox28298232006-09-29 02:00:58 -07002467 *
2468 * FIXME: may race normal receive processing
Alan Coxaf9b8972006-08-27 01:24:01 -07002469 */
2470
Linus Torvalds1da177e2005-04-16 15:20:36 -07002471static int tiocsti(struct tty_struct *tty, char __user *p)
2472{
2473 char ch, mbz = 0;
2474 struct tty_ldisc *ld;
Alan Cox37bdfb02008-02-08 04:18:47 -08002475
Linus Torvalds1da177e2005-04-16 15:20:36 -07002476 if ((current->signal->tty != tty) && !capable(CAP_SYS_ADMIN))
2477 return -EPERM;
2478 if (get_user(ch, p))
2479 return -EFAULT;
2480 ld = tty_ldisc_ref_wait(tty);
Alan Coxa352def2008-07-16 21:53:12 +01002481 ld->ops->receive_buf(tty, &ch, &mbz, 1);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002482 tty_ldisc_deref(ld);
2483 return 0;
2484}
2485
Alan Coxaf9b8972006-08-27 01:24:01 -07002486/**
2487 * tiocgwinsz - implement window query ioctl
2488 * @tty; tty
2489 * @arg: user buffer for result
2490 *
Alan Cox808a0d32006-09-29 02:00:40 -07002491 * Copies the kernel idea of the window size into the user buffer.
Alan Coxaf9b8972006-08-27 01:24:01 -07002492 *
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002493 * Locking: tty->termios_mutex is taken to ensure the winsize data
Alan Cox808a0d32006-09-29 02:00:40 -07002494 * is consistent.
Alan Coxaf9b8972006-08-27 01:24:01 -07002495 */
2496
Alan Cox37bdfb02008-02-08 04:18:47 -08002497static int tiocgwinsz(struct tty_struct *tty, struct winsize __user *arg)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002498{
Alan Cox808a0d32006-09-29 02:00:40 -07002499 int err;
2500
Arjan van de Ven5785c952006-09-29 02:00:43 -07002501 mutex_lock(&tty->termios_mutex);
Alan Cox808a0d32006-09-29 02:00:40 -07002502 err = copy_to_user(arg, &tty->winsize, sizeof(*arg));
Arjan van de Ven5785c952006-09-29 02:00:43 -07002503 mutex_unlock(&tty->termios_mutex);
Alan Cox808a0d32006-09-29 02:00:40 -07002504
2505 return err ? -EFAULT: 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002506}
2507
Alan Coxaf9b8972006-08-27 01:24:01 -07002508/**
Alan Cox8c9a9dd2008-08-15 10:39:38 +01002509 * tty_do_resize - resize event
2510 * @tty: tty being resized
Alan Coxa152db72008-08-26 19:55:58 +01002511 * @real_tty: real tty (not the same as tty if using a pty/tty pair)
Alan Cox8c9a9dd2008-08-15 10:39:38 +01002512 * @rows: rows (character)
2513 * @cols: cols (character)
Alan Coxaf9b8972006-08-27 01:24:01 -07002514 *
Alan Cox8c9a9dd2008-08-15 10:39:38 +01002515 * Update the termios variables and send the neccessary signals to
2516 * peform a terminal resize correctly
Alan Coxaf9b8972006-08-27 01:24:01 -07002517 */
2518
Alan Cox8c9a9dd2008-08-15 10:39:38 +01002519int tty_do_resize(struct tty_struct *tty, struct tty_struct *real_tty,
2520 struct winsize *ws)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002521{
Alan Cox47f86832008-04-30 00:53:30 -07002522 struct pid *pgrp, *rpgrp;
2523 unsigned long flags;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002524
Alan Coxa152db72008-08-26 19:55:58 +01002525 /* For a PTY we need to lock the tty side */
2526 mutex_lock(&real_tty->termios_mutex);
Alan Cox8c9a9dd2008-08-15 10:39:38 +01002527 if (!memcmp(ws, &tty->winsize, sizeof(*ws)))
Alan Coxca9bda02006-09-29 02:00:03 -07002528 goto done;
Alan Cox47f86832008-04-30 00:53:30 -07002529 /* Get the PID values and reference them so we can
2530 avoid holding the tty ctrl lock while sending signals */
2531 spin_lock_irqsave(&tty->ctrl_lock, flags);
2532 pgrp = get_pid(tty->pgrp);
2533 rpgrp = get_pid(real_tty->pgrp);
2534 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
2535
2536 if (pgrp)
2537 kill_pgrp(pgrp, SIGWINCH, 1);
2538 if (rpgrp != pgrp && rpgrp)
2539 kill_pgrp(rpgrp, SIGWINCH, 1);
2540
2541 put_pid(pgrp);
2542 put_pid(rpgrp);
2543
Alan Cox8c9a9dd2008-08-15 10:39:38 +01002544 tty->winsize = *ws;
2545 real_tty->winsize = *ws;
Alan Coxca9bda02006-09-29 02:00:03 -07002546done:
Alan Coxa152db72008-08-26 19:55:58 +01002547 mutex_unlock(&real_tty->termios_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002548 return 0;
2549}
2550
Alan Coxaf9b8972006-08-27 01:24:01 -07002551/**
Alan Cox8c9a9dd2008-08-15 10:39:38 +01002552 * tiocswinsz - implement window size set ioctl
2553 * @tty; tty
2554 * @arg: user buffer for result
2555 *
2556 * Copies the user idea of the window size to the kernel. Traditionally
2557 * this is just advisory information but for the Linux console it
2558 * actually has driver level meaning and triggers a VC resize.
2559 *
2560 * Locking:
2561 * Driver dependant. The default do_resize method takes the
2562 * tty termios mutex and ctrl_lock. The console takes its own lock
2563 * then calls into the default method.
2564 */
2565
2566static int tiocswinsz(struct tty_struct *tty, struct tty_struct *real_tty,
2567 struct winsize __user *arg)
2568{
2569 struct winsize tmp_ws;
2570 if (copy_from_user(&tmp_ws, arg, sizeof(*arg)))
2571 return -EFAULT;
2572
2573 if (tty->ops->resize)
2574 return tty->ops->resize(tty, real_tty, &tmp_ws);
2575 else
2576 return tty_do_resize(tty, real_tty, &tmp_ws);
2577}
2578
2579/**
Alan Coxaf9b8972006-08-27 01:24:01 -07002580 * tioccons - allow admin to move logical console
2581 * @file: the file to become console
2582 *
2583 * Allow the adminstrator to move the redirected console device
2584 *
2585 * Locking: uses redirect_lock to guard the redirect information
2586 */
2587
Linus Torvalds1da177e2005-04-16 15:20:36 -07002588static int tioccons(struct file *file)
2589{
2590 if (!capable(CAP_SYS_ADMIN))
2591 return -EPERM;
2592 if (file->f_op->write == redirected_tty_write) {
2593 struct file *f;
2594 spin_lock(&redirect_lock);
2595 f = redirect;
2596 redirect = NULL;
2597 spin_unlock(&redirect_lock);
2598 if (f)
2599 fput(f);
2600 return 0;
2601 }
2602 spin_lock(&redirect_lock);
2603 if (redirect) {
2604 spin_unlock(&redirect_lock);
2605 return -EBUSY;
2606 }
2607 get_file(file);
2608 redirect = file;
2609 spin_unlock(&redirect_lock);
2610 return 0;
2611}
2612
Alan Coxaf9b8972006-08-27 01:24:01 -07002613/**
2614 * fionbio - non blocking ioctl
2615 * @file: file to set blocking value
2616 * @p: user parameter
2617 *
2618 * Historical tty interfaces had a blocking control ioctl before
2619 * the generic functionality existed. This piece of history is preserved
2620 * in the expected tty API of posix OS's.
2621 *
2622 * Locking: none, the open fle handle ensures it won't go away.
2623 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002624
2625static int fionbio(struct file *file, int __user *p)
2626{
2627 int nonblock;
2628
2629 if (get_user(nonblock, p))
2630 return -EFAULT;
2631
Alan Cox04f378b2008-04-30 00:53:29 -07002632 /* file->f_flags is still BKL protected in the fs layer - vomit */
2633 lock_kernel();
Linus Torvalds1da177e2005-04-16 15:20:36 -07002634 if (nonblock)
2635 file->f_flags |= O_NONBLOCK;
2636 else
2637 file->f_flags &= ~O_NONBLOCK;
Alan Cox04f378b2008-04-30 00:53:29 -07002638 unlock_kernel();
Linus Torvalds1da177e2005-04-16 15:20:36 -07002639 return 0;
2640}
2641
Alan Coxaf9b8972006-08-27 01:24:01 -07002642/**
2643 * tiocsctty - set controlling tty
2644 * @tty: tty structure
2645 * @arg: user argument
2646 *
2647 * This ioctl is used to manage job control. It permits a session
2648 * leader to set this tty as the controlling tty for the session.
2649 *
2650 * Locking:
Alan Cox28298232006-09-29 02:00:58 -07002651 * Takes tty_mutex() to protect tty instance
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002652 * Takes tasklist_lock internally to walk sessions
2653 * Takes ->siglock() when updating signal->tty
Alan Coxaf9b8972006-08-27 01:24:01 -07002654 */
2655
Linus Torvalds1da177e2005-04-16 15:20:36 -07002656static int tiocsctty(struct tty_struct *tty, int arg)
2657{
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002658 int ret = 0;
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08002659 if (current->signal->leader && (task_session(current) == tty->session))
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002660 return ret;
2661
2662 mutex_lock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002663 /*
2664 * The process must be a session leader and
2665 * not have a controlling tty already.
2666 */
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002667 if (!current->signal->leader || current->signal->tty) {
2668 ret = -EPERM;
2669 goto unlock;
2670 }
2671
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08002672 if (tty->session) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002673 /*
2674 * This tty is already the controlling
2675 * tty for another session group!
2676 */
Alan Cox37bdfb02008-02-08 04:18:47 -08002677 if (arg == 1 && capable(CAP_SYS_ADMIN)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002678 /*
2679 * Steal it away
2680 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002681 read_lock(&tasklist_lock);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002682 session_clear_tty(tty->session);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002683 read_unlock(&tasklist_lock);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002684 } else {
2685 ret = -EPERM;
2686 goto unlock;
2687 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07002688 }
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002689 proc_set_tty(current, tty);
2690unlock:
Alan Cox28298232006-09-29 02:00:58 -07002691 mutex_unlock(&tty_mutex);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002692 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002693}
2694
Alan Coxaf9b8972006-08-27 01:24:01 -07002695/**
Alan Cox5d0fdf12008-04-30 00:53:31 -07002696 * tty_get_pgrp - return a ref counted pgrp pid
2697 * @tty: tty to read
2698 *
2699 * Returns a refcounted instance of the pid struct for the process
2700 * group controlling the tty.
2701 */
2702
2703struct pid *tty_get_pgrp(struct tty_struct *tty)
2704{
2705 unsigned long flags;
2706 struct pid *pgrp;
2707
2708 spin_lock_irqsave(&tty->ctrl_lock, flags);
2709 pgrp = get_pid(tty->pgrp);
2710 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
2711
2712 return pgrp;
2713}
2714EXPORT_SYMBOL_GPL(tty_get_pgrp);
2715
2716/**
Alan Coxaf9b8972006-08-27 01:24:01 -07002717 * tiocgpgrp - get process group
2718 * @tty: tty passed by user
2719 * @real_tty: tty side of the tty pased by the user if a pty else the tty
2720 * @p: returned pid
2721 *
2722 * Obtain the process group of the tty. If there is no process group
2723 * return an error.
2724 *
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002725 * Locking: none. Reference to current->signal->tty is safe.
Alan Coxaf9b8972006-08-27 01:24:01 -07002726 */
2727
Linus Torvalds1da177e2005-04-16 15:20:36 -07002728static int tiocgpgrp(struct tty_struct *tty, struct tty_struct *real_tty, pid_t __user *p)
2729{
Alan Cox5d0fdf12008-04-30 00:53:31 -07002730 struct pid *pid;
2731 int ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002732 /*
2733 * (tty == real_tty) is a cheap way of
2734 * testing if the tty is NOT a master pty.
2735 */
2736 if (tty == real_tty && current->signal->tty != real_tty)
2737 return -ENOTTY;
Alan Cox5d0fdf12008-04-30 00:53:31 -07002738 pid = tty_get_pgrp(real_tty);
2739 ret = put_user(pid_vnr(pid), p);
2740 put_pid(pid);
2741 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002742}
2743
Alan Coxaf9b8972006-08-27 01:24:01 -07002744/**
2745 * tiocspgrp - attempt to set process group
2746 * @tty: tty passed by user
2747 * @real_tty: tty side device matching tty passed by user
2748 * @p: pid pointer
2749 *
2750 * Set the process group of the tty to the session passed. Only
2751 * permitted where the tty session is our session.
2752 *
Alan Cox47f86832008-04-30 00:53:30 -07002753 * Locking: RCU, ctrl lock
Alan Coxaf9b8972006-08-27 01:24:01 -07002754 */
2755
Linus Torvalds1da177e2005-04-16 15:20:36 -07002756static int tiocspgrp(struct tty_struct *tty, struct tty_struct *real_tty, pid_t __user *p)
2757{
Eric W. Biederman04a2e6a2007-02-12 00:52:56 -08002758 struct pid *pgrp;
2759 pid_t pgrp_nr;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002760 int retval = tty_check_change(real_tty);
Alan Cox47f86832008-04-30 00:53:30 -07002761 unsigned long flags;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002762
2763 if (retval == -EIO)
2764 return -ENOTTY;
2765 if (retval)
2766 return retval;
2767 if (!current->signal->tty ||
2768 (current->signal->tty != real_tty) ||
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08002769 (real_tty->session != task_session(current)))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002770 return -ENOTTY;
Eric W. Biederman04a2e6a2007-02-12 00:52:56 -08002771 if (get_user(pgrp_nr, p))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002772 return -EFAULT;
Eric W. Biederman04a2e6a2007-02-12 00:52:56 -08002773 if (pgrp_nr < 0)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002774 return -EINVAL;
Eric W. Biederman04a2e6a2007-02-12 00:52:56 -08002775 rcu_read_lock();
Pavel Emelyanovb4888932007-10-18 23:40:14 -07002776 pgrp = find_vpid(pgrp_nr);
Eric W. Biederman04a2e6a2007-02-12 00:52:56 -08002777 retval = -ESRCH;
2778 if (!pgrp)
2779 goto out_unlock;
2780 retval = -EPERM;
2781 if (session_of_pgrp(pgrp) != task_session(current))
2782 goto out_unlock;
2783 retval = 0;
Alan Cox47f86832008-04-30 00:53:30 -07002784 spin_lock_irqsave(&tty->ctrl_lock, flags);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08002785 put_pid(real_tty->pgrp);
2786 real_tty->pgrp = get_pid(pgrp);
Alan Cox47f86832008-04-30 00:53:30 -07002787 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
Eric W. Biederman04a2e6a2007-02-12 00:52:56 -08002788out_unlock:
2789 rcu_read_unlock();
2790 return retval;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002791}
2792
Alan Coxaf9b8972006-08-27 01:24:01 -07002793/**
2794 * tiocgsid - get session id
2795 * @tty: tty passed by user
2796 * @real_tty: tty side of the tty pased by the user if a pty else the tty
2797 * @p: pointer to returned session id
2798 *
2799 * Obtain the session id of the tty. If there is no session
2800 * return an error.
2801 *
Peter Zijlstra24ec8392006-12-08 02:36:04 -08002802 * Locking: none. Reference to current->signal->tty is safe.
Alan Coxaf9b8972006-08-27 01:24:01 -07002803 */
2804
Linus Torvalds1da177e2005-04-16 15:20:36 -07002805static int tiocgsid(struct tty_struct *tty, struct tty_struct *real_tty, pid_t __user *p)
2806{
2807 /*
2808 * (tty == real_tty) is a cheap way of
2809 * testing if the tty is NOT a master pty.
2810 */
2811 if (tty == real_tty && current->signal->tty != real_tty)
2812 return -ENOTTY;
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08002813 if (!real_tty->session)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002814 return -ENOTTY;
Pavel Emelyanovb4888932007-10-18 23:40:14 -07002815 return put_user(pid_vnr(real_tty->session), p);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002816}
2817
Alan Coxaf9b8972006-08-27 01:24:01 -07002818/**
2819 * tiocsetd - set line discipline
2820 * @tty: tty device
2821 * @p: pointer to user data
2822 *
2823 * Set the line discipline according to user request.
2824 *
2825 * Locking: see tty_set_ldisc, this function is just a helper
2826 */
2827
Linus Torvalds1da177e2005-04-16 15:20:36 -07002828static int tiocsetd(struct tty_struct *tty, int __user *p)
2829{
2830 int ldisc;
Alan Cox04f378b2008-04-30 00:53:29 -07002831 int ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002832
2833 if (get_user(ldisc, p))
2834 return -EFAULT;
Alan Cox04f378b2008-04-30 00:53:29 -07002835
2836 lock_kernel();
2837 ret = tty_set_ldisc(tty, ldisc);
2838 unlock_kernel();
2839
2840 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002841}
2842
Alan Coxaf9b8972006-08-27 01:24:01 -07002843/**
2844 * send_break - performed time break
2845 * @tty: device to break on
2846 * @duration: timeout in mS
2847 *
2848 * Perform a timed break on hardware that lacks its own driver level
2849 * timed break functionality.
2850 *
2851 * Locking:
Alan Cox28298232006-09-29 02:00:58 -07002852 * atomic_write_lock serializes
Alan Coxaf9b8972006-08-27 01:24:01 -07002853 *
Alan Coxaf9b8972006-08-27 01:24:01 -07002854 */
2855
Domen Puncerb20f3ae2005-06-25 14:58:42 -07002856static int send_break(struct tty_struct *tty, unsigned int duration)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002857{
Alan Cox9e989662008-07-22 11:18:03 +01002858 int retval;
2859
2860 if (tty->ops->break_ctl == NULL)
2861 return 0;
2862
2863 if (tty->driver->flags & TTY_DRIVER_HARDWARE_BREAK)
2864 retval = tty->ops->break_ctl(tty, duration);
2865 else {
2866 /* Do the work ourselves */
2867 if (tty_write_lock(tty, 0) < 0)
2868 return -EINTR;
2869 retval = tty->ops->break_ctl(tty, -1);
2870 if (retval)
2871 goto out;
2872 if (!signal_pending(current))
2873 msleep_interruptible(duration);
2874 retval = tty->ops->break_ctl(tty, 0);
2875out:
2876 tty_write_unlock(tty);
2877 if (signal_pending(current))
2878 retval = -EINTR;
2879 }
2880 return retval;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002881}
2882
Alan Coxaf9b8972006-08-27 01:24:01 -07002883/**
Alan Coxf34d7a52008-04-30 00:54:13 -07002884 * tty_tiocmget - get modem status
Alan Coxaf9b8972006-08-27 01:24:01 -07002885 * @tty: tty device
2886 * @file: user file pointer
2887 * @p: pointer to result
2888 *
2889 * Obtain the modem status bits from the tty driver if the feature
2890 * is supported. Return -EINVAL if it is not available.
2891 *
2892 * Locking: none (up to the driver)
2893 */
2894
2895static int tty_tiocmget(struct tty_struct *tty, struct file *file, int __user *p)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002896{
2897 int retval = -EINVAL;
2898
Alan Coxf34d7a52008-04-30 00:54:13 -07002899 if (tty->ops->tiocmget) {
2900 retval = tty->ops->tiocmget(tty, file);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002901
2902 if (retval >= 0)
2903 retval = put_user(retval, p);
2904 }
2905 return retval;
2906}
2907
Alan Coxaf9b8972006-08-27 01:24:01 -07002908/**
Alan Coxf34d7a52008-04-30 00:54:13 -07002909 * tty_tiocmset - set modem status
Alan Coxaf9b8972006-08-27 01:24:01 -07002910 * @tty: tty device
2911 * @file: user file pointer
2912 * @cmd: command - clear bits, set bits or set all
2913 * @p: pointer to desired bits
2914 *
2915 * Set the modem status bits from the tty driver if the feature
2916 * is supported. Return -EINVAL if it is not available.
2917 *
2918 * Locking: none (up to the driver)
2919 */
2920
2921static int tty_tiocmset(struct tty_struct *tty, struct file *file, unsigned int cmd,
Linus Torvalds1da177e2005-04-16 15:20:36 -07002922 unsigned __user *p)
2923{
Alan Coxae677512008-07-16 21:56:54 +01002924 int retval;
2925 unsigned int set, clear, val;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002926
Alan Coxae677512008-07-16 21:56:54 +01002927 if (tty->ops->tiocmset == NULL)
2928 return -EINVAL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002929
Alan Coxae677512008-07-16 21:56:54 +01002930 retval = get_user(val, p);
2931 if (retval)
2932 return retval;
2933 set = clear = 0;
2934 switch (cmd) {
2935 case TIOCMBIS:
2936 set = val;
2937 break;
2938 case TIOCMBIC:
2939 clear = val;
2940 break;
2941 case TIOCMSET:
2942 set = val;
2943 clear = ~val;
2944 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002945 }
Alan Coxae677512008-07-16 21:56:54 +01002946 set &= TIOCM_DTR|TIOCM_RTS|TIOCM_OUT1|TIOCM_OUT2|TIOCM_LOOP;
2947 clear &= TIOCM_DTR|TIOCM_RTS|TIOCM_OUT1|TIOCM_OUT2|TIOCM_LOOP;
2948 return tty->ops->tiocmset(tty, file, set, clear);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002949}
2950
2951/*
2952 * Split this up, as gcc can choke on it otherwise..
2953 */
Alan Cox04f378b2008-04-30 00:53:29 -07002954long tty_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002955{
2956 struct tty_struct *tty, *real_tty;
2957 void __user *p = (void __user *)arg;
2958 int retval;
2959 struct tty_ldisc *ld;
Alan Cox04f378b2008-04-30 00:53:29 -07002960 struct inode *inode = file->f_dentry->d_inode;
Alan Cox37bdfb02008-02-08 04:18:47 -08002961
Linus Torvalds1da177e2005-04-16 15:20:36 -07002962 tty = (struct tty_struct *)file->private_data;
2963 if (tty_paranoia_check(tty, inode, "tty_ioctl"))
2964 return -EINVAL;
2965
2966 real_tty = tty;
2967 if (tty->driver->type == TTY_DRIVER_TYPE_PTY &&
2968 tty->driver->subtype == PTY_TYPE_MASTER)
2969 real_tty = tty->link;
2970
Linus Torvalds1da177e2005-04-16 15:20:36 -07002971
2972 /*
2973 * Factor out some common prep work
2974 */
2975 switch (cmd) {
2976 case TIOCSETD:
2977 case TIOCSBRK:
2978 case TIOCCBRK:
2979 case TCSBRK:
Alan Cox37bdfb02008-02-08 04:18:47 -08002980 case TCSBRKP:
Linus Torvalds1da177e2005-04-16 15:20:36 -07002981 retval = tty_check_change(tty);
2982 if (retval)
2983 return retval;
2984 if (cmd != TIOCCBRK) {
2985 tty_wait_until_sent(tty, 0);
2986 if (signal_pending(current))
2987 return -EINTR;
2988 }
2989 break;
2990 }
2991
Alan Cox9e989662008-07-22 11:18:03 +01002992 /*
2993 * Now do the stuff.
2994 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002995 switch (cmd) {
Alan Cox37bdfb02008-02-08 04:18:47 -08002996 case TIOCSTI:
2997 return tiocsti(tty, p);
2998 case TIOCGWINSZ:
2999 return tiocgwinsz(tty, p);
3000 case TIOCSWINSZ:
3001 return tiocswinsz(tty, real_tty, p);
3002 case TIOCCONS:
3003 return real_tty != tty ? -EINVAL : tioccons(file);
3004 case FIONBIO:
3005 return fionbio(file, p);
3006 case TIOCEXCL:
3007 set_bit(TTY_EXCLUSIVE, &tty->flags);
3008 return 0;
3009 case TIOCNXCL:
3010 clear_bit(TTY_EXCLUSIVE, &tty->flags);
3011 return 0;
3012 case TIOCNOTTY:
3013 if (current->signal->tty != tty)
3014 return -ENOTTY;
3015 no_tty();
3016 return 0;
3017 case TIOCSCTTY:
3018 return tiocsctty(tty, arg);
3019 case TIOCGPGRP:
3020 return tiocgpgrp(tty, real_tty, p);
3021 case TIOCSPGRP:
3022 return tiocspgrp(tty, real_tty, p);
3023 case TIOCGSID:
3024 return tiocgsid(tty, real_tty, p);
3025 case TIOCGETD:
Alan Coxa352def2008-07-16 21:53:12 +01003026 return put_user(tty->ldisc.ops->num, (int __user *)p);
Alan Cox37bdfb02008-02-08 04:18:47 -08003027 case TIOCSETD:
3028 return tiocsetd(tty, p);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003029#ifdef CONFIG_VT
Alan Cox37bdfb02008-02-08 04:18:47 -08003030 case TIOCLINUX:
3031 return tioclinux(tty, arg);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003032#endif
Alan Cox37bdfb02008-02-08 04:18:47 -08003033 /*
3034 * Break handling
3035 */
3036 case TIOCSBRK: /* Turn break on, unconditionally */
Alan Coxf34d7a52008-04-30 00:54:13 -07003037 if (tty->ops->break_ctl)
Alan Cox9e989662008-07-22 11:18:03 +01003038 return tty->ops->break_ctl(tty, -1);
Alan Cox37bdfb02008-02-08 04:18:47 -08003039 return 0;
Alan Cox37bdfb02008-02-08 04:18:47 -08003040 case TIOCCBRK: /* Turn break off, unconditionally */
Alan Coxf34d7a52008-04-30 00:54:13 -07003041 if (tty->ops->break_ctl)
Alan Cox9e989662008-07-22 11:18:03 +01003042 return tty->ops->break_ctl(tty, 0);
Alan Cox37bdfb02008-02-08 04:18:47 -08003043 return 0;
3044 case TCSBRK: /* SVID version: non-zero arg --> no break */
3045 /* non-zero arg means wait for all output data
3046 * to be sent (performed above) but don't send break.
3047 * This is used by the tcdrain() termios function.
Linus Torvalds1da177e2005-04-16 15:20:36 -07003048 */
Alan Cox37bdfb02008-02-08 04:18:47 -08003049 if (!arg)
3050 return send_break(tty, 250);
3051 return 0;
3052 case TCSBRKP: /* support for POSIX tcsendbreak() */
3053 return send_break(tty, arg ? arg*100 : 250);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003054
Alan Cox37bdfb02008-02-08 04:18:47 -08003055 case TIOCMGET:
3056 return tty_tiocmget(tty, file, p);
3057 case TIOCMSET:
3058 case TIOCMBIC:
3059 case TIOCMBIS:
3060 return tty_tiocmset(tty, file, cmd, p);
3061 case TCFLSH:
3062 switch (arg) {
3063 case TCIFLUSH:
3064 case TCIOFLUSH:
3065 /* flush tty buffer and allow ldisc to process ioctl */
3066 tty_buffer_flush(tty);
Paul Fulghumc5c34d42007-05-12 10:36:55 -07003067 break;
Alan Cox37bdfb02008-02-08 04:18:47 -08003068 }
3069 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003070 }
Alan Coxf34d7a52008-04-30 00:54:13 -07003071 if (tty->ops->ioctl) {
3072 retval = (tty->ops->ioctl)(tty, file, cmd, arg);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003073 if (retval != -ENOIOCTLCMD)
3074 return retval;
3075 }
3076 ld = tty_ldisc_ref_wait(tty);
3077 retval = -EINVAL;
Alan Coxa352def2008-07-16 21:53:12 +01003078 if (ld->ops->ioctl) {
3079 retval = ld->ops->ioctl(tty, file, cmd, arg);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003080 if (retval == -ENOIOCTLCMD)
3081 retval = -EINVAL;
3082 }
3083 tty_ldisc_deref(ld);
3084 return retval;
3085}
3086
Paul Fulghume10cc1d2007-05-10 22:22:50 -07003087#ifdef CONFIG_COMPAT
Alan Cox37bdfb02008-02-08 04:18:47 -08003088static long tty_compat_ioctl(struct file *file, unsigned int cmd,
Paul Fulghume10cc1d2007-05-10 22:22:50 -07003089 unsigned long arg)
3090{
3091 struct inode *inode = file->f_dentry->d_inode;
3092 struct tty_struct *tty = file->private_data;
3093 struct tty_ldisc *ld;
3094 int retval = -ENOIOCTLCMD;
3095
3096 if (tty_paranoia_check(tty, inode, "tty_ioctl"))
3097 return -EINVAL;
3098
Alan Coxf34d7a52008-04-30 00:54:13 -07003099 if (tty->ops->compat_ioctl) {
3100 retval = (tty->ops->compat_ioctl)(tty, file, cmd, arg);
Paul Fulghume10cc1d2007-05-10 22:22:50 -07003101 if (retval != -ENOIOCTLCMD)
3102 return retval;
3103 }
3104
3105 ld = tty_ldisc_ref_wait(tty);
Alan Coxa352def2008-07-16 21:53:12 +01003106 if (ld->ops->compat_ioctl)
3107 retval = ld->ops->compat_ioctl(tty, file, cmd, arg);
Paul Fulghume10cc1d2007-05-10 22:22:50 -07003108 tty_ldisc_deref(ld);
3109
3110 return retval;
3111}
3112#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -07003113
3114/*
3115 * This implements the "Secure Attention Key" --- the idea is to
3116 * prevent trojan horses by killing all processes associated with this
3117 * tty when the user hits the "Secure Attention Key". Required for
3118 * super-paranoid applications --- see the Orange Book for more details.
Alan Cox37bdfb02008-02-08 04:18:47 -08003119 *
Linus Torvalds1da177e2005-04-16 15:20:36 -07003120 * This code could be nicer; ideally it should send a HUP, wait a few
3121 * seconds, then send a INT, and then a KILL signal. But you then
3122 * have to coordinate with the init process, since all processes associated
3123 * with the current tty must be dead before the new getty is allowed
3124 * to spawn.
3125 *
3126 * Now, if it would be correct ;-/ The current code has a nasty hole -
3127 * it doesn't catch files in flight. We may send the descriptor to ourselves
3128 * via AF_UNIX socket, close it and later fetch from socket. FIXME.
3129 *
3130 * Nasty bug: do_SAK is being called in interrupt context. This can
3131 * deadlock. We punt it up to process context. AKPM - 16Mar2001
3132 */
Eric W. Biederman8b6312f2007-02-10 01:44:34 -08003133void __do_SAK(struct tty_struct *tty)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003134{
3135#ifdef TTY_SOFT_SAK
3136 tty_hangup(tty);
3137#else
Eric W. Biederman652486f2006-03-28 16:11:02 -08003138 struct task_struct *g, *p;
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08003139 struct pid *session;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003140 int i;
3141 struct file *filp;
Dipankar Sarmabadf1662005-09-09 13:04:10 -07003142 struct fdtable *fdt;
Alan Cox37bdfb02008-02-08 04:18:47 -08003143
Linus Torvalds1da177e2005-04-16 15:20:36 -07003144 if (!tty)
3145 return;
Peter Zijlstra24ec8392006-12-08 02:36:04 -08003146 session = tty->session;
Alan Cox37bdfb02008-02-08 04:18:47 -08003147
Dan Carpenterb3f13de2006-12-13 00:35:09 -08003148 tty_ldisc_flush(tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003149
Alan Coxf34d7a52008-04-30 00:54:13 -07003150 tty_driver_flush_buffer(tty);
Alan Cox37bdfb02008-02-08 04:18:47 -08003151
Linus Torvalds1da177e2005-04-16 15:20:36 -07003152 read_lock(&tasklist_lock);
Eric W. Biederman652486f2006-03-28 16:11:02 -08003153 /* Kill the entire session */
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08003154 do_each_pid_task(session, PIDTYPE_SID, p) {
Eric W. Biederman652486f2006-03-28 16:11:02 -08003155 printk(KERN_NOTICE "SAK: killed process %d"
Pavel Emelianova47afb02007-10-18 23:39:46 -07003156 " (%s): task_session_nr(p)==tty->session\n",
Pavel Emelyanovba25f9d2007-10-18 23:40:40 -07003157 task_pid_nr(p), p->comm);
Eric W. Biederman652486f2006-03-28 16:11:02 -08003158 send_sig(SIGKILL, p, 1);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08003159 } while_each_pid_task(session, PIDTYPE_SID, p);
Eric W. Biederman652486f2006-03-28 16:11:02 -08003160 /* Now kill any processes that happen to have the
3161 * tty open.
3162 */
3163 do_each_thread(g, p) {
3164 if (p->signal->tty == tty) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07003165 printk(KERN_NOTICE "SAK: killed process %d"
Pavel Emelianova47afb02007-10-18 23:39:46 -07003166 " (%s): task_session_nr(p)==tty->session\n",
Pavel Emelyanovba25f9d2007-10-18 23:40:40 -07003167 task_pid_nr(p), p->comm);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003168 send_sig(SIGKILL, p, 1);
3169 continue;
3170 }
3171 task_lock(p);
3172 if (p->files) {
Dipankar Sarmaca99c1d2006-04-18 22:21:46 -07003173 /*
3174 * We don't take a ref to the file, so we must
3175 * hold ->file_lock instead.
3176 */
3177 spin_lock(&p->files->file_lock);
Dipankar Sarmabadf1662005-09-09 13:04:10 -07003178 fdt = files_fdtable(p->files);
Alan Cox37bdfb02008-02-08 04:18:47 -08003179 for (i = 0; i < fdt->max_fds; i++) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07003180 filp = fcheck_files(p->files, i);
3181 if (!filp)
3182 continue;
3183 if (filp->f_op->read == tty_read &&
3184 filp->private_data == tty) {
3185 printk(KERN_NOTICE "SAK: killed process %d"
3186 " (%s): fd#%d opened to the tty\n",
Pavel Emelyanovba25f9d2007-10-18 23:40:40 -07003187 task_pid_nr(p), p->comm, i);
Eric W. Biederman20ac9432006-04-13 04:49:07 -06003188 force_sig(SIGKILL, p);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003189 break;
3190 }
3191 }
Dipankar Sarmaca99c1d2006-04-18 22:21:46 -07003192 spin_unlock(&p->files->file_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003193 }
3194 task_unlock(p);
Eric W. Biederman652486f2006-03-28 16:11:02 -08003195 } while_each_thread(g, p);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003196 read_unlock(&tasklist_lock);
3197#endif
3198}
3199
Eric W. Biederman8b6312f2007-02-10 01:44:34 -08003200static void do_SAK_work(struct work_struct *work)
3201{
3202 struct tty_struct *tty =
3203 container_of(work, struct tty_struct, SAK_work);
3204 __do_SAK(tty);
3205}
3206
Linus Torvalds1da177e2005-04-16 15:20:36 -07003207/*
3208 * The tq handling here is a little racy - tty->SAK_work may already be queued.
3209 * Fortunately we don't need to worry, because if ->SAK_work is already queued,
3210 * the values which we write to it will be identical to the values which it
3211 * already has. --akpm
3212 */
3213void do_SAK(struct tty_struct *tty)
3214{
3215 if (!tty)
3216 return;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003217 schedule_work(&tty->SAK_work);
3218}
3219
3220EXPORT_SYMBOL(do_SAK);
3221
Alan Coxaf9b8972006-08-27 01:24:01 -07003222/**
3223 * flush_to_ldisc
David Howells65f27f32006-11-22 14:55:48 +00003224 * @work: tty structure passed from work queue.
Alan Coxaf9b8972006-08-27 01:24:01 -07003225 *
3226 * This routine is called out of the software interrupt to flush data
3227 * from the buffer chain to the line discipline.
3228 *
3229 * Locking: holds tty->buf.lock to guard buffer list. Drops the lock
3230 * while invoking the line discipline receive_buf method. The
3231 * receive_buf method is single threaded for each tty instance.
Linus Torvalds1da177e2005-04-16 15:20:36 -07003232 */
Alan Cox37bdfb02008-02-08 04:18:47 -08003233
David Howells65f27f32006-11-22 14:55:48 +00003234static void flush_to_ldisc(struct work_struct *work)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003235{
David Howells65f27f32006-11-22 14:55:48 +00003236 struct tty_struct *tty =
3237 container_of(work, struct tty_struct, buf.work.work);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003238 unsigned long flags;
3239 struct tty_ldisc *disc;
Paul Fulghum2c3bb202006-06-28 04:26:48 -07003240 struct tty_buffer *tbuf, *head;
Paul Fulghum8977d922006-02-10 01:51:14 -08003241 char *char_buf;
3242 unsigned char *flag_buf;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003243
3244 disc = tty_ldisc_ref(tty);
3245 if (disc == NULL) /* !TTY_LDISC */
3246 return;
3247
Paul Fulghum808249c2006-02-03 03:04:41 -08003248 spin_lock_irqsave(&tty->buf.lock, flags);
Alan Cox37bdfb02008-02-08 04:18:47 -08003249 /* So we know a flush is running */
3250 set_bit(TTY_FLUSHING, &tty->flags);
Paul Fulghum2c3bb202006-06-28 04:26:48 -07003251 head = tty->buf.head;
3252 if (head != NULL) {
3253 tty->buf.head = NULL;
3254 for (;;) {
3255 int count = head->commit - head->read;
3256 if (!count) {
3257 if (head->next == NULL)
3258 break;
3259 tbuf = head;
3260 head = head->next;
3261 tty_buffer_free(tty, tbuf);
3262 continue;
3263 }
Alan Cox42fd5522007-08-10 13:01:05 -07003264 /* Ldisc or user is trying to flush the buffers
3265 we are feeding to the ldisc, stop feeding the
3266 line discipline as we want to empty the queue */
3267 if (test_bit(TTY_FLUSHPENDING, &tty->flags))
3268 break;
Paul Fulghum2c3bb202006-06-28 04:26:48 -07003269 if (!tty->receive_room) {
3270 schedule_delayed_work(&tty->buf.work, 1);
3271 break;
3272 }
3273 if (count > tty->receive_room)
3274 count = tty->receive_room;
3275 char_buf = head->char_buf_ptr + head->read;
3276 flag_buf = head->flag_buf_ptr + head->read;
3277 head->read += count;
Paul Fulghum8977d922006-02-10 01:51:14 -08003278 spin_unlock_irqrestore(&tty->buf.lock, flags);
Alan Coxa352def2008-07-16 21:53:12 +01003279 disc->ops->receive_buf(tty, char_buf,
3280 flag_buf, count);
Paul Fulghum8977d922006-02-10 01:51:14 -08003281 spin_lock_irqsave(&tty->buf.lock, flags);
3282 }
Alan Cox42fd5522007-08-10 13:01:05 -07003283 /* Restore the queue head */
Paul Fulghum2c3bb202006-06-28 04:26:48 -07003284 tty->buf.head = head;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003285 }
Alan Cox42fd5522007-08-10 13:01:05 -07003286 /* We may have a deferred request to flush the input buffer,
3287 if so pull the chain under the lock and empty the queue */
3288 if (test_bit(TTY_FLUSHPENDING, &tty->flags)) {
3289 __tty_buffer_flush(tty);
3290 clear_bit(TTY_FLUSHPENDING, &tty->flags);
3291 wake_up(&tty->read_wait);
3292 }
3293 clear_bit(TTY_FLUSHING, &tty->flags);
Paul Fulghum808249c2006-02-03 03:04:41 -08003294 spin_unlock_irqrestore(&tty->buf.lock, flags);
Paul Fulghum817d6d32006-06-28 04:26:47 -07003295
Linus Torvalds1da177e2005-04-16 15:20:36 -07003296 tty_ldisc_deref(disc);
3297}
3298
Linus Torvalds1da177e2005-04-16 15:20:36 -07003299/**
3300 * tty_flip_buffer_push - terminal
3301 * @tty: tty to push
3302 *
3303 * Queue a push of the terminal flip buffers to the line discipline. This
3304 * function must not be called from IRQ context if tty->low_latency is set.
3305 *
3306 * In the event of the queue being busy for flipping the work will be
3307 * held off and retried later.
Alan Coxaf9b8972006-08-27 01:24:01 -07003308 *
3309 * Locking: tty buffer lock. Driver locks in low latency mode.
Linus Torvalds1da177e2005-04-16 15:20:36 -07003310 */
3311
3312void tty_flip_buffer_push(struct tty_struct *tty)
3313{
Paul Fulghum808249c2006-02-03 03:04:41 -08003314 unsigned long flags;
3315 spin_lock_irqsave(&tty->buf.lock, flags);
Paul Fulghum33b37a32006-06-28 04:26:49 -07003316 if (tty->buf.tail != NULL)
Paul Fulghum8977d922006-02-10 01:51:14 -08003317 tty->buf.tail->commit = tty->buf.tail->used;
Paul Fulghum808249c2006-02-03 03:04:41 -08003318 spin_unlock_irqrestore(&tty->buf.lock, flags);
3319
Linus Torvalds1da177e2005-04-16 15:20:36 -07003320 if (tty->low_latency)
David Howells65f27f32006-11-22 14:55:48 +00003321 flush_to_ldisc(&tty->buf.work.work);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003322 else
Alan Cox33f0f882006-01-09 20:54:13 -08003323 schedule_delayed_work(&tty->buf.work, 1);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003324}
3325
3326EXPORT_SYMBOL(tty_flip_buffer_push);
3327
Alan Cox33f0f882006-01-09 20:54:13 -08003328
Alan Coxaf9b8972006-08-27 01:24:01 -07003329/**
3330 * initialize_tty_struct
3331 * @tty: tty to initialize
3332 *
3333 * This subroutine initializes a tty structure that has been newly
3334 * allocated.
3335 *
3336 * Locking: none - tty in question must not be exposed at this point
Linus Torvalds1da177e2005-04-16 15:20:36 -07003337 */
Alan Coxaf9b8972006-08-27 01:24:01 -07003338
Linus Torvalds1da177e2005-04-16 15:20:36 -07003339static void initialize_tty_struct(struct tty_struct *tty)
3340{
3341 memset(tty, 0, sizeof(struct tty_struct));
3342 tty->magic = TTY_MAGIC;
Alan Cox01e1abb2008-07-22 11:16:55 +01003343 tty_ldisc_init(tty);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08003344 tty->session = NULL;
3345 tty->pgrp = NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003346 tty->overrun_time = jiffies;
Alan Cox33f0f882006-01-09 20:54:13 -08003347 tty->buf.head = tty->buf.tail = NULL;
3348 tty_buffer_init(tty);
David Howells65f27f32006-11-22 14:55:48 +00003349 INIT_DELAYED_WORK(&tty->buf.work, flush_to_ldisc);
Arjan van de Ven5785c952006-09-29 02:00:43 -07003350 mutex_init(&tty->termios_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003351 init_waitqueue_head(&tty->write_wait);
3352 init_waitqueue_head(&tty->read_wait);
David Howells65f27f32006-11-22 14:55:48 +00003353 INIT_WORK(&tty->hangup_work, do_tty_hangup);
Ingo Molnar70522e12006-03-23 03:00:31 -08003354 mutex_init(&tty->atomic_read_lock);
3355 mutex_init(&tty->atomic_write_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003356 spin_lock_init(&tty->read_lock);
Alan Cox04f378b2008-04-30 00:53:29 -07003357 spin_lock_init(&tty->ctrl_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003358 INIT_LIST_HEAD(&tty->tty_files);
Eric W. Biederman7f1f86a2007-02-13 14:38:58 -07003359 INIT_WORK(&tty->SAK_work, do_SAK_work);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003360}
3361
Alan Coxf34d7a52008-04-30 00:54:13 -07003362/**
3363 * tty_put_char - write one character to a tty
3364 * @tty: tty
3365 * @ch: character
3366 *
3367 * Write one byte to the tty using the provided put_char method
3368 * if present. Returns the number of characters successfully output.
3369 *
3370 * Note: the specific put_char operation in the driver layer may go
3371 * away soon. Don't call it directly, use this method
Linus Torvalds1da177e2005-04-16 15:20:36 -07003372 */
Alan Coxaf9b8972006-08-27 01:24:01 -07003373
Alan Coxf34d7a52008-04-30 00:54:13 -07003374int tty_put_char(struct tty_struct *tty, unsigned char ch)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003375{
Alan Coxf34d7a52008-04-30 00:54:13 -07003376 if (tty->ops->put_char)
3377 return tty->ops->put_char(tty, ch);
3378 return tty->ops->write(tty, &ch, 1);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003379}
3380
Alan Coxf34d7a52008-04-30 00:54:13 -07003381EXPORT_SYMBOL_GPL(tty_put_char);
3382
gregkh@suse.de7fe845d2005-03-15 14:23:15 -08003383static struct class *tty_class;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003384
3385/**
Alan Coxaf9b8972006-08-27 01:24:01 -07003386 * tty_register_device - register a tty device
3387 * @driver: the tty driver that describes the tty device
3388 * @index: the index in the tty driver for this tty device
3389 * @device: a struct device that is associated with this tty device.
3390 * This field is optional, if there is no known struct device
3391 * for this tty device it can be set to NULL safely.
Linus Torvalds1da177e2005-04-16 15:20:36 -07003392 *
Greg Kroah-Hartman01107d32006-08-07 22:19:37 -07003393 * Returns a pointer to the struct device for this tty device
3394 * (or ERR_PTR(-EFOO) on error).
Hansjoerg Lipp1cdcb6b2006-04-22 18:36:53 +02003395 *
Alan Coxaf9b8972006-08-27 01:24:01 -07003396 * This call is required to be made to register an individual tty device
3397 * if the tty driver's flags have the TTY_DRIVER_DYNAMIC_DEV bit set. If
3398 * that bit is not set, this function should not be called by a tty
3399 * driver.
3400 *
3401 * Locking: ??
Linus Torvalds1da177e2005-04-16 15:20:36 -07003402 */
Alan Coxaf9b8972006-08-27 01:24:01 -07003403
Greg Kroah-Hartman01107d32006-08-07 22:19:37 -07003404struct device *tty_register_device(struct tty_driver *driver, unsigned index,
3405 struct device *device)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003406{
3407 char name[64];
3408 dev_t dev = MKDEV(driver->major, driver->minor_start) + index;
3409
3410 if (index >= driver->num) {
3411 printk(KERN_ERR "Attempt to register invalid tty line number "
3412 " (%d).\n", index);
Hansjoerg Lipp1cdcb6b2006-04-22 18:36:53 +02003413 return ERR_PTR(-EINVAL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003414 }
3415
Linus Torvalds1da177e2005-04-16 15:20:36 -07003416 if (driver->type == TTY_DRIVER_TYPE_PTY)
3417 pty_line_name(driver, index, name);
3418 else
3419 tty_line_name(driver, index, name);
Hansjoerg Lipp1cdcb6b2006-04-22 18:36:53 +02003420
Greg Kroah-Hartman47aa5792008-05-21 12:52:33 -07003421 return device_create_drvdata(tty_class, device, dev, NULL, name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003422}
3423
3424/**
Alan Coxaf9b8972006-08-27 01:24:01 -07003425 * tty_unregister_device - unregister a tty device
3426 * @driver: the tty driver that describes the tty device
3427 * @index: the index in the tty driver for this tty device
Linus Torvalds1da177e2005-04-16 15:20:36 -07003428 *
Alan Coxaf9b8972006-08-27 01:24:01 -07003429 * If a tty device is registered with a call to tty_register_device() then
3430 * this function must be called when the tty device is gone.
3431 *
3432 * Locking: ??
Linus Torvalds1da177e2005-04-16 15:20:36 -07003433 */
Alan Coxaf9b8972006-08-27 01:24:01 -07003434
Linus Torvalds1da177e2005-04-16 15:20:36 -07003435void tty_unregister_device(struct tty_driver *driver, unsigned index)
3436{
Alan Cox37bdfb02008-02-08 04:18:47 -08003437 device_destroy(tty_class,
3438 MKDEV(driver->major, driver->minor_start) + index);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003439}
3440
3441EXPORT_SYMBOL(tty_register_device);
3442EXPORT_SYMBOL(tty_unregister_device);
3443
3444struct tty_driver *alloc_tty_driver(int lines)
3445{
3446 struct tty_driver *driver;
3447
Jean Delvare506eb992007-07-15 23:40:14 -07003448 driver = kzalloc(sizeof(struct tty_driver), GFP_KERNEL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003449 if (driver) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07003450 driver->magic = TTY_DRIVER_MAGIC;
3451 driver->num = lines;
3452 /* later we'll move allocation of tables here */
3453 }
3454 return driver;
3455}
3456
3457void put_tty_driver(struct tty_driver *driver)
3458{
3459 kfree(driver);
3460}
3461
Jeff Dikeb68e31d2006-10-02 02:17:18 -07003462void tty_set_operations(struct tty_driver *driver,
3463 const struct tty_operations *op)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003464{
Alan Coxf34d7a52008-04-30 00:54:13 -07003465 driver->ops = op;
3466};
Linus Torvalds1da177e2005-04-16 15:20:36 -07003467
3468EXPORT_SYMBOL(alloc_tty_driver);
3469EXPORT_SYMBOL(put_tty_driver);
3470EXPORT_SYMBOL(tty_set_operations);
3471
3472/*
3473 * Called by a tty driver to register itself.
3474 */
3475int tty_register_driver(struct tty_driver *driver)
3476{
3477 int error;
Alan Cox37bdfb02008-02-08 04:18:47 -08003478 int i;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003479 dev_t dev;
3480 void **p = NULL;
3481
3482 if (driver->flags & TTY_DRIVER_INSTALLED)
3483 return 0;
3484
Andy Whitcroft543691a2007-05-06 14:49:33 -07003485 if (!(driver->flags & TTY_DRIVER_DEVPTS_MEM) && driver->num) {
3486 p = kzalloc(driver->num * 3 * sizeof(void *), GFP_KERNEL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003487 if (!p)
3488 return -ENOMEM;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003489 }
3490
3491 if (!driver->major) {
Alan Cox37bdfb02008-02-08 04:18:47 -08003492 error = alloc_chrdev_region(&dev, driver->minor_start,
3493 driver->num, driver->name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003494 if (!error) {
3495 driver->major = MAJOR(dev);
3496 driver->minor_start = MINOR(dev);
3497 }
3498 } else {
3499 dev = MKDEV(driver->major, driver->minor_start);
Geert Uytterhoevene5717c42007-02-20 15:45:21 +01003500 error = register_chrdev_region(dev, driver->num, driver->name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003501 }
3502 if (error < 0) {
3503 kfree(p);
3504 return error;
3505 }
3506
3507 if (p) {
3508 driver->ttys = (struct tty_struct **)p;
Alan Coxedc6afc2006-12-08 02:38:44 -08003509 driver->termios = (struct ktermios **)(p + driver->num);
Alan Cox37bdfb02008-02-08 04:18:47 -08003510 driver->termios_locked = (struct ktermios **)
3511 (p + driver->num * 2);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003512 } else {
3513 driver->ttys = NULL;
3514 driver->termios = NULL;
3515 driver->termios_locked = NULL;
3516 }
3517
3518 cdev_init(&driver->cdev, &tty_fops);
3519 driver->cdev.owner = driver->owner;
3520 error = cdev_add(&driver->cdev, dev, driver->num);
3521 if (error) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07003522 unregister_chrdev_region(dev, driver->num);
3523 driver->ttys = NULL;
3524 driver->termios = driver->termios_locked = NULL;
3525 kfree(p);
3526 return error;
3527 }
3528
Alexey Dobriyanca509f62007-05-08 00:27:12 -07003529 mutex_lock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003530 list_add(&driver->tty_drivers, &tty_drivers);
Alexey Dobriyanca509f62007-05-08 00:27:12 -07003531 mutex_unlock(&tty_mutex);
Alan Cox37bdfb02008-02-08 04:18:47 -08003532
3533 if (!(driver->flags & TTY_DRIVER_DYNAMIC_DEV)) {
3534 for (i = 0; i < driver->num; i++)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003535 tty_register_device(driver, i, NULL);
3536 }
3537 proc_tty_register_driver(driver);
3538 return 0;
3539}
3540
3541EXPORT_SYMBOL(tty_register_driver);
3542
3543/*
3544 * Called by a tty driver to unregister itself.
3545 */
3546int tty_unregister_driver(struct tty_driver *driver)
3547{
3548 int i;
Alan Coxedc6afc2006-12-08 02:38:44 -08003549 struct ktermios *tp;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003550 void *p;
3551
3552 if (driver->refcount)
3553 return -EBUSY;
3554
3555 unregister_chrdev_region(MKDEV(driver->major, driver->minor_start),
3556 driver->num);
Alexey Dobriyanca509f62007-05-08 00:27:12 -07003557 mutex_lock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003558 list_del(&driver->tty_drivers);
Alexey Dobriyanca509f62007-05-08 00:27:12 -07003559 mutex_unlock(&tty_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003560
3561 /*
3562 * Free the termios and termios_locked structures because
3563 * we don't want to get memory leaks when modular tty
3564 * drivers are removed from the kernel.
3565 */
3566 for (i = 0; i < driver->num; i++) {
3567 tp = driver->termios[i];
3568 if (tp) {
3569 driver->termios[i] = NULL;
3570 kfree(tp);
3571 }
3572 tp = driver->termios_locked[i];
3573 if (tp) {
3574 driver->termios_locked[i] = NULL;
3575 kfree(tp);
3576 }
Greg Kroah-Hartman331b8312005-06-20 21:15:16 -07003577 if (!(driver->flags & TTY_DRIVER_DYNAMIC_DEV))
Linus Torvalds1da177e2005-04-16 15:20:36 -07003578 tty_unregister_device(driver, i);
3579 }
3580 p = driver->ttys;
3581 proc_tty_unregister_driver(driver);
3582 driver->ttys = NULL;
3583 driver->termios = driver->termios_locked = NULL;
3584 kfree(p);
3585 cdev_del(&driver->cdev);
3586 return 0;
3587}
Linus Torvalds1da177e2005-04-16 15:20:36 -07003588EXPORT_SYMBOL(tty_unregister_driver);
3589
Peter Zijlstra24ec8392006-12-08 02:36:04 -08003590dev_t tty_devnum(struct tty_struct *tty)
3591{
3592 return MKDEV(tty->driver->major, tty->driver->minor_start) + tty->index;
3593}
3594EXPORT_SYMBOL(tty_devnum);
3595
3596void proc_clear_tty(struct task_struct *p)
3597{
3598 spin_lock_irq(&p->sighand->siglock);
3599 p->signal->tty = NULL;
3600 spin_unlock_irq(&p->sighand->siglock);
3601}
Peter Zijlstra24ec8392006-12-08 02:36:04 -08003602
Alan Cox47f86832008-04-30 00:53:30 -07003603/* Called under the sighand lock */
3604
Eric W. Biederman2a65f1d2007-05-08 00:26:53 -07003605static void __proc_set_tty(struct task_struct *tsk, struct tty_struct *tty)
Peter Zijlstra24ec8392006-12-08 02:36:04 -08003606{
3607 if (tty) {
Alan Cox47f86832008-04-30 00:53:30 -07003608 unsigned long flags;
3609 /* We should not have a session or pgrp to put here but.... */
3610 spin_lock_irqsave(&tty->ctrl_lock, flags);
Eric W. Biedermand9c1e9a2007-03-18 12:45:44 -06003611 put_pid(tty->session);
3612 put_pid(tty->pgrp);
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08003613 tty->pgrp = get_pid(task_pgrp(tsk));
Alan Cox47f86832008-04-30 00:53:30 -07003614 spin_unlock_irqrestore(&tty->ctrl_lock, flags);
3615 tty->session = get_pid(task_session(tsk));
Peter Zijlstra24ec8392006-12-08 02:36:04 -08003616 }
Eric W. Biederman2a65f1d2007-05-08 00:26:53 -07003617 put_pid(tsk->signal->tty_old_pgrp);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08003618 tsk->signal->tty = tty;
Eric W. Biedermanab521dc2007-02-12 00:53:00 -08003619 tsk->signal->tty_old_pgrp = NULL;
Peter Zijlstra24ec8392006-12-08 02:36:04 -08003620}
3621
Eric W. Biederman98a27ba2007-05-08 00:26:56 -07003622static void proc_set_tty(struct task_struct *tsk, struct tty_struct *tty)
Peter Zijlstra24ec8392006-12-08 02:36:04 -08003623{
3624 spin_lock_irq(&tsk->sighand->siglock);
Eric W. Biederman2a65f1d2007-05-08 00:26:53 -07003625 __proc_set_tty(tsk, tty);
Peter Zijlstra24ec8392006-12-08 02:36:04 -08003626 spin_unlock_irq(&tsk->sighand->siglock);
3627}
3628
3629struct tty_struct *get_current_tty(void)
3630{
3631 struct tty_struct *tty;
3632 WARN_ON_ONCE(!mutex_is_locked(&tty_mutex));
3633 tty = current->signal->tty;
3634 /*
3635 * session->tty can be changed/cleared from under us, make sure we
3636 * issue the load. The obtained pointer, when not NULL, is valid as
3637 * long as we hold tty_mutex.
3638 */
3639 barrier();
3640 return tty;
3641}
Heiko Carstensa311f742006-12-13 00:33:41 -08003642EXPORT_SYMBOL_GPL(get_current_tty);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003643
3644/*
3645 * Initialize the console device. This is called *early*, so
3646 * we can't necessarily depend on lots of kernel help here.
3647 * Just do some early initializations, and do the complex setup
3648 * later.
3649 */
3650void __init console_init(void)
3651{
3652 initcall_t *call;
3653
3654 /* Setup the default TTY line discipline. */
Alan Cox01e1abb2008-07-22 11:16:55 +01003655 tty_ldisc_begin();
Linus Torvalds1da177e2005-04-16 15:20:36 -07003656
3657 /*
Alan Cox37bdfb02008-02-08 04:18:47 -08003658 * set up the console device so that later boot sequences can
Linus Torvalds1da177e2005-04-16 15:20:36 -07003659 * inform about problems etc..
3660 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07003661 call = __con_initcall_start;
3662 while (call < __con_initcall_end) {
3663 (*call)();
3664 call++;
3665 }
3666}
3667
Linus Torvalds1da177e2005-04-16 15:20:36 -07003668static int __init tty_class_init(void)
3669{
gregkh@suse.de7fe845d2005-03-15 14:23:15 -08003670 tty_class = class_create(THIS_MODULE, "tty");
Linus Torvalds1da177e2005-04-16 15:20:36 -07003671 if (IS_ERR(tty_class))
3672 return PTR_ERR(tty_class);
3673 return 0;
3674}
3675
3676postcore_initcall(tty_class_init);
3677
3678/* 3/2004 jmc: why do these devices exist? */
3679
3680static struct cdev tty_cdev, console_cdev;
3681#ifdef CONFIG_UNIX98_PTYS
3682static struct cdev ptmx_cdev;
3683#endif
3684#ifdef CONFIG_VT
3685static struct cdev vc0_cdev;
3686#endif
3687
3688/*
3689 * Ok, now we can initialize the rest of the tty devices and can count
3690 * on memory allocations, interrupts etc..
3691 */
3692static int __init tty_init(void)
3693{
3694 cdev_init(&tty_cdev, &tty_fops);
3695 if (cdev_add(&tty_cdev, MKDEV(TTYAUX_MAJOR, 0), 1) ||
3696 register_chrdev_region(MKDEV(TTYAUX_MAJOR, 0), 1, "/dev/tty") < 0)
3697 panic("Couldn't register /dev/tty driver\n");
Greg Kroah-Hartman47aa5792008-05-21 12:52:33 -07003698 device_create_drvdata(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 0), NULL,
3699 "tty");
Linus Torvalds1da177e2005-04-16 15:20:36 -07003700
3701 cdev_init(&console_cdev, &console_fops);
3702 if (cdev_add(&console_cdev, MKDEV(TTYAUX_MAJOR, 1), 1) ||
3703 register_chrdev_region(MKDEV(TTYAUX_MAJOR, 1), 1, "/dev/console") < 0)
3704 panic("Couldn't register /dev/console driver\n");
Greg Kroah-Hartman47aa5792008-05-21 12:52:33 -07003705 device_create_drvdata(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 1), NULL,
3706 "console");
Linus Torvalds1da177e2005-04-16 15:20:36 -07003707
3708#ifdef CONFIG_UNIX98_PTYS
3709 cdev_init(&ptmx_cdev, &ptmx_fops);
3710 if (cdev_add(&ptmx_cdev, MKDEV(TTYAUX_MAJOR, 2), 1) ||
3711 register_chrdev_region(MKDEV(TTYAUX_MAJOR, 2), 1, "/dev/ptmx") < 0)
3712 panic("Couldn't register /dev/ptmx driver\n");
Greg Kroah-Hartman47aa5792008-05-21 12:52:33 -07003713 device_create_drvdata(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 2), NULL, "ptmx");
Linus Torvalds1da177e2005-04-16 15:20:36 -07003714#endif
3715
3716#ifdef CONFIG_VT
3717 cdev_init(&vc0_cdev, &console_fops);
3718 if (cdev_add(&vc0_cdev, MKDEV(TTY_MAJOR, 0), 1) ||
3719 register_chrdev_region(MKDEV(TTY_MAJOR, 0), 1, "/dev/vc/0") < 0)
3720 panic("Couldn't register /dev/tty0 driver\n");
Greg Kroah-Hartman47aa5792008-05-21 12:52:33 -07003721 device_create_drvdata(tty_class, NULL, MKDEV(TTY_MAJOR, 0), NULL, "tty0");
Linus Torvalds1da177e2005-04-16 15:20:36 -07003722
3723 vty_init();
3724#endif
3725 return 0;
3726}
3727module_init(tty_init);