RE: [PATCH 09/12] platform/x86: wmi: create character devices when requested by drivers

From: Mario.Limonciello
Date: Thu Sep 21 2017 - 15:21:20 EST


> -----Original Message-----
> From: Andy Shevchenko [mailto:andy.shevchenko@xxxxxxxxx]
> Sent: Thursday, September 21, 2017 11:47 AM
> To: Limonciello, Mario <Mario_Limonciello@xxxxxxxx>
> Cc: dvhart@xxxxxxxxxxxxx; LKML <linux-kernel@xxxxxxxxxxxxxxx>; Platform Driver
> <platform-driver-x86@xxxxxxxxxxxxxxx>; quasisec@xxxxxxxxxx; Pali RohÃr
> <pali.rohar@xxxxxxxxx>
> Subject: Re: [PATCH 09/12] platform/x86: wmi: create character devices when
> requested by drivers
>
> On Thu, Sep 21, 2017 at 4:57 PM, Mario Limonciello
> <mario.limonciello@xxxxxxxx> wrote:
> > For WMI operations that are only Set or Query read or write sysfs
> > attributes created by WMI vendor drivers make sense.
> >
> > For other WMI operations that are run on Method, there needs to be a
> > way to guarantee to userspace that the results from the method call
> > belong to the data request to the method call. Sysfs attributes don't
> > work well in this scenario because two userspace processes may be
> > competing at reading/writing an attribute and step on each other's
> > data.
> >
> > When a WMI vendor driver declares a set of functions in a
> > file_operations object the WMI bus driver will create a character
> > device that maps to those file operations.
> >
> > The WMI vendor drivers will be responsible for managing access to
> > this character device and proper locking on it.
> >
> > When a WMI vendor driver is unloaded the WMI bus driver will clean
> > up the character device.
> >
>
> > @@ -44,12 +44,17 @@
> > #include <linux/platform_device.h>
> > #include <linux/wmi.h>
> > #include <linux/uuid.h>
> > +#include <linux/cdev.h>
> > +#include <linux/idr.h>
>
> Keep alphabetical ordering.
>

The existing list wasn't in alphabetical order. I'll submit a patch in v2 earlier
in the series to sort and then put them in the right place for my patch.