Skip to content

Commit

Permalink
hosted/jlink: Expect the last byte for JTAG3 result in a single packet
Browse files Browse the repository at this point in the history
* Asking for 1 byte less raises a libusb OVERFLOW error when using
  JLink on STLinkReflash and BMDA on Linux.
* libusb docs recommend receiving into a bigger buffer (1028=512*2+4)
  and checking whether all of expected data got indeed received.
* For firmwares which send that transaction-error byte in a separate packet,
  keep the second read call.
  • Loading branch information
ALTracer committed Nov 8, 2023
1 parent 7061f22 commit c5db5f8
Showing 1 changed file with 7 additions and 4 deletions.
11 changes: 7 additions & 4 deletions src/platforms/hosted/jlink.c
Original file line number Diff line number Diff line change
Expand Up @@ -137,10 +137,13 @@ bool jlink_transfer(const uint16_t clock_cycles, const uint8_t *const tms, const
/* Copy in the TDI values to transmit (if present) */
if (tdi)
memcpy(buffer + 4U + byte_count, tdi, byte_count);
/* Send the resulting transaction and try to read back the response data */
if (bmda_usb_transfer(bmda_probe_info.usb_link, buffer, sizeof(*header) + (byte_count * 2U), buffer, byte_count,
JLINK_USB_TIMEOUT) < 0 ||
/* Try to read back the transaction return code */
/* Send the resulting transaction and try to read back the response data (including the response code first try) */
const ssize_t bytes_received = bmda_usb_transfer(bmda_probe_info.usb_link, buffer,
sizeof(*header) + (byte_count * 2U), buffer, byte_count + 1U, JLINK_USB_TIMEOUT);
if (bytes_received < 0)
return false;
/* If the first read didn't return the transaction return code, try to read it back separately */
if (bytes_received < (ssize_t)byte_count + 1 &&
bmda_usb_transfer(bmda_probe_info.usb_link, NULL, 0, buffer + byte_count, 1U, JLINK_USB_TIMEOUT) < 0)
return false;
/* Copy out the response into the TDO buffer (if present) */
Expand Down

0 comments on commit c5db5f8

Please sign in to comment.