Hi Anatolij,

> Subject: [PATCH v2 2/2] serial: lpuart: request dm device removal when
> booting OS
> 
> Extend the driver to allow dm device removal, but always let the console
> serial device power domain enabled, so that U-Boot doesn't crash when i. e.
> the serial output is enabled for debugging.
> 
> Signed-off-by: Anatolij Gustschin <ag...@denx.de>
> ---
> Changes in v2:
>  - None
> 
>  drivers/serial/serial_lpuart.c | 9 +++++++++
>  1 file changed, 9 insertions(+)
> 
> diff --git a/drivers/serial/serial_lpuart.c b/drivers/serial/serial_lpuart.c 
> index
> 57dd4a72c6..b028f4b35f 100644
> --- a/drivers/serial/serial_lpuart.c
> +++ b/drivers/serial/serial_lpuart.c
> @@ -489,6 +489,13 @@ static int lpuart_serial_probe(struct udevice *dev)
>               return _lpuart_serial_init(dev);
>  }
> 
> +static int lpuart_serial_remove(struct udevice *dev) {
> +     if (dev == gd->cur_serial_dev)
> +             dev->flags |= DM_FLAG_REMOVE_WITH_PD_ON;

How about introduce a device tree property for DM? Then
Set the flags in common code, not in specific driver.

Thanks,
Peng

> +     return 0;
> +}
> +
>  static int lpuart_serial_ofdata_to_platdata(struct udevice *dev)  {
>       struct lpuart_serial_platdata *plat = dev->platdata; @@ -543,5 +550,7
> @@ U_BOOT_DRIVER(serial_lpuart) = {
>       .ofdata_to_platdata = lpuart_serial_ofdata_to_platdata,
>       .platdata_auto_alloc_size = sizeof(struct lpuart_serial_platdata),
>       .probe = lpuart_serial_probe,
> +     .remove = lpuart_serial_remove,
>       .ops    = &lpuart_serial_ops,
> +     .flags  = DM_FLAG_OS_PREPARE,
>  };
> --
> 2.17.1

_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot

Reply via email to