Message ID | 20200217113644.21434-1-agust@denx.de |
---|---|
State | Accepted |
Commit | 5349e255ff913971d8b812eb363da62eace169bc |
Headers | show |
Series | [1/2] dm: core: Add a flag for power domain control on device removal | expand |
On 17/02/2020 12:36, Anatolij Gustschin wrote: > In various cases a power domain must stay enabled after device > removal when booting OS (i.e. serial debug console or display). > Add a flag to selectively skip switching off a power domain. > > Fixes: 52edfed65de9 ("dm: core: device: switch off power domain after device removal") > Signed-off-by: Anatolij Gustschin <agust at denx.de> > --- > drivers/core/device-remove.c | 5 +++-- > include/dm/device.h | 6 ++++++ > 2 files changed, 9 insertions(+), 2 deletions(-) > > diff --git a/drivers/core/device-remove.c b/drivers/core/device-remove.c > index 444e34b492..ff5b28cb6a 100644 > --- a/drivers/core/device-remove.c > +++ b/drivers/core/device-remove.c > @@ -194,8 +194,9 @@ int device_remove(struct udevice *dev, uint flags) > } > } > > - if (!(drv->flags & DM_FLAG_DEFAULT_PD_CTRL_OFF) && > - (dev != gd->cur_serial_dev)) > + if (!(drv->flags & > + (DM_FLAG_DEFAULT_PD_CTRL_OFF | DM_FLAG_REMOVE_WITH_PD_ON)) && > + dev != gd->cur_serial_dev) > dev_power_domain_off(dev); > > if (flags_remove(flags, drv->flags)) { > diff --git a/include/dm/device.h b/include/dm/device.h > index ab806d0b7e..a56164b19b 100644 > --- a/include/dm/device.h > +++ b/include/dm/device.h > @@ -67,6 +67,12 @@ struct driver_info; > /* Driver platdata has been read. Cleared when the device is removed */ > #define DM_FLAG_PLATDATA_VALID (1 << 12) > > +/* > + * Device is removed without switching off its power domain. This might > + * be required, i. e. for serial console (debug) output when booting OS. > + */ > +#define DM_FLAG_REMOVE_WITH_PD_ON (1 << 13) > + > /* > * One or multiple of these flags are passed to device_remove() so that > * a selective device removal as specified by the remove-stage and the > Acked-by: Neil Armstrong <narmstrong at baylibre.com> and Tested-by: Guillaume La Roque <glaroque at baylibre.com> Thanks, Neil
Hi Anatolij, On Mon, 17 Feb 2020 at 04:36, Anatolij Gustschin <agust at denx.de> wrote: > > In various cases a power domain must stay enabled after device > removal when booting OS (i.e. serial debug console or display). > Add a flag to selectively skip switching off a power domain. > > Fixes: 52edfed65de9 ("dm: core: device: switch off power domain after device removal") > Signed-off-by: Anatolij Gustschin <agust at denx.de> > --- > drivers/core/device-remove.c | 5 +++-- > include/dm/device.h | 6 ++++++ > 2 files changed, 9 insertions(+), 2 deletions(-) This seems OK. Should we add a device tree property for this? Or is the driver-level side enough. Regards, Simon
Hi Simon, On Tue, 18 Feb 2020 11:31:26 -0700 Simon Glass sjg at chromium.org wrote: > Hi Anatolij, > > On Mon, 17 Feb 2020 at 04:36, Anatolij Gustschin <agust at denx.de> wrote: > > > > In various cases a power domain must stay enabled after device > > removal when booting OS (i.e. serial debug console or display). > > Add a flag to selectively skip switching off a power domain. > > > > Fixes: 52edfed65de9 ("dm: core: device: switch off power domain after device removal") > > Signed-off-by: Anatolij Gustschin <agust at denx.de> > > --- > > drivers/core/device-remove.c | 5 +++-- > > include/dm/device.h | 6 ++++++ > > 2 files changed, 9 insertions(+), 2 deletions(-) > > This seems OK. Should we add a device tree property for this? Or is > the driver-level side enough. For all potential users I'm currently aware of the driver-level side is enough. Should this ever be required per device, then we can add a property later. -- Anatolij
Hi Anatolij, On Tue, 18 Feb 2020 at 12:42, Anatolij Gustschin <agust at denx.de> wrote: > > Hi Simon, > > On Tue, 18 Feb 2020 11:31:26 -0700 > Simon Glass sjg at chromium.org wrote: > > > Hi Anatolij, > > > > On Mon, 17 Feb 2020 at 04:36, Anatolij Gustschin <agust at denx.de> wrote: > > > > > > In various cases a power domain must stay enabled after device > > > removal when booting OS (i.e. serial debug console or display). > > > Add a flag to selectively skip switching off a power domain. > > > > > > Fixes: 52edfed65de9 ("dm: core: device: switch off power domain after device removal") > > > Signed-off-by: Anatolij Gustschin <agust at denx.de> > > > --- > > > drivers/core/device-remove.c | 5 +++-- > > > include/dm/device.h | 6 ++++++ > > > 2 files changed, 9 insertions(+), 2 deletions(-) > > > > This seems OK. Should we add a device tree property for this? Or is > > the driver-level side enough. > > For all potential users I'm currently aware of the driver-level > side is enough. Should this ever be required per device, then we > can add a property later. Reviewed-by: Simon Glass <sjg at chromium.org> Thanks, Simon
Hi Anatolij, On Tue, 18 Feb 2020 at 12:42, Anatolij Gustschin <agust at denx.de> wrote: > > Hi Simon, > > On Tue, 18 Feb 2020 11:31:26 -0700 > Simon Glass sjg at chromium.org wrote: > > > Hi Anatolij, > > > > On Mon, 17 Feb 2020 at 04:36, Anatolij Gustschin <agust at denx.de> wrote: > > > > > > In various cases a power domain must stay enabled after device > > > removal when booting OS (i.e. serial debug console or display). > > > Add a flag to selectively skip switching off a power domain. > > > > > > Fixes: 52edfed65de9 ("dm: core: device: switch off power domain after device removal") > > > Signed-off-by: Anatolij Gustschin <agust at denx.de> > > > --- > > > drivers/core/device-remove.c | 5 +++-- > > > include/dm/device.h | 6 ++++++ > > > 2 files changed, 9 insertions(+), 2 deletions(-) > > > > This seems OK. Should we add a device tree property for this? Or is > > the driver-level side enough. > > For all potential users I'm currently aware of the driver-level > side is enough. Should this ever be required per device, then we > can add a property later. Reviewed-by: Simon Glass <sjg at chromium.org> Thanks, Simon Applied to u-boot-dm, thanks!
diff --git a/drivers/core/device-remove.c b/drivers/core/device-remove.c index 444e34b492..ff5b28cb6a 100644 --- a/drivers/core/device-remove.c +++ b/drivers/core/device-remove.c @@ -194,8 +194,9 @@ int device_remove(struct udevice *dev, uint flags) } } - if (!(drv->flags & DM_FLAG_DEFAULT_PD_CTRL_OFF) && - (dev != gd->cur_serial_dev)) + if (!(drv->flags & + (DM_FLAG_DEFAULT_PD_CTRL_OFF | DM_FLAG_REMOVE_WITH_PD_ON)) && + dev != gd->cur_serial_dev) dev_power_domain_off(dev); if (flags_remove(flags, drv->flags)) { diff --git a/include/dm/device.h b/include/dm/device.h index ab806d0b7e..a56164b19b 100644 --- a/include/dm/device.h +++ b/include/dm/device.h @@ -67,6 +67,12 @@ struct driver_info; /* Driver platdata has been read. Cleared when the device is removed */ #define DM_FLAG_PLATDATA_VALID (1 << 12) +/* + * Device is removed without switching off its power domain. This might + * be required, i. e. for serial console (debug) output when booting OS. + */ +#define DM_FLAG_REMOVE_WITH_PD_ON (1 << 13) + /* * One or multiple of these flags are passed to device_remove() so that * a selective device removal as specified by the remove-stage and the
In various cases a power domain must stay enabled after device removal when booting OS (i.e. serial debug console or display). Add a flag to selectively skip switching off a power domain. Fixes: 52edfed65de9 ("dm: core: device: switch off power domain after device removal") Signed-off-by: Anatolij Gustschin <agust at denx.de> --- drivers/core/device-remove.c | 5 +++-- include/dm/device.h | 6 ++++++ 2 files changed, 9 insertions(+), 2 deletions(-)