Re: [PATCH] leds: use QoS to control LED suspend behavior from userspace

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sun, Feb 4, 2018 at 3:01 PM, Jacek Anaszewski
<jacek.anaszewski@xxxxxxxxx> wrote:
> On 02/02/2018 11:19 PM, Samuel Morris wrote:
>> On Fri, Feb 2, 2018 at 3:52 PM, Jacek Anaszewski
>> <jacek.anaszewski@xxxxxxxxx> wrote:
>>> On 02/02/2018 04:40 PM, Samuel Morris wrote:
>>>> On Thu, Feb 1, 2018 at 4:29 PM, Jacek Anaszewski
>>>> <jacek.anaszewski@xxxxxxxxx> wrote:
>>>>> Hi Samuel,
>>>>>
>>>>> Thanks for the patch.
>>>>>
>>>>> On 01/30/2018 03:55 PM, Samuel Morris wrote:
>>>>>> On Tue, Jan 30, 2018 at 3:28 AM, Pavel Machek <pavel@xxxxxx> wrote:
>>>>>>> On Mon 2018-01-29 19:49:47, 0v3rdr0n3@xxxxxxxxx wrote:
>>>>>>>> From: Samuel Morris <samorris@xxxxxxxxxxx>
>>>>>>>>
>>>>>>>> Signed-off-by: Samuel Morris <samorris@xxxxxxxxxxx>
>>>>>>>
>>>>>>> But... we'll really need description what this is supposed to do.
>>>>>>
>>>>>> I have an LED that indicates to the user that the machine is still
>>>>>> powered when in suspend, so it needs to remain powered. This LED uses
>>>>>> the leds-pwm driver, but it may use a different driver on future
>>>>>> products, so making this change in that driver only would not be
>>>>>> ideal. I asked linux-pm a related question a week or two ago, and
>>>>>> Raphael Wysocki suggested looking into the PM_QOS_FLAG_NO_POWER_OFF
>>>>>> flag. This is what I came up with. I realize this is a pretty broad
>>>>>> change, but I figured I'd try the most general thing first.
>>>>>>
>>>>>>>
>>>>>>> Because at least some LEDs (keyboard LEDs on PC) can't be powered on
>>>>>>> during suspend.
>>>>>>
>>>>>> That is why I set the default behavior to PM_QOS_FLAG_NO_POWER_OFF=0 on probe.
>>>>>>
>>>>>>>
>>>>>>> Does this work for your LEDs? Do we need a way for userspace to tell
>>>>>>> if LED supports it or not?
>>>>>>
>>>>>> Yes, this fixes my problem. I could try testing on other LEDs as well
>>>>>> that use different drivers if need be.
>>>>>>
>>>>>> I didn't see any reason not to make this userspace configurable. I
>>>>>> imagine for some LEDs, the switch just won't work. Are you aware of
>>>>>> any cases where attempting to keep an LED on would cause outright
>>>>>> breakage? I would like these QoS parameters to be device tree, or
>>>>>> otherwise per-board configurable, but I'm not aware of a standard way
>>>>>> to do that. Maybe someone from linux-pm has an idea. Something like
>>>>>> that might be more reasonable than allowing default userspace
>>>>>> configurability.
>>>>>
>>>>> There is already retain-state-suspended property defined in
>>>>> Documentation/devicetree/bindings/leds/leds-gpio.txt and used
>>>>> in drivers/leds/leds-gpio.c. Now if we are going to add generic
>>>>> pm_qos support to the LED core, the DT property should be made generic
>>>>> too and moved to the Documentation/devicetree/bindings/leds/common.txt.
>>>>
>>>> Sounds good, I'll start working on it. Though I can't help but think,
>>>> if all devices share this pm_qos interface, couldn't the device tree
>>>> interface be shared as well?
>>>
>>> Could you please elaborate on that?
>>
>> It just seems odd to me that there does not seem to be a standard way
>> to set QoS parameters like PM_QOS_FLAG_NO_POWER_OFF from the device
>> tree. Each subsystem must define its own way of saying essentially the
>> same thing afaik: leds-gpio chose 'retain-state-suspended' but it
>> could be any variation on "don't power off this device in suspend".
>
> Well, that seems to be a question to pm and devicetree guys.

Yes. And further, another thing that's bothered me, I noticed this in
linux/Documentation/power/runtime_pm.txt:

Once the subsystem-level suspend callback (or the driver suspend
callback, if invoked directly) has completed successfully for the
given device, the PM core regards the device as suspended, which need
not mean that it has been put into a low power state.  It is supposed
to mean, however, that the device will not process data and will not
communicate with the CPU(s) and RAM until the appropriate resume
callback is executed for it.  The runtime PM status of a device after
successful execution of the suspend callback is 'suspended'.

I assume this applies to both runtime_suspend and system suspend. I
imagine we might not be able to make the guarantee that if we allow
any led(or any device for that matter) to remain powered that it will
not communicate with CPU(s) and RAM. Is that so? Could that cause
serious breakage if so? In my case, the pwm led does not, but if it
did communicate with CPU/RAM, and there was no serious breakage, I
would like to be able to make the decision to keep it powered.
Otherwise I simply wouldn't be able to use system suspend at all
without significant hardware changes. Maybe I'm misunderstanding
something basic though...

>
>>>>> Then, if the property is present, we shouldn't expose this setting
>>>>> to the userspace, see below.
>>>>
>>>> I'm okay with dt only configurability. Though, if you're suggesting we
>>>> should expose the flag to userspace based on whether or not it's dt
>>>> configurable, I'm not so sure. I think those decisions should be
>>>> independent.
>>>
>>> My concern here is backward compatibility - current users expect that
>>> once the property is set in DT, the behavior on suspend is guaranteed
>>> to not change.
>>
>> I see now, yes, in a later patch, if we do expose this to userspace,
>> it would only initialize to zero if there is no dt setting.
>
> I'd just not expose PM_QOS_FLAG_NO_POWER_OFF at all if DT provides
> the property but I think it needs broader discussion and involvement
> of pm and DT people.
>
> Adding devicetree@xxxxxxxxxxxxxxx and maintainers.
>
>>>> When you expose that flag with dev_pm_qos_expose_flags(),
>>>> you also expose other flags.
>>>
>>> How so? You're exposing only one flag:
>>>
>>> dev_pm_qos_expose_flags(led_cdev->dev, PM_QOS_FLAG_NO_POWER_OFF)
>>
>> Oh, yes, you're right, I don't know what I was thinking...
>>
>>>
>>> I'm not familiar with this interface, though.
>>>
>>>> I will probably just remove the userspace
>>>> configurability for now. That can go in a separate patch, and maybe
>>>> that can be configurable from the dt, or a kernel config parameter.
>>>
>>> I'm fine with that.
>>>
>>>>>>>
>>>>>>>> @@ -196,6 +197,11 @@ static int led_suspend(struct device *dev)
>>>>>>>>  {
>>>>>>>>       struct led_classdev *led_cdev = dev_get_drvdata(dev);
>>>>>>>>
>>>>>>>> +     if(dev_pm_qos_flags(dev, PM_QOS_FLAG_NO_POWER_OFF) ==
>>>>>>>> +                     PM_QOS_FLAGS_ALL) {
>>>>>>>> +             return 0;
>>>>>>>> +     }
>>>>>>>
>>>>>>> "if (". No need for { } s.
>>>>>>
>>>>>> Ok, I'll generate a new patch later if this seems likely to be integrated.
>>>>>
>>>>> Please also address problems detected by build bot [0].
>>>>
>>>> Will do.
>>>>
>>>>>
>>>>>>>> +
>>>>>>>>       if (led_cdev->flags & LED_CORE_SUSPENDRESUME)
>>>>>>>>               led_classdev_suspend(led_cdev);
>>>>>>>>
>>>>>>>> @@ -206,6 +212,11 @@ static int led_resume(struct device *dev)
>>>>>>>>  {
>>>>>>>>       struct led_classdev *led_cdev = dev_get_drvdata(dev);
>>>>>>>>
>>>>>>>> +     if(dev_pm_qos_flags(dev, PM_QOS_FLAG_NO_POWER_OFF) ==
>>>>>>>> +                     PM_QOS_FLAGS_ALL) {
>>>>>>>> +             return 0;
>>>>>>>> +     }
>>>>>>>> +
>>>>>>>>       if (led_cdev->flags & LED_CORE_SUSPENDRESUME)
>>>>>>>>               led_classdev_resume(led_cdev);
>>>>>>>>
>>>>>>>> @@ -287,6 +298,18 @@ int led_classdev_register(struct device *parent, struct led_classdev *led_cdev)
>>>>>>>>       list_add_tail(&led_cdev->node, &leds_list);
>>>>>>>>       up_write(&leds_list_lock);
>>>>>>>>
>>>>>>>> +     /* Attempt to let userspace take over the policy. */
>>>>>>>> +     ret = dev_pm_qos_expose_flags(led_cdev->dev,
>>>>>>>> +                     PM_QOS_FLAG_NO_POWER_OFF);
>>>>>>>> +     if (ret < 0) {
>>>>>>>> +             dev_warn(led_cdev->dev, "failed to expose pm_qos_no_poweroff\n");
>>>>>>>> +             return 0;
>>>>>>>> +     }
>>>>>>>> +
>>>>>>>> +     ret = dev_pm_qos_update_flags(led_cdev->dev,
>>>>>>>> +                     PM_QOS_FLAG_NO_POWER_OFF,
>>>>>>>> +                     0);
>>>>>>>> +
>>>>>
>>>>> So this part should be executed conditionally only if
>>>>> retain-state-suspended wasn't defined. BTW you will have
>>>>> to rebase your code onto some more recent code base.
>>>>>
>>>>> led_classdev_register() was renamed to of_led_classdev_register()
>>>>> in 4.12 and it now accepts struct device_node. leds-gpio.c was
>>>>> already changed to use it so it will be convenient to test the use case
>>>>> with retain-state-suspended DT property.
>>>>
>>>> Sounds good.
>>>>
>>>>>
>>>>>>>>       if (!led_cdev->max_brightness)
>>>>>>>>               led_cdev->max_brightness = LED_FULL;
>>>>>>>
>>>>>>> Best regards,
>>>>>>>                                                                         Pavel
>>>>>>> --
>>>>>>> (english) http://www.livejournal.com/~pavelmachek
>>>>>>> (cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
>>>>>>
>>>>>> thanks,
>>>>>> Sam
>>>>>>
>>>>>
>>>>> [0] https://www.spinics.net/lists/linux-leds/msg09031.html
>>>>>
>>>>> --
>>>>> Best regards,
>>>>> Jacek Anaszewski
>>>>
>>>> Thanks for the feedback,
>>>> Sam
>>>>
>>>
>>> --
>>> Best regards,
>>> Jacek Anaszewski
>>
>> thanks,
>> Sam
>>
>
> --
> Best regards,
> Jacek Anaszewski
>

thanks for the feedback,
Sam



[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux