acpi_handle handle;             /* the handle of the hotk device */
        u32 cm_supported;               /* the control methods supported
                                           by this BIOS */
-       uint init_flag;                 /* Init flags */
        u16 event_count[128];           /* count for each event */
        struct input_dev *inputdev;
        u16 *keycode_map;
 /*
  * ACPI Helpers
  */
-static int write_acpi_int(acpi_handle handle, const char *method, int val,
-                         struct acpi_buffer *output)
+static int write_acpi_int(acpi_handle handle, const char *method, int val)
 {
        struct acpi_object_list params;
        union acpi_object in_obj;
        in_obj.type = ACPI_TYPE_INTEGER;
        in_obj.integer.value = val;
 
-       status = acpi_evaluate_object(handle, (char *)method, ¶ms, output);
+       status = acpi_evaluate_object(handle, (char *)method, ¶ms, NULL);
        return (status == AE_OK ? 0 : -1);
 }
 
        if ((ehotk->cm_supported & (0x1 << cm)) == 0)
                return -ENODEV;
 
-       if (write_acpi_int(ehotk->handle, method, value, NULL))
+       if (write_acpi_int(ehotk->handle, method, value))
                pr_warning("Error writing %s\n", method);
        return 0;
 }
        cmsg_quirk(CM_ASL_TPD, "TPD");
 }
 
-static int eeepc_hotk_check(void)
+static int eeepc_hotk_init(void)
 {
-       struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL };
+       unsigned int init_flags;
        int result;
 
        result = acpi_bus_get_status(ehotk->device);
        if (result)
                return result;
-       if (ehotk->device->status.present) {
-               if (write_acpi_int(ehotk->handle, "INIT", ehotk->init_flag,
-                                   &buffer)) {
-                       pr_err("Hotkey initialization failed\n");
-                       return -ENODEV;
-               } else {
-                       pr_notice("Hotkey init flags 0x%x\n", ehotk->init_flag);
-               }
-               /* get control methods supported */
-               if (read_acpi_int(ehotk->handle, "CMSG"
-                                  , &ehotk->cm_supported)) {
-                       pr_err("Get control methods supported failed\n");
-                       return -ENODEV;
-               } else {
-                       cmsg_quirks();
-                       pr_info("Get control methods supported: 0x%x\n",
-                               ehotk->cm_supported);
-               }
-       } else {
+       if (!ehotk->device->status.present) {
                pr_err("Hotkey device not present, aborting\n");
-               return -EINVAL;
+               return -ENODEV;
        }
+
+       init_flags = DISABLE_ASL_WLAN | DISABLE_ASL_DISPLAYSWITCH;
+       pr_notice("Hotkey init flags 0x%x\n", init_flags);
+
+       if (write_acpi_int(ehotk->handle, "INIT", init_flags)) {
+               pr_err("Hotkey initialization failed\n");
+               return -ENODEV;
+       }
+
+       /* get control methods supported */
+       if (read_acpi_int(ehotk->handle, "CMSG",
+                               &ehotk->cm_supported)) {
+               pr_err("Get control methods supported failed\n");
+               return -ENODEV;
+       }
+       cmsg_quirks();
+       pr_info("Get control methods supported: 0x%x\n", ehotk->cm_supported);
+
        return 0;
 }
 
        ehotk = kzalloc(sizeof(struct eeepc_hotk), GFP_KERNEL);
        if (!ehotk)
                return -ENOMEM;
-       ehotk->init_flag = DISABLE_ASL_WLAN | DISABLE_ASL_DISPLAYSWITCH;
        ehotk->handle = device->handle;
        strcpy(acpi_device_name(device), EEEPC_HOTK_DEVICE_NAME);
        strcpy(acpi_device_class(device), EEEPC_HOTK_CLASS);
        device->driver_data = ehotk;
        ehotk->device = device;
 
-       result = eeepc_hotk_check();
+       result = eeepc_hotk_init();
        if (result)
                goto fail_platform_driver;
        eeepc_enable_camera();