#define NOTIFY_BRNDOWN_MIN             0x20
 #define NOTIFY_BRNDOWN_MAX             0x2e
 #define NOTIFY_FNLOCK_TOGGLE           0x4e
+#define NOTIFY_KBD_DOCK_CHANGE         0x75
 #define NOTIFY_KBD_BRTUP               0xc4
 #define NOTIFY_KBD_BRTDWN              0xc5
 #define NOTIFY_KBD_BRTTOGGLE           0xc7
 
 static int asus_wmi_input_init(struct asus_wmi *asus)
 {
-       int err;
+       int err, result;
 
        asus->inputdev = input_allocate_device();
        if (!asus->inputdev)
        if (err)
                goto err_free_dev;
 
+       result = asus_wmi_get_devstate_simple(asus, ASUS_WMI_DEVID_KBD_DOCK);
+       if (result >= 0) {
+               input_set_capability(asus->inputdev, EV_SW, SW_TABLET_MODE);
+               input_report_switch(asus->inputdev, SW_TABLET_MODE, !result);
+       } else if (result != -ENODEV) {
+               pr_err("Error checking for keyboard-dock: %d\n", result);
+       }
+
        err = input_register_device(asus->inputdev);
        if (err)
                goto err_free_dev;
 
 static void asus_wmi_handle_event_code(int code, struct asus_wmi *asus)
 {
-       int orig_code;
        unsigned int key_value = 1;
        bool autorelease = 1;
+       int result, orig_code;
 
        orig_code = code;
 
                return;
        }
 
+       if (code == NOTIFY_KBD_DOCK_CHANGE) {
+               result = asus_wmi_get_devstate_simple(asus,
+                                                     ASUS_WMI_DEVID_KBD_DOCK);
+               if (result >= 0) {
+                       input_report_switch(asus->inputdev, SW_TABLET_MODE,
+                                           !result);
+                       input_sync(asus->inputdev);
+               }
+               return;
+       }
+
        if (asus->fan_boost_mode_available && code == NOTIFY_KBD_FBM) {
                fan_boost_mode_switch_next(asus);
                return;