* [PATCH] tty/serial: at91: restore dynamic driver binding
@ 2016-02-23 16:59 Romain Izard
2016-02-23 19:18 ` Paul Gortmaker
2016-02-24 14:53 ` Nicolas Ferre
0 siblings, 2 replies; 5+ messages in thread
From: Romain Izard @ 2016-02-23 16:59 UTC (permalink / raw)
To: linux-serial, Greg Kroah-Hartman, Nicolas Ferre
Cc: linux-kernel, Paul Gortmaker, Jiri Slaby, Romain Izard
In commit c39dfebc7798956fd2140ae6321786ff35da30c3, the modular support
code for atmel_serial was removed, as the driver cannot be built as a
module. Because no use case was proposed, the dynamic driver binding
support was removed as well.
The atmel_serial driver can manage up to 7 serial controllers, which are
multiplexed with other functions. For example, in the Atmel SAMA5D2, the
Flexcom controllers can work as USART, SPI or I2C controllers, and on
all Atmel devices serial lines can be reconfigured as GPIOs.
My use case uses GPIOs to transfer a firmware update using a custom
protocol on the lines used as a serial port during the normal life of
the device. If it is not possible to unbind the atmel_serial driver, the
GPIO lines remain reserved and prevent this case from working.
This patch reinstates the atmel_serial_remove function, and fixes it as
it failed to clear the "clk" field on removal, triggering an oops when
a device was bound again after being unbound.
Signed-off-by: Romain Izard <romain.izard.pro@gmail.com>
---
drivers/tty/serial/atmel_serial.c | 30 +++++++++++++++++++++++++++---
1 file changed, 27 insertions(+), 3 deletions(-)
diff --git a/drivers/tty/serial/atmel_serial.c b/drivers/tty/serial/atmel_serial.c
index 1c0884d8ef32..59e241723edc 100644
--- a/drivers/tty/serial/atmel_serial.c
+++ b/drivers/tty/serial/atmel_serial.c
@@ -2759,14 +2759,38 @@ err:
return ret;
}
+static int atmel_serial_remove(struct platform_device *pdev)
+{
+ struct uart_port *port = platform_get_drvdata(pdev);
+ struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
+ int ret = 0;
+
+ tasklet_kill(&atmel_port->tasklet);
+
+ device_init_wakeup(&pdev->dev, 0);
+
+ ret = uart_remove_one_port(&atmel_uart, port);
+
+ kfree(atmel_port->rx_ring.buf);
+
+ /* "port" is allocated statically, so we shouldn't free it */
+
+ clear_bit(port->line, atmel_ports_in_use);
+
+ clk_put(atmel_port->clk);
+ atmel_port->clk = NULL;
+
+ return ret;
+}
+
static struct platform_driver atmel_serial_driver = {
.probe = atmel_serial_probe,
+ .remove = atmel_serial_remove,
.suspend = atmel_serial_suspend,
.resume = atmel_serial_resume,
.driver = {
- .name = "atmel_usart",
- .of_match_table = of_match_ptr(atmel_serial_dt_ids),
- .suppress_bind_attrs = true,
+ .name = "atmel_usart",
+ .of_match_table = of_match_ptr(atmel_serial_dt_ids),
},
};
--
2.5.0
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH] tty/serial: at91: restore dynamic driver binding
2016-02-23 16:59 [PATCH] tty/serial: at91: restore dynamic driver binding Romain Izard
@ 2016-02-23 19:18 ` Paul Gortmaker
2016-02-24 14:09 ` Romain Izard
2016-02-24 14:53 ` Nicolas Ferre
1 sibling, 1 reply; 5+ messages in thread
From: Paul Gortmaker @ 2016-02-23 19:18 UTC (permalink / raw)
To: Romain Izard
Cc: linux-serial, Greg Kroah-Hartman, Nicolas Ferre, linux-kernel,
Jiri Slaby
[[PATCH] tty/serial: at91: restore dynamic driver binding] On 23/02/2016 (Tue 17:59) Romain Izard wrote:
> In commit c39dfebc7798956fd2140ae6321786ff35da30c3, the modular support
> code for atmel_serial was removed, as the driver cannot be built as a
> module. Because no use case was proposed, the dynamic driver binding
> support was removed as well.
>
> The atmel_serial driver can manage up to 7 serial controllers, which are
> multiplexed with other functions. For example, in the Atmel SAMA5D2, the
> Flexcom controllers can work as USART, SPI or I2C controllers, and on
> all Atmel devices serial lines can be reconfigured as GPIOs.
>
> My use case uses GPIOs to transfer a firmware update using a custom
> protocol on the lines used as a serial port during the normal life of
> the device. If it is not possible to unbind the atmel_serial driver, the
> GPIO lines remain reserved and prevent this case from working.
>
> This patch reinstates the atmel_serial_remove function, and fixes it as
> it failed to clear the "clk" field on removal, triggering an oops when
> a device was bound again after being unbound.
I'd suggest that you add a comment above the remove fcn that gives the
executive summary of the above; i.e. an unbind allows a fw update via
blah blah and hence the .remove makes sense even though the driver is
not modular.
P.
--
>
> Signed-off-by: Romain Izard <romain.izard.pro@gmail.com>
> ---
> drivers/tty/serial/atmel_serial.c | 30 +++++++++++++++++++++++++++---
> 1 file changed, 27 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/tty/serial/atmel_serial.c b/drivers/tty/serial/atmel_serial.c
> index 1c0884d8ef32..59e241723edc 100644
> --- a/drivers/tty/serial/atmel_serial.c
> +++ b/drivers/tty/serial/atmel_serial.c
> @@ -2759,14 +2759,38 @@ err:
> return ret;
> }
>
> +static int atmel_serial_remove(struct platform_device *pdev)
> +{
> + struct uart_port *port = platform_get_drvdata(pdev);
> + struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
> + int ret = 0;
> +
> + tasklet_kill(&atmel_port->tasklet);
> +
> + device_init_wakeup(&pdev->dev, 0);
> +
> + ret = uart_remove_one_port(&atmel_uart, port);
> +
> + kfree(atmel_port->rx_ring.buf);
> +
> + /* "port" is allocated statically, so we shouldn't free it */
> +
> + clear_bit(port->line, atmel_ports_in_use);
> +
> + clk_put(atmel_port->clk);
> + atmel_port->clk = NULL;
> +
> + return ret;
> +}
> +
> static struct platform_driver atmel_serial_driver = {
> .probe = atmel_serial_probe,
> + .remove = atmel_serial_remove,
> .suspend = atmel_serial_suspend,
> .resume = atmel_serial_resume,
> .driver = {
> - .name = "atmel_usart",
> - .of_match_table = of_match_ptr(atmel_serial_dt_ids),
> - .suppress_bind_attrs = true,
> + .name = "atmel_usart",
> + .of_match_table = of_match_ptr(atmel_serial_dt_ids),
> },
> };
>
> --
> 2.5.0
>
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] tty/serial: at91: restore dynamic driver binding
2016-02-23 19:18 ` Paul Gortmaker
@ 2016-02-24 14:09 ` Romain Izard
0 siblings, 0 replies; 5+ messages in thread
From: Romain Izard @ 2016-02-24 14:09 UTC (permalink / raw)
To: Paul Gortmaker
Cc: linux-serial, Greg Kroah-Hartman, Nicolas Ferre, LKML, Jiri Slaby
2016-02-23 20:18 GMT+01:00 Paul Gortmaker <paul.gortmaker@windriver.com>:
> [[PATCH] tty/serial: at91: restore dynamic driver binding] On 23/02/2016 (Tue 17:59) Romain Izard wrote:
>
>> In commit c39dfebc7798956fd2140ae6321786ff35da30c3, the modular support
>> code for atmel_serial was removed, as the driver cannot be built as a
>> module. Because no use case was proposed, the dynamic driver binding
>> support was removed as well.
>>
>> The atmel_serial driver can manage up to 7 serial controllers, which are
>> multiplexed with other functions. For example, in the Atmel SAMA5D2, the
>> Flexcom controllers can work as USART, SPI or I2C controllers, and on
>> all Atmel devices serial lines can be reconfigured as GPIOs.
>>
>> My use case uses GPIOs to transfer a firmware update using a custom
>> protocol on the lines used as a serial port during the normal life of
>> the device. If it is not possible to unbind the atmel_serial driver, the
>> GPIO lines remain reserved and prevent this case from working.
>>
>> This patch reinstates the atmel_serial_remove function, and fixes it as
>> it failed to clear the "clk" field on removal, triggering an oops when
>> a device was bound again after being unbound.
>
> I'd suggest that you add a comment above the remove fcn that gives the
> executive summary of the above; i.e. an unbind allows a fw update via
> blah blah and hence the .remove makes sense even though the driver is
> not modular.
>
OK, I'll send a v2.
Best regards,
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] tty/serial: at91: restore dynamic driver binding
2016-02-23 16:59 [PATCH] tty/serial: at91: restore dynamic driver binding Romain Izard
2016-02-23 19:18 ` Paul Gortmaker
@ 2016-02-24 14:53 ` Nicolas Ferre
2016-02-24 15:32 ` romain izard
1 sibling, 1 reply; 5+ messages in thread
From: Nicolas Ferre @ 2016-02-24 14:53 UTC (permalink / raw)
To: Romain Izard, linux-serial, Greg Kroah-Hartman
Cc: linux-kernel, Paul Gortmaker, Jiri Slaby
Le 23/02/2016 17:59, Romain Izard a écrit :
> In commit c39dfebc7798956fd2140ae6321786ff35da30c3, the modular support
> code for atmel_serial was removed, as the driver cannot be built as a
> module. Because no use case was proposed, the dynamic driver binding
> support was removed as well.
>
> The atmel_serial driver can manage up to 7 serial controllers, which are
> multiplexed with other functions. For example, in the Atmel SAMA5D2, the
> Flexcom controllers can work as USART, SPI or I2C controllers, and on
> all Atmel devices serial lines can be reconfigured as GPIOs.
Well this paragraph somehow puzzled me and made me think that you only
have to keep the serial port as "disabled" in the DT to achieve what you
had had in mind.
> My use case uses GPIOs to transfer a firmware update using a custom
> protocol on the lines used as a serial port during the normal life of
> the device. If it is not possible to unbind the atmel_serial driver, the
> GPIO lines remain reserved and prevent this case from working.
Yes, here I understand better. Your use case is somewhat uncommon as
your SoC pads can be configured for two different uses with two
different drivers in front of your hardware device...
> This patch reinstates the atmel_serial_remove function, and fixes it as
> it failed to clear the "clk" field on removal, triggering an oops when
> a device was bound again after being unbound.
Well, okay. As the modification is not that big and that the solution is
pretty elegant, I'll take it.
> Signed-off-by: Romain Izard <romain.izard.pro@gmail.com>
> ---
> drivers/tty/serial/atmel_serial.c | 30 +++++++++++++++++++++++++++---
> 1 file changed, 27 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/tty/serial/atmel_serial.c b/drivers/tty/serial/atmel_serial.c
> index 1c0884d8ef32..59e241723edc 100644
> --- a/drivers/tty/serial/atmel_serial.c
> +++ b/drivers/tty/serial/atmel_serial.c
> @@ -2759,14 +2759,38 @@ err:
> return ret;
> }
>
> +static int atmel_serial_remove(struct platform_device *pdev)
> +{
> + struct uart_port *port = platform_get_drvdata(pdev);
> + struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
> + int ret = 0;
> +
> + tasklet_kill(&atmel_port->tasklet);
> +
> + device_init_wakeup(&pdev->dev, 0);
> +
> + ret = uart_remove_one_port(&atmel_uart, port);
> +
> + kfree(atmel_port->rx_ring.buf);
> +
> + /* "port" is allocated statically, so we shouldn't free it */
> +
> + clear_bit(port->line, atmel_ports_in_use);
> +
> + clk_put(atmel_port->clk);
> + atmel_port->clk = NULL;
> +
> + return ret;
> +}
> +
> static struct platform_driver atmel_serial_driver = {
> .probe = atmel_serial_probe,
> + .remove = atmel_serial_remove,
> .suspend = atmel_serial_suspend,
> .resume = atmel_serial_resume,
> .driver = {
> - .name = "atmel_usart",
> - .of_match_table = of_match_ptr(atmel_serial_dt_ids),
> - .suppress_bind_attrs = true,
> + .name = "atmel_usart",
> + .of_match_table = of_match_ptr(atmel_serial_dt_ids),
The 2 modifications above are not related to the patch: keep them like
they were event if it's not as pretty as you would like...
> },
> };
>
>
Thanks, bye.
--
Nicolas Ferre
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] tty/serial: at91: restore dynamic driver binding
2016-02-24 14:53 ` Nicolas Ferre
@ 2016-02-24 15:32 ` romain izard
0 siblings, 0 replies; 5+ messages in thread
From: romain izard @ 2016-02-24 15:32 UTC (permalink / raw)
To: Nicolas Ferre
Cc: linux-serial, Greg Kroah-Hartman, LKML, Paul Gortmaker,
Jiri Slaby
2016-02-24 15:53 GMT+01:00 Nicolas Ferre <nicolas.ferre@atmel.com>:
> Le 23/02/2016 17:59, Romain Izard a écrit :
>> In commit c39dfebc7798956fd2140ae6321786ff35da30c3, the modular support
>> code for atmel_serial was removed, as the driver cannot be built as a
>> module. Because no use case was proposed, the dynamic driver binding
>> support was removed as well.
>>
>> The atmel_serial driver can manage up to 7 serial controllers, which are
>> multiplexed with other functions. For example, in the Atmel SAMA5D2, the
>> Flexcom controllers can work as USART, SPI or I2C controllers, and on
>> all Atmel devices serial lines can be reconfigured as GPIOs.
>
> Well this paragraph somehow puzzled me and made me think that you only
> have to keep the serial port as "disabled" in the DT to achieve what you
> had had in mind.
>
>> My use case uses GPIOs to transfer a firmware update using a custom
>> protocol on the lines used as a serial port during the normal life of
>> the device. If it is not possible to unbind the atmel_serial driver, the
>> GPIO lines remain reserved and prevent this case from working.
>
> Yes, here I understand better. Your use case is somewhat uncommon as
> your SoC pads can be configured for two different uses with two
> different drivers in front of your hardware device...
>
>> This patch reinstates the atmel_serial_remove function, and fixes it as
>> it failed to clear the "clk" field on removal, triggering an oops when
>> a device was bound again after being unbound.
>
> Well, okay. As the modification is not that big and that the solution is
> pretty elegant, I'll take it.
>
>
>> Signed-off-by: Romain Izard <romain.izard.pro@gmail.com>
>> ---
>> drivers/tty/serial/atmel_serial.c | 30 +++++++++++++++++++++++++++---
>> 1 file changed, 27 insertions(+), 3 deletions(-)
>>
>> diff --git a/drivers/tty/serial/atmel_serial.c b/drivers/tty/serial/atmel_serial.c
>> index 1c0884d8ef32..59e241723edc 100644
>> --- a/drivers/tty/serial/atmel_serial.c
>> +++ b/drivers/tty/serial/atmel_serial.c
>> @@ -2759,14 +2759,38 @@ err:
>> return ret;
>> }
>>
>> +static int atmel_serial_remove(struct platform_device *pdev)
>> +{
>> + struct uart_port *port = platform_get_drvdata(pdev);
>> + struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
>> + int ret = 0;
>> +
>> + tasklet_kill(&atmel_port->tasklet);
>> +
>> + device_init_wakeup(&pdev->dev, 0);
>> +
>> + ret = uart_remove_one_port(&atmel_uart, port);
>> +
>> + kfree(atmel_port->rx_ring.buf);
>> +
>> + /* "port" is allocated statically, so we shouldn't free it */
>> +
>> + clear_bit(port->line, atmel_ports_in_use);
>> +
>> + clk_put(atmel_port->clk);
>> + atmel_port->clk = NULL;
>> +
>> + return ret;
>> +}
>> +
>> static struct platform_driver atmel_serial_driver = {
>> .probe = atmel_serial_probe,
>> + .remove = atmel_serial_remove,
>> .suspend = atmel_serial_suspend,
>> .resume = atmel_serial_resume,
>> .driver = {
>> - .name = "atmel_usart",
>> - .of_match_table = of_match_ptr(atmel_serial_dt_ids),
>> - .suppress_bind_attrs = true,
>> + .name = "atmel_usart",
>> + .of_match_table = of_match_ptr(atmel_serial_dt_ids),
>
> The 2 modifications above are not related to the patch: keep them like
> they were event if it's not as pretty as you would like...
>
These modifications were introduced by the patch I reversed, so the
alignment just returned to what it was before Paul's patch. And I need
to remove "suppress_bind_attrs", otherwise it's not possible to unbind
the device and the driver.
Best regards,
--
Romain Izard
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2016-02-24 15:32 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-02-23 16:59 [PATCH] tty/serial: at91: restore dynamic driver binding Romain Izard
2016-02-23 19:18 ` Paul Gortmaker
2016-02-24 14:09 ` Romain Izard
2016-02-24 14:53 ` Nicolas Ferre
2016-02-24 15:32 ` romain izard
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).