Received: by 2002:a05:6520:4d:b0:139:a872:a4c9 with SMTP id i13csp2565550lkm; Mon, 20 Sep 2021 18:51:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzGTh1UkImwFrPsHemEGfjpsk7uiG4/k8fVPGVX5uJglAblI7oqr+/t1IsBcmHHghtMHiHd X-Received: by 2002:a92:b301:: with SMTP id p1mr18796532ilh.10.1632188993301; Mon, 20 Sep 2021 18:49:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632188993; cv=none; d=google.com; s=arc-20160816; b=cbdUGNyYWBLQ4BwFvCuzJfrDnlw/mkrJo1rYjaNuUJ/e10muzIrfLn7Fk++fG6LYjH AiOu6iHKBxRj/Z3+COzlJ6SphNyeQMX4goIUpt2Z7Nura8Dse6JGXeK6nRAEBMYXbVoB u7Yo18DTFJL757zS/yWmMQHv3mOnryVL79nnK4GhVgQ2BNT3ap8JOI0tloxOHQgMMq8U wrISwmIJ28L3IMqYaRca3Ub0XC5nIkY4YoeXCQEzdDLi8qKn0mQTGYuxZJeLLp/Sx+rY KwPW6Uk5CUhg7A6sAzlL5IYqYfcYltTR9eAikOPaBZjQSzoJ0Mp68D3yEwA1M064G8ot nqUQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=MafM3NGewcp82w6Rk1MLXmGJdt+AaXMeVFQcecEd+nQ=; b=evr8TSKEluXTfACEBTYP3Dd8bRhNDuV4zjTjhmXREw90REuACF7GF5wwn+xZoh9BdZ fe+kyM8Vz0nMI7IFX7wpqp7oQTnLhIa5udeEtrdmwxusSo9N8E6fRQMxNk9jDlHpXZZx rOR2ydAG/Wu7Z5N16XIIg4/LFEvOjxt+MeRQMh4s9mAcMxo82sfDxywOKHMCgaZlVwrR T3s7ZbzLp8vCweOGSJnJ+GZt3nG3u9wgIGeZWCYxO7ODN4gKJFYx/BDTWLQvxNvb5KSz aTVDAbTIULyVe/CSChz+GknksLfhTelRMrcSArwq9KdX7aXLCgIa/sOPa+fGIno91dko yV/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Ssea8KPw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s26si15540928iov.21.2021.09.20.18.49.42; Mon, 20 Sep 2021 18:49:53 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Ssea8KPw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1355525AbhITRy7 (ORCPT + 99 others); Mon, 20 Sep 2021 13:54:59 -0400 Received: from mail.kernel.org ([198.145.29.99]:52986 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345985AbhITRtD (ORCPT ); Mon, 20 Sep 2021 13:49:03 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 5B52761BC2; Mon, 20 Sep 2021 17:11:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1632157885; bh=xe70vIt72YFdj5RAjDRRzRRdgCGG+uduzHGLstwLBsU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Ssea8KPwdGQtTncCYp4Yr1xPKuVvVkPL9DLYgp3DNIlbyIBA4+WGv1wkhO42Cq5VH fiq8jaSSqko0AzKwXdY5io2WduG7GHGOXsUsikcDc1fmKDc9o8vhALb02IZXF6UlRt Cjrc5i9h6rXfa2ACcp/0dX7YEiVv9oAzPRa9qrHA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Maciej W. Rozycki" , Sasha Levin Subject: [PATCH 4.19 196/293] serial: 8250: Define RX trigger levels for OxSemi 950 devices Date: Mon, 20 Sep 2021 18:42:38 +0200 Message-Id: <20210920163939.978178012@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210920163933.258815435@linuxfoundation.org> References: <20210920163933.258815435@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Maciej W. Rozycki [ Upstream commit d7aff291d069c4418285f3c8ee27b0ff67ce5998 ] Oxford Semiconductor 950 serial port devices have a 128-byte FIFO and in the enhanced (650) mode, which we select in `autoconfig_has_efr' with the ECB bit set in the EFR register, they support the receive interrupt trigger level selectable with FCR bits 7:6 from the set of 16, 32, 112, 120. This applies to the original OX16C950 discrete UART[1] as well as 950 cores embedded into more complex devices. For these devices we set the default to 112, which sets an excessively high level of 112 or 7/8 of the FIFO capacity, unlike with other port types where we choose at most 1/2 of their respective FIFO capacities. Additionally we don't make the trigger level configurable. Consequently frequent input overruns happen with high bit rates where hardware flow control cannot be used (e.g. terminal applications) even with otherwise highly-performant systems. Lower the default receive interrupt trigger level to 32 then, and make it configurable. Document the trigger levels along with other port types, including the set of 16, 32, 64, 112 for the transmit interrupt as well[2]. [1] "OX16C950 rev B High Performance UART with 128 byte FIFOs", Oxford Semiconductor, Inc., DS-0031, Sep 05, Table 10: "Receiver Trigger Levels", p. 22 [2] same, Table 9: "Transmit Interrupt Trigger Levels", p. 22 Signed-off-by: Maciej W. Rozycki Link: https://lore.kernel.org/r/alpine.DEB.2.21.2106260608480.37803@angie.orcam.me.uk Signed-off-by: Greg Kroah-Hartman Signed-off-by: Sasha Levin --- drivers/tty/serial/8250/8250_port.c | 3 ++- include/uapi/linux/serial_reg.h | 1 + 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/tty/serial/8250/8250_port.c b/drivers/tty/serial/8250/8250_port.c index 68f71298c11b..39e821d6e537 100644 --- a/drivers/tty/serial/8250/8250_port.c +++ b/drivers/tty/serial/8250/8250_port.c @@ -132,7 +132,8 @@ static const struct serial8250_config uart_config[] = { .name = "16C950/954", .fifo_size = 128, .tx_loadsz = 128, - .fcr = UART_FCR_ENABLE_FIFO | UART_FCR_R_TRIG_10, + .fcr = UART_FCR_ENABLE_FIFO | UART_FCR_R_TRIG_01, + .rxtrig_bytes = {16, 32, 112, 120}, /* UART_CAP_EFR breaks billionon CF bluetooth card. */ .flags = UART_CAP_FIFO | UART_CAP_SLEEP, }, diff --git a/include/uapi/linux/serial_reg.h b/include/uapi/linux/serial_reg.h index be07b5470f4b..f51bc8f36813 100644 --- a/include/uapi/linux/serial_reg.h +++ b/include/uapi/linux/serial_reg.h @@ -62,6 +62,7 @@ * ST16C654: 8 16 56 60 8 16 32 56 PORT_16654 * TI16C750: 1 16 32 56 xx xx xx xx PORT_16750 * TI16C752: 8 16 56 60 8 16 32 56 + * OX16C950: 16 32 112 120 16 32 64 112 PORT_16C950 * Tegra: 1 4 8 14 16 8 4 1 PORT_TEGRA */ #define UART_FCR_R_TRIG_00 0x00 -- 2.30.2