From patchwork Tue May 21 15:45:44 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Erwan Le Ray X-Patchwork-Id: 164736 Delivered-To: patch@linaro.org Received: by 2002:a92:9e1a:0:0:0:0:0 with SMTP id q26csp1768629ili; Tue, 21 May 2019 08:47:05 -0700 (PDT) X-Google-Smtp-Source: APXvYqwngOuZNkxDiw/Lf7eq8n6KXI0YFlDLGWUKp4FwwfwWpwM4PFDZEV8+h3PLSwxHw4r08tqD X-Received: by 2002:a62:2687:: with SMTP id m129mr89927800pfm.204.1558453625797; Tue, 21 May 2019 08:47:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558453625; cv=none; d=google.com; s=arc-20160816; b=byyXg+cQYnUmx4ila6XenwJz2plnfwVzrPY0se8m6RBQxo+/aCbiqmWFb0l23bcfCo /IpNLfk4iNykMLVkNHnnujCjxWWeTVJsqEqMlbkQa+ePo8BUMEFIYxdqV7QpTxiLAONK WysSlZCwbiYPOJCyAd/Bj2GD4Z1wsDX+97u4HkCfIyA7UpomtGEpDsVo8aZZtmSv/X1J UALOXtvsGSqdVqimG1AufWFOgkkpfstX9fLsmX5jx4O/G6xhfQwOVDxZ4X6C796ayU7D aNcah8GqO1Bu0V9bLg5T/ca5Bc8rj+SlZP0PLbnfCyTlKNWLHXpe60MwfZ5DgitHFqjw 60Dw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:dkim-signature; bh=mnC1Tndm9L/rYWC+Exy6JcO/o527PKiqdOEVN3qIE3I=; b=zbjSbMO0ns8NmdtR83bqemoIS9tOkOj32ELh9+ypO/YzShLGMTNt0kwHGvNDDe/L6Q yDgqmMZgg1+Tm+Ch2ABxZWTZXLFuA0cBQJIWs8V01KUv39GICdH1R51bGiW3mECAzJM6 zf3o8DBJBcD+o8ALaig1F/ellkFmr48oNMFDvMgaGePTM0e8tGYWH9akEOdZaoBjML7C hgbXE33LH9FBGkgz+Yhl4gJS/vcckpDxVw1mt8vsxrG/u2pH/7dHnDg6ru3l3BhAFk3R 7QfQZxsIrsdA2gr+2y9uywDFg6s8jJcdpQRR7iwKhsBml10NHLP4KO0SpgP85XGqm0r7 gYgQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@st.com header.s=STMicroelectronics header.b="x7iZq/YO"; 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 f15si22415425pgu.218.2019.05.21.08.47.05; Tue, 21 May 2019 08:47:05 -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=@st.com header.s=STMicroelectronics header.b="x7iZq/YO"; 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 S1728972AbfEUPrE (ORCPT + 30 others); Tue, 21 May 2019 11:47:04 -0400 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:35384 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728212AbfEUPrB (ORCPT ); Tue, 21 May 2019 11:47:01 -0400 Received: from pps.filterd (m0046668.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.27/8.16.0.27) with SMTP id x4LFkWKs028109; Tue, 21 May 2019 17:46:40 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=st.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-type; s=STMicroelectronics; bh=mnC1Tndm9L/rYWC+Exy6JcO/o527PKiqdOEVN3qIE3I=; b=x7iZq/YOx7XmcpuNBtN9o2vRciBsnMIWprSj+kBleFZz3XcOv6l0rFFN3hIw6Hw1ZX4+ 0CmJenbit3dUskHSbxzzKAX0ArK15M1iJEjEZEPc5n8X6oZQH41QH3lO5kvClsxFztOv kNPS0uXmSYqufj/CUf00AXcEm6D7S6l8Q5Q6e8eJ9QwirrT3MULnwPZPO9Mw2/3UjNJn pCShOAXHniWrFgLLlWUUJP3sidL1uAnaD9kLj+vd/c5CVwvyCc7T+QsWPW9xWREMV4aS R08XkUXHG4oXowZxK8+eHKqvqdE33wWjZPpEj+JEck2/VUk6MPp5sFjsZ56D+lFoe1ux Vg== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 2sj7h0tky3-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Tue, 21 May 2019 17:46:40 +0200 Received: from zeta.dmz-eu.st.com (zeta.dmz-eu.st.com [164.129.230.9]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 54A9534; Tue, 21 May 2019 15:46:39 +0000 (GMT) Received: from Webmail-eu.st.com (Safex1hubcas22.st.com [10.75.90.92]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 3CE182CEB; Tue, 21 May 2019 15:46:39 +0000 (GMT) Received: from SAFEX1HUBCAS23.st.com (10.75.90.46) by Safex1hubcas22.st.com (10.75.90.92) with Microsoft SMTP Server (TLS) id 14.3.439.0; Tue, 21 May 2019 17:46:39 +0200 Received: from localhost (10.201.23.31) by webmail-ga.st.com (10.75.90.48) with Microsoft SMTP Server (TLS) id 14.3.439.0; Tue, 21 May 2019 17:46:38 +0200 From: Erwan Le Ray To: Greg Kroah-Hartman , Jiri Slaby , Maxime Coquelin , "Alexandre Torgue" CC: , , , , "Erwan Le Ray" , Fabrice Gasnier Subject: [PATCH 4/7] serial: stm32: fix transmit_chars when tx is stopped Date: Tue, 21 May 2019 17:45:44 +0200 Message-ID: <1558453547-22866-5-git-send-email-erwan.leray@st.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1558453547-22866-1-git-send-email-erwan.leray@st.com> References: <1558453547-22866-1-git-send-email-erwan.leray@st.com> MIME-Version: 1.0 X-Originating-IP: [10.201.23.31] X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:, , definitions=2019-05-21_03:, , signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Disables the tx irq when the transmission is ended and updates stop_tx conditions for code cleanup. Fixes: 48a6092fb41f ("serial: stm32-usart: Add STM32 USART Driver") Signed-off-by: Erwan Le Ray -- 1.9.1 diff --git a/drivers/tty/serial/stm32-usart.c b/drivers/tty/serial/stm32-usart.c index 0a7953e..2e7757d 100644 --- a/drivers/tty/serial/stm32-usart.c +++ b/drivers/tty/serial/stm32-usart.c @@ -420,13 +420,8 @@ static void stm32_transmit_chars(struct uart_port *port) return; } - if (uart_tx_stopped(port)) { - stm32_stop_tx(port); - return; - } - - if (uart_circ_empty(xmit)) { - stm32_stop_tx(port); + if (uart_circ_empty(xmit) || uart_tx_stopped(port)) { + stm32_clr_bits(port, ofs->cr1, USART_CR1_TXEIE); return; } @@ -439,7 +434,7 @@ static void stm32_transmit_chars(struct uart_port *port) uart_write_wakeup(port); if (uart_circ_empty(xmit)) - stm32_stop_tx(port); + stm32_clr_bits(port, ofs->cr1, USART_CR1_TXEIE); } static irqreturn_t stm32_interrupt(int irq, void *ptr)