From: Bjørn Mork Date: Mon, 18 Dec 2017 14:00:55 +0000 (+0100) Subject: support Quanta and Blackberry modes X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=d8dc33512453fa73264a1990b25496da6cfd2a4a;p=oweals%2Fusbmode.git support Quanta and Blackberry modes Quanta mode was introduced in usb_modeswitch 1.2.6 and Blackberry mode in usb_modeswitch 1.2.7 Signed-off-by: Bjørn Mork --- diff --git a/convert-modeswitch.pl b/convert-modeswitch.pl index 71c2b79..48d0fd4 100755 --- a/convert-modeswitch.pl +++ b/convert-modeswitch.pl @@ -62,6 +62,8 @@ my %options = ( MBIM => $mode_option, HuaweiMode => $mode_option, HuaweiNewMode => $mode_option, + QuantaMode => $mode_option, + BlackberryMode => $mode_option, OptionMode => $mode_option, SierraMode => $mode_option, SonyMode => $mode_option, diff --git a/switch.c b/switch.c index b3f62fa..fe25e80 100644 --- a/switch.c +++ b/switch.c @@ -375,6 +375,23 @@ static void handle_mbim(struct usbdev_data *data, struct blob_attr **tb) } } +static void handle_quanta(struct usbdev_data *data, struct blob_attr **tb) +{ + int type = LIBUSB_REQUEST_TYPE_VENDOR | LIBUSB_RECIPIENT_DEVICE | LIBUSB_ENDPOINT_IN; + + detach_driver(data); + send_control_packet(data, type, 0xff, 0, 0, 8); +} + +static void handle_blackberry(struct usbdev_data *data, struct blob_attr **tb) +{ + int type = LIBUSB_REQUEST_TYPE_VENDOR | LIBUSB_RECIPIENT_DEVICE | LIBUSB_ENDPOINT_IN; + + detach_driver(data); + send_control_packet(data, type, 0xb1, 0x0000, 0, 8); + send_control_packet(data, type, 0xa9, 0x000e, 0, 8); +} + static void set_alt_setting(struct usbdev_data *data, int setting) { if (libusb_claim_interface(data->devh, data->interface)) @@ -399,6 +416,8 @@ enum { MODE_CISCO, MODE_MBIM, MODE_OPTION, + MODE_QUANTA, + MODE_BLACKBERRY, __MODE_MAX }; @@ -420,6 +439,8 @@ static const struct { [MODE_CISCO] = { "Cisco", handle_cisco }, [MODE_MBIM] = { "MBIM", handle_mbim }, [MODE_OPTION] = { "Option", handle_option }, + [MODE_QUANTA] = { "Quanta", handle_quanta }, + [MODE_BLACKBERRY] = { "Blackberry", handle_blackberry }, }; void handle_switch(struct usbdev_data *data)