diff options
| author | Ingo Molnar <mingo@kernel.org> | 2012-04-14 15:18:27 +0400 | 
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2012-04-14 15:19:04 +0400 | 
| commit | 6ac1ef482d7ae0c690f1640bf6eb818ff9a2d91e (patch) | |
| tree | 021cc9f6b477146fcebe6f3be4752abfa2ba18a9 /drivers/usb/class/cdc-acm.c | |
| parent | 682968e0c425c60f0dde37977e5beb2b12ddc4cc (diff) | |
| parent | a385ec4f11bdcf81af094c03e2444ee9b7fad2e5 (diff) | |
| download | linux-6ac1ef482d7ae0c690f1640bf6eb818ff9a2d91e.tar.xz | |
Merge branch 'perf/core' into perf/uprobes
Merge in latest upstream (and the latest perf development tree),
to prepare for tooling changes, and also to pick up v3.4 MM
changes that the uprobes code needs to take care of.
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'drivers/usb/class/cdc-acm.c')
| -rw-r--r-- | drivers/usb/class/cdc-acm.c | 38 | 
1 files changed, 30 insertions, 8 deletions
| diff --git a/drivers/usb/class/cdc-acm.c b/drivers/usb/class/cdc-acm.c index 9543b19d410c..b32ccb461019 100644 --- a/drivers/usb/class/cdc-acm.c +++ b/drivers/usb/class/cdc-acm.c @@ -39,6 +39,7 @@  #include <linux/serial.h>  #include <linux/tty_driver.h>  #include <linux/tty_flip.h> +#include <linux/serial.h>  #include <linux/module.h>  #include <linux/mutex.h>  #include <linux/uaccess.h> @@ -508,17 +509,12 @@ static int acm_tty_install(struct tty_driver *driver, struct tty_struct *tty)  	if (!acm)  		return -ENODEV; -	retval = tty_init_termios(tty); +	retval = tty_standard_install(driver, tty);  	if (retval)  		goto error_init_termios;  	tty->driver_data = acm; -	/* Final install (we use the default method) */ -	tty_driver_kref_get(driver); -	tty->count++; -	driver->ttys[tty->index] = tty; -  	return 0;  error_init_termios: @@ -773,10 +769,37 @@ static int acm_tty_tiocmset(struct tty_struct *tty,  	return acm_set_control(acm, acm->ctrlout = newctrl);  } +static int get_serial_info(struct acm *acm, struct serial_struct __user *info) +{ +	struct serial_struct tmp; + +	if (!info) +		return -EINVAL; + +	memset(&tmp, 0, sizeof(tmp)); +	tmp.flags = ASYNC_LOW_LATENCY; +	tmp.xmit_fifo_size = acm->writesize; +	tmp.baud_base = le32_to_cpu(acm->line.dwDTERate); + +	if (copy_to_user(info, &tmp, sizeof(tmp))) +		return -EFAULT; +	else +		return 0; +} +  static int acm_tty_ioctl(struct tty_struct *tty,  					unsigned int cmd, unsigned long arg)  { -	return -ENOIOCTLCMD; +	struct acm *acm = tty->driver_data; +	int rv = -ENOIOCTLCMD; + +	switch (cmd) { +	case TIOCGSERIAL: /* gets serial port data */ +		rv = get_serial_info(acm, (struct serial_struct __user *) arg); +		break; +	} + +	return rv;  }  static const __u32 acm_tty_speed[] = { @@ -1675,7 +1698,6 @@ static int __init acm_init(void)  	acm_tty_driver = alloc_tty_driver(ACM_TTY_MINORS);  	if (!acm_tty_driver)  		return -ENOMEM; -	acm_tty_driver->owner = THIS_MODULE,  	acm_tty_driver->driver_name = "acm",  	acm_tty_driver->name = "ttyACM",  	acm_tty_driver->major = ACM_TTY_MAJOR, | 
