diff options
| author | Ingo Molnar <mingo@elte.hu> | 2011-03-15 08:29:44 +0100 | 
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2011-03-15 08:29:44 +0100 | 
| commit | 8460b3e5bc64955aeefdd8357b3bf7b5ff79b3f2 (patch) | |
| tree | 7e5f6d050b72ab08a4497e82a4a103fefb086e80 /drivers/usb/serial | |
| parent | 56396e6823fe9b42fe9cf9403d6ed67756255f70 (diff) | |
| parent | 521cb40b0c44418a4fd36dc633f575813d59a43d (diff) | |
Merge commit 'v2.6.38' into x86/mm
Conflicts:
	arch/x86/mm/numa_64.c
Merge reason: Resolve the conflict, update the branch to .38.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'drivers/usb/serial')
| -rw-r--r-- | drivers/usb/serial/sierra.c | 3 | ||||
| -rw-r--r-- | drivers/usb/serial/usb_wwan.c | 15 | ||||
| -rw-r--r-- | drivers/usb/serial/visor.c | 12 | 
3 files changed, 24 insertions, 6 deletions
| diff --git a/drivers/usb/serial/sierra.c b/drivers/usb/serial/sierra.c index 7481ff8a49e4..0457813eebee 100644 --- a/drivers/usb/serial/sierra.c +++ b/drivers/usb/serial/sierra.c @@ -301,6 +301,9 @@ static const struct usb_device_id id_table[] = {  	{ USB_DEVICE(0x1199, 0x68A3), 	/* Sierra Wireless Direct IP modems */  	  .driver_info = (kernel_ulong_t)&direct_ip_interface_blacklist  	}, +	{ USB_DEVICE(0x0f3d, 0x68A3), 	/* Airprime/Sierra Wireless Direct IP modems */ +	  .driver_info = (kernel_ulong_t)&direct_ip_interface_blacklist +	},         { USB_DEVICE(0x413C, 0x08133) }, /* Dell Computer Corp. Wireless 5720 VZW Mobile Broadband (EVDO Rev-A) Minicard GPS Port */  	{ } diff --git a/drivers/usb/serial/usb_wwan.c b/drivers/usb/serial/usb_wwan.c index b004b2a485c3..9c014e2ecd68 100644 --- a/drivers/usb/serial/usb_wwan.c +++ b/drivers/usb/serial/usb_wwan.c @@ -295,12 +295,15 @@ static void usb_wwan_indat_callback(struct urb *urb)  		    __func__, status, endpoint);  	} else {  		tty = tty_port_tty_get(&port->port); -		if (urb->actual_length) { -			tty_insert_flip_string(tty, data, urb->actual_length); -			tty_flip_buffer_push(tty); -		} else -			dbg("%s: empty read urb received", __func__); -		tty_kref_put(tty); +		if (tty) { +			if (urb->actual_length) { +				tty_insert_flip_string(tty, data, +						urb->actual_length); +				tty_flip_buffer_push(tty); +			} else +				dbg("%s: empty read urb received", __func__); +			tty_kref_put(tty); +		}  		/* Resubmit urb so we continue receiving */  		if (status != -ESHUTDOWN) { diff --git a/drivers/usb/serial/visor.c b/drivers/usb/serial/visor.c index 15a5d89b7f39..1c11959a7d58 100644 --- a/drivers/usb/serial/visor.c +++ b/drivers/usb/serial/visor.c @@ -27,6 +27,7 @@  #include <linux/uaccess.h>  #include <linux/usb.h>  #include <linux/usb/serial.h> +#include <linux/usb/cdc.h>  #include "visor.h"  /* @@ -479,6 +480,17 @@ static int visor_probe(struct usb_serial *serial,  	dbg("%s", __func__); +	/* +	 * some Samsung Android phones in modem mode have the same ID +	 * as SPH-I500, but they are ACM devices, so dont bind to them +	 */ +	if (id->idVendor == SAMSUNG_VENDOR_ID && +		id->idProduct == SAMSUNG_SPH_I500_ID && +		serial->dev->descriptor.bDeviceClass == USB_CLASS_COMM && +		serial->dev->descriptor.bDeviceSubClass == +			USB_CDC_SUBCLASS_ACM) +		return -ENODEV; +  	if (serial->dev->actconfig->desc.bConfigurationValue != 1) {  		dev_err(&serial->dev->dev, "active config #%d != 1 ??\n",  			serial->dev->actconfig->desc.bConfigurationValue); | 
