On Wed, Jan 25, 2023 at 12:26:32AM -0800, Alan Previn wrote: > From: Alexander Usyskin <alexander.usyskin@xxxxxxxxx> > > Asynchronous runtime resume is not possible while the system > is suspending. > The power management subsystem resumes the device only in the > suspend phase, not in the prepare phase. > Force resume device in prepare to allow drivers on mei bus > to communicate in their prepare callbacks. > > Signed-off-by: Alexander Usyskin <alexander.usyskin@xxxxxxxxx> > Reviewed-by: Tomas Winkler <tomas.winkler@xxxxxxxxx> > Signed-off-by: Alan Previn <alan.previn.teres.alexis@xxxxxxxxx> > --- > drivers/misc/mei/pci-me.c | 20 +++++++++++++++++++- > 1 file changed, 19 insertions(+), 1 deletion(-) > > diff --git a/drivers/misc/mei/pci-me.c b/drivers/misc/mei/pci-me.c > index 5bf0d50d55a0..676d566f38dd 100644 > --- a/drivers/misc/mei/pci-me.c > +++ b/drivers/misc/mei/pci-me.c > @@ -342,6 +342,12 @@ static void mei_me_remove(struct pci_dev *pdev) > } > > #ifdef CONFIG_PM_SLEEP > +static int mei_me_pci_prepare(struct device *device) > +{ > + pm_runtime_resume(device); > + return 0; > +} > + > static int mei_me_pci_suspend(struct device *device) > { > struct pci_dev *pdev = to_pci_dev(device); > @@ -398,7 +404,17 @@ static int mei_me_pci_resume(struct device *device) > > return 0; > } > -#endif /* CONFIG_PM_SLEEP */ > + > +static void mei_me_pci_complete(struct device *device) > +{ > + pm_runtime_suspend(device); > +} > +#else /* CONFIG_PM_SLEEP */ > + > +#define mei_me_pci_prepare NULL > +#define mei_me_pci_complete NULL > + > +#endif /* !CONFIG_PM_SLEEP */ > > #ifdef CONFIG_PM > static int mei_me_pm_runtime_idle(struct device *device) > @@ -501,6 +517,8 @@ static inline void mei_me_unset_pm_domain(struct mei_device *dev) > } > > static const struct dev_pm_ops mei_me_pm_ops = { > + .prepare = mei_me_pci_prepare, > + .complete = mei_me_pci_complete, > SET_SYSTEM_SLEEP_PM_OPS(mei_me_pci_suspend, > mei_me_pci_resume) > SET_RUNTIME_PM_OPS( > -- > 2.39.0 > Acked-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>