diff options
| author | Greg Kroah-Hartman <gregkh@google.com> | 2021-04-07 13:34:18 +0200 | 
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@google.com> | 2021-04-07 13:34:18 +0200 | 
| commit | 816b5bcff6fe2e18ee7e30a300c13e1e97d51f23 (patch) | |
| tree | 440ad4885111bdc92d9ae4be4a400d763cf178d6 /drivers/usb/class/cdc-acm.c | |
| parent | 7a842f5f3a816a818dc89e4ec4cffb7a32a38543 (diff) | |
| parent | a0c646821e9dedc5368abd2f71f50ebe2c351d19 (diff) | |
Merge 4.4.265 into android-4.4-p
Changes in 4.4.265
	selinux: vsock: Set SID for socket returned by accept()
	ipv6: weaken the v4mapped source check
	ext4: fix bh ref count on error paths
	rpc: fix NULL dereference on kmalloc failure
	ASoC: rt5640: Fix dac- and adc- vol-tlv values being off by a factor of 10
	ASoC: rt5651: Fix dac- and adc- vol-tlv values being off by a factor of 10
	ASoC: sgtl5000: set DAP_AVC_CTRL register to correct default value on probe
	scsi: st: Fix a use after free in st_open()
	scsi: qla2xxx: Fix broken #endif placement
	staging: comedi: cb_pcidas: fix request_irq() warn
	staging: comedi: cb_pcidas64: fix request_irq() warn
	ext4: do not iput inode under running transaction in ext4_rename()
	appletalk: Fix skb allocation size in loopback case
	net: wan/lmc: unregister device when no matching device is found
	ALSA: usb-audio: Apply sample rate quirk to Logitech Connect
	ALSA: hda/realtek: call alc_update_headset_mode() in hp_automute_hook
	tracing: Fix stack trace event size
	mm: fix race by making init_zero_pfn() early_initcall
	reiserfs: update reiserfs_xattrs_initialized() condition
	pinctrl: rockchip: fix restore error in resume
	extcon: Fix error handling in extcon_dev_register
	firewire: nosy: Fix a use-after-free bug in nosy_ioctl()
	USB: quirks: ignore remote wake-up on Fibocom L850-GL LTE modem
	cdc-acm: fix BREAK rx code path adding necessary calls
	USB: cdc-acm: downgrade message to debug
	USB: cdc-acm: fix use-after-free after probe failure
	staging: rtl8192e: Fix incorrect source in memcpy()
	staging: rtl8192e: Change state information from u16 to u8
	Linux 4.4.265
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
Change-Id: I23368777e608080ef12898664935fe7394c5f40d
Diffstat (limited to 'drivers/usb/class/cdc-acm.c')
| -rw-r--r-- | drivers/usb/class/cdc-acm.c | 12 | 
1 files changed, 10 insertions, 2 deletions
| diff --git a/drivers/usb/class/cdc-acm.c b/drivers/usb/class/cdc-acm.c index 53d2f02e18a3..8c476a785360 100644 --- a/drivers/usb/class/cdc-acm.c +++ b/drivers/usb/class/cdc-acm.c @@ -334,8 +334,10 @@ static void acm_ctrl_irq(struct urb *urb)  			acm->iocount.dsr++;  		if (difference & ACM_CTRL_DCD)  			acm->iocount.dcd++; -		if (newctrl & ACM_CTRL_BRK) +		if (newctrl & ACM_CTRL_BRK) {  			acm->iocount.brk++; +			tty_insert_flip_char(&acm->port, 0, TTY_BREAK); +		}  		if (newctrl & ACM_CTRL_RI)  			acm->iocount.rng++;  		if (newctrl & ACM_CTRL_FRAMING) @@ -548,7 +550,8 @@ static void acm_port_dtr_rts(struct tty_port *port, int raise)  	res = acm_set_control(acm, val);  	if (res && (acm->ctrl_caps & USB_CDC_CAP_LINE)) -		dev_err(&acm->control->dev, "failed to set dtr/rts\n"); +		/* This is broken in too many devices to spam the logs */ +		dev_dbg(&acm->control->dev, "failed to set dtr/rts\n");  }  static int acm_port_activate(struct tty_port *port, struct tty_struct *tty) @@ -1499,6 +1502,11 @@ skip_countries:  	return 0;  alloc_fail8: +	if (!acm->combined_interfaces) { +		/* Clear driver data so that disconnect() returns early. */ +		usb_set_intfdata(data_interface, NULL); +		usb_driver_release_interface(&acm_driver, data_interface); +	}  	if (acm->country_codes) {  		device_remove_file(&acm->control->dev,  				&dev_attr_wCountryCodes); | 
