From patchwork Mon Aug 28 08:56:09 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Bhupinder Thakur X-Patchwork-Id: 9924881 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id D93BA60311 for ; Mon, 28 Aug 2017 08:59:32 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id C7D4428531 for ; Mon, 28 Aug 2017 08:59:32 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id BCF1C28682; Mon, 28 Aug 2017 08:59:32 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-3.6 required=2.0 tests=BAYES_00,DKIM_SIGNED, RCVD_IN_DNSWL_MED,RCVD_IN_SORBS_SPAM,T_DKIM_INVALID autolearn=ham version=3.3.1 Received: from lists.xenproject.org (lists.xenproject.org [192.237.175.120]) (using TLSv1.2 with cipher AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id 533C028671 for ; Mon, 28 Aug 2017 08:59:32 +0000 (UTC) Received: from localhost ([127.0.0.1] helo=lists.xenproject.org) by lists.xenproject.org with esmtp (Exim 4.84_2) (envelope-from ) id 1dmFrf-000663-Pb; Mon, 28 Aug 2017 08:57:47 +0000 Received: from mail6.bemta5.messagelabs.com ([195.245.231.135]) by lists.xenproject.org with esmtp (Exim 4.84_2) (envelope-from ) id 1dmFre-000640-PQ for xen-devel@lists.xenproject.org; Mon, 28 Aug 2017 08:57:46 +0000 Received: from [85.158.139.211] by server-10.bemta-5.messagelabs.com id 8E/E4-01732-A0BD3A95; Mon, 28 Aug 2017 08:57:46 +0000 X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFprLIsWRWlGSWpSXmKPExsXiVRtsoMt5e3G kwZ6dchbft0xmcmD0OPzhCksAYxRrZl5SfkUCa8aOjtcsBU2yFVe3L2ZsYHwj1sXIxSEkMJ1R 4kjvDLYuRk4OFoF5zBIT58eDJCQE+lklXi3ZwQiSkBBIk2if8JYdwq6W+LZvNzOILSSgJXH01 GxWiEn7mSQ23fsO5HBwsAmYSMzqkACpERFQkri3ajITiM0sUC+x7dwvRpASYYE8ic/nVSH2qk r0T20HG8kr4COxuX8P1Fo5iZvnOsHinEDxHWvvskOs9Zboev2BdQKjwAJGhlWM6sWpRWWpRbo WeklFmekZJbmJmTm6hgamermpxcWJ6ak5iUnFesn5uZsYgUHFAAQ7GA82Ox9ilORgUhLl3Vmx OFKILyk/pTIjsTgjvqg0J7X4EKMMB4eSBO+Zm0A5waLU9NSKtMwcYHjDpCU4eJREeD+ApHmLC xJzizPTIVKnGHU5Jh3Y/oVJiCUvPy9VSpz3IUiRAEhRRmke3AhYrF1ilJUS5mUEOkqIpyC1KD ezBFX+FaM4B6OSMO9BkCk8mXklcJteAR3BBHSEouBCkCNKEhFSUg2Mwszp55iyfL84fy2M/3v lzNltpVLnWoKWPbfacp09sdJMrGLjUsvf/Y8rbA4J/RCKZ6hmOWE+ldNqOfuy1dv3eYWe2RdQ wsjnb6XV3rXHcf8tebaL/I/nCzDK6l5rvuZ64yTXCpbQzcYejIJZ11bwXyr17KvdHBsa8rjb5 q6g68fL7xn4/u5QYinOSDTUYi4qTgQAgm3dW7ACAAA= X-Env-Sender: bhupinder.thakur@linaro.org X-Msg-Ref: server-11.tower-206.messagelabs.com!1503910664!88019028!1 X-Originating-IP: [74.125.83.48] X-SpamReason: No, hits=0.0 required=7.0 tests= X-StarScan-Received: X-StarScan-Version: 9.4.45; banners=-,-,- X-VirusChecked: Checked Received: (qmail 28547 invoked from network); 28 Aug 2017 08:57:45 -0000 Received: from mail-pg0-f48.google.com (HELO mail-pg0-f48.google.com) (74.125.83.48) by server-11.tower-206.messagelabs.com with AES128-GCM-SHA256 encrypted SMTP; 28 Aug 2017 08:57:45 -0000 Received: by mail-pg0-f48.google.com with SMTP id 83so22182263pgb.4 for ; Mon, 28 Aug 2017 01:57:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=ru488eqnUG9k+hwFsDMdo4vA5QD8i26TWlWnwk6dwgg=; b=LCs5SCbOnlnHiqHaMmZ6TPQlUpeQHYV2h/9YRnZ0rUqLZHUyp/7iF9XICGB/9vIYNW yh02KqLzfyb6o9JVqK6U2HhrcrIH9g62b+k9PZ2R+Zv/JUBHTZczIpanbQc2mhjhe4DC FB/878qwslj7on1gE55WR3UqELCtVUSmxtMr4= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=ru488eqnUG9k+hwFsDMdo4vA5QD8i26TWlWnwk6dwgg=; b=alW9hl8XVnber9mMY2uSJ7R9FTAiZyiEAVIMdDAWihQeoksp+33THRFgz5bhFP4YIB 20Gqh4vHc24En9FaBLQtgYQrrBqo9UTWQvHSuV+2H35A73fcgDWqfHp+b34ADGb1nUCK 4at/amhjGpkiFd5IFawClKwfZocDw8x0eTD61sAB6Tsqf0liUWJDP+avNvaFskQO/nkJ TQb/QnfLmrwe14Lhdx84b/Ziyk6e8f50RdWYZDJ5Um/9+fujuptFCaQ0UjA6qztEDvZ0 YfF97QyxgwxuT7kWlF6u/ovdccH9X553oQXnU6keYoNs1IPrngS/NP5pnz/SyaJHswYw PFsA== X-Gm-Message-State: AHYfb5gzQWytCM8ZBBLQAh5XnSD0fDzY9PK5ssgBhM3XjPTzGqxI8pZc efwg3AA1u3wIEzmcuC4AcA== X-Received: by 10.99.105.136 with SMTP id e130mr6898659pgc.422.1503910663630; Mon, 28 Aug 2017 01:57:43 -0700 (PDT) Received: from blr-ubuntu-linaro.wlan.qualcomm.com (blr-bdr-fw-01_globalnat_allzones-outside.qualcomm.com. [103.229.18.19]) by smtp.gmail.com with ESMTPSA id d88sm21713569pfl.158.2017.08.28.01.57.41 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Mon, 28 Aug 2017 01:57:43 -0700 (PDT) From: Bhupinder Thakur To: xen-devel@lists.xenproject.org Date: Mon, 28 Aug 2017 14:26:09 +0530 Message-Id: <1503910570-24427-27-git-send-email-bhupinder.thakur@linaro.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1503910570-24427-1-git-send-email-bhupinder.thakur@linaro.org> References: <1503910570-24427-1-git-send-email-bhupinder.thakur@linaro.org> Cc: Andre Przywara , Julien Grall , Stefano Stabellini Subject: [Xen-devel] [PATCH 26/27 v8] xen/arm: vpl011: Correct the logic for asserting/de-asserting SBSA UART TX interrupt X-BeenThere: xen-devel@lists.xen.org X-Mailman-Version: 2.1.18 Precedence: list List-Id: Xen developer discussion List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Errors-To: xen-devel-bounces@lists.xen.org Sender: "Xen-devel" X-Virus-Scanned: ClamAV using ClamSMTP This patch fixes the issue observed when pl011 patches were tested on the junos hardware by Andre/Julien. It was observed that when large output is generated such as on running 'find /', output was getting truncated intermittently due to OUT ring buffer getting full. This issue was due to the fact that the SBSA UART driver expects that when a TX interrupt is asserted then the FIFO queue should be atleast half empty and that it can write N bytes in the FIFO, where N is half the FIFO queue size, without the bytes getting dropped due to FIFO getting full. This requirement is as per section 3.4.2 of [1], which is: ------------------------------------------------------------------------------- UARTTXINTR If the FIFOs are enabled and the transmit FIFO reaches the programmed trigger level. When this happens, the transmit interrupt is asserted HIGH. The transmit interrupt is cleared by writing data to the transmit FIFO until it becomes greater than the trigger level, or by clearing the interrupt. ------------------------------------------------------------------------------- The SBSA UART fifo size is 32 bytes and so it expects that space for 16 bytes should be available when TX interrupt is asserted. The pl011 emulation logic was asserting the TX interrupt as soon as any space became available in the FIFO and the SBSA UART driver tried to write more data (upto 16 bytes) in the FIFO expecting that there is enough space available. The fix was to ensure that the TX interriupt is raised only when there is space available for 16 bytes or more in the FIFO. [1] http://infocenter.arm.com/help/topic/com.arm.doc.ddi0183f/DDI0183.pdf Signed-off-by: Bhupinder Thakur --- CC: Julien Grall CC: Andre Przywara CC: Stefano Stabellini xen/arch/arm/vpl011.c | 29 +++++++++++++++++++++++------ 1 file changed, 23 insertions(+), 6 deletions(-) diff --git a/xen/arch/arm/vpl011.c b/xen/arch/arm/vpl011.c index 56d9cbe..1e72fca 100644 --- a/xen/arch/arm/vpl011.c +++ b/xen/arch/arm/vpl011.c @@ -152,12 +152,20 @@ static void vpl011_write_data(struct domain *d, uint8_t data) else gprintk(XENLOG_ERR, "vpl011: Unexpected OUT ring buffer full\n"); - if ( xencons_queued(out_prod, out_cons, sizeof(intf->out)) == - sizeof (intf->out) ) - { - vpl011->uartfr |= TXFF; + /* + * Ensure that there is space for atleast 16 bytes before asserting the + * TXI interrupt status bit because the SBSA UART driver may write + * 16 bytes (i.e. half the SBSA UART fifo size of 32) on getting + * a TX interrupt. + */ + if ( xencons_queued(out_prod, out_cons, sizeof(intf->out)) <= + (sizeof (intf->out) - 16) ) + vpl011->uartris |= TXI; + else if ( xencons_queued(out_prod, out_cons, sizeof(intf->out)) != + sizeof (intf->out) ) vpl011->uartris &= ~TXI; - } + else + vpl011->uartfr |= TXFF; vpl011->uartfr |= BUSY; @@ -368,7 +376,16 @@ static void vpl011_data_avail(struct domain *d) if ( out_ring_qsize != sizeof(intf->out) ) { vpl011->uartfr &= ~TXFF; - vpl011->uartris |= TXI; + + /* + * Ensure that there is space for atleast 16 bytes before asserting the + * TXI interrupt status bit because the SBSA UART driver may write upto + * 16 bytes (i.e. half the SBSA UART fifo size of 32) on getting + * a TX interrupt. + */ + if ( out_ring_qsize <= (sizeof(intf->out) - 16) ) + vpl011->uartris |= TXI; + if ( out_ring_qsize == 0 ) { vpl011->uartfr &= ~BUSY;