Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp27854874rwd; Tue, 4 Jul 2023 08:46:48 -0700 (PDT) X-Google-Smtp-Source: APBJJlHPuA/O7EVugtGbHtVA6w1k6g0VUs1sOtZXnaX/XgDgg0hm6KOFHrcSCAJLGFDdmjX0QMUa X-Received: by 2002:a05:6a00:1ace:b0:682:4e4c:48bc with SMTP id f14-20020a056a001ace00b006824e4c48bcmr18328768pfv.21.1688485608512; Tue, 04 Jul 2023 08:46:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1688485608; cv=none; d=google.com; s=arc-20160816; b=Hr6S470dDpfztsHjVITbyZSj3K0/UOAwIi4NRmt62pa0R4hsiIKikLuLfZTXzsqdLx 3TpSQvUmrxUtL87IIMiY+6TO4gJk3aYrjSwTLSPNH4HBEaHaLWZ6E8mV77F6yhcXq2zX IsaiL6z2LhROlne6FUcrUlrAVY86BGl2ZhCj3nro3e9BiCeiaDo33sJkBfnYK7cZIuil F0Cly1jjKl+qr7U92xkGDfzqZJxpJBRfXlBwXme0W4KrTR1Kto2SdMuqILc+IPJrhSiN 2N/SBvBLLg8+GK+NFkawT8EMlESVPFf5f/8NDI8idS00Xv8edgyvNyIA4rNPVQ5zKEuo x0vA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature:dkim-filter; bh=QqMgquqipSlP9zH8819FUOffDSsMIheYOnoKQYVcXkM=; fh=G/0DMKHW3GPCInfVW9dOLMH6v9Kpo2gQqvZtaTshFNU=; b=MhdHw2UHNMnBo0NlZDUAmyH5urc+8RkyHPiDQvRF6Z6ShJ2x4cCATxnuQUQvfiJ0Bg FINdaCC8ojuBFav0tCS3LVYtPyW6ASeG6WoYXV7wzgI8Hxl/1h+ZuYYt5Up2A2RRc/z1 BCZPGpYHpP5kKJCdJKU8eOrwM4a8+MUCpdCrnvBeLa0V57IBKC1b/3Rb7ak/tc9AAs3d xAwr+YdvqA7O5havRhryksr/nGsWIvtswxfSUbrE9rtMfMdE3j17lhItYMl8tm2/KVUN AzJMUHQjfTYQ/PMX8lq+M3JfdEDTfDfEhRiZZYDWW/U7ZK9d0ZXCOQneysYe7oOZt+aD 4Ueg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sberdevices.ru header.s=mail header.b=JZvTuS2K; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=sberdevices.ru Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ce6-20020a056a002a0600b00648019bae38si9311920pfb.277.2023.07.04.08.46.35; Tue, 04 Jul 2023 08:46:48 -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=@sberdevices.ru header.s=mail header.b=JZvTuS2K; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=sberdevices.ru Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231486AbjGDO75 (ORCPT + 99 others); Tue, 4 Jul 2023 10:59:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60356 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229971AbjGDO7h (ORCPT ); Tue, 4 Jul 2023 10:59:37 -0400 Received: from mx1.sberdevices.ru (mx2.sberdevices.ru [45.89.224.132]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6345710CA; Tue, 4 Jul 2023 07:59:35 -0700 (PDT) Received: from p-infra-ksmg-sc-msk02 (localhost [127.0.0.1]) by mx1.sberdevices.ru (Postfix) with ESMTP id D6D47120056; Tue, 4 Jul 2023 17:59:33 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 mx1.sberdevices.ru D6D47120056 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sberdevices.ru; s=mail; t=1688482773; bh=QqMgquqipSlP9zH8819FUOffDSsMIheYOnoKQYVcXkM=; h=Date:From:To:Subject:Message-ID:MIME-Version:Content-Type:From; b=JZvTuS2Kb7/pyohFSDNxVUHzcD+VnVvrY1Kljk6fNWv704shSk0P+l8lctIyP/Gfj EE9A+fkkdpDUV0xLdFuYx/uVrY4iIALxutr/MAkjwRwHqL4dTUIlldeFWQzaITrt/3 PmzNhnFcrgjf1NmLgjTBt+Ycl/Nk0zNS4HFHwuz6rcE/nQNv2HuGrKjhFqRnyH64eR Mrb2bU7+hfIuHGlXTBlM0LFPD3i1EIaFnJHAjrBI2/Z8AAwdPQ865GaUplU1w6IHqA nC2SgvIqEVRhDe647zoWE1uOmMnZPuJR50DMNKxglcfHyuEjW6H7HWSJiix4WZ3U4Y kl5rC5Z1Zg7Ew== Received: from p-i-exch-sc-m01.sberdevices.ru (p-i-exch-sc-m01.sberdevices.ru [172.16.192.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mx1.sberdevices.ru (Postfix) with ESMTPS; Tue, 4 Jul 2023 17:59:33 +0300 (MSK) Received: from localhost (100.64.160.123) by p-i-exch-sc-m01.sberdevices.ru (172.16.192.107) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.30; Tue, 4 Jul 2023 17:59:23 +0300 Date: Tue, 4 Jul 2023 17:59:33 +0300 From: Dmitry Rokosov To: CC: , , , , , , , , , , , , , , , , Subject: Re: [PATCH v1 3/5] tty: serial: meson: apply ttyS devname instead of ttyAML for new SoCs Message-ID: <20230704145933.y3o3fhjj6q7df44d@CAB-WSD-L081021> References: <20230704135936.14697-1-ddrokosov@sberdevices.ru> <20230704135936.14697-4-ddrokosov@sberdevices.ru> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20220415 X-Originating-IP: [100.64.160.123] X-ClientProxiedBy: p-i-exch-sc-m02.sberdevices.ru (172.16.192.103) To p-i-exch-sc-m01.sberdevices.ru (172.16.192.107) X-KSMG-Rule-ID: 10 X-KSMG-Message-Action: clean X-KSMG-AntiSpam-Lua-Profiles: 178426 [Jul 04 2023] X-KSMG-AntiSpam-Version: 5.9.59.0 X-KSMG-AntiSpam-Envelope-From: DDRokosov@sberdevices.ru X-KSMG-AntiSpam-Rate: 0 X-KSMG-AntiSpam-Status: not_detected X-KSMG-AntiSpam-Method: none X-KSMG-AntiSpam-Auth: dkim=none X-KSMG-AntiSpam-Info: LuaCore: 520 520 ccb018a655251011855942a2571029252d3d69a2, {Tracking_uf_ne_domains}, {Track_E25351}, {Tracking_from_domain_doesnt_match_to}, sberdevices.ru:7.1.1,5.0.1;libera.irclog.whitequark.org:7.1.1;127.0.0.199:7.1.2;100.64.160.123:7.1.2;p-i-exch-sc-m01.sberdevices.ru:7.1.1,5.0.1;d41d8cd98f00b204e9800998ecf8427e.com:7.1.1, FromAlignment: s, {Tracking_white_helo}, ApMailHostAddress: 100.64.160.123 X-MS-Exchange-Organization-SCL: -1 X-KSMG-AntiSpam-Interceptor-Info: scan successful X-KSMG-AntiPhishing: Clean, bases: 2023/07/04 13:59:00 X-KSMG-LinksScanning: Clean, bases: 2023/07/04 13:58:00 X-KSMG-AntiVirus: Kaspersky Secure Mail Gateway, version 2.0.1.6960, bases: 2023/07/04 05:54:00 #21559896 X-KSMG-AntiVirus-Status: Clean, skipped X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,SPF_NONE, T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED 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 Hello Neil, Thank you for quick feedback! On Tue, Jul 04, 2023 at 04:42:39PM +0200, neil.armstrong@linaro.org wrote: > On 04/07/2023 15:59, Dmitry Rokosov wrote: > > It is worth noting that the devname ttyS is a widely recognized tty name > > and is commonly used by many uart device drivers. Given the established > > usage and compatibility concerns, it may not be feasible to change the > > devname for older SoCs. However, for new definitions, it is acceptable > > and even recommended to use a new devname to help ensure clarity and > > avoid any potential conflicts on lower or upper software levels. In > > addition, modify the meson_uart_dt match data for g12a, a1, and s4 to > > their appropriate values to ensure proper devname values and > > functionality. > > I'm not confident about modifying a global struct from a probe, > I think you should add a separate meson_uart_driver/meson_serial_console couple > with ttyS instead of ttyAML, refer to the right uart_driver in meson_uart_data > and in probe() register it and pass it to uart_add_one_port(). Could you provide some insight into why you believe this solution may not be acceptable? It appears that the meson_uart_driver and meson_serial_console are not labeled with __init, which means it stay in memory forever. To clarify, are you suggesting a solution that involves segregating the meson_uart_driver and meson_serial_console objects for each scenario and subsequently declaring pointers to both objects within the meson_uart_data? I want to make sure that I have accurately grasped the essence of your proposed approach. > > > > For more information please refer to IRC discussion at [1]. > > > > Links: > > [1]: https://libera.irclog.whitequark.org/linux-amlogic/2023-07-03 > > > > Signed-off-by: Dmitry Rokosov > > --- > > drivers/tty/serial/meson_uart.c | 33 +++++++++++++++++++++++++++++++-- > > 1 file changed, 31 insertions(+), 2 deletions(-) > > > > diff --git a/drivers/tty/serial/meson_uart.c b/drivers/tty/serial/meson_uart.c > > index 87c0eb5f2dba..361f9326b527 100644 > > --- a/drivers/tty/serial/meson_uart.c > > +++ b/drivers/tty/serial/meson_uart.c > > @@ -82,6 +82,7 @@ static struct uart_driver meson_uart_driver; > > static struct uart_port *meson_ports[AML_UART_PORT_NUM]; > > struct meson_uart_data { > > + const char *dev_name; > > bool has_xtal_div2; > > }; > > @@ -683,6 +684,7 @@ static int meson_uart_probe_clocks(struct platform_device *pdev, > > static int meson_uart_probe(struct platform_device *pdev) > > { > > + const struct meson_uart_data *priv_data; > > struct resource *res_mem; > > struct uart_port *port; > > u32 fifosize = 64; /* Default is 64, 128 for EE UART_0 */ > > @@ -729,6 +731,18 @@ static int meson_uart_probe(struct platform_device *pdev) > > if (ret) > > return ret; > > + priv_data = device_get_match_data(&pdev->dev); > > + > > + if (priv_data) { > > + struct console *cons = meson_uart_driver.cons; > > + > > + meson_uart_driver.dev_name = priv_data->dev_name; > > + > > + if (cons) > > + strscpy(cons->name, priv_data->dev_name, > > + sizeof(cons->name)); > > + } > > + > > if (!meson_uart_driver.state) { > > ret = uart_register_driver(&meson_uart_driver); > > if (ret) > > @@ -748,7 +762,7 @@ static int meson_uart_probe(struct platform_device *pdev) > > port->x_char = 0; > > port->ops = &meson_uart_ops; > > port->fifosize = fifosize; > > - port->private_data = (void *)device_get_match_data(&pdev->dev); > > + port->private_data = (void *)priv_data; > > meson_ports[pdev->id] = port; > > platform_set_drvdata(pdev, port); > > @@ -780,6 +794,17 @@ static int meson_uart_remove(struct platform_device *pdev) > > } > > static struct meson_uart_data meson_g12a_uart_data = { > > + .dev_name = "ttyAML", > > + .has_xtal_div2 = true, > > +}; > > + > > +static struct meson_uart_data meson_a1_uart_data = { > > + .dev_name = "ttyS", > > + .has_xtal_div2 = false, > > +}; > > + > > +static struct meson_uart_data meson_s4_uart_data = { > > + .dev_name = "ttyS", > > .has_xtal_div2 = true, > > }; > > @@ -794,7 +819,11 @@ static const struct of_device_id meson_uart_dt_match[] = { > > }, > > { > > .compatible = "amlogic,meson-s4-uart", > > - .data = (void *)&meson_g12a_uart_data, > > + .data = (void *)&meson_s4_uart_data, > > + }, > > + { > > + .compatible = "amlogic,meson-a1-uart", > > + .data = (void *)&meson_a1_uart_data, > > }, > > { /* sentinel */ }, > > }; > -- Thank you, Dmitry