[RESEND PATCH 1/2] spi: rockchip: Convert to late and early system PM callbacks
jeffy
jeffy.chen at rock-chips.com
Fri Oct 13 11:19:28 PDT 2017
Hi guys,
it looks like the suspend sequence depends on the dt node sequence, and
we are putting display-subsystem dt node above spi dt node, so it would
be earlier in the device list, then got suspended later than spi device.
the pwm backlight and cros_ec_spi pwm are very interesting, not only
about suspend dependency... if we unbind cros_ec_spi pwm, the pwm
backlight would still hold a reference to it, and crash the kernel later.
On 10/14/2017 12:42 AM, Mark Brown wrote:
> On Fri, Oct 13, 2017 at 08:51:21AM -0700, Brian Norris wrote:
>
>> Yes, this does seem odd to me too. This looks like an arms race hack
>> that should be avoided unless we know a legit root cause. Also,
>> "probe order implies suspend order" doesn't quite work for async suspend
>> anyway, so we'd probably want to express the dependency properly
>> anyway.
>
> Yeah, it's the same stuff as we get with initcall ordering. This sort
> of thing does happen with things like PMICs which tend to have hardware
> that the system wants to manipulate in the IRQs off part of suspend.
> Ideally the dependency annotation stuff would figure things out though
> I'm not sure what the status of that is.
>
>> Any chance this is related? Seems like that might break the parent/child
>> relationship for master/slave:
>
>> commit d7e2ee257038baeb03baef602500368a51ee9eef
>> Author: Linus Walleij <linus.walleij at linaro.org>
>> Date: Mon Apr 11 13:51:03 2016 +0200
>
>> spi: let SPI masters ignore their children for PM
>
> That's for runtime PM, I'd not expect it to affect system suspend.
>
More information about the linux-arm-kernel
mailing list