aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSpencer Oliver <spen@spen-soft.co.uk>2014-10-02 21:54:23 +0100
committerSpencer Oliver <spen@spen-soft.co.uk>2014-10-16 12:30:50 +0000
commit885f4388144840e411512543cd92fb9335ce806a (patch)
tree4c69aa1a676bbf352876c940f382f1521a43cef7 /src
parentef02315de3392c164f18e26e06006d7f56dc1b81 (diff)
cmsis-dap: add serial number support
Change-Id: I66926d1013e2b3a43ce0d18d3599771428706b6a Signed-off-by: Spencer Oliver <spen@spen-soft.co.uk> Reviewed-on: http://openocd.zylin.com/2329 Tested-by: jenkins Reviewed-by: Andreas Fritiofson <andreas.fritiofson@gmail.com>
Diffstat (limited to 'src')
-rw-r--r--src/jtag/drivers/cmsis_dap_usb.c41
1 files changed, 40 insertions, 1 deletions
diff --git a/src/jtag/drivers/cmsis_dap_usb.c b/src/jtag/drivers/cmsis_dap_usb.c
index fd8c82e0..95f553b6 100644
--- a/src/jtag/drivers/cmsis_dap_usb.c
+++ b/src/jtag/drivers/cmsis_dap_usb.c
@@ -60,6 +60,7 @@
/* vid = pid = 0 marks the end of the list */
static uint16_t cmsis_dap_vid[MAX_USB_IDS + 1] = { 0 };
static uint16_t cmsis_dap_pid[MAX_USB_IDS + 1] = { 0 };
+static wchar_t *cmsis_dap_serial;
static bool swd_mode;
#define PACKET_SIZE (64 + 1) /* 64 bytes plus report id */
@@ -201,7 +202,12 @@ static int cmsis_dap_usb_open(void)
if (found) {
/* we have found an adapter, so exit further checks */
- break;
+ /* check serial number matches if given */
+ if (cmsis_dap_serial != NULL) {
+ if (wcscmp(cmsis_dap_serial, cur_dev->serial_number) == 0)
+ break;
+ } else
+ break;
}
cur_dev = cur_dev->next;
@@ -278,6 +284,11 @@ static void cmsis_dap_usb_close(struct cmsis_dap *dap)
cmsis_dap_handle = NULL;
}
+ if (cmsis_dap_serial) {
+ free(cmsis_dap_serial);
+ cmsis_dap_serial = NULL;
+ }
+
return;
}
@@ -1006,6 +1017,27 @@ COMMAND_HANDLER(cmsis_dap_handle_vid_pid_command)
return ERROR_OK;
}
+COMMAND_HANDLER(cmsis_dap_handle_serial_command)
+{
+ if (CMD_ARGC == 1) {
+ size_t len = mbstowcs(NULL, CMD_ARGV[0], 0);
+ cmsis_dap_serial = calloc(len + 1, sizeof(wchar_t));
+ if (cmsis_dap_serial == NULL) {
+ LOG_ERROR("unable to allocate memory");
+ return ERROR_OK;
+ }
+ if (mbstowcs(cmsis_dap_serial, CMD_ARGV[0], len + 1) == (size_t)-1) {
+ free(cmsis_dap_serial);
+ cmsis_dap_serial = NULL;
+ LOG_ERROR("unable to convert serial");
+ }
+ } else {
+ LOG_ERROR("expected exactly one argument to cmsis_dap_serial <serial-number>");
+ }
+
+ return ERROR_OK;
+}
+
static const struct command_registration cmsis_dap_subcommand_handlers[] = {
{
.name = "info",
@@ -1032,6 +1064,13 @@ static const struct command_registration cmsis_dap_command_handlers[] = {
.help = "the vendor ID and product ID of the CMSIS-DAP device",
.usage = "(vid pid)* ",
},
+ {
+ .name = "cmsis_dap_serial",
+ .handler = &cmsis_dap_handle_serial_command,
+ .mode = COMMAND_CONFIG,
+ .help = "set the serial number of the adapter",
+ .usage = "serial_string",
+ },
COMMAND_REGISTRATION_DONE
};