Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3576632pxb; Mon, 24 Jan 2022 12:37:55 -0800 (PST) X-Google-Smtp-Source: ABdhPJz0OsdTkWwOkESnoLeHsShW3CeWdZdIfXRA9oLxDUDDscxTBIOYVYn48i7JpqDBPU0XixzK X-Received: by 2002:a63:724b:: with SMTP id c11mr13000433pgn.576.1643056675664; Mon, 24 Jan 2022 12:37:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643056675; cv=none; d=google.com; s=arc-20160816; b=qeri99VtLmwDi4/7HkJCi6+z6D9wIUI6PY7DivOvEpHlxYMAShT1djiuNcaUbeXvtw EfchGYx+G+5eaZMPA8Myzlm/TGjakvI8td9cv3IswMHmCAyxkQaa5iYGCIA75vfwbC6X peTLqiG/xKpBkbZla4oXM9CUvyf5jbTIGR0dziWlYAhVYYjjkP2niyd8Wzg9sKs3CXw/ Fex4PVfy6/v814m6E8xQl5wEKUmlZ0P5UzqsuIp54uMGMd1kbtitrP1TTUsgcCfqjwZc pPrgDHOPRGAQNi5JyzPFXUTI4JixRTEIL53hnE7TA8gG+2/MhtqIZho50gnWBDH2AGl0 U8xg== 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=11HuGG2VGSwNBZO4KHq7IDLukCCNm/XltBBLV1QY4N4=; b=vfdHUGYDEsEZklmnBnEKpHBeQniEkM1CNO2m9ny/PPwi1AViARQ9P4xvv8KbyYIT6C 4a2GNJTMbtP7NBUN1AvDomi5Vw1lMjuU773Qg/gvXFf6RZdsszHWNc7XpXqFjY73hHqy YJZ0C8P4ee7lSdSBb3LHdFJjbgI6jqmOScXRs/IgvLKXG0KDteRhj73pemVGJ+vM3Qid CwWoY0fKRhnY5VfTSMFU4jVR6QKUIBYB7+BEbh/kLFJorBwtllg/g5W42b7iHV67utW2 BxarQvOz42DkJH2go877SNX+/ekYbsTs8S71TtJjWoVhBUOUUP6O60CfxKaEAChYf1Wk cRIA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=IoGVSyYM; 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 o33si297445pjo.17.2022.01.24.12.37.43; Mon, 24 Jan 2022 12:37:55 -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=IoGVSyYM; 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 S1351231AbiAXToo (ORCPT + 99 others); Mon, 24 Jan 2022 14:44:44 -0500 Received: from dfw.source.kernel.org ([139.178.84.217]:33860 "EHLO dfw.source.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1353863AbiAXTfa (ORCPT ); Mon, 24 Jan 2022 14:35:30 -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 dfw.source.kernel.org (Postfix) with ESMTPS id F08896121F; Mon, 24 Jan 2022 19:35:29 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id B86DBC340E5; Mon, 24 Jan 2022 19:35:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643052929; bh=ybTUdVpSs4tP9fA30UA8SByCPb6Bm5xSjfuBftAAKl0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=IoGVSyYM6Nq0EDzcXOpJtNUDY1URjnw91tt4xxjAyFXxUNsZF+SZBDHyUYMe4SjT3 cd5ISitkjRuNGszUgktNJMzZdkp5UOqzCWWLmLJaE01Q45KgrFqj8FkGW9ftIFKA7R OHqdzQ941dDr+oVWECfDitngTtjlDpBjnNw+nwnA= 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.4 220/320] serial: pl010: Drop CR register reset on set_termios Date: Mon, 24 Jan 2022 19:43:24 +0100 Message-Id: <20220124184001.139499978@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124183953.750177707@linuxfoundation.org> References: <20220124183953.750177707@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 2c37d11726aba..13f882e5e7b76 100644 --- a/drivers/tty/serial/amba-pl010.c +++ b/drivers/tty/serial/amba-pl010.c @@ -452,14 +452,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