Re: [PATCH -next] misc: rtsx: fix build for CONFIG_PM not set
From: Paul Cercueil
Date: Sun Feb 27 2022 - 12:56:45 EST
Le dim., févr. 27 2022 at 18:51:38 +0100, Arnd Bergmann
<arnd@xxxxxxxx> a écrit :
On Sun, Feb 27, 2022 at 6:46 PM Paul Cercueil <paul@xxxxxxxxxxxxxxx>
wrote:
Le dim., févr. 27 2022 at 18:30:16 +0100, Arnd Bergmann
There could be a DEFINE_DEV_PM_OPS(), but I don't think that's
really
needed - you can very well declare your struct dev_pm_ops without
using
one of these macros. Just make sure to use the SYSTEM_SLEEP_PM_OPS /
RUNTIME_PM_OPS macros for the callbacks and pm_ptr() for the
device.pm
pointer.
Ah, of course, so it comes down to
s/SET_SYSTEM_SLEEP_PM_OPS/SYSTEM_SLEEP_PM_OPS/ while
removing all the #ifdef an __maybe_unused annotations. The pm_ptr()
in driver.pm makes this slightly more optimized AFAICT, but has no
effect on behavior, right?
The use of SYSTEM_SLEEP_PM_OPS makes sure that the callbacks are
dropped if the dev_pm_ops is dead code, and the pm_ptr() must be used
for the compiler to know that the dev_pm_ops is dead code.
-Paul