"Rafael J. Wysocki" <[email protected]> writes:

> On Thu, Jun 29, 2017 at 8:00 PM, Sudeep Holla <[email protected]> wrote:
>> If the genpd->attach_dev or genpd->power_on fails, genpd_dev_pm_attach
>> may return -EPROBE_DEFER initially. However genpd_alloc_dev_data sets
>> the PM domain for the device unconditionally.
>>
>> When subsequent attempts are made to call genpd_dev_pm_attach, it may
>> return -EEXISTS checking dev->pm_domain without re-attempting to call
>> attach_dev or power_on.
>>
>> platform_drv_probe then attempts to call drv->probe as the return value
>> -EEXIST != -EPROBE_DEFER, which may end up in a situation where the
>> device is accessed without it's power domain switched on.
>>
>> Cc: "Rafael J. Wysocki" <[email protected]>
>> Cc: Kevin Hilman <[email protected]>
>> Cc: Ulf Hansson <[email protected]>
>> Signed-off-by: Sudeep Holla <[email protected]>
>
> Ulf, this looks like a genuine fix to me, any comments?
>

This looks like the right fix to me.

Acked-by: Kevin Hilman <[email protected]>

Reply via email to