On Tue, Feb 28, 2017 at 09:44:26PM +1030, Jonathan Woithe wrote:
> On Tue, Feb 28, 2017 at 09:07:04AM +0100, Greg Kroah-Hartman wrote:
> > On Mon, Feb 27, 2017 at 10:17:55PM -0800, Darren Hart wrote:
> > > > > > > > The problem I have with this driver is that it is generally
> > > > > > > > oblivious to
> > > > > > > > the user's chosen backlight provider. It was written before
> > > > > > > > acpi_video
> > > > > > > > support for backlight control was automatically detected by the
> > > > > > > > kernel
> > > > > > > > and as such it required a fix which was allegedly provided by
> > > > > > > >
> > > > > > > > 7d5c89a615c5 ("fujitsu-laptop: fingers off backlight if
> > > > > > > > video.ko is
> > > > > > > > serving this functionality"). However, that fix was
> > > > > > > > superficial as the
> > > > > > > > module still registered its vendor-specific ACPI driver for
> > > > > > > > backlight
> > > > > > > > control. That in turn caused SBLL/SBL2 to be called when
> > > > > > > > brightness
> > > > > > > > hotkeys were pressed even when acpi_video was supposed to
> > > > > > > > handle
> > > > > > > > brightness changes, which is exactly what that patch was hoping
> > > > > > > > to
> > > > > > > > prevent. Moreover, the module unconditionally exports
> > > > > > > > backlight-related
> > > > > > > > sysfs attributes which enable userspace to change the
> > > > > > > > brightness level,
> > > > > > > > which should also only be possible when vendor backlight
> > > > > > > > control is
> > > > > > > > used. Fast forward several years and on modern Fujitsu
> > > > > > > > machines (e.g.
> > > > > > > > Lifebook E744), the kernel automatically detects that native
> > > > > > > > backlight
> > > > > > > > control [1] should be used and SBLL becomes a noop [2]. This
> > > > > > > > creates
> > > > > > > > confusion, because the driver claims that it can get/set LCD
> > > > > > > > brightness
> > > > > > > > level via the platform device's sysfs attributes, but it
> > > > > > > > actually
> > > > > > > > cannot. It gets even more confusing on Skylake machines on
> > > > > > > > which the
> > > > > > > > FUJ02B1 ACPI device is not present at all.
> > > > > > > >
> > >
> > > Right, evolved.... time to take a step back and clean it up.
> > >
> > > > > > > > The proposal I put forward in regard to the above is to remove
> > > > > > > > the three
> > > > > > > > backlight-related attributes (brightness_changed, lcd_level,
> > > > > > > > max_brightness) from the platform driver's sysfs tree. I
> > > > > > > > believe the
> > > > > > > > functions they implement should only be exposed through the
> > > > > > > > backlight
> > > > > > > > device, because the latter is only created when the user
> > > > > > > > explicitly
> > > > > > > > selects vendor backlight control or it is automatically
> > > > > > > > selected by the
> > > > > > > > kernel (this should be the case for older machines).
> > >
> > > This seems to be a good approach as in combination with the discussion
> > > below re
> > > the ACPI device, it eliminates the sysfs attributes from the platform
> > > device
> > > completely and makes the driver more consistent with others in the
> > > subsystem.
>
> I have now had a chance to revisit the historical background, especially as
> it relates to the three sysfs attributes mentioned (brightness_changed,
> lcd_level, max_brightness). It seems to me that these are most likely left
> overs from a very early version of fujitsu-laptop, originally out-of-tree,
> merged to mainline by myself and others. Like Michael I doubt there is any
> userspace utility which makes use of these. Checking the scripts which I
> personally use on my S7020 I see that I only ever use the attributes
> provided under/sys/devices/virtual/backlight/fujitsu-laptop when controlling
> the backlight. Like Michael said, it's impossible to completely rule out
> the possiblity of an obscure Fujitsu-only utility somewhere in the universe
> which makes use of the /sys/devices/platform/fujitsu-laptop/ backlight
> attributes but I think the probability of such a thing existing is
> vanishingly small. Even if there was, there is a mostly trivial mapping
> from old to new (lcd_level -> brightness, max_brightness -> max_brightness).
> Only brightness_changed isn't replicated but I'm sure something could be
> hooked if necessary.
>
> What this means is that from my perspective it is highly unlikely that
> removing the three sysfs attributes as proposed by Michael
> (brightness_changed, lcd_level, max_brightness) will break userspace in a
> practical sense. Instead, it will improve the structure of the
> fujitsu-laptop driver and make it more consistent with other platform
> drivers. Putting all this together, I have no objections to the removal as
> proposed by Michael: there appears to be far more gains than losses.
As the person who wrote the original driver, for Fujitsu, I can almost
guarantee that there is no specific "fujitsu utility" that uses that
platform driver. We just used the "normal" backlight/led interface
instead, so all should be fine there.
thanks,
greg k-h