Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/orbcode/orbtrace
Debug and parallel trace hardware for CORTEX-M (FPGA + support code)
https://github.com/orbcode/orbtrace
Last synced: 15 days ago
JSON representation
Debug and parallel trace hardware for CORTEX-M (FPGA + support code)
- Host: GitHub
- URL: https://github.com/orbcode/orbtrace
- Owner: orbcode
- License: other
- Created: 2021-03-13T20:55:35.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-12-02T23:49:44.000Z (about 1 month ago)
- Last Synced: 2024-12-06T19:17:42.234Z (about 1 month ago)
- Language: Python
- Homepage:
- Size: 3.08 MB
- Stars: 140
- Watchers: 18
- Forks: 20
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: COPYING
- Support: support/makecount.py
Awesome Lists containing this project
- amaranth-awesome - ORBTrace - HS Debug and Trace interface for ARM CORTEX-M processors. (Uncategorized / Uncategorized)
- amaranth-awesome - ORBTrace - HS Debug and Trace interface for ARM CORTEX-M processors. (Uncategorized / Uncategorized)
README
ORBTrace
========This is the repository for gateware for the ORBTrace debug tool, targetting ARM CORTEX JTAG & SWD debug and parallel TRACE.
The current gateware runs on the ORBTrace mini hardware. It can also run on the ECPIX-5 development board and (optional) breakout board which you can find in the `lcd/bob' directory. You can use Orbtrace without this breakout board, but there will be a lot of flying wires around and you're unlikely to reach the maximum speeds that are possible.
Alongside the TRACE capability, ORBTrace is a very fastest CMSIS-DAP interface. We've removed the table of speed claims for now while we do some more testing, but read speeds of 500KBytes/sec should be attainable.
On the Debug side the gateware exports cmsis-dap v1 and v2 interfaces. These have been validated against BlackMagic Probe, OpenOCD and pyOCD. Information about success with other cmsis-dap clients gratefully received (and bug reports too, so we can fix them).
On the TRACE side primary the gateware exports a USB-Bulk endpoint carrying 1-4 bit TRACE data. Testing is against Orbuculum.
Full documentation for Orbtrace is available via Read The Docs at https://orbtrace.readthedocs.io/en/latest/. You should also checkout https://orbcode.org/.
Building
--------First install dependencies:
`pdm install`
Then build the gateware by running:
`pdm run orbtrace_builder --platform orbtrace_mini --build`
(You might also want `--profile dfu` and `--profile test` if you're working on those elements. They build in separate directories.)
To burn application firmware using boot button hold down the boot button while powring on the device (Status goes purple), then;
`dfu-util -d 1209:3442 -a 1 -D build/orbtrace_mini/gateware/orbtrace_mini.bit`
and power cycle.
To burn bootloader and application using openFPGALoader;
`openFPGALoader -c ft232 -f -o 0x0 build/orbtrace_mini_dfu/gateware/orbtrace_mini.bit`
and
`openFPGALoader -c ft232 -f -o 0x100000 build/orbtrace_mini/gateware/orbtrace_mini.bit`
You may need udev rules, in which case add a file 99-orbtrace.rules into /etc/udev/rules.d with the following contents;
```
SUBSYSTEMS=="usb", ATTRS{idVendor}=="1209", ATTRS{idProduct}=="3443", GROUP="plugdev", MODE="0666"
SUBSYSTEMS=="usb", ATTRS{idVendor}=="1209", ATTRS{idProduct}=="3442", GROUP="plugdev", MODE="0666"
```...you can then activate the new rules with `sudo udevadm control --reload-rules && sudo udevadm trigger`.
Thanks and stuff
----------------Orbtrace is built on top of a whole slew of other projects, and it simply wouldn't be possible without the effort of literally hundreds of very smart people across the net. Thanks are due to all of them for contributing to the common good that is Open Source. You are more than welcome to use the material here, but whatever the words of the various licences attached to these files, on your honour please respect the Open Source ethos, pay it forward, and go out of your way to be nice to others.