diff options
author | Felix Fietkau <nbd@openwrt.org> | 2013-05-30 19:25:40 +0200 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2013-05-30 19:25:40 +0200 |
commit | 5da2894852546646990c6fee47c9521143176c1a (patch) | |
tree | c2ea9bbf692d5f2e05ac574583674ed25a94f756 | |
parent | a63255ff23043196fce74f143a6ebc79184fcdf2 (diff) |
allow the device data to override the interface
-rw-r--r-- | switch.c | 11 | ||||
-rw-r--r-- | switch.h | 8 |
2 files changed, 11 insertions, 8 deletions
@@ -1,5 +1,12 @@ #include "switch.h" +enum { + DATA_MODE, + DATA_MSG, + DATA_INTERFACE, + __DATA_MAX +}; + static void handle_generic(struct usbdev_data *data, struct blob_attr **tb) { fprintf(stderr, "Do generic switch!\n"); @@ -85,12 +92,16 @@ void handle_switch(struct usbdev_data *data) static const struct blobmsg_policy data_policy[__DATA_MAX] = { [DATA_MODE] = { .name = "mode", .type = BLOBMSG_TYPE_STRING }, [DATA_MSG] = { .name = "msg", .type = BLOBMSG_TYPE_ARRAY }, + [DATA_INTERFACE] = { .name = "interface", .type = BLOBMSG_TYPE_INT32 }, }; struct blob_attr *tb[__DATA_MAX]; int mode = MODE_GENERIC; blobmsg_parse(data_policy, __DATA_MAX, tb, blobmsg_data(data->info), blobmsg_data_len(data->info)); + if (tb[DATA_INTERFACE]) + data->interface = blobmsg_get_u32(tb[DATA_INTERFACE]); + if (tb[DATA_MODE]) { const char *modestr; int i; @@ -15,14 +15,6 @@ struct usbdev_data { char mfg[128], prod[128], serial[128]; }; -enum { - DATA_MODE, - DATA_MSG, - DATA_MSG2, - DATA_MSG3, - __DATA_MAX -}; - void handle_switch(struct usbdev_data *data); #endif |