All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press
@ 2014-07-16 11:25 Hans de Goede
  2014-07-16 11:25 ` [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness up/down keypress Hans de Goede
  2014-07-16 12:03 ` [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press Bjørn Mork
  0 siblings, 2 replies; 5+ messages in thread
From: Hans de Goede @ 2014-07-16 11:25 UTC (permalink / raw)
  To: Rafael J. Wysocki, Linus Torvalds, Bjørn Mork; +Cc: linux-acpi

Hi All,

Here is my cleaned-up version of Linus' patch to fix the 2 steps on a
brightness key press problem.

Changes compared to Linus' version:
-Move the global variables to inside struct acpi_video_device
-Rebase on top of Rafael's linux-pm linux-next branch (so on top of the
 revert of changing the brightness_switch_enabled default)

I've tested this on a laptop affected by the 2 steps problem and I can confirm
that it fixes the 2 steps issue under normal usage. I managed to trigger the
race by generating a heavy io-load, as exptected hitting the race has no
unwanted side-effects other then taking 2 steps instead of one.

Bjørn can you test this patch on your system and confirm that it does not
break things for you please ? Note that in order to apply it you first need
to do: "git revert 886129a8eebebec", as the revert has not yet reached
Linus' tree AFAIK.

Regards,

Hans
--
To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness up/down keypress
  2014-07-16 11:25 [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press Hans de Goede
@ 2014-07-16 11:25 ` Hans de Goede
  2014-07-16 12:03 ` [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press Bjørn Mork
  1 sibling, 0 replies; 5+ messages in thread
From: Hans de Goede @ 2014-07-16 11:25 UTC (permalink / raw)
  To: Rafael J. Wysocki, Linus Torvalds, Bjørn Mork
  Cc: linux-acpi, Hans de Goede

From: Linus Torvalds <torvalds@linux-foundation.org>

In various scenarious userspace will respond to brightness up/down keypresses
by increasing/decreasing the backlight brightness itself. If the kernel then
also changes the brightness this results in the brightness having changed 2
steps for a single keypress which is undesirable. See e.g. :

https://bugs.launchpad.net/gnome-settings-daemon/+bug/527157
http://askubuntu.com/questions/173921/why-does-my-thinkpad-brightness-control-skip-steps

This commit delays responding to brightness up/down keypresses by 100 ms and
if userspace in that time responds by changing the backlight itself, cancels
the kernels own handling of these keypresses, fixing the 2 steps issue.

[hdegoede@redhat.com: Move the delayed_work struct into struct
 acpi_video_device instead of having it as a global]
Tested-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
---
 drivers/acpi/video.c | 47 +++++++++++++++++++++++++++++++++++------------
 1 file changed, 35 insertions(+), 12 deletions(-)

diff --git a/drivers/acpi/video.c b/drivers/acpi/video.c
index 1a450c9..3a4a3ef 100644
--- a/drivers/acpi/video.c
+++ b/drivers/acpi/video.c
@@ -68,8 +68,8 @@ MODULE_AUTHOR("Bruno Ducrot");
 MODULE_DESCRIPTION("ACPI Video Driver");
 MODULE_LICENSE("GPL");
 
-static bool brightness_switch_enabled = 1;
-module_param(brightness_switch_enabled, bool, 0644);
+static int brightness_switch_enabled = -1;
+module_param(brightness_switch_enabled, int, 0644);
 
 /*
  * By default, we don't allow duplicate ACPI video bus devices
@@ -204,6 +204,8 @@ struct acpi_video_device {
 	struct acpi_video_device_flags flags;
 	struct acpi_video_device_cap cap;
 	struct list_head entry;
+	struct delayed_work switch_brightness_work;
+	int switch_brightness_event;
 	struct acpi_video_bus *video;
 	struct acpi_device *dev;
 	struct acpi_video_device_brightness *brightness;
@@ -270,11 +272,20 @@ static int acpi_video_get_brightness(struct backlight_device *bd)
 	return 0;
 }
 
+static void acpi_video_set_brighness_delayed(struct work_struct *work)
+{
+	struct acpi_video_device *vd = container_of(to_delayed_work(work),
+			    struct acpi_video_device, switch_brightness_work);
+
+	acpi_video_switch_brightness(vd, vd->switch_brightness_event);
+}
+
 static int acpi_video_set_brightness(struct backlight_device *bd)
 {
 	int request_level = bd->props.brightness + 2;
 	struct acpi_video_device *vd = bl_get_data(bd);
 
+	cancel_delayed_work(&vd->switch_brightness_work);
 	return acpi_video_device_lcd_set_level(vd,
 				vd->brightness->levels[request_level]);
 }
@@ -1252,6 +1263,8 @@ acpi_video_bus_get_one_device(struct acpi_device *device,
 	data->device_id = device_id;
 	data->video = video;
 	data->dev = device;
+	INIT_DELAYED_WORK(&data->switch_brightness_work,
+			  acpi_video_set_brighness_delayed);
 
 	attribute = acpi_video_get_device_attr(video, device_id);
 
@@ -1673,6 +1686,21 @@ static void acpi_video_bus_notify(struct acpi_device *device, u32 event)
 	return;
 }
 
+static void brightness_switch_event(struct acpi_video_device *video_device,
+				    u32 event)
+{
+	if (!brightness_switch_enabled)
+		return;
+
+	if (brightness_switch_enabled > 0) {
+		acpi_video_switch_brightness(video_device, event);
+		return;
+	}
+
+	video_device->switch_brightness_event = event;
+	schedule_delayed_work(&video_device->switch_brightness_work, HZ / 10);
+}
+
 static void acpi_video_device_notify(acpi_handle handle, u32 event, void *data)
 {
 	struct acpi_video_device *video_device = data;
@@ -1690,28 +1718,23 @@ static void acpi_video_device_notify(acpi_handle handle, u32 event, void *data)
 
 	switch (event) {
 	case ACPI_VIDEO_NOTIFY_CYCLE_BRIGHTNESS:	/* Cycle brightness */
-		if (brightness_switch_enabled)
-			acpi_video_switch_brightness(video_device, event);
+		brightness_switch_event(video_device, event);
 		keycode = KEY_BRIGHTNESS_CYCLE;
 		break;
 	case ACPI_VIDEO_NOTIFY_INC_BRIGHTNESS:	/* Increase brightness */
-		if (brightness_switch_enabled)
-			acpi_video_switch_brightness(video_device, event);
+		brightness_switch_event(video_device, event);
 		keycode = KEY_BRIGHTNESSUP;
 		break;
 	case ACPI_VIDEO_NOTIFY_DEC_BRIGHTNESS:	/* Decrease brightness */
-		if (brightness_switch_enabled)
-			acpi_video_switch_brightness(video_device, event);
+		brightness_switch_event(video_device, event);
 		keycode = KEY_BRIGHTNESSDOWN;
 		break;
 	case ACPI_VIDEO_NOTIFY_ZERO_BRIGHTNESS:	/* zero brightness */
-		if (brightness_switch_enabled)
-			acpi_video_switch_brightness(video_device, event);
+		brightness_switch_event(video_device, event);
 		keycode = KEY_BRIGHTNESS_ZERO;
 		break;
 	case ACPI_VIDEO_NOTIFY_DISPLAY_OFF:	/* display device off */
-		if (brightness_switch_enabled)
-			acpi_video_switch_brightness(video_device, event);
+		brightness_switch_event(video_device, event);
 		keycode = KEY_DISPLAY_OFF;
 		break;
 	default:
-- 
2.0.0


^ permalink raw reply related	[flat|nested] 5+ messages in thread

* Re: [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press
  2014-07-16 11:25 [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press Hans de Goede
  2014-07-16 11:25 ` [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness up/down keypress Hans de Goede
@ 2014-07-16 12:03 ` Bjørn Mork
  2014-07-16 14:32   ` Hans de Goede
  1 sibling, 1 reply; 5+ messages in thread
From: Bjørn Mork @ 2014-07-16 12:03 UTC (permalink / raw)
  To: Hans de Goede; +Cc: Rafael J. Wysocki, Linus Torvalds, linux-acpi

Hans de Goede <hdegoede@redhat.com> writes:

> Hi All,
>
> Here is my cleaned-up version of Linus' patch to fix the 2 steps on a
> brightness key press problem.
>
> Changes compared to Linus' version:
> -Move the global variables to inside struct acpi_video_device
> -Rebase on top of Rafael's linux-pm linux-next branch (so on top of the
>  revert of changing the brightness_switch_enabled default)
>
> I've tested this on a laptop affected by the 2 steps problem and I can confirm
> that it fixes the 2 steps issue under normal usage. I managed to trigger the
> race by generating a heavy io-load, as exptected hitting the race has no
> unwanted side-effects other then taking 2 steps instead of one.
>
> Bjørn can you test this patch on your system and confirm that it does not
> break things for you please ? Note that in order to apply it you first need
> to do: "git revert 886129a8eebebec", as the revert has not yet reached
> Linus' tree AFAIK.

Tested and verified that it still works fine for me, so feel free to add

Tested-by: Bjørn Mork <bjorn@mork.no>

if you like.

But as noted earlier, I believe this poses another risk if anyone has a
config using bool input values:

-static bool brightness_switch_enabled = 1;
-module_param(brightness_switch_enabled, bool, 0644);
+static int brightness_switch_enabled = -1;
+module_param(brightness_switch_enabled, int, 0644);


I wonder if it wouldn't be better to just redefine the behaviour of
"brightness_switch_enabled = 1" to the new delayed response scheme and
avoid changing the type of this parameter?



Bjørn
--
To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press
  2014-07-16 12:03 ` [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press Bjørn Mork
@ 2014-07-16 14:32   ` Hans de Goede
  2014-07-16 21:26     ` Rafael J. Wysocki
  0 siblings, 1 reply; 5+ messages in thread
From: Hans de Goede @ 2014-07-16 14:32 UTC (permalink / raw)
  To: Bjørn Mork; +Cc: Rafael J. Wysocki, Linus Torvalds, linux-acpi

Hi,

On 07/16/2014 02:03 PM, Bjørn Mork wrote:
> Hans de Goede <hdegoede@redhat.com> writes:
> 
>> Hi All,
>>
>> Here is my cleaned-up version of Linus' patch to fix the 2 steps on a
>> brightness key press problem.
>>
>> Changes compared to Linus' version:
>> -Move the global variables to inside struct acpi_video_device
>> -Rebase on top of Rafael's linux-pm linux-next branch (so on top of the
>>  revert of changing the brightness_switch_enabled default)
>>
>> I've tested this on a laptop affected by the 2 steps problem and I can confirm
>> that it fixes the 2 steps issue under normal usage. I managed to trigger the
>> race by generating a heavy io-load, as exptected hitting the race has no
>> unwanted side-effects other then taking 2 steps instead of one.
>>
>> Bjørn can you test this patch on your system and confirm that it does not
>> break things for you please ? Note that in order to apply it you first need
>> to do: "git revert 886129a8eebebec", as the revert has not yet reached
>> Linus' tree AFAIK.
> 
> Tested and verified that it still works fine for me, so feel free to add
> 
> Tested-by: Bjørn Mork <bjorn@mork.no>
> if you like.
>

Thanks, if there is a need for a v2 I'll add your tested-by.

Rafael, if there is not going to be a v2, could you pick up this tested-by
then?

> But as noted earlier, I believe this poses another risk if anyone has a
> config using bool input values:
> 
> -static bool brightness_switch_enabled = 1;
> -module_param(brightness_switch_enabled, bool, 0644);
> +static int brightness_switch_enabled = -1;
> +module_param(brightness_switch_enabled, int, 0644);
> 

The only way I can see that being a problem is if someone is using
video.brightness_switch_enabled=N for reasons other then the 2 step
problem this patch fixes. That is not unthinkable though.

> I wonder if it wouldn't be better to just redefine the behaviour of
> "brightness_switch_enabled = 1" to the new delayed response scheme and
> avoid changing the type of this parameter?

I think that is a good idea, that would also allow to simplify the patch
somewhat more. Rafael, what is your take on this ?

Regards,

Hans
--
To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press
  2014-07-16 14:32   ` Hans de Goede
@ 2014-07-16 21:26     ` Rafael J. Wysocki
  0 siblings, 0 replies; 5+ messages in thread
From: Rafael J. Wysocki @ 2014-07-16 21:26 UTC (permalink / raw)
  To: Hans de Goede; +Cc: Bjørn Mork, Linus Torvalds, linux-acpi

On Wednesday, July 16, 2014 04:32:36 PM Hans de Goede wrote:
> Hi,
> 
> On 07/16/2014 02:03 PM, Bjørn Mork wrote:
> > Hans de Goede <hdegoede@redhat.com> writes:
> > 
> >> Hi All,
> >>
> >> Here is my cleaned-up version of Linus' patch to fix the 2 steps on a
> >> brightness key press problem.
> >>
> >> Changes compared to Linus' version:
> >> -Move the global variables to inside struct acpi_video_device
> >> -Rebase on top of Rafael's linux-pm linux-next branch (so on top of the
> >>  revert of changing the brightness_switch_enabled default)
> >>
> >> I've tested this on a laptop affected by the 2 steps problem and I can confirm
> >> that it fixes the 2 steps issue under normal usage. I managed to trigger the
> >> race by generating a heavy io-load, as exptected hitting the race has no
> >> unwanted side-effects other then taking 2 steps instead of one.
> >>
> >> Bjørn can you test this patch on your system and confirm that it does not
> >> break things for you please ? Note that in order to apply it you first need
> >> to do: "git revert 886129a8eebebec", as the revert has not yet reached
> >> Linus' tree AFAIK.
> > 
> > Tested and verified that it still works fine for me, so feel free to add
> > 
> > Tested-by: Bjørn Mork <bjorn@mork.no>
> > if you like.
> >
> 
> Thanks, if there is a need for a v2 I'll add your tested-by.
> 
> Rafael, if there is not going to be a v2, could you pick up this tested-by
> then?
> 
> > But as noted earlier, I believe this poses another risk if anyone has a
> > config using bool input values:
> > 
> > -static bool brightness_switch_enabled = 1;
> > -module_param(brightness_switch_enabled, bool, 0644);
> > +static int brightness_switch_enabled = -1;
> > +module_param(brightness_switch_enabled, int, 0644);
> > 
> 
> The only way I can see that being a problem is if someone is using
> video.brightness_switch_enabled=N for reasons other then the 2 step
> problem this patch fixes. That is not unthinkable though.
> 
> > I wonder if it wouldn't be better to just redefine the behaviour of
> > "brightness_switch_enabled = 1" to the new delayed response scheme and
> > avoid changing the type of this parameter?
> 
> I think that is a good idea, that would also allow to simplify the patch
> somewhat more. Rafael, what is your take on this ?

I prefer simpler, so why don't you do that?

Rafael

--
To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2014-07-16 21:08 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-07-16 11:25 [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press Hans de Goede
2014-07-16 11:25 ` [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness up/down keypress Hans de Goede
2014-07-16 12:03 ` [PATCH] acpi-video: Fix backlight taking 2 steps on a brightness key press Bjørn Mork
2014-07-16 14:32   ` Hans de Goede
2014-07-16 21:26     ` Rafael J. Wysocki

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.