Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3547741pxb; Mon, 24 Jan 2022 11:57:40 -0800 (PST) X-Google-Smtp-Source: ABdhPJybC6qqRD7s7IGCXXfi8QssoqnNfCI1r27rRMGFMv+ySdJbG6AlsT62v0KvR5sut2sfRtEB X-Received: by 2002:a17:90a:8b95:: with SMTP id z21mr3440955pjn.29.1643054260649; Mon, 24 Jan 2022 11:57:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643054260; cv=none; d=google.com; s=arc-20160816; b=c+ov2xzoyutoHsbMVFnkUTujhDAMtczb4oTTh+SrtaXZMMASI82bcVPez29dABTbMp XzvDs6oyva+414RQ7MrnGcUxwTf/UYXLdqiL4tuwxleN6H6rMtIto+XIzY4H1z55O3T7 eUHzKM/v+pcmRbboain3EnvE4T3I9OkgYJb0ccyUV76osnnWcv+cqdLq6KIEe1BP8Y2a uVJ7ZgDuHNYxHXzKNjiB3Ua1i1TwiNZGPlfhB99gBgHwjZHWzAwpyjjrUOW1fDhyUzHL v0GzO+TvwqSerIUL/7wTbC2SAqlD+XVLwyyBFDnZjMDEhZsaDuQvgMB4iYGAWkR34AMf 9sHg== 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=L3EdB/0u3CRLGGAleQrfa9G2AgagCcu+ZNxJxokhjFM=; b=NgrGXtyxJ7+jO4iQIUDczQ5/vCQhExNxZ9cUCgAuDzVoC6qX4YEVpjU+mSv7c8AVZc pBJy3BmOmImVDrkhm2Y3dxdLom+W74INjhbhz9yLz8QLObeym1KfwbX+h+KrN+vpFxUg DOIPSoQX+ESzMvKOx7m/ilLzVyIwTcRHgqiGh/vrSimIsqY7dZ15A2MQdgVmSCgY+6p6 oED/KAipGTA+BIbkdCO5gbRosnuUs8LT0XVG1YN01T0IOH6F730VFw0YdxS49F1d7wsO Wk5QnT5udkQvGjjMeliLx2NZSI0KbCtYHaA+ZOQ3QyQaiy/8YZTh2Ksxl5omNl0h+Tzn 1SDw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=at53GGcW; 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 t3si14523925pgq.452.2022.01.24.11.57.28; Mon, 24 Jan 2022 11:57: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=at53GGcW; 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 S245503AbiAXSxj (ORCPT + 99 others); Mon, 24 Jan 2022 13:53:39 -0500 Received: from ams.source.kernel.org ([145.40.68.75]:51220 "EHLO ams.source.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343823AbiAXSwJ (ORCPT ); Mon, 24 Jan 2022 13:52:09 -0500 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 BF5E0B81235; Mon, 24 Jan 2022 18:52:07 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id DD2F7C340E8; Mon, 24 Jan 2022 18:52:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643050326; bh=mOa3viRnCiyugN9lsjwtjitWUVuvU+gNzpDpjLjWNzE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=at53GGcWgI0wNYCSpoRMg5z+51aTIAv1moiu4nAxIA4UD00rFu7bIVv5xnybDkfGA zHJcouBhWUIuGC3x1UVHwMw/bqOAeReTLJ++kQ3Rh8he3MYsnpvV+qmAJc6mHrVD5Q 33Y/rQK9yK1NIS8fk70f7Wx63865+Z38Pvz8cjLk= 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 4.4 081/114] serial: pl010: Drop CR register reset on set_termios Date: Mon, 24 Jan 2022 19:42:56 +0100 Message-Id: <20220124183929.610093670@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124183927.095545464@linuxfoundation.org> References: <20220124183927.095545464@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 5d41d5b92619a..7f4ba92739663 100644 --- a/drivers/tty/serial/amba-pl010.c +++ b/drivers/tty/serial/amba-pl010.c @@ -465,14 +465,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