diff options
| author | Thomas Meyer <thomas@m3y3r.de> | 2011-10-05 23:13:13 +0200 | 
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@suse.de> | 2011-10-18 14:17:11 -0700 | 
| commit | 8193c4290620d9b2a6ac116719f11aa99053a90d (patch) | |
| tree | 68f97623f0ae19ca5e6a31fda4cda4a1abf8c880 | |
| parent | 361162459f62dc0826b82c9690a741a940f457f0 (diff) | |
| download | olio-linux-3.10-8193c4290620d9b2a6ac116719f11aa99053a90d.tar.xz olio-linux-3.10-8193c4290620d9b2a6ac116719f11aa99053a90d.zip  | |
tty: Support compat_ioctl get/set termios_locked
When running a Fedora 15 (x86) on an x86_64 kernel, in the boot process
plymouthd complains about those two missing ioctls:
[    2.581783] ioctl32(plymouthd:186): Unknown cmd fd(10) cmd(00005457){t:'T';sz:0} arg(ffb6a5d0) on /dev/tty1
[    2.581803] ioctl32(plymouthd:186): Unknown cmd fd(10) cmd(00005456){t:'T';sz:0} arg(ffb6a680) on /dev/tty1
both ioctl functions work on the 'struct termios' resp. 'struct termios2',
which has the same size (36 bytes resp. 44 bytes) on x86 and x86_64,
so it's just a matter of converting the pointer from userland.
Signed-off-by: Thomas Meyer <thomas@m3y3r.de>
Cc: Arnd Bergmann <arnd@arndb.de>
Cc: Alan Cox <alan@lxorguk.ukuu.org.uk>
Signed-off-by: Andrew Morton <akpm@google.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
| -rw-r--r-- | drivers/tty/tty_io.c | 2 | ||||
| -rw-r--r-- | drivers/tty/tty_ioctl.c | 17 | ||||
| -rw-r--r-- | include/linux/tty.h | 2 | 
3 files changed, 21 insertions, 0 deletions
diff --git a/drivers/tty/tty_io.c b/drivers/tty/tty_io.c index 150e4f747c7..4ca4bcd28ff 100644 --- a/drivers/tty/tty_io.c +++ b/drivers/tty/tty_io.c @@ -2717,6 +2717,8 @@ static long tty_compat_ioctl(struct file *file, unsigned int cmd,  	ld = tty_ldisc_ref_wait(tty);  	if (ld->ops->compat_ioctl)  		retval = ld->ops->compat_ioctl(tty, file, cmd, arg); +	else +		retval = n_tty_compat_ioctl_helper(tty, file, cmd, arg);  	tty_ldisc_deref(ld);  	return retval; diff --git a/drivers/tty/tty_ioctl.c b/drivers/tty/tty_ioctl.c index 53f2442c609..9314d93c1a2 100644 --- a/drivers/tty/tty_ioctl.c +++ b/drivers/tty/tty_ioctl.c @@ -19,6 +19,7 @@  #include <linux/module.h>  #include <linux/bitops.h>  #include <linux/mutex.h> +#include <linux/compat.h>  #include <asm/io.h>  #include <asm/uaccess.h> @@ -1179,3 +1180,19 @@ int n_tty_ioctl_helper(struct tty_struct *tty, struct file *file,  	}  }  EXPORT_SYMBOL(n_tty_ioctl_helper); + +#ifdef CONFIG_COMPAT +long n_tty_compat_ioctl_helper(struct tty_struct *tty, struct file *file, +					unsigned int cmd, unsigned long arg) +{ +	switch (cmd) { +	case TIOCGLCKTRMIOS: +	case TIOCSLCKTRMIOS: +		return tty_mode_ioctl(tty, file, cmd, (unsigned long) compat_ptr(arg)); +	default: +		return -ENOIOCTLCMD; +	} +} +EXPORT_SYMBOL(n_tty_compat_ioctl_helper); +#endif + diff --git a/include/linux/tty.h b/include/linux/tty.h index 0ad68889fc1..64c12a3e65f 100644 --- a/include/linux/tty.h +++ b/include/linux/tty.h @@ -579,6 +579,8 @@ extern int __init tty_init(void);  /* tty_ioctl.c */  extern int n_tty_ioctl_helper(struct tty_struct *tty, struct file *file,  		       unsigned int cmd, unsigned long arg); +extern long n_tty_compat_ioctl_helper(struct tty_struct *tty, struct file *file, +		       unsigned int cmd, unsigned long arg);  /* serial.c */  |