hid_err(msc->hdev, "unable to request touch data (%d)\n", ret);
 }
 
+static bool is_usb_magicmouse2(__u32 vendor, __u32 product)
+{
+       if (vendor != USB_VENDOR_ID_APPLE)
+               return false;
+       return product == USB_DEVICE_ID_APPLE_MAGICMOUSE2 ||
+              product == USB_DEVICE_ID_APPLE_MAGICMOUSE2_USBC;
+}
+
+static bool is_usb_magictrackpad2(__u32 vendor, __u32 product)
+{
+       if (vendor != USB_VENDOR_ID_APPLE)
+               return false;
+       return product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2 ||
+              product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2_USBC;
+}
+
 static int magicmouse_fetch_battery(struct hid_device *hdev)
 {
 #ifdef CONFIG_HID_BATTERY_STRENGTH
        struct hid_report_enum *report_enum;
        struct hid_report *report;
 
-       if (!hdev->battery || hdev->vendor != USB_VENDOR_ID_APPLE ||
-           (hdev->product != USB_DEVICE_ID_APPLE_MAGICMOUSE2 &&
-            hdev->product != USB_DEVICE_ID_APPLE_MAGICMOUSE2_USBC &&
-            hdev->product != USB_DEVICE_ID_APPLE_MAGICTRACKPAD2 &&
-            hdev->product != USB_DEVICE_ID_APPLE_MAGICTRACKPAD2_USBC))
+       if (!hdev->battery ||
+           (!is_usb_magicmouse2(hdev->vendor, hdev->product) &&
+            !is_usb_magictrackpad2(hdev->vendor, hdev->product)))
                return -1;
 
        report_enum = &hdev->report_enum[hdev->battery_report_type];
                return ret;
        }
 
-       timer_setup(&msc->battery_timer, magicmouse_battery_timer_tick, 0);
-       mod_timer(&msc->battery_timer,
-                 jiffies + msecs_to_jiffies(USB_BATTERY_TIMEOUT_MS));
-       magicmouse_fetch_battery(hdev);
-
-       if (id->vendor == USB_VENDOR_ID_APPLE &&
-           (id->product == USB_DEVICE_ID_APPLE_MAGICMOUSE2 ||
-            id->product == USB_DEVICE_ID_APPLE_MAGICMOUSE2_USBC ||
-            ((id->product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2 ||
-              id->product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2_USBC) &&
-             hdev->type != HID_TYPE_USBMOUSE)))
+       if (is_usb_magicmouse2(id->vendor, id->product) ||
+           is_usb_magictrackpad2(id->vendor, id->product)) {
+               timer_setup(&msc->battery_timer, magicmouse_battery_timer_tick, 0);
+               mod_timer(&msc->battery_timer,
+                         jiffies + msecs_to_jiffies(USB_BATTERY_TIMEOUT_MS));
+               magicmouse_fetch_battery(hdev);
+       }
+
+       if (is_usb_magicmouse2(id->vendor, id->product) ||
+           (is_usb_magictrackpad2(id->vendor, id->product) &&
+            hdev->type != HID_TYPE_USBMOUSE))
                return 0;
 
        if (!msc->input) {
 
        return 0;
 err_stop_hw:
-       timer_delete_sync(&msc->battery_timer);
+       if (is_usb_magicmouse2(id->vendor, id->product) ||
+           is_usb_magictrackpad2(id->vendor, id->product))
+               timer_delete_sync(&msc->battery_timer);
+
        hid_hw_stop(hdev);
        return ret;
 }
 
        if (msc) {
                cancel_delayed_work_sync(&msc->work);
-               timer_delete_sync(&msc->battery_timer);
+               if (is_usb_magicmouse2(hdev->vendor, hdev->product) ||
+                   is_usb_magictrackpad2(hdev->vendor, hdev->product))
+                       timer_delete_sync(&msc->battery_timer);
        }
 
        hid_hw_stop(hdev);
         *   0x05, 0x01,       // Usage Page (Generic Desktop)        0
         *   0x09, 0x02,       // Usage (Mouse)                       2
         */
-       if (hdev->vendor == USB_VENDOR_ID_APPLE &&
-           (hdev->product == USB_DEVICE_ID_APPLE_MAGICMOUSE2 ||
-            hdev->product == USB_DEVICE_ID_APPLE_MAGICMOUSE2_USBC ||
-            hdev->product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2 ||
-            hdev->product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2_USBC) &&
+       if ((is_usb_magicmouse2(hdev->vendor, hdev->product) ||
+            is_usb_magictrackpad2(hdev->vendor, hdev->product)) &&
            *rsize == 83 && rdesc[46] == 0x84 && rdesc[58] == 0x85) {
                hid_info(hdev,
                         "fixing up magicmouse battery report descriptor\n");