Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3552432pxb; Mon, 24 Jan 2022 12:03:45 -0800 (PST) X-Google-Smtp-Source: ABdhPJwCsUAvI3tQducfTdI3NwCxmLC9gpdUCcqenJ+h2y9uGOmVT81j+OLOHHRaxlWi1ZAnfONf X-Received: by 2002:a17:90b:4c42:: with SMTP id np2mr3452589pjb.201.1643054624959; Mon, 24 Jan 2022 12:03:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643054624; cv=none; d=google.com; s=arc-20160816; b=p7AgFvm05cRiASmlpFTxTdh/fmTdbO3RpxpzK/4oCdiN+JUI2L5YmD2Hzb2xpoGyzV nlhVof0NWMhBcIIco655T5wcqu9MZMoDwgDRjOkPevtCL4cgnypiOsqZlYQ6cWZMBgwi FCAAXeUbVIiBF8qIbdecMaEL0x4cOLYnnKk7rFMNPtIoCv2St5lnejlCLMHUXxFna8sS 2eXOVtyYK+2jn6QpWEkPeASTa0JZTN+wYm6ZDbqNtcDZG7r6Tp/jkkPZPcEd/CMO0ces 1fuq35YBIS1OR1E89VYHlimpsUpZT763MhHM9yDp3Kb0Og9Dur2nZbn6RVNxCm65FqX9 7ElQ== 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=fGDvTKt9fMo1YPQjywCt42yRn6cgg22KTkT7JEZqD3ke8iirQMI9rad/rC+UBGMu+O dRDCHLiW4vlBcAiwUiiUFbadEZsU9JFJu4vQcMWkI0AySoy7cyMaiLbW78mT7+nKJzhR Rk+20/u4mclp3UNFrwsXQciB88foqFuLyxytxi0/2F2j0BKryS46LQDcnaOzRjw9+BO/ /SJjCtSRtnVn0Z+VzCf1wAOqinfHQcQAbDdJ2qLN3Gx6glCOuUwOHN1SbpvAROvvvQfZ Ys6xx0ZleLKSMlh9Dm+iVBGv6LWk24I0fM1skL2k8uUY4gIq7X8MMklCaxUEAgPSmjQW Xu9w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="XwoAm/SK"; 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 y22si13259151pge.642.2022.01.24.12.03.32; Mon, 24 Jan 2022 12:03:44 -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="XwoAm/SK"; 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 S1344544AbiAXTD2 (ORCPT + 99 others); Mon, 24 Jan 2022 14:03:28 -0500 Received: from ams.source.kernel.org ([145.40.68.75]:56920 "EHLO ams.source.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1344054AbiAXS7S (ORCPT ); Mon, 24 Jan 2022 13:59:18 -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 9EDAEB81232; Mon, 24 Jan 2022 18:59:17 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id ACE3DC340E8; Mon, 24 Jan 2022 18:59:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643050756; bh=mOa3viRnCiyugN9lsjwtjitWUVuvU+gNzpDpjLjWNzE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XwoAm/SKUAqIeRNVaFY9g5m6hhBwAyQYw71Q0oNmpcUx5v185nDozUBxnFTzJAuxt 7U5wGz7KLACcOaVgRXV1eT5aPPWxloHIXzrIzZr+tjQnWvRf2mDNM0E9rFHrN06O6G tDl7LZcZor3J63bhj3eGbYj16SP4FCtm2jXRC0Co= 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.9 102/157] serial: pl010: Drop CR register reset on set_termios Date: Mon, 24 Jan 2022 19:43:12 +0100 Message-Id: <20220124183935.998455892@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124183932.787526760@linuxfoundation.org> References: <20220124183932.787526760@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