Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3625137pxb; Mon, 24 Jan 2022 13:48:40 -0800 (PST) X-Google-Smtp-Source: ABdhPJxX2pfzoxs6xT0Y6ng4foj0JhhQSW8pvk8s4f+cQiLl8OpbTnByS+q74mZ265ol8t3MBL3+ X-Received: by 2002:a17:903:41c9:b0:14b:376c:39ad with SMTP id u9-20020a17090341c900b0014b376c39admr9924401ple.174.1643060920298; Mon, 24 Jan 2022 13:48:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643060920; cv=none; d=google.com; s=arc-20160816; b=uxuGogNBNjrw3b9IIuRuIDRgjaWuBL8C75rGidO7lW8xXpY6GTZGPHLXqa0GV3E5qe tqOg2MG3BoZGmBadZroyJlzk8MdNbIaJUsCrsrIxdE2C2DL/PZXXtJyUWUOS9R9rZUqj ttepmCP3eB97N3GG3b4y7JHV2LIwmuJPfF8NZIpSi5+0mNKFMLAeFPZUK2o3o1m6O6LJ mSnAaat/HFfEneyhchNwTB7fO/nrucKpJ/FnA7JYDPgkz+VOxlxXd7FqIKiiOawVujvY D5nOrdw0slqWNZBm/l94eSP8kVGrrY6O5z1VBaSYNGdx+Bytj3Qe97gyEBcLU5gIHIm5 q5Yg== 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=L2Rqh2NKE02iKdgcVWB80dZxSv6eJtGpmUkYDf77Hl8=; b=C02hPXmpWxVv2VOZiLH8eu6u9vY5T9kfNh1Y+REyrcYGF+pmeJFKwn0WECnpQqzS85 0mlC8MDF+iQXz8E8tIF4TDOP7PEovBTY296uNlYhI8urR7kPlh6AOjfqI9uky+7/0V1e bVUWyeMHsoD39omr5KJHH5Eecv3LknuMOJ+d4bs+FgswwpFC3SezKv6LzWMARVyjQr4u GianSVFwX7zam/VeZJP0qtGXvo374xEN/mQtSQqTTpCJxgSd4RUho2fcQatOP7Um5ih8 496ALZkZad/LMQHeKECf8AUeK2DYli62Nr3/TnNBNa9+Ym6oGXLfgZiXO/6b/PfTeKxr fzXQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=d5Rlr3Q7; 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 v14si13229786pgk.382.2022.01.24.13.48.24; Mon, 24 Jan 2022 13:48:40 -0800 (PST) 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=d5Rlr3Q7; 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 S1453541AbiAXVaT (ORCPT + 99 others); Mon, 24 Jan 2022 16:30:19 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46164 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1443056AbiAXU7O (ORCPT ); Mon, 24 Jan 2022 15:59:14 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 73E7CC04D625; Mon, 24 Jan 2022 12:01:20 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 2FD1BB8123A; Mon, 24 Jan 2022 20:01:19 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 3F1B2C340E5; Mon, 24 Jan 2022 20:01:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643054477; bh=RKSEmNaXGd0qqSaJBIwGtQiobulqLStSBkj1kyOlIzM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=d5Rlr3Q7rf37Au/zHqCOVvn21ytUMqcNfO+pR+tm88aJPb0WZXrHgpROQRKX+jKX8 J+3w11LnBSykm/Ubz0wz8+YSFevfBK1gpI4Y/Q4wxnMZrSYMTUruM7sDsMxNlyYZko Be4cE9LYJeqHxgZXUA8UZtF00+XlrE+46UniE33U= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Russell King , Lukas Wunner , Sasha Levin Subject: [PATCH 5.10 403/563] serial: pl010: Drop CR register reset on set_termios Date: Mon, 24 Jan 2022 19:42:48 +0100 Message-Id: <20220124184038.386658409@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124184024.407936072@linuxfoundation.org> References: <20220124184024.407936072@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: Lukas Wunner [ Upstream commit 08a0c6dff91c965e39905cf200d22db989203ccb ] pl010_set_termios() briefly resets the CR register to zero. Where does this register write come from? The PL010 driver's IRQ handler ambauart_int() originally modified the CR register without holding the port spinlock. ambauart_set_termios() also modified that register. To prevent concurrent read-modify-writes by the IRQ handler and to prevent transmission while changing baudrate, ambauart_set_termios() had to disable interrupts. That is achieved by writing zero to the CR register. However in 2004 the PL010 driver was amended to acquire the port spinlock in the IRQ handler, obviating the need to disable interrupts in ->set_termios(): https://git.kernel.org/history/history/c/157c0342e591 That rendered the CR register write obsolete. Drop it. Cc: Russell King Signed-off-by: Lukas Wunner Link: https://lore.kernel.org/r/fcaff16e5b1abb4cc3da5a2879ac13f278b99ed0.1641128728.git.lukas@wunner.de Signed-off-by: Greg Kroah-Hartman Signed-off-by: Sasha Levin --- drivers/tty/serial/amba-pl010.c | 3 --- 1 file changed, 3 deletions(-) diff --git a/drivers/tty/serial/amba-pl010.c b/drivers/tty/serial/amba-pl010.c index 3284f34e9dfe1..75d61e038a775 100644 --- a/drivers/tty/serial/amba-pl010.c +++ b/drivers/tty/serial/amba-pl010.c @@ -448,14 +448,11 @@ pl010_set_termios(struct uart_port *port, struct ktermios *termios, if ((termios->c_cflag & CREAD) == 0) uap->port.ignore_status_mask |= UART_DUMMY_RSR_RX; - /* first, disable everything */ old_cr = readb(uap->port.membase + UART010_CR) & ~UART010_CR_MSIE; if (UART_ENABLE_MS(port, termios->c_cflag)) old_cr |= UART010_CR_MSIE; - writel(0, uap->port.membase + UART010_CR); - /* Set baud rate */ quot -= 1; writel((quot & 0xf00) >> 8, uap->port.membase + UART010_LCRM); -- 2.34.1