Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jiegec/jtag-remote-server
Remote JTAG server for remote debugging
https://github.com/jiegec/jtag-remote-server
jtag jtag-vpi rbb xvc
Last synced: 2 months ago
JSON representation
Remote JTAG server for remote debugging
- Host: GitHub
- URL: https://github.com/jiegec/jtag-remote-server
- Owner: jiegec
- License: mit
- Created: 2022-04-08T17:02:05.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2024-04-30T14:41:39.000Z (9 months ago)
- Last Synced: 2024-10-26T22:49:18.946Z (3 months ago)
- Topics: jtag, jtag-vpi, rbb, xvc
- Language: C++
- Homepage:
- Size: 119 KB
- Stars: 35
- Watchers: 4
- Forks: 11
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# jtag-remote-server
This tool can help you debug chips remotely. It requires libftdi to communicate with FTDI chips and exposes various protocol for remote debugging.
An example scenario where this tool might be useful:
```
┌────────┐ JTAG ┌────────┐ USB ┌──────────┐ TCP ┌──────────┐
│ FPGA ├──────┤ FTDI ├─────┤ HOST 1 ├─────┤ HOST 2 │
└────────┘ └────────┘ └──────────┘ └──────────┘
```You can run this tool on `HOST 1` and debug the chip on `HOST 2` remotely.
Supported protocols:
- Xilinx virtual cable: for Vivado
- Remote bitbang: for OpenOCD
- JTAG vpi: for OpenOCDSupported adapters:
- FT2232/FT4232 based Xilinx cables
- USB Blaster
- Digilent HS2/HS3 (Specify via `-a hs2` or `-a hs3`)Some example OpenOCD configs are provided under `examples` directory.
## Example usage
For example, you use MacBook and Arty A7 for FPGA development, you can:
1. Run this tool with xvc interface (ftdi chip here has pid=0x6010): `./jtag-remote-server -p 6010 -x` (`-p 6010` means pid=0x6010, `-x` means Xilinx Virtual Cable)
2. Use ssh to forward local port to Linux server: `ssh -R 2542:127.0.0.1:2542 server`
3. Add Xilinx Virtual Cable in Xilinx: 127.0.0.1:2542Then you can find `xc7a35t` device in Xilinx and you can debug remotely.
For USB Blaster: `./jtag-remote-server -V 09fb -p 6001 -b`(`-V 09fb` means vid=0x09fb, `-p 6001` means pid=0x6001, `-b` means USB Blaster).
When there are multiple FTDI devices on the same system it is possible to select a specific one using it's USB bus and device ID: `./jtag-remote-server -B 1 -D 2`(`-B 1` means USB bus 1, `-D 2` means USB device 2).
## Performance
Some testing reveals that this tool can run at 14Mbps(rbb mode)/4Mbps(jtag_vpi mode)/3Mbps(xvc mode) when programming bitstream to FPGA. The speed of 14Mbps is mainly limited by the 15MHz jtag clock and could be improved by using a faster clock if the jtag tap can work under 30MHz(maximum clock frequency is 60MHz / 2). As per DS893, maximum TCK frequency of Xilinx Virtex Ultrascale devices is 20MHz(SLR-based) or 50MHz(others).
Let us analyze the difference. Both jtag_vpi & xvc mode reads tdo upon shifting, while remote bitbang might not. We made a small optimization to skip reading from mpsse for remote bitbang mode when the client does not send `R` to the server(in OpenOCD, this is `scan_type::SCAN_OUT`). In jtag_vpi & xvc mode however, it has to read every bit shifted out of tdo, and runs `write, read` sequence in a loop. This leads to a great bandwidth loss, because we have to wait the latency for each request.
A possible improvement is to group all the write requests and send them at once, and then read the responses back. This is exactly what OpenOCD has done. In OpenOCD, there is a global jtag command queue and the ftdi driver can send many asynchronous requests at the same time upon `ftdi_execute_queue()`; the jtag_vpi driver on the other hand, always runs `write + read` for each request in the queue.
The analysis above mainly focues on fpga programming, where in the most time, tdo is omitted to optimize performance. In other cases, like gdb debugging, further optimization needs to be employed.