eeepc-wmi: add touchpad sysfs file
authorCorentin Chary <corentincj@iksaif.net>
Sun, 6 Feb 2011 12:28:42 +0000 (13:28 +0100)
committerMatthew Garrett <mjg@redhat.com>
Mon, 28 Mar 2011 10:05:20 +0000 (06:05 -0400)
Signed-off-by: Corentin Chary <corentincj@iksaif.net>
Signed-off-by: Matthew Garrett <mjg@redhat.com>
Documentation/ABI/testing/sysfs-platform-eeepc-wmi
drivers/platform/x86/eeepc-wmi.c

index 9fc8d33e280d608549eb4d82c5043c13761e2bb3..26acb6842c444ec421350cf2b833dab8e23bac94 100644 (file)
@@ -22,3 +22,10 @@ KernelVersion:       2.6.39
 Contact:       "Corentin Chary" <corentincj@iksaif.net>
 Description:
                Control the card reader. 1 means on, 0 means off.
+
+What:          /sys/devices/platform/eeepc-wmi/touchpad
+Date:          Jan 2010
+KernelVersion: 2.6.39
+Contact:       "Corentin Chary" <corentincj@iksaif.net>
+Description:
+               Control the card touchpad. 1 means on, 0 means off.
index a78a90d886da4e562f8989f72a601d217b1162ba..16c7f2d62515d850dd99a21b2310de14914bf3bd 100644 (file)
@@ -77,6 +77,7 @@ MODULE_ALIAS("wmi:"EEEPC_WMI_MGMT_GUID);
 #define EEEPC_WMI_DEVID_BRIGHTNESS     0x00050012
 #define EEEPC_WMI_DEVID_CAMERA         0x00060013
 #define EEEPC_WMI_DEVID_CARDREADER     0x00080013
+#define EEEPC_WMI_DEVID_TOUCHPAD       0x00100011
 #define EEEPC_WMI_DEVID_TOUCHPAD_LED   0x00100012
 
 #define EEEPC_WMI_DSTS_STATUS_BIT      0x00000001
@@ -1006,6 +1007,7 @@ static ssize_t show_sys_wmi(int devid, char *buf)
                .store  = store_##_name,                                \
        }
 
+EEEPC_WMI_CREATE_DEVICE_ATTR(touchpad, 0644, EEEPC_WMI_DEVID_TOUCHPAD);
 EEEPC_WMI_CREATE_DEVICE_ATTR(camera, 0644, EEEPC_WMI_DEVID_CAMERA);
 EEEPC_WMI_CREATE_DEVICE_ATTR(cardr, 0644, EEEPC_WMI_DEVID_CARDREADER);
 
@@ -1036,6 +1038,7 @@ static struct attribute *platform_attributes[] = {
        &dev_attr_cpufv.attr,
        &dev_attr_camera.attr,
        &dev_attr_cardr.attr,
+       &dev_attr_touchpad.attr,
        NULL
 };
 
@@ -1050,6 +1053,8 @@ static mode_t eeepc_sysfs_is_visible(struct kobject *kobj,
                devid = EEEPC_WMI_DEVID_CAMERA;
        else if (attr == &dev_attr_cardr.attr)
                devid = EEEPC_WMI_DEVID_CARDREADER;
+       else if (attr == &dev_attr_touchpad.attr)
+               devid = EEEPC_WMI_DEVID_TOUCHPAD;
 
        if (devid != -1)
                supported = eeepc_wmi_get_devstate_simple(devid) != -ENODEV;