aboutsummaryrefslogtreecommitdiffstats
path: root/minadbd
diff options
context:
space:
mode:
authorChristopher Ferris <cferris@google.com>2015-01-26 21:28:20 +0000
committerGerrit Code Review <noreply-gerritcodereview@google.com>2015-01-26 21:28:21 +0000
commitcdc38d0401f2798bb13e73d6ca290abab60fc2bf (patch)
tree1334f195c793793d4649efe53a240358cefa7e47 /minadbd
parentcad5ce81adb28e131f2521fa5e553e222e0a19f4 (diff)
parent3ed8ef02ede8539dc80adc3e6cf5650a80650763 (diff)
downloadbootable_recovery-cdc38d0401f2798bb13e73d6ca290abab60fc2bf.zip
bootable_recovery-cdc38d0401f2798bb13e73d6ca290abab60fc2bf.tar.gz
bootable_recovery-cdc38d0401f2798bb13e73d6ca290abab60fc2bf.tar.bz2
Merge "Fix the v2 descriptor handling."
Diffstat (limited to 'minadbd')
-rw-r--r--minadbd/usb_linux_client.c17
1 files changed, 6 insertions, 11 deletions
diff --git a/minadbd/usb_linux_client.c b/minadbd/usb_linux_client.c
index e7d3c48..b3a38dc 100644
--- a/minadbd/usb_linux_client.c
+++ b/minadbd/usb_linux_client.c
@@ -69,14 +69,10 @@ struct desc_v1 {
} __attribute__((packed));
struct desc_v2 {
- struct usb_functionfs_descs_head_v2 {
- __le32 magic;
- __le32 length;
- __le32 flags;
- __le32 fs_count;
- __le32 hs_count;
- __le32 ss_count;
- } __attribute__((packed)) header;
+ struct usb_functionfs_descs_head_v2 header;
+ // The rest of the structure depends on the flags in the header.
+ __le32 fs_count;
+ __le32 hs_count;
struct func_desc fs_descs, hs_descs;
} __attribute__((packed));
@@ -304,9 +300,8 @@ static void init_functionfs(struct usb_handle *h)
v2_descriptor.header.magic = cpu_to_le32(FUNCTIONFS_DESCRIPTORS_MAGIC_V2);
v2_descriptor.header.length = cpu_to_le32(sizeof(v2_descriptor));
v2_descriptor.header.flags = FUNCTIONFS_HAS_FS_DESC | FUNCTIONFS_HAS_HS_DESC;
- v2_descriptor.header.fs_count = 3;
- v2_descriptor.header.hs_count = 3;
- v2_descriptor.header.ss_count = 0;
+ v2_descriptor.fs_count = 3;
+ v2_descriptor.hs_count = 3;
v2_descriptor.fs_descs = fs_descriptors;
v2_descriptor.hs_descs = hs_descriptors;