Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp494937yba; Mon, 1 Apr 2019 10:26:04 -0700 (PDT) X-Google-Smtp-Source: APXvYqxAJ1toRkxdzmy4Scnq35+991ue/+Q8Ccs1uXJUYoka2bw3uzWIPR3tOBkC0pgu/nTLTyCO X-Received: by 2002:a63:1247:: with SMTP id 7mr57050093pgs.352.1554139564547; Mon, 01 Apr 2019 10:26:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554139564; cv=none; d=google.com; s=arc-20160816; b=fPazQdNhyjio5mVvY+qe5G3Vj7QKOJGqT4r40ghRD9tQ/i6FUOsATWKJjkBfcrMiwX 7V9XlHrvawG1bMkJNTUsVxM7Ho+OfLdqRur/pFuXFBjz6XPLS6PHWVBK43xEaRzmtga0 THxq7Kv3rhWVIbKCHTznFE5MxSsGfP7qQrujtzWDmR+wRKcqdwXokkEcF/Epj0mBOLQR lBeLXr49gWm53pKDQWDmjxf8ZV8Gg4NWDaTm7xlKShUBbTB17tl+UKAl+I1+8pNECC4v aT2EHjgsW3F/unlXRKKg4ODUGKsT/TtunKrlIqURyGoc1m9OWpX4owO1mOFYM6PF+1kW PXPA== 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=agnOdBK+yiVKTW4WUTui7fnBMRAoIK8G4zS+b9Wv/KY=; b=uYqXsuEt8RDKHJF2oK9SEgu/qTjoTVNJLkdKasI925AhsS+XhgF5aMlCa6joACI2uf yfLWLdc07ODV2GPhYyySPdVXfvB6H6r9UXVtE+NeQGWi0JBz32a47xj0Dwwx2eesgzgB vB+nTqg8YyH6WMpLMx01Ihjgc3Xdi4b3SN3qsO8zEqyOTuYXXtRjH5UVUG36cksJVl4V 3TG/zLQbzmJ1+NTHJyzsrEd72lbHpo6qiPVzEppMr37cjXaiIJJKgydcXoaVpeX7j7GZ IK796hbQTXADMKrZVy2YHYWtXAd1iMstLMZPAbJJ9rk8xwiTZ3SUJX96zDNeUaI7tXZ/ fHWg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="TQM8AV8/"; 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 v16si9093837plo.33.2019.04.01.10.25.49; Mon, 01 Apr 2019 10:26:04 -0700 (PDT) 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="TQM8AV8/"; 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 S1732020AbfDARZS (ORCPT + 99 others); Mon, 1 Apr 2019 13:25:18 -0400 Received: from mail.kernel.org ([198.145.29.99]:56436 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732178AbfDARZQ (ORCPT ); Mon, 1 Apr 2019 13:25:16 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.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 3CB3A20830; Mon, 1 Apr 2019 17:25:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1554139515; bh=4hc8+VfxJq6ro2Pgz1M83a75L0RWYHRRuVZ8INshSzs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=TQM8AV8/NBSx1bxEktJlPj04HRJBXFoUuOlo7xBxcuAxpW40wIkrIt5H7URPFgXgX zLa+Izb3pE4p1snj4p6lvVXhlqF5ft1lMEKK4jgDx0gBLyWXFFmLOjGxCt3+yf2Tix WIqNGG4ByBYf1E52c680FyQJvxVNWjMWl4Bu0fxs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Romain Izard , Oliver Neukum Subject: [PATCH 4.14 099/107] usb: cdc-acm: fix race during wakeup blocking TX traffic Date: Mon, 1 Apr 2019 19:02:54 +0200 Message-Id: <20190401170054.703090718@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190401170045.246405031@linuxfoundation.org> References: <20190401170045.246405031@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.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Romain Izard commit 93e1c8a638308980309e009cc40b5a57ef87caf1 upstream. When the kernel is compiled with preemption enabled, the URB completion handler can run in parallel with the work responsible for waking up the tty layer. If the URB handler sets the EVENT_TTY_WAKEUP bit during the call to tty_port_tty_wakeup() to signal that there is room for additional input, it will be cleared at the end of this call. As a result, TX traffic on the upper layer will be blocked. This can be seen with a kernel configured with CONFIG_PREEMPT, and a fast modem connected with PPP running over a USB CDC-ACM port. Use test_and_clear_bit() instead, which ensures that each wakeup requested by the URB completion code will trigger a call to tty_port_tty_wakeup(). Fixes: 1aba579f3cf5 cdc-acm: handle read pipe errors Signed-off-by: Romain Izard Cc: stable Acked-by: Oliver Neukum Signed-off-by: Greg Kroah-Hartman --- drivers/usb/class/cdc-acm.c | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) --- a/drivers/usb/class/cdc-acm.c +++ b/drivers/usb/class/cdc-acm.c @@ -570,10 +570,8 @@ static void acm_softint(struct work_stru clear_bit(EVENT_RX_STALL, &acm->flags); } - if (test_bit(EVENT_TTY_WAKEUP, &acm->flags)) { + if (test_and_clear_bit(EVENT_TTY_WAKEUP, &acm->flags)) tty_port_tty_wakeup(&acm->port); - clear_bit(EVENT_TTY_WAKEUP, &acm->flags); - } } /*