On Mon, May 01, 2017 at 11:02:45PM +0930, Jonathan Woithe wrote: > On Mon, Apr 24, 2017 at 03:33:28PM +0200, Micha?? K??pie?? wrote: > > fujitsu-laptop registers two ACPI drivers: one for ACPI device FUJ02B1 > > enabling backlight control and another for ACPI device FUJ02E3 which > > handles various other stuff (hotkeys, LEDs, etc.) So far, these two > > drivers have been entangled by calls to fext_backlight() (previously > > known as call_fext_func()) in the backlight part of the module which use > > module-wide data managed by the other part of the module and accesses to > > the backlight device from within acpi_fujitsu_laptop_add(). This > > entaglement can be solved by storing an independently fetched ACPI > > handle to the FUJ02E3 device inside the data structure managed by the > > backlight part of the module. > > > > Add a field to struct fujitsu_bl for storing a handle to the FUJ02E3 > > ACPI device. Make fext_backlight() calls use that handle instead of the > > one from struct fujitsu_laptop. Move backlight power synchronization > > from acpi_fujitsu_laptop_add() to fujitsu_backlight_register(). > > > > This makes the bl_device field of struct fujitsu_bl redundant, so remove > > it. > > > > Signed-off-by: Micha?? K??pie?? <kernel@xxxxxxxxxx> > > --- > > drivers/platform/x86/fujitsu-laptop.c | 27 ++++++++++++--------------- > > 1 file changed, 12 insertions(+), 15 deletions(-) > > > > diff --git a/drivers/platform/x86/fujitsu-laptop.c b/drivers/platform/x86/fujitsu-laptop.c > > index ea3210ee83ec..5f6b34a97348 100644 > > --- a/drivers/platform/x86/fujitsu-laptop.c > > +++ b/drivers/platform/x86/fujitsu-laptop.c > > @@ -131,9 +131,9 @@ > > /* Device controlling the backlight and associated keys */ > > struct fujitsu_bl { > > acpi_handle handle; > > + acpi_handle fext_handle; > > This is the extra "handle" field I eluded to in my comment about an earlier > part of this patch series. The end result is two "handle" fields: one whose > job is obvious (fext_handle) and one whose name in no way reflects what it > might be used for (handle). One could of course adopt the view that any > unqualified handle is a generic acpi handle, but I like the clarification > which comes with the additional suffix. Perhaps "acpi_handle" is too > generic and I'm certainly not opposed to the use of something more specific. > However, IMHO leaving it as "handle" seems like an unnecessary obfuscation > without much gain. Yeah, that's a fair criticism. Naming is hard. I can see the argument for "handle" is for the system in general, "fext_handle" is for this specific subset of functionality". The alternative appears to be "plt_handle", "fuj_handle", "main_handle", or "hk_led_etc_handle ;-)" which honestly doesn't add any new information or is just silly. So, if you want to prefix handle, go ahead and do so, but I don't think it's a big deal. > > This change reinforces the shift away from ACPI drivers linked to specific > ACPI devices, and towards a focus on the driver's functionality (backlight > and "various other stuff"). With the evolution of the hardware I think this > makes sense. While the "other stuff" still needs a driver, the backlight > component is not always needed. The case for separation therefore makes > sense. > > As a point of discussion though, since the backlight driver needs access to > both FUJ02B1 and FUJ02E3, should we consider rolling both ACPI drivers into > one? Aside from conceptual neatness and perhaps a small runtime memory > footprint saving in the event that no backlight control functionality need > be provided by fujitsu-laptop, is there a whole lot to be gained through the > use of two separate drivers? This on the other hand is something we need to consider carefully. I'd like to hear from Michal on this before I comment further. -- Darren Hart VMware Open Source Technology Center