Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp890036imu; Fri, 11 Jan 2019 10:52:26 -0800 (PST) X-Google-Smtp-Source: ALg8bN68etBvuZSZQ/ySU4SN9Wfz2Dm1Z9sTuZQ6h/Fw2NWaKgS1h9yHAA8QSiQbLzreQWVEZuZO X-Received: by 2002:a17:902:20e9:: with SMTP id v38mr15130770plg.250.1547232746283; Fri, 11 Jan 2019 10:52:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547232746; cv=none; d=google.com; s=arc-20160816; b=Xl7iv+vdqedSOkjaPPRgMBSIdQ1GxyuFioWzE9lSjeckg13i3oGPyT0CMK8IvKlF/T VImfzxmDdajbaOnlt2YRokBc7hW3wQ46Jfbc4JwzS4X/sfybsvKGz32WHEI5xxQH3YY2 92me2UYiOJpN8hNXJUcijniy1Btjnu8JPbYMJ3C/UutmuV+Qmv1MzYUsJNrfcJ56BsYk 25hCeoefJXv5uCtra1gcgxj5HIRLPD4zfqZMRM4ZsuCpWzT2FmO/IF/9y+cJo67mTNdt Gnvg0efBXYJ8DieqqzcW+tPpIVZc8YrLVBmO9w9/mgQLslHcvuwQfs0e6WARvpCgppMS Hu8A== 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=Pjlv/4pbspPTlurH3evT9d/BKnGP0k0PZ8svd3wybWQ=; b=Tls+5XLVXXqFUDfpZmp8+KRD9SOJ27hrp79EMcyK1376TBIMHkws+JMAaa92LHSCew GkKog9pU5gVA+KWHzzzmD0Qm63fqAXqNBk0VIsxfz5fg90fVzk8ZDca71LOL9cnslWUv QoCE+X8FtvP2f0pi6/kWMvAv0prC3hzo0Fbz7bnAJlbcnIJ9x41uckF3AlM7Y1dXh7SQ c3nQBRElpw1RsC6UkvB6d8U7QDMCTtaVhVgU2Zf40HR15WrKgQCSJGF0OtBn631rwmU2 CyTtpz+r7S5GciFQBFYxGW8HUNZu9MbjaoVJgfUnCEmoJTtiCcQSer/USiqbxSQTEa0a JuCQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=X1DACgPx; 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 q140si71382153pfc.20.2019.01.11.10.52.09; Fri, 11 Jan 2019 10:52:26 -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=X1DACgPx; 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 S2388043AbfAKOUE (ORCPT + 99 others); Fri, 11 Jan 2019 09:20:04 -0500 Received: from mail.kernel.org ([198.145.29.99]:37472 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731874AbfAKOUC (ORCPT ); Fri, 11 Jan 2019 09:20:02 -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 9D6E62177B; Fri, 11 Jan 2019 14:20:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1547216401; bh=+8bnEF3Qj6Vv9Ay0hcuuYFkwcWYH/2+Xe7fvK/GTWtg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=X1DACgPxvKaHKBXTSGFAEphdJ1yF5rdbMNPK2m8W9g/2RUxkSCc7j7R+Pt9wRa7sE urGmN2OOlmeMSGuksO68jLEJ0YeTWmZvuiM+OGPw3eP0gBSPv10zLkMoqY78NWtwOh geeNDDE7kiX2FqYLY7bGtRNbpgv3KgB7nowCkIy4= 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.4 49/88] cdc-acm: fix abnormal DATA RX issue for Mediatek Preloader. Date: Fri, 11 Jan 2019 15:08:18 +0100 Message-Id: <20190111131053.347555508@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190111131045.137499039@linuxfoundation.org> References: <20190111131045.137499039@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.4-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 @@ -507,6 +507,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; @@ -1677,6 +1684,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)