Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp5950553ybv; Wed, 12 Feb 2020 03:20:09 -0800 (PST) X-Google-Smtp-Source: APXvYqzD8KmtUA6XG2bF8grfboTdw8ANjLtkDGNTXSHoYfE85pHwScWOv0jyFYwG+RIZFjYbwnyl X-Received: by 2002:aca:c401:: with SMTP id u1mr5888238oif.62.1581506409513; Wed, 12 Feb 2020 03:20:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581506409; cv=none; d=google.com; s=arc-20160816; b=tClAIu93TWZ6Esw+rPDOLPpzUVUzjBml9JSaMBSj1d8SVSHLCDjNa8QjD3aNv27GW7 ZfZ6fRwQ3GZzJeRcxpRLeZPYVIfnTMP2LycbS2y7ZztuX8uZQYI4CZ5txKkD/LQWV3gO 8XnJC0z0nfhzEbSOSy43QLNHhsm/vUT6eAHvRzKjRI3Tpcy3f9tvxwKAVYBq52d7L0vW cL4TrQjXXqQgLB7hLVFATIy2aCFx7jH3LgvFGPvs4md8xlVkn/PwpBuXYCpaad8Ycj3u 6WdJIdEBhzPJE3Xtd93eO6Zo6IEd3O1x8GiJcDfAfUt7yRikZpx0r/itNEWyN0AGERoJ ioEw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=HTAbsiExrv4QW5/STpGu+6w7JGxPZpOjJdCEoGEBulE=; b=bVX+uHXvEMYlUK5mWhD7SeP2ZCxnkCnojDfuu/byTwTuKGBpamKjZxQU49SLR2k0he YbniGwLbs+I1HB2lv0yu5yLgyk8k4WVXjoIYESEnPTvhHCpgmfKEeLq1HJ5bDhLAHE/c NvL78+9WvPvC9tbtJc936lli1f+01c9sewVmKAs8V4JOoIDTIEXZusTgoQhWkzab8Y7k 3stsNEdCMHxw4W2AsLMJsOwew3S90lTLOTYXoLvK8QU/XkMzuRde+KLMy+BJp+12XIJ5 a2XcIYCp1/6xy/tNdsfLS9QpKm9j9/s9eNVl5z2RQuQpbjwWRC9rszock5dDWjt62V3Y D7mg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=asC2bVXd; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o7si3022239oie.265.2020.02.12.03.19.51; Wed, 12 Feb 2020 03:20:09 -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=@gmail.com header.s=20161025 header.b=asC2bVXd; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727567AbgBLLTh (ORCPT + 99 others); Wed, 12 Feb 2020 06:19:37 -0500 Received: from mail-wm1-f65.google.com ([209.85.128.65]:51797 "EHLO mail-wm1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727007AbgBLLTh (ORCPT ); Wed, 12 Feb 2020 06:19:37 -0500 Received: by mail-wm1-f65.google.com with SMTP id t23so1753498wmi.1; Wed, 12 Feb 2020 03:19:36 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=HTAbsiExrv4QW5/STpGu+6w7JGxPZpOjJdCEoGEBulE=; b=asC2bVXdzvBx2cv631MWiOZTxgICbuneQqKi8jfIo5dqiZz0iQBe81K/qJOaxhm6Rs 3Zw+GgWiVagyFqB07np+5rwwcH598FjsDyOChfSCPUsoC8IlWL5MusYCKHfZ+NSBG0Uy 8Ypisw0s6+NJL73FtztJHvi84kXMdy+QLlq48H69RO5NeSFhgGpfv3uJY8ogDRPNQPl0 CICVXNayohk4XXsQiP59rNGzOnXzIXcGr2JAf3fuQyj9ke8nBLUgWXwgY+v5u3RU9BD6 Cp15qkrpgkjyEf4QKF83kFQBXnlnKZzzQk/0jaTeWhf+Pp/kzC1qCCWs9MZhScTZaWel KMoA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=HTAbsiExrv4QW5/STpGu+6w7JGxPZpOjJdCEoGEBulE=; b=qDxEhOcnuCD6GF9rF4fa20WIQ0xb8+nKVllb8VTR5OHQTUw/uuN4ed6v/uEzU3xWTe BxtmRzrMxjKAmvkxh7zr/IVaY9ps/KSIrFclkrEOrdJ/vxkxw27LewIxS1mmbSwrrYPK 5M5fadGYnEd7ZoxsY0MoK8UwY/kL0JloyQ666Usj64znv+c5G9yXMSzDo1O8DGwXHhAO e75qm4GnwRvji4rAAqoa2tUGj1BoArQdO5T3+aPggTAyzWJOiyVP54YaTu2ILwsItfQg esT3UVitLnPsJBRrB+iBcL1bJS6JI+zeY/kushlrAaitHP0/gkFNg36jakDt94OcQY61 6YXw== X-Gm-Message-State: APjAAAUr/V6nkLzVAy9qH7b2akyAPSDI1tU6GU/gfGrl3pUr9MUpAcZq k0nUf/NGXs3U0E5CcdVJEcg= X-Received: by 2002:a7b:c216:: with SMTP id x22mr12685206wmi.51.1581506375637; Wed, 12 Feb 2020 03:19:35 -0800 (PST) Received: from [192.168.2.41] ([46.227.18.67]) by smtp.gmail.com with ESMTPSA id m21sm300439wmi.27.2020.02.12.03.19.34 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 12 Feb 2020 03:19:34 -0800 (PST) Subject: Re: [PATCH] tty/serial: atmel: manage shutdown in case of RS485 or ISO7816 mode To: Nicolas Ferre , Greg Kroah-Hartman , linux-serial@vger.kernel.org Cc: Alexandre Belloni , Ludovic Desroches , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Codrin Ciubotariu References: <20200210152053.8289-1-nicolas.ferre@microchip.com> From: Richard Genoud Message-ID: Date: Wed, 12 Feb 2020 12:19:18 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.4.1 MIME-Version: 1.0 In-Reply-To: <20200210152053.8289-1-nicolas.ferre@microchip.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Le 10/02/2020 à 16:20, Nicolas Ferre a écrit : > In atmel_shutdown() we call atmel_stop_rx() and atmel_stop_tx() functions. > Prevent the rx restart that is implemented in RS485 or ISO7816 modes when > calling atmel_stop_tx() by using the atomic information tasklet_shutdown > that is already in place for this purpose. > > Fixes: 98f2082c3ac4 ("tty/serial: atmel: enforce tasklet init and termination sequences") > Signed-off-by: Nicolas Ferre Acked-by: Richard Genoud > --- > drivers/tty/serial/atmel_serial.c | 3 ++- > 1 file changed, 2 insertions(+), 1 deletion(-) > > diff --git a/drivers/tty/serial/atmel_serial.c b/drivers/tty/serial/atmel_serial.c > index c15c398c88a9..a39c87a7c2e1 100644 > --- a/drivers/tty/serial/atmel_serial.c > +++ b/drivers/tty/serial/atmel_serial.c > @@ -570,7 +570,8 @@ static void atmel_stop_tx(struct uart_port *port) > atmel_uart_writel(port, ATMEL_US_IDR, atmel_port->tx_done_mask); > > if (atmel_uart_is_half_duplex(port)) > - atmel_start_rx(port); > + if (!atomic_read(&atmel_port->tasklet_shutdown)) > + atmel_start_rx(port); > > } > >