linux-samsung-soc.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] serial: samsung: Continue to work if DMA request fails
@ 2017-02-25 16:24 Krzysztof Kozlowski
  2017-02-25 16:28 ` Tobias Jakobi
  0 siblings, 1 reply; 3+ messages in thread
From: Krzysztof Kozlowski @ 2017-02-25 16:24 UTC (permalink / raw)
  To: Greg Kroah-Hartman, Jiri Slaby, Marek Szyprowski, linux-serial,
	linux-kernel
  Cc: linux-samsung-soc, Krzysztof Kozlowski, stable

If DMA is not available (even when configured in DeviceTree), the driver
will fail the startup procedure thus making serial console not
available.

For example this causes boot failure on QEMU ARMv7 (Exynos4210, SMDKC210):
    [    1.302575] OF: amba_device_add() failed (-19) for /amba/pdma@12680000
    ...
    [   11.435732] samsung-uart 13800000.serial: DMA request failed
    [   72.963893] samsung-uart 13800000.serial: DMA request failed
    [   73.143361] Kernel panic - not syncing: Attempted to kill init! exitcode=0x00000000

DMA is not necessary for serial to work, so continue with UART startup
after emitting a warning.

Fixes: Fixes: 62c37eedb74c ("serial: samsung: add dma reqest/release functions")
Cc: <stable@vger.kernel.org>
Signed-off-by: Krzysztof Kozlowski <krzk@kernel.org>
---
 drivers/tty/serial/samsung.c | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)

diff --git a/drivers/tty/serial/samsung.c b/drivers/tty/serial/samsung.c
index b4f86c219db1..7a17aedbf902 100644
--- a/drivers/tty/serial/samsung.c
+++ b/drivers/tty/serial/samsung.c
@@ -1031,8 +1031,10 @@ static int s3c64xx_serial_startup(struct uart_port *port)
 	if (ourport->dma) {
 		ret = s3c24xx_serial_request_dma(ourport);
 		if (ret < 0) {
-			dev_warn(port->dev, "DMA request failed\n");
-			return ret;
+			dev_warn(port->dev,
+				 "DMA request failed, DMA will not be used\n");
+			devm_kfree(port->dev, ourport->dma);
+			ourport->dma = NULL;
 		}
 	}
 
-- 
2.9.3

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [PATCH] serial: samsung: Continue to work if DMA request fails
  2017-02-25 16:24 [PATCH] serial: samsung: Continue to work if DMA request fails Krzysztof Kozlowski
@ 2017-02-25 16:28 ` Tobias Jakobi
  2017-02-25 16:34   ` Krzysztof Kozlowski
  0 siblings, 1 reply; 3+ messages in thread
From: Tobias Jakobi @ 2017-02-25 16:28 UTC (permalink / raw)
  To: Krzysztof Kozlowski, Greg Kroah-Hartman, Jiri Slaby,
	Marek Szyprowski, linux-serial, linux-kernel
  Cc: linux-samsung-soc, stable

Hello Krzysztof,

Krzysztof Kozlowski wrote:
> If DMA is not available (even when configured in DeviceTree), the driver
> will fail the startup procedure thus making serial console not
> available.
> 
> For example this causes boot failure on QEMU ARMv7 (Exynos4210, SMDKC210):
>     [    1.302575] OF: amba_device_add() failed (-19) for /amba/pdma@12680000
>     ...
>     [   11.435732] samsung-uart 13800000.serial: DMA request failed
>     [   72.963893] samsung-uart 13800000.serial: DMA request failed
>     [   73.143361] Kernel panic - not syncing: Attempted to kill init! exitcode=00000000
> 
> DMA is not necessary for serial to work, so continue with UART startup
> after emitting a warning.
> 
> Fixes: Fixes: 62c37eedb74c ("serial: samsung: add dma reqest/release functions")
> Cc: <stable@vger.kernel.org>
> Signed-off-by: Krzysztof Kozlowski <krzk@kernel.org>
> ---
>  drivers/tty/serial/samsung.c | 6 ++++--
>  1 file changed, 4 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/tty/serial/samsung.c b/drivers/tty/serial/samsung.c
> index b4f86c219db1..7a17aedbf902 100644
> --- a/drivers/tty/serial/samsung.c
> +++ b/drivers/tty/serial/samsung.c
> @@ -1031,8 +1031,10 @@ static int s3c64xx_serial_startup(struct uart_port *port)
>  	if (ourport->dma) {
>  		ret =3c24xx_serial_request_dma(ourport);
>  		if (ret < 0) {
> -			dev_warn(port->dev, "DMA request failed\n");
> -			return ret;
> +			dev_warn(port->dev,
> +				 "DMA request failed, DMA will not be used\n");
> +			devm_kfree(port->dev, ourport->dma);
> +			ourport->dma =ULL;
This line looks odd. Did you want to assign NULL here?
Also, whitespace on both sides of '='?

- Tobias

>  		}
>  	}
>  
> 

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH] serial: samsung: Continue to work if DMA request fails
  2017-02-25 16:28 ` Tobias Jakobi
@ 2017-02-25 16:34   ` Krzysztof Kozlowski
  0 siblings, 0 replies; 3+ messages in thread
From: Krzysztof Kozlowski @ 2017-02-25 16:34 UTC (permalink / raw)
  To: Tobias Jakobi
  Cc: Greg Kroah-Hartman, Jiri Slaby, Marek Szyprowski, linux-serial,
	linux-kernel, linux-samsung-soc, stable

On Sat, Feb 25, 2017 at 05:28:41PM +0100, Tobias Jakobi wrote:
> Hello Krzysztof,
> 
> Krzysztof Kozlowski wrote:
> > If DMA is not available (even when configured in DeviceTree), the driver
> > will fail the startup procedure thus making serial console not
> > available.
> > 
> > For example this causes boot failure on QEMU ARMv7 (Exynos4210, SMDKC210):
> >     [    1.302575] OF: amba_device_add() failed (-19) for /amba/pdma@12680000
> >     ...
> >     [   11.435732] samsung-uart 13800000.serial: DMA request failed
> >     [   72.963893] samsung-uart 13800000.serial: DMA request failed
> >     [   73.143361] Kernel panic - not syncing: Attempted to kill init! exitcode=00000000
> > 
> > DMA is not necessary for serial to work, so continue with UART startup
> > after emitting a warning.
> > 
> > Fixes: Fixes: 62c37eedb74c ("serial: samsung: add dma reqest/release functions")
> > Cc: <stable@vger.kernel.org>
> > Signed-off-by: Krzysztof Kozlowski <krzk@kernel.org>
> > ---
> >  drivers/tty/serial/samsung.c | 6 ++++--
> >  1 file changed, 4 insertions(+), 2 deletions(-)
> > 
> > diff --git a/drivers/tty/serial/samsung.c b/drivers/tty/serial/samsung.c
> > index b4f86c219db1..7a17aedbf902 100644
> > --- a/drivers/tty/serial/samsung.c
> > +++ b/drivers/tty/serial/samsung.c
> > @@ -1031,8 +1031,10 @@ static int s3c64xx_serial_startup(struct uart_port *port)
> >  	if (ourport->dma) {
> >  		ret =3c24xx_serial_request_dma(ourport);
> >  		if (ret < 0) {
> > -			dev_warn(port->dev, "DMA request failed\n");
> > -			return ret;
> > +			dev_warn(port->dev,
> > +				 "DMA request failed, DMA will not be used\n");
> > +			devm_kfree(port->dev, ourport->dma);
> > +			ourport->dma =ULL;
> This line looks odd. Did you want to assign NULL here?
> Also, whitespace on both sides of '='?

Ugh, I must ate it by mistake somehow because my git contains proper
"NULL" here.

Thanks for pointing this, I'll resend v3.


Best regards,
Krzysztof

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2017-02-25 16:34 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-02-25 16:24 [PATCH] serial: samsung: Continue to work if DMA request fails Krzysztof Kozlowski
2017-02-25 16:28 ` Tobias Jakobi
2017-02-25 16:34   ` Krzysztof Kozlowski

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).