chiark / gitweb /
delete hid2hci which moved to the bluez tree
authorKay Sievers <kay.sievers@vrfy.org>
Fri, 29 Apr 2011 12:31:53 +0000 (14:31 +0200)
committerKay Sievers <kay.sievers@vrfy.org>
Fri, 29 Apr 2011 12:31:53 +0000 (14:31 +0200)
INSTALL
Makefile.am
configure.ac
extras/hid2hci/.gitignore [deleted file]
extras/hid2hci/70-hid2hci.rules [deleted file]
extras/hid2hci/hid2hci.c [deleted file]

diff --git a/INSTALL b/INSTALL
index 09dc3f7d248135c8a57691758e06aaf5862550ee..2ea4ba50cb04dc4298c318be59a56e903a4e6124 100644 (file)
--- a/INSTALL
+++ b/INSTALL
@@ -41,8 +41,6 @@ All options:
       Enable legacy floppy support.
   --enable-edd
       Enable disk edd support.
-  --enable-hid2hci
-      Enable bluetooth hid to hci switch.
   --enable-action_modeswitch
       Enable action modeswitch support.
 
index 9db127038c93256762f1f66a144af1fbd11cce73..63bd2bf329ea66164f1a0b0d5a63a66f0b8f1f9c 100644 (file)
@@ -613,17 +613,6 @@ libexec_PROGRAMS += extras/edd_id/edd_id
 dist_udevrules_DATA += extras/edd_id/61-persistent-storage-edd.rules
 endif
 
-if ENABLE_HID2HCI
-# ------------------------------------------------------------------------------
-# Bluetooth HID devices with special magic to switch the device
-# ------------------------------------------------------------------------------
-extras_hid2hci_hid2hci_SOURCES = extras/hid2hci/hid2hci.c
-extras_hid2hci_hid2hci_CPPFLAGS = $(AM_CPPFLAGS) $(LIBUSB_CFLAGS)
-extras_hid2hci_hid2hci_LDADD = libudev/libudev-private.la $(LIBUSB_LIBS)
-dist_udevrules_DATA += extras/hid2hci/70-hid2hci.rules
-libexec_PROGRAMS += extras/hid2hci/hid2hci
-endif
-
 if ENABLE_ACTION_MODESWITCH
 # ------------------------------------------------------------------------------
 # mobile-action-modeswitch - switch Mobile Action cables into serial mode
index d5585b3c4a3839c153c5e9bb36ac812a24e337e4..a2a042ba60761018fb0f61693755466c6c3b3b8d 100644 (file)
@@ -179,19 +179,6 @@ AC_ARG_ENABLE([edd],
        [], [enable_edd=no])
 AM_CONDITIONAL([ENABLE_EDD], [test "x$enable_edd" = xyes])
 
-# ------------------------------------------------------------------------------
-# Bluetooth HID devices with special magic to switch the device
-# ------------------------------------------------------------------------------
-AC_ARG_ENABLE([hid2hci],
-       AS_HELP_STRING([--enable-hid2hci], [enable bluetooth hid to hci switch]),
-       [], [enable_hid2hci=no])
-if test "x$enable_hid2hci" = xyes; then
-       PKG_CHECK_MODULES(LIBUSB, libusb >= 0.1.12)
-       AC_SUBST(LIBUSB_CFLAGS)
-       AC_SUBST(LIBUSB_LIBS)
-fi
-AM_CONDITIONAL([ENABLE_HID2HCI], [test "x$enable_hid2hci" = xyes])
-
 # ------------------------------------------------------------------------------
 # mobile-action-modeswitch - switch Mobile Action cables into serial mode
 # ------------------------------------------------------------------------------
@@ -255,7 +242,6 @@ AC_MSG_RESULT([
        keymap:                 ${enable_keymap}
        floppy:                 ${enable_floppy}
        edd:                    ${enable_edd}
-       hid2hci:                ${enable_hid2hci}
        action_modeswitch:      ${enable_action_modeswitch}
 
        usb.ids:                ${USB_DATABASE}
diff --git a/extras/hid2hci/.gitignore b/extras/hid2hci/.gitignore
deleted file mode 100644 (file)
index efd9729..0000000
+++ /dev/null
@@ -1 +0,0 @@
-hid2hci
diff --git a/extras/hid2hci/70-hid2hci.rules b/extras/hid2hci/70-hid2hci.rules
deleted file mode 100644 (file)
index 3b36629..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-# do not edit this file, it will be overwritten on update
-
-ACTION=="remove", GOTO="hid2hci_end"
-SUBSYSTEM!="usb", GOTO="hid2hci_end"
-
-# Variety of Dell Bluetooth devices - match on a mouse device that is
-# self powered and where a HID report needs to be sent to switch modes
-# Known supported devices: 413c:8154, 413c:8158, 413c:8162
-ATTR{bInterfaceClass}=="03", ATTR{bInterfaceSubClass}=="01", ATTR{bInterfaceProtocol}=="02", \
-  ATTRS{bDeviceClass}=="00", ATTRS{idVendor}=="413c", ATTRS{bmAttributes}=="e0", \
-  RUN+="hid2hci --method=dell --devpath=%p", ENV{HID2HCI_SWITCH}="1"
-
-# Logitech devices
-KERNEL=="hiddev*", ATTRS{idVendor}=="046d", ATTRS{idProduct}=="c70[35e]", \
-  RUN+="hid2hci --method=logitech-hid --devpath=%p"
-KERNEL=="hidraw*", ATTRS{idVendor}=="046d", ATTRS{idProduct}=="c70[4abc]|c71[34bc]", \
-  RUN+="hid2hci --method=logitech-hid --devpath=%p"
-
-ENV{DEVTYPE}!="usb_device", GOTO="hid2hci_end"
-
-# When a Dell device recovers from S3, the mouse child needs to be repoked
-# Unfortunately the only event seen is the BT device disappearing, so the mouse
-# device needs to be chased down on the USB bus.
-ATTR{bDeviceClass}=="e0", ATTR{bDeviceSubClass}=="01", ATTR{bDeviceProtocol}=="01", ATTR{idVendor}=="413c", \
-  ENV{REMOVE_CMD}="/sbin/udevadm trigger --action=change --subsystem-match=usb --property-match=HID2HCI_SWITCH=1"
-
-# CSR devices
-ATTR{idVendor}=="0a12|0458|05ac", ATTR{idProduct}=="1000", RUN+="hid2hci --method=csr --devpath=%p"
-
-LABEL="hid2hci_end"
diff --git a/extras/hid2hci/hid2hci.c b/extras/hid2hci/hid2hci.c
deleted file mode 100644 (file)
index 559c6f7..0000000
+++ /dev/null
@@ -1,346 +0,0 @@
-/*
- * hid2hci : switch the radio on devices that support
- *           it from HID to HCI and back
- *
- * Copyright (C) 2003-2010  Marcel Holtmann <marcel@holtmann.org>
- * Copyright (C) 2008-2009  Mario Limonciello <mario_limonciello@dell.com>
- * Copyright (C) 2009-2011 Kay Sievers <kay.sievers@vrfy.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
- */
-
-#include <stdio.h>
-#include <errno.h>
-#include <fcntl.h>
-#include <stdint.h>
-#include <string.h>
-#include <getopt.h>
-#include <sys/ioctl.h>
-#include <linux/types.h>
-#include <linux/hiddev.h>
-#include <usb.h>
-
-#include "libudev.h"
-
-enum mode {
-       HCI = 0,
-       HID = 1,
-};
-
-static int usb_switch_csr(struct usb_dev_handle *dev, enum mode mode)
-{
-       int err;
-
-       err = usb_control_msg(dev,
-                             USB_ENDPOINT_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
-                             0, mode, 0, NULL, 0, 10000);
-       if (err == 0) {
-               err = -1;
-               errno = EALREADY;
-       } else {
-               if (errno == ETIMEDOUT)
-                       err = 0;
-       }
-       return err;
-}
-
-static int hid_logitech_send_report(int fd, const char *buf, size_t size)
-{
-       struct hiddev_report_info rinfo;
-       struct hiddev_usage_ref uref;
-       unsigned int i;
-       int err;
-
-       for (i = 0; i < size; i++) {
-               memset(&uref, 0, sizeof(uref));
-               uref.report_type = HID_REPORT_TYPE_OUTPUT;
-               uref.report_id   = 0x10;
-               uref.field_index = 0;
-               uref.usage_index = i;
-               uref.usage_code  = 0xff000001;
-               uref.value       = buf[i] & 0x000000ff;
-               err = ioctl(fd, HIDIOCSUSAGE, &uref);
-               if (err < 0)
-                       return err;
-       }
-
-       memset(&rinfo, 0, sizeof(rinfo));
-       rinfo.report_type = HID_REPORT_TYPE_OUTPUT;
-       rinfo.report_id   = 0x10;
-       rinfo.num_fields  = 1;
-       err = ioctl(fd, HIDIOCSREPORT, &rinfo);
-
-       return err;
-}
-
-static int hid_switch_logitech(const char *filename)
-{
-       char rep1[] = { 0xff, 0x80, 0x80, 0x01, 0x00, 0x00 };
-       char rep2[] = { 0xff, 0x80, 0x00, 0x00, 0x30, 0x00 };
-       char rep3[] = { 0xff, 0x81, 0x80, 0x00, 0x00, 0x00 };
-       int fd;
-       int err = -1;
-
-       fd = open(filename, O_RDWR);
-       if (fd < 0)
-               return err;
-
-       err = ioctl(fd, HIDIOCINITREPORT, 0);
-       if (err < 0)
-               goto out;
-
-       err = hid_logitech_send_report(fd, rep1, sizeof(rep1));
-       if (err < 0)
-               goto out;
-
-       err = hid_logitech_send_report(fd, rep2, sizeof(rep2));
-       if (err < 0)
-               goto out;
-
-       err = hid_logitech_send_report(fd, rep3, sizeof(rep3));
-out:
-       close(fd);
-       return err;
-}
-
-static int usb_switch_dell(struct usb_dev_handle *dev, enum mode mode)
-{
-       char report[] = { 0x7f, 0x00, 0x00, 0x00 };
-       int err;
-
-       switch (mode) {
-       case HCI:
-               report[1] = 0x13;
-               break;
-       case HID:
-               report[1] = 0x14;
-               break;
-       }
-
-       /* Don't need to check return, as might not be in use */
-       usb_detach_kernel_driver_np(dev, 0);
-
-       if (usb_claim_interface(dev, 0) < 0)
-               return -EIO;
-
-       err = usb_control_msg(dev,
-                       USB_ENDPOINT_OUT | USB_TYPE_CLASS | USB_RECIP_INTERFACE,
-                       USB_REQ_SET_CONFIGURATION, 0x7f | (0x03 << 8), 0,
-                       report, sizeof(report), 5000);
-
-       if (err == 0) {
-               err = -1;
-               errno = EALREADY;
-       } else {
-               if (errno == ETIMEDOUT)
-                       err = 0;
-       }
-       return err;
-}
-
-/*
- * libusb needs to scan and open all devices, just to to find the
- * device we already have. This should be fixed in libusb.
- */
-static struct usb_device *usb_device_open_from_udev(struct udev_device *usb_dev)
-{
-       struct usb_bus *bus;
-       const char *str;
-       int busnum;
-       int devnum;
-
-       str = udev_device_get_sysattr_value(usb_dev, "busnum");
-       if (str == NULL)
-               return NULL;
-       busnum = strtol(str, NULL, 0);
-
-       str = udev_device_get_sysattr_value(usb_dev, "devnum");
-       if (str == NULL)
-               return NULL;
-       devnum = strtol(str, NULL, 0);
-
-       usb_init();
-       usb_find_busses();
-       usb_find_devices();
-
-       for (bus = usb_get_busses(); bus; bus = bus->next) {
-               struct usb_device *dev;
-
-               if (strtol(bus->dirname, NULL, 10) != busnum)
-                       continue;
-
-               for (dev = bus->devices; dev; dev = dev->next) {
-                       if (dev->devnum == devnum)
-                               return dev;
-               }
-       }
-
-       return NULL;
-}
-
-static struct usb_dev_handle *find_device(struct udev_device *udev_dev)
-{
-       struct usb_device *dev;
-
-       dev = usb_device_open_from_udev(udev_dev);
-       if (dev == NULL)
-               return NULL;
-       return usb_open(dev);
-}
-
-static void usage(const char *error)
-{
-       if (error)
-               fprintf(stderr,"\n%s\n", error);
-       else
-               printf("hid2hci - Bluetooth HID to HCI mode switching utility\n\n");
-
-       printf("Usage: hid2hci [options]\n"
-               "  --mode=               mode to switch to [hid|hci] (default hci)\n"
-               "  --devpath=            sys device path\n"
-               "  --method=             method to use to switch [csr|logitech-hid|dell]\n"
-               "  --help\n\n");
-}
-
-int main(int argc, char *argv[])
-{
-       static const struct option options[] = {
-               { "help", no_argument, NULL, 'h' },
-               { "mode", required_argument, NULL, 'm' },
-               { "devpath", required_argument, NULL, 'p' },
-               { "method", required_argument, NULL, 'M' },
-               { }
-       };
-       enum method {
-               METHOD_UNDEF,
-               METHOD_CSR,
-               METHOD_LOGITECH_HID,
-               METHOD_DELL,
-       } method = METHOD_UNDEF;
-       struct udev *udev;
-       struct udev_device *udev_dev = NULL;
-       char syspath[PATH_MAX];
-       int (*usb_switch)(struct usb_dev_handle *dev, enum mode mode) = NULL;
-       enum mode mode = HCI;
-       const char *devpath = NULL;
-       int err = -1;
-       int rc = 1;
-
-       for (;;) {
-               int option;
-
-               option = getopt_long(argc, argv, "m:p:M:h", options, NULL);
-               if (option == -1)
-                       break;
-
-               switch (option) {
-               case 'm':
-                       if (!strcmp(optarg, "hid")) {
-                               mode = HID;
-                       } else if (!strcmp(optarg, "hci")) {
-                               mode = HCI;
-                       } else {
-                               usage("error: undefined radio mode\n");
-                               exit(1);
-                       }
-                       break;
-               case 'p':
-                       devpath = optarg;
-                       break;
-               case 'M':
-                       if (!strcmp(optarg, "csr")) {
-                               method = METHOD_CSR;
-                               usb_switch = usb_switch_csr;
-                       } else if (!strcmp(optarg, "logitech-hid")) {
-                               method = METHOD_LOGITECH_HID;
-                       } else if (!strcmp(optarg, "dell")) {
-                               method = METHOD_DELL;
-                               usb_switch = usb_switch_dell;
-                       } else {
-                               usage("error: undefined switching method\n");
-                               exit(1);
-                       }
-                       break;
-               case 'h':
-                       usage(NULL);
-               }
-       }
-
-       if (!devpath || method == METHOD_UNDEF) {
-               usage("error: --devpath= and --method= must be defined\n");
-               exit(1);
-       }
-
-       udev = udev_new();
-       if (udev == NULL)
-               goto exit;
-
-       snprintf(syspath, sizeof(syspath), "%s/%s", udev_get_sys_path(udev), devpath);
-       udev_dev = udev_device_new_from_syspath(udev, syspath);
-       if (udev_dev == NULL) {
-               fprintf(stderr, "error: could not find '%s'\n", devpath);
-               goto exit;
-       }
-
-       switch (method) {
-       case METHOD_CSR:
-       case METHOD_DELL: {
-               struct udev_device *dev;
-               struct usb_dev_handle *handle;
-               const char *type;
-
-               /* get the parent usb_device if needed */
-               dev = udev_dev;
-               type = udev_device_get_devtype(dev);
-               if (type == NULL || strcmp(type, "usb_device") != 0) {
-                       dev = udev_device_get_parent_with_subsystem_devtype(dev, "usb", "usb_device");
-                       if (dev == NULL) {
-                               fprintf(stderr, "error: could not find usb_device for '%s'\n", devpath);
-                               goto exit;
-                       }
-               }
-
-               handle = find_device(dev);
-               if (handle == NULL) {
-                       fprintf(stderr, "error: unable to handle '%s'\n",
-                               udev_device_get_syspath(dev));
-                       goto exit;
-               }
-               err = usb_switch(handle, mode);
-               break;
-       }
-       case METHOD_LOGITECH_HID: {
-               const char *device;
-
-               device = udev_device_get_devnode(udev_dev);
-               if (device == NULL) {
-                       fprintf(stderr, "error: could not find hiddev device node\n");
-                       goto exit;
-               }
-               err = hid_switch_logitech(device);
-               break;
-       }
-       default:
-               break;
-       }
-
-       if (err < 0)
-               fprintf(stderr, "error: switching device '%s' failed.\n",
-                       udev_device_get_syspath(udev_dev));
-exit:
-       udev_device_unref(udev_dev);
-       udev_unref(udev);
-       return rc;
-}