From: Florian Fainelli <f.fainelli@gmail.com>
To: Jeremy Linton <jeremy.linton@arm.com>,
Adrien Thierry <athierry@redhat.com>,
linux-serial@vger.kernel.org,
linux-rpi-kernel@lists.infradead.org,
linux-arm-kernel@lists.infradead.org,
linux-kernel@vger.kernel.org
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Jiri Slaby <jirislaby@kernel.org>,
Nicolas Saenz Julienne <nsaenz@kernel.org>,
Ray Jui <rjui@broadcom.com>,
Scott Branden <sbranden@broadcom.com>,
bcm-kernel-feedback-list@broadcom.com
Subject: Re: [PATCH] serial: 8250_bcm2835aux: Add ACPI support
Date: Tue, 1 Feb 2022 19:39:49 -0800 [thread overview]
Message-ID: <4502f052-9740-4e1e-0466-ddc92ff1fc0f@gmail.com> (raw)
In-Reply-To: <1ed6d576-63cb-fdd5-eaee-cc4154d25e0d@arm.com>
On 2/1/2022 12:42 PM, Jeremy Linton wrote:
> Hi,
>
> On 2/1/22 13:24, Florian Fainelli wrote:
>>
>>
>> On 2/1/2022 10:50 AM, Adrien Thierry wrote:
>>> Add ACPI support to 8250_bcm2835aux driver. This makes it possible to
>>> use the miniuart on the Raspberry Pi with the tianocore/edk2 UEFI
>>> firmware.
>>>
>>> Signed-off-by: Adrien Thierry <athierry@redhat.com>
>>> ---
>>> drivers/tty/serial/8250/8250_bcm2835aux.c | 103 +++++++++++++++++-----
>>> 1 file changed, 83 insertions(+), 20 deletions(-)
>>>
>>> diff --git a/drivers/tty/serial/8250/8250_bcm2835aux.c
>>> b/drivers/tty/serial/8250/8250_bcm2835aux.c
>>> index fd95860cd..b904b321e 100644
>>> --- a/drivers/tty/serial/8250/8250_bcm2835aux.c
>>> +++ b/drivers/tty/serial/8250/8250_bcm2835aux.c
>>> @@ -12,6 +12,7 @@
>>> * simultaneously to rs485.
>>> */
>>> +#include <linux/acpi.h>
>>> #include <linux/clk.h>
>>> #include <linux/io.h>
>>> #include <linux/module.h>
>>> @@ -44,6 +45,10 @@ struct bcm2835aux_data {
>>> u32 cntl;
>>> };
>>> +struct bcm2835_aux_serial_acpi_driver_data {
>>> + resource_size_t offset;
>>> +};
>>> +
>>> static void bcm2835aux_rs485_start_tx(struct uart_8250_port *up)
>>> {
>>> if (!(up->port.rs485.flags & SER_RS485_RX_DURING_TX)) {
>>> @@ -82,8 +87,12 @@ static int bcm2835aux_serial_probe(struct
>>> platform_device *pdev)
>>> {
>>> struct uart_8250_port up = { };
>>> struct bcm2835aux_data *data;
>>> + struct bcm2835_aux_serial_acpi_driver_data *acpi_data;
>>> struct resource *res;
>>> int ret;
>>> + resource_size_t mapbase;
>>> + resource_size_t mapsize;
>>> + unsigned int uartclk;
>>> /* allocate the custom structure */
>>> data = devm_kzalloc(&pdev->dev, sizeof(*data), GFP_KERNEL);
>>> @@ -108,10 +117,12 @@ static int bcm2835aux_serial_probe(struct
>>> platform_device *pdev)
>>> platform_set_drvdata(pdev, data);
>>> - /* get the clock - this also enables the HW */
>>> - data->clk = devm_clk_get(&pdev->dev, NULL);
>>> - if (IS_ERR(data->clk))
>>> - return dev_err_probe(&pdev->dev, PTR_ERR(data->clk), "could
>>> not get clk\n");
>>> + if (dev_of_node(&pdev->dev)) {
>>> + /* get the clock - this also enables the HW */
>>> + data->clk = devm_clk_get(&pdev->dev, NULL);
>>> + if (IS_ERR(data->clk))
>>> + return dev_err_probe(&pdev->dev, PTR_ERR(data->clk),
>>> "could not get clk\n");
>>> + }
>>
>> This does not seem necessary, if the clk is NULL when probed via ACPI,
>> all of the clk_* APIs will deal with that gracefully. If you need not
>> to treat -ENOENT as a hard error here, consider switching to
>> devm_clk_get_optional(). Given that you look at the 'clock-frequency'
>> property, you can still have some generic code, something like:
>>
>> if (IS_ERR(data->clk)) {
>> ret = device_property_read_u32(&pdev->dev, "clock-frequency",
>> &uartclk);
>> if (ret)
>> return dev_err_probe(&pdev->dev, ret, "could not get
>> clk\n");
>> }
>>
>>> /* get the interrupt */
>>> ret = platform_get_irq(pdev, 0);
>>> @@ -125,20 +136,59 @@ static int bcm2835aux_serial_probe(struct
>>> platform_device *pdev)
>>> dev_err(&pdev->dev, "memory resource not found");
>>> return -EINVAL;
>>> }
>>> - up.port.mapbase = res->start;
>>> - up.port.mapsize = resource_size(res);
>>> -
>>> - /* Check for a fixed line number */
>>> - ret = of_alias_get_id(pdev->dev.of_node, "serial");
>>> - if (ret >= 0)
>>> - up.port.line = ret;
>>> -
>>> - /* enable the clock as a last step */
>>> - ret = clk_prepare_enable(data->clk);
>>> - if (ret) {
>>> - dev_err(&pdev->dev, "unable to enable uart clock - %d\n",
>>> - ret);
>>> - return ret;
>>
>> All of that path can be common, and you can just define an offset to
>> apply to the resource at the top after you fetched the memory
>> resource. The offset will be non-0 for ACPI and 0 for non-ACPI. That
>> is, no need for the intermediate variables and conditional paths
>> whether this is ACPI apply this offset, or not.
>>
>>> +
>>> + mapbase = res->start;
>>> + mapsize = resource_size(res);
>>> +
>>> + if (has_acpi_companion(&pdev->dev)) {
>>> + const struct acpi_device_id *match;
>>> +
>>> + match =
>>> acpi_match_device(pdev->dev.driver->acpi_match_table, &pdev->dev);
>>> + if (!match)
>>> + return -ENODEV;
>>> +
>>> + acpi_data = (struct bcm2835_aux_serial_acpi_driver_data
>>> *)match->driver_data;
>>> +
>>> + /* Some UEFI implementations (e.g. tianocore/edk2 for the
>>> Raspberry Pi)
>>> + * describe the miniuart with a base address that
>>> encompasses the auxiliary
>>> + * registers shared between the miniuart and spi.
>>> + *
>>> + * This is due to historical reasons, see discussion here :
>>> + * https://edk2.groups.io/g/devel/topic/87501357#84349
>>> + *
>>> + * We need to add the offset between the miniuart and auxiliary
>>> + * registers to get the real miniuart base address.
>>
>> And ACPI on the Pi4 is so widely deployed that fixing the miniuart
>> resources is not an option at all? This really really continues to
>> contribute to my impression that ACPI on the Pi4 is a fad more than a
>> real thing, sorry.
>
> The problem again, is that this resource is legacy and used by
> windows/vmware/etc on both the rpi3 and rpi4. So, unfortunately it
> cannot really be changed without breaking existing OSs.
Cannot we create another entry that only Linux would match? This is the
first time that an attempt for ACPIfying the 8250_bcm2835aux is done as
far as upstream is concerned so any cruft of legacy that is artificial
should really be avoided and this appear to be some.
--
Florian
next prev parent reply other threads:[~2022-02-02 3:39 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-02-01 18:50 [PATCH] serial: 8250_bcm2835aux: Add ACPI support Adrien Thierry
2022-02-01 19:24 ` Florian Fainelli
2022-02-01 20:42 ` Jeremy Linton
2022-02-02 3:39 ` Florian Fainelli [this message]
2022-02-02 15:30 ` Jeremy Linton
2022-02-03 21:39 ` Adrien Thierry
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4502f052-9740-4e1e-0466-ddc92ff1fc0f@gmail.com \
--to=f.fainelli@gmail.com \
--cc=athierry@redhat.com \
--cc=bcm-kernel-feedback-list@broadcom.com \
--cc=gregkh@linuxfoundation.org \
--cc=jeremy.linton@arm.com \
--cc=jirislaby@kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-rpi-kernel@lists.infradead.org \
--cc=linux-serial@vger.kernel.org \
--cc=nsaenz@kernel.org \
--cc=rjui@broadcom.com \
--cc=sbranden@broadcom.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).