Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3534451imu; Mon, 7 Jan 2019 05:14:02 -0800 (PST) X-Google-Smtp-Source: ALg8bN7htWAtinUwjQOEIdttme25E3r2HXidxLcT+FZHZwCZ1fvVa90edpuS0rMxCar/FE5cN02z X-Received: by 2002:a63:160d:: with SMTP id w13mr11121743pgl.43.1546866842433; Mon, 07 Jan 2019 05:14:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546866842; cv=none; d=google.com; s=arc-20160816; b=L9cEgLplB6uHDN+LiXJdaw6UCOqPJY8hdFmhwopDCQhQ/1qjmH/g1G/gKEU9Y0r5dy i58jXU0UDcnBziupglU23rjinhHCw9YN3QxQvhGj9vl5vYiVsY3tfwx7er0JXthy46r9 LIkEur70ageQPK3viFXdp9yMLI2/maaxA16hus+34sQ/xrHYHiIkIdfxSMXFvLds9EFx NNwCm3Vd8MB1TO9BKAB/TCEHVF8CyM+fL0w8hKiyjv9ynRorZ6WT/SIlux6AYqyPsm2D p+3rb+S9lKYqu1iAPdZUrKGlskw5bLR5OIj+wGSd39huan9WR6ywIY/lr81NbOg8BL4T MSyg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=XcTigjcHLH7MnXP/RBC86o3BQu6Rcql84T7n6wPZwOg=; b=n4g3L5C+i3I+eoIx3/25oiSRgcxF3GI/1LUGc4wkKaIzaFceKIC9VRlpM/hc6rzRni r/TvUrmkq6nlVC4krpYYlrL3Kc36ZAPZKJtngV6npXgyFJZEoYWmo7ifc0njO8L5xNjN Zj8XiruyAKjAu+LRdbXGVvwlO2bz4cFSfCMkHyxxHYH55UGCvQuvh8T2sgHDvnb+gDNB bz2hz9xDkL12EHWsD6Nmj4dyCuGW/Q6Vo4i+DZ79HvOmIile+wIp1McEcIiUt82cfcJC MMWkf0t5zrU9haYRax5ZHJJX8sa8NtoZR0Gz81koy/N4rGyse6vv/GhHlwZl/+9EVw/Y hPzQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="Rj5/QdMm"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c81si7136036pfc.82.2019.01.07.05.13.47; Mon, 07 Jan 2019 05:14:02 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="Rj5/QdMm"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731689AbfAGNIk (ORCPT + 99 others); Mon, 7 Jan 2019 08:08:40 -0500 Received: from mail.kernel.org ([198.145.29.99]:55732 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731538AbfAGNIj (ORCPT ); Mon, 7 Jan 2019 08:08:39 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 2445221855; Mon, 7 Jan 2019 13:08:36 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1546866517; bh=w6l8LXZK16/fQ1LJ8myXy6nLkRP8r+2G2SttO1sv28c=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Rj5/QdMmMem6JnD+zYR3RFhwcNiY6QcunQ1WWarIfzz8hAnYs36FSWkkk/NCMNhv8 wPQaq1lR4su1BptavW1is9V/lxIKRE1KBRtQHv/sqHS4yrh8nBpVssDdAIt0qBtcah dXj0dMZpedqRpjSqANM+dkwktv/GoMog8dPs3aog= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Macpaul Lin , Johan Hovold , Oliver Neukum Subject: [PATCH 4.9 56/71] cdc-acm: fix abnormal DATA RX issue for Mediatek Preloader. Date: Mon, 7 Jan 2019 13:33:25 +0100 Message-Id: <20190107105335.920025127@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190107105330.280153213@linuxfoundation.org> References: <20190107105330.280153213@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.9-stable review patch. If anyone has any objections, please let me know. ------------------ From: Macpaul Lin commit eafb27fa5283599ce6c5492ea18cf636a28222bb upstream. Mediatek Preloader is a proprietary embedded boot loader for loading Little Kernel and Linux into device DRAM. This boot loader also handle firmware update. Mediatek Preloader will be enumerated as a virtual COM port when the device is connected to Windows or Linux OS via CDC-ACM class driver. When the USB enumeration has been done, Mediatek Preloader will send out handshake command "READY" to PC actively instead of waiting command from the download tool. Since Linux 4.12, the commit "tty: reset termios state on device registration" (93857edd9829e144acb6c7e72d593f6e01aead66) causes Mediatek Preloader receiving some abnoraml command like "READYXX" as it sent. This will be recognized as an incorrect response. The behavior change also causes the download handshake fail. This change only affects subsequent connects if the reconnected device happens to get the same minor number. By disabling the ECHO termios flag could avoid this problem. However, it cannot be done by user space configuration when download tool open /dev/ttyACM0. This is because the device running Mediatek Preloader will send handshake command "READY" immediately once the CDC-ACM driver is ready. This patch wants to fix above problem by introducing "DISABLE_ECHO" property in driver_info. When Mediatek Preloader is connected, the CDC-ACM driver could disable ECHO flag in termios to avoid the problem. Signed-off-by: Macpaul Lin Cc: stable@vger.kernel.org Reviewed-by: Johan Hovold Acked-by: Oliver Neukum Signed-off-by: Greg Kroah-Hartman --- drivers/usb/class/cdc-acm.c | 10 ++++++++++ drivers/usb/class/cdc-acm.h | 1 + 2 files changed, 11 insertions(+) --- a/drivers/usb/class/cdc-acm.c +++ b/drivers/usb/class/cdc-acm.c @@ -502,6 +502,13 @@ static int acm_tty_install(struct tty_dr if (retval) goto error_init_termios; + /* + * Suppress initial echoing for some devices which might send data + * immediately after acm driver has been installed. + */ + if (acm->quirks & DISABLE_ECHO) + tty->termios.c_lflag &= ~ECHO; + tty->driver_data = acm; return 0; @@ -1620,6 +1627,9 @@ static const struct usb_device_id acm_id { USB_DEVICE(0x0e8d, 0x0003), /* FIREFLY, MediaTek Inc; andrey.arapov@gmail.com */ .driver_info = NO_UNION_NORMAL, /* has no union descriptor */ }, + { USB_DEVICE(0x0e8d, 0x2000), /* MediaTek Inc Preloader */ + .driver_info = DISABLE_ECHO, /* DISABLE ECHO in termios flag */ + }, { USB_DEVICE(0x0e8d, 0x3329), /* MediaTek Inc GPS */ .driver_info = NO_UNION_NORMAL, /* has no union descriptor */ }, --- a/drivers/usb/class/cdc-acm.h +++ b/drivers/usb/class/cdc-acm.h @@ -134,3 +134,4 @@ struct acm { #define QUIRK_CONTROL_LINE_STATE BIT(6) #define CLEAR_HALT_CONDITIONS BIT(7) #define SEND_ZERO_PACKET BIT(8) +#define DISABLE_ECHO BIT(9)