Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp779879rwb; Mon, 26 Sep 2022 05:54:21 -0700 (PDT) X-Google-Smtp-Source: AMsMyM4f8Emd3Uen2vgtPkThVPKbCbl7LXmR1KbSJ+kqmZ508qFCS1/LdyvZ6ZS36/EOCB71YtDQ X-Received: by 2002:a17:907:9714:b0:782:6cb6:f53d with SMTP id jg20-20020a170907971400b007826cb6f53dmr15975106ejc.567.1664196860867; Mon, 26 Sep 2022 05:54:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1664196860; cv=none; d=google.com; s=arc-20160816; b=DpNWrxM0x/iYffqEGVKUEY58xV2cfM1PT2UYQdF7epC8g1JMCtR+OyHw9zloeRJE/N xRBGAjiUINwv5Z6phblfafeGMKqSLzqCFAlVbY1LCZOA3s+S5g2XNUl5TG60HrC3z5Al WyeVOTeyaCHuKjid4BfA/qqh7k5hS+K1Y/cf2QvP9wQki4KJQr9oKASTuNchw0X6zd8n 0oU+vn/2eLRI+76BXE81ILwI/sKsaznCUWJ91NsnWGtAXlmys4e5R8ZNFFMomp3jOG5h HMKBncdtMZOIJ4pdRP74rzcKtuXSMdvsfN16I92W5DRaBX9PV0OguNEb/vZoPTW9/KRG 3uug== 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=+0WViY9Fk1Bz+91wYDC+ow0/D6LVvFse+Zq72eXc5O4=; b=tt8VlnGMsS/gROB1H4JcF8/1sRyjF5ApSAk9N/kWiLeYl4fdetgjwQ3K4GNEc52ikG rdX8FtuXIm3S6GJiDX4jWsS27IsHtsOWr5BOWrOJBV3lw4ENC7rPWG39VTkPUkL3TkFU jcjHr5Zy2iQInDkRFr14nqjmO95/+0k6COMwIYJic7q0C0wyVpXsTCpuA14E9M9mp3Ru vIQ6V8zrZl8NqIJV5yezAqIUJI3h/XYKEN2AMjSPvtqSan/kCa9k/SyLNcI75GPKM+js aj+xKJud7Dvl+GXOxXmz2Jow2mECAhzvtgKuY2eQFfa1e9fNrUXxpvr9dhRDXPw714h5 x1Gg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=v+69XJeX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x10-20020a170906658a00b00780ada0f8easi12606169ejn.865.2022.09.26.05.53.54; Mon, 26 Sep 2022 05:54:20 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=v+69XJeX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S237877AbiIZLZS (ORCPT + 99 others); Mon, 26 Sep 2022 07:25:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51888 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237958AbiIZLXo (ORCPT ); Mon, 26 Sep 2022 07:23:44 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B825726AE7; Mon, 26 Sep 2022 03:40:02 -0700 (PDT) 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 DCECDB801BF; Mon, 26 Sep 2022 10:40:01 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 4D684C433C1; Mon, 26 Sep 2022 10:40:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1664188800; bh=DoyjJPRgE81u2h5r3ajYpubUne6Xk3znZRS03RjWaLA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=v+69XJeX0ziMd4tPUlRUPzDashhb9aKYO7twXu55r665FbCiAtkgXIs9BRGWXMUHa LEJRZzxHQ/kAqqObc6jfHYbaPp4+M07CWzCcw8PupfqvnfcYWflj1qOzBAiDeAh7n0 VppWxB0q+aAk18YuDE7i7S5viI7j15BLe/mTKESs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Fugang Duan , Sherry Sun , =?UTF-8?q?Ilpo=20J=C3=A4rvinen?= , Lukas Wunner Subject: [PATCH 5.15 118/148] serial: fsl_lpuart: Reset prior to registration Date: Mon, 26 Sep 2022 12:12:32 +0200 Message-Id: <20220926100800.561048554@linuxfoundation.org> X-Mailer: git-send-email 2.37.3 In-Reply-To: <20220926100756.074519146@linuxfoundation.org> References: <20220926100756.074519146@linuxfoundation.org> User-Agent: quilt/0.67 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.2 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lukas Wunner commit 60f361722ad2ae5ee667d0b0545d40c42f754daf upstream. Since commit bd5305dcabbc ("tty: serial: fsl_lpuart: do software reset for imx7ulp and imx8qxp"), certain i.MX UARTs are reset after they've already been registered. Register state may thus be clobbered after user space has begun to open and access the UART. Avoid by performing the reset prior to registration. Fixes: bd5305dcabbc ("tty: serial: fsl_lpuart: do software reset for imx7ulp and imx8qxp") Cc: stable@vger.kernel.org # v5.15+ Cc: Fugang Duan Cc: Sherry Sun Reviewed-by: Ilpo Järvinen Signed-off-by: Lukas Wunner Link: https://lore.kernel.org/r/72fb646c1b0b11c989850c55f52f9ff343d1b2fa.1662884345.git.lukas@wunner.de Signed-off-by: Greg Kroah-Hartman --- drivers/tty/serial/fsl_lpuart.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) --- a/drivers/tty/serial/fsl_lpuart.c +++ b/drivers/tty/serial/fsl_lpuart.c @@ -2726,14 +2726,15 @@ static int lpuart_probe(struct platform_ lpuart_reg.cons = LPUART_CONSOLE; handler = lpuart_int; } - ret = uart_add_one_port(&lpuart_reg, &sport->port); - if (ret) - goto failed_attach_port; ret = lpuart_global_reset(sport); if (ret) goto failed_reset; + ret = uart_add_one_port(&lpuart_reg, &sport->port); + if (ret) + goto failed_attach_port; + ret = uart_get_rs485_mode(&sport->port); if (ret) goto failed_get_rs485; @@ -2756,9 +2757,9 @@ static int lpuart_probe(struct platform_ failed_irq_request: failed_get_rs485: -failed_reset: uart_remove_one_port(&lpuart_reg, &sport->port); failed_attach_port: +failed_reset: lpuart_disable_clks(sport); return ret; }