[LEDE-DEV] [PATCH 1/3] fix support for Option modems

Bjørn Mork bjorn at mork.no
Mon Dec 18 06:00:54 PST 2017


USB_ModeSwitch version 2.3.0 introduced "OptionMode".

Signed-off-by: Bjørn Mork <bjorn at mork.no>
---
 convert-modeswitch.pl |  1 +
 switch.c              | 16 ++++++++++++++++
 2 files changed, 17 insertions(+)

diff --git a/convert-modeswitch.pl b/convert-modeswitch.pl
index 6930e5f8d668..71c2b7950cb5 100755
--- a/convert-modeswitch.pl
+++ b/convert-modeswitch.pl
@@ -62,6 +62,7 @@ my %options = (
 	MBIM => $mode_option,
 	HuaweiMode => $mode_option,
 	HuaweiNewMode => $mode_option,
+	OptionMode => $mode_option,
 	SierraMode => $mode_option,
 	SonyMode => $mode_option,
 	QisdaMode => $mode_option,
diff --git a/switch.c b/switch.c
index 587a2af05c53..b3f62fa0da29 100644
--- a/switch.c
+++ b/switch.c
@@ -152,6 +152,20 @@ static void handle_huaweinew(struct usbdev_data *data, struct blob_attr **tb)
 	send_messages(data, msgs, ARRAY_SIZE(msgs));
 }
 
+static void handle_option(struct usbdev_data *data, struct blob_attr **tb)
+{
+	static struct msg_entry msgs[] = {
+		{
+			"\x55\x53\x42\x43\x12\x34\x56\x78\x00\x00\x00\x00\x00\x00\x06\x01"
+			"\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00", 31
+		}
+	};
+
+	detach_driver(data);
+	data->need_response = false;
+	send_messages(data, msgs, ARRAY_SIZE(msgs));
+}
+
 static void handle_standardeject(struct usbdev_data *data, struct blob_attr **tb)
 {
 	static struct msg_entry msgs[] = {
@@ -384,6 +398,7 @@ enum {
 	MODE_MOBILE_ACTION,
 	MODE_CISCO,
 	MODE_MBIM,
+	MODE_OPTION,
 	__MODE_MAX
 };
 
@@ -404,6 +419,7 @@ static const struct {
 	[MODE_MOBILE_ACTION] = { "MobileAction", handle_mobile_action },
 	[MODE_CISCO] = { "Cisco", handle_cisco },
 	[MODE_MBIM] = { "MBIM", handle_mbim },
+	[MODE_OPTION] = { "Option", handle_option },
 };
 
 void handle_switch(struct usbdev_data *data)
-- 
2.11.0




More information about the Lede-dev mailing list