Received: by 2002:ab2:620c:0:b0:1ef:ffd0:ce49 with SMTP id o12csp755017lqt; Tue, 19 Mar 2024 02:53:50 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUXb4N3/frbSnAK3kE3Vpa58QQMjxkoWqSzuCwCIOkV/n4GPjiIGT+f2Fpmiq6xLwz/wTdo2eLz/BdLKWqgXtyL4kE5m+Byd0Hfhq/15w== X-Google-Smtp-Source: AGHT+IEABHHSkdnag9Hg91yBbvpu5IJFHy+fmwTWwc55nJm6NaDoLCkrLrSUjAU9q0u/HkfBOeYs X-Received: by 2002:a17:907:5cb:b0:a46:c56f:fe39 with SMTP id wg11-20020a17090705cb00b00a46c56ffe39mr3461306ejb.39.1710842030792; Tue, 19 Mar 2024 02:53:50 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710842030; cv=pass; d=google.com; s=arc-20160816; b=vUpBXGDlBZ690GmakAOIJVYWnnqkrU2PchL8pwxNuDe5ORgMxB6qBNL5nkiOfjHmZf AZHX9y/BWir4EJVIwAvqU9VKenm1UPr8YEEtMUFG8DqV72fgpwQkOocOj8Elb29rwxDj 0N3qxyb14SADyqCTpmsE3Iod/+stsyc0vVyDFXv5el8+ikHgPYeeECcI5O0hNj4j5pJq SDTZd1dBClaoKgsm8dDJcQTJF23uuVfH4LmflHDXUFsRLMkFMiKu0In/6gAhK/w2ilHb 4FS1Oyknc29Q9Edp4ws7jGw1KQJZIGVe1WYIeqhqG0pWQ6V52s+N4tJOTifu49n3IuA2 0NSA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from:dkim-signature; bh=Jd3caB16kfKvEUvYRhJLpfSt6qSfDDoPgTkca0ySu8w=; fh=8sw0ML7Uqx9UzK/qHb4E8SC9p45i4XUf+uHIjhvifBE=; b=gcw57y9rj5fAqvmCKIhsxRWVRCm03YhkHkIoqz7n8Qd5QUiUC7fIkSh7vJwQZu5WEJ laJGcDwTnCrimytCZyjhpHHE4ZHZy+Q1B3E1kXdQxSvsvrib24Q/qszkm36xmI6WpKOy q5d6RsXY7clNLPV0ToXzQ3Kj4FwbxZfLbkyMR1k+9M6TukDXrGP6uSCLjhTyuXoja7GY R9f/7In6Ek8KQ8HuEHNghKJnmSR1fhoQG7UW7O+gkI25bbCwFHJT5FE+1Jf1yeybryNG 1E5sR4Gv7V1FvsoVyXuLYQ9lPIXF2MthOz0DYPf6UecnwX2C6lPkuI9ksmKh9heqZSnV MbuQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=OGizSRYd; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-107332-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-107332-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [2604:1380:4601:e00::3]) by mx.google.com with ESMTPS id nc40-20020a1709071c2800b00a45f83050a5si5618022ejc.1006.2024.03.19.02.53.50 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Mar 2024 02:53:50 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-107332-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) client-ip=2604:1380:4601:e00::3; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=OGizSRYd; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-107332-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-107332-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 632821F226E3 for ; Tue, 19 Mar 2024 09:53:50 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 6839D7D41B; Tue, 19 Mar 2024 09:53:30 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="OGizSRYd" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 29A127D083; Tue, 19 Mar 2024 09:53:28 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710842009; cv=none; b=X101GlxGEzS86pcPvQ29m+3PTOZbSfTJWbYqPjD0NiaalDf9bwYtPwZGpfRq9+trVu6a4BeKDCnk4To5RKIBAaE4tMVG8hcUHWbr3qCcsXUvwQcM2iwvrcN9RqqJOBn/Kk8l5bmnBlJyu/bYLwxdLhlqQ8SpYe9hRKB9yUbOhh8= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710842009; c=relaxed/simple; bh=ai0U2zh0od3mIZWy2eSqdoVTkokovEgyzUxpISIiZ7Q=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version:Content-Type; b=rXvZ8vxFlmBQD64RYl7EYJBG/tnvnYMHxdzpaiy6+p1rFvGRRoaS6Q4ZaKPs11stygWqxvZjVZtBDqgwfW2+7DD8elUQBR5rTHgTY1LSH8z5Y+F+eBzWeG3djGhTzXZ8ZiFl76BI22CgYucsBVyuosuHNJHNVYaU1B8GTRciFFo= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=OGizSRYd; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 320E8C43390; Tue, 19 Mar 2024 09:53:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1710842008; bh=ai0U2zh0od3mIZWy2eSqdoVTkokovEgyzUxpISIiZ7Q=; h=From:To:Cc:Subject:Date:From; b=OGizSRYd4Dt2lxl4soBg5WoJ+adA/2jX4E2a5JOsSA9V9OZ4is/tXnnNlo9Y1tHQW K/vGAF2iFcOVfkpMeKFF3u6/RwBV0G1Gg+PYPkO4miEuzIcQZ2seSd2b1Hx20LKhsj CvEv99RJ4UUkgEGDABwEOgFmHMi5TgA3IaEdP/hv1iq1jc7f2zJ9zs8Jc11Y/oQgTf ABirlSDmm6oOoYx83oht/L71/YC1NdESe8b3jgviAUCn3gHX6AUupeH9SUVbNw0MK+ ysie6fH0jEz65NWHe2vS1tE3p4hK7iT+/ysrJ7hXzy6tuOr6AVCJ2pvZr/Y5ylbTHP AadAssOLVrSEw== From: "Jiri Slaby (SUSE)" To: linux-serial@vger.kernel.org Cc: linux-kernel@vger.kernel.org, "Jiri Slaby (SUSE)" , Al Cooper , Alexander Shiyan , Alexandre Belloni , Alexandre Torgue , Alim Akhtar , Andrew Morton , "Aneesh Kumar K.V" , AngeloGioacchino Del Regno , Baolin Wang , Baruch Siach , Bjorn Andersson , Claudiu Beznea , "David S. Miller" , Fabio Estevam , Hammer Hsieh , =?UTF-8?q?Christian=20K=C3=B6nig?= , Christophe Leroy , Chunyan Zhang , Jerome Brunet , Jonathan Hunter , Kevin Hilman , Konrad Dybcio , Krzysztof Kozlowski , Kumaravel Thiagarajan , Laxman Dewangan , linux-arm-kernel@lists.infradead.org, linux-arm-msm@vger.kernel.org, "Maciej W. Rozycki" , Manivannan Sadhasivam , Martin Blumenstingl , Matthias Brugger , Maxime Coquelin , Michael Ellerman , Michal Simek , "Naveen N. Rao" , Neil Armstrong , Nicolas Ferre , Nicholas Piggin , Orson Zhai , =?UTF-8?q?Pali=20Roh=C3=A1r?= , Patrice Chotard , Peter Korsgaard , Richard Genoud , Russell King , Sascha Hauer , Shawn Guo , Stefani Seibold , Sumit Semwal , Taichi Sugaya , Takao Orito , Tharun Kumar P , Thierry Reding , Timur Tabi , Vineet Gupta Subject: [RFT 00/15] tty: serial: switch from circ_buf to kfifo Date: Tue, 19 Mar 2024 10:52:59 +0100 Message-ID: <20240319095315.27624-1-jirislaby@kernel.org> X-Mailer: git-send-email 2.44.0 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This series switches tty serial layer to use kfifo instead of circ_buf. Excerpt from the switching patch: """ Switch from struct circ_buf to proper kfifo. kfifo provides much better API, esp. when wrap-around of the buffer needs to be taken into account. Look at pl011_dma_tx_refill() or cpm_uart_tx_pump() changes for example. Kfifo API can also fill in scatter-gather DMA structures, so it easier for that use case too. Look at lpuart_dma_tx() for example. Note that not all drivers can be converted to that (like atmel_serial), they handle DMA specially. Note that usb-serial uses kfifo for TX for ages. """ This is Request for Testing as I cannot test all the changes (obviously). So please test your HW's serial properly. And of course comments welcome. I will send this as PATCHes later, when -rc1 is out, at earliest. Cc: Al Cooper Cc: Alexander Shiyan Cc: Alexandre Belloni Cc: Alexandre Torgue Cc: Alim Akhtar Cc: Andrew Morton Cc: "Aneesh Kumar K.V" Cc: AngeloGioacchino Del Regno Cc: Baolin Wang Cc: Baruch Siach Cc: Bjorn Andersson Cc: Claudiu Beznea Cc: "David S. Miller" Cc: Fabio Estevam Cc: Hammer Hsieh Cc: "Christian König" Cc: Christophe Leroy Cc: Chunyan Zhang Cc: Jerome Brunet Cc: Jonathan Hunter Cc: Kevin Hilman Cc: Konrad Dybcio Cc: Krzysztof Kozlowski Cc: Kumaravel Thiagarajan Cc: Laxman Dewangan Cc: linux-arm-kernel@lists.infradead.org Cc: linux-arm-msm@vger.kernel.org Cc: "Maciej W. Rozycki" Cc: Manivannan Sadhasivam Cc: Martin Blumenstingl Cc: Matthias Brugger Cc: Maxime Coquelin Cc: Michael Ellerman Cc: Michal Simek Cc: "Naveen N. Rao" Cc: Neil Armstrong Cc: Nicolas Ferre Cc: Nicholas Piggin Cc: Orson Zhai Cc: "Pali Rohár" Cc: Patrice Chotard Cc: Peter Korsgaard Cc: Richard Genoud Cc: Russell King Cc: Sascha Hauer Cc: Shawn Guo Cc: Stefani Seibold Cc: Sumit Semwal Cc: Taichi Sugaya Cc: Takao Orito Cc: Tharun Kumar P Cc: Thierry Reding Cc: Timur Tabi Cc: Vineet Gupta Jiri Slaby (SUSE) (15): kfifo: drop __kfifo_dma_out_finish_r() kfifo: introduce and use kfifo_skip_count() kfifo: add kfifo_out_linear{,_ptr}() kfifo: remove support for physically non-contiguous memory kfifo: rename l to len_to_end in setup_sgl() kfifo: pass offset to setup_sgl_buf() instead of a pointer kfifo: add kfifo_dma_out_prepare_mapped() kfifo: fix typos in kernel-doc tty: 8250_dma: use dmaengine_prep_slave_sg() tty: 8250_omap: use dmaengine_prep_slave_sg() tty: msm_serial: use dmaengine_prep_slave_sg() tty: serial: switch from circ_buf to kfifo tty: atmel_serial: use single DMA mapping for TX tty: atmel_serial: define macro for RX size tty: atmel_serial: use single DMA mapping for RX drivers/tty/serial/8250/8250_bcm7271.c | 14 +-- drivers/tty/serial/8250/8250_core.c | 3 +- drivers/tty/serial/8250/8250_dma.c | 31 +++-- drivers/tty/serial/8250/8250_exar.c | 5 +- drivers/tty/serial/8250/8250_mtk.c | 2 +- drivers/tty/serial/8250/8250_omap.c | 48 +++++--- drivers/tty/serial/8250/8250_pci1xxxx.c | 50 ++++---- drivers/tty/serial/8250/8250_port.c | 22 ++-- drivers/tty/serial/amba-pl011.c | 46 +++----- drivers/tty/serial/ar933x_uart.c | 15 ++- drivers/tty/serial/arc_uart.c | 8 +- drivers/tty/serial/atmel_serial.c | 150 +++++++++++------------- drivers/tty/serial/clps711x.c | 12 +- drivers/tty/serial/cpm_uart.c | 20 ++-- drivers/tty/serial/digicolor-usart.c | 12 +- drivers/tty/serial/dz.c | 13 +- drivers/tty/serial/fsl_linflexuart.c | 17 +-- drivers/tty/serial/fsl_lpuart.c | 39 +++--- drivers/tty/serial/icom.c | 25 +--- drivers/tty/serial/imx.c | 54 ++++----- drivers/tty/serial/ip22zilog.c | 26 ++-- drivers/tty/serial/jsm/jsm_cls.c | 29 ++--- drivers/tty/serial/jsm/jsm_neo.c | 38 ++---- drivers/tty/serial/max3100.c | 14 +-- drivers/tty/serial/max310x.c | 35 +++--- drivers/tty/serial/men_z135_uart.c | 26 ++-- drivers/tty/serial/meson_uart.c | 11 +- drivers/tty/serial/milbeaut_usio.c | 15 +-- drivers/tty/serial/msm_serial.c | 114 +++++++++--------- drivers/tty/serial/mvebu-uart.c | 8 +- drivers/tty/serial/mxs-auart.c | 23 +--- drivers/tty/serial/pch_uart.c | 21 ++-- drivers/tty/serial/pic32_uart.c | 15 ++- drivers/tty/serial/pmac_zilog.c | 24 ++-- drivers/tty/serial/qcom_geni_serial.c | 36 +++--- drivers/tty/serial/rda-uart.c | 17 +-- drivers/tty/serial/samsung_tty.c | 54 +++++---- drivers/tty/serial/sb1250-duart.c | 13 +- drivers/tty/serial/sc16is7xx.c | 40 +++---- drivers/tty/serial/sccnxp.c | 16 ++- drivers/tty/serial/serial-tegra.c | 43 ++++--- drivers/tty/serial/serial_core.c | 56 ++++----- drivers/tty/serial/serial_port.c | 2 +- drivers/tty/serial/sh-sci.c | 51 ++++---- drivers/tty/serial/sprd_serial.c | 20 ++-- drivers/tty/serial/st-asc.c | 4 +- drivers/tty/serial/stm32-usart.c | 52 ++++---- drivers/tty/serial/sunhv.c | 35 +++--- drivers/tty/serial/sunplus-uart.c | 16 +-- drivers/tty/serial/sunsab.c | 30 ++--- drivers/tty/serial/sunsu.c | 15 +-- drivers/tty/serial/sunzilog.c | 27 ++--- drivers/tty/serial/tegra-tcu.c | 10 +- drivers/tty/serial/timbuart.c | 17 ++- drivers/tty/serial/uartlite.c | 13 +- drivers/tty/serial/ucc_uart.c | 20 ++-- drivers/tty/serial/xilinx_uartps.c | 20 ++-- drivers/tty/serial/zs.c | 13 +- include/linux/kfifo.h | 143 ++++++++++++++++------ include/linux/serial_core.h | 49 +++++--- lib/kfifo.c | 107 +++++++++-------- 61 files changed, 944 insertions(+), 960 deletions(-) -- 2.44.0