This Arduino sketch turns your Arduino UNO into a hardware debugger for the classic ATtinys and the ATmegaX8s, such as the ATmega328. And since version 2.2.0, you can use dw-link as a (STK500 v1) programmer as well.
The debugger speaks debugWIRE and implements a gdbServer. This means that you can use GDB or any IDE that integrates GDB to debug your program while running on the target hardware (e.g., an ATtiny). And it is all platform independent, i.e., you can use it under macOS, Linux, or Windows.
Why is this good news? Arduino IDE 1.X does not support debugging at all. Even the new IDE 2.X did not provide debugging for the small AVR MCUs. With this sketch, you get a tool that allows you to set breakpoints, single-step, and inspect and set variables. And since version 4.0.0, this can all be done in the Arduino IDE 2.
Do you want to try it? Use the Quick-start Guide to see if it works for you. If you like it and want to incorporate it into your workflow, you can buy the (optional) Uno shield at Tindie.
The background and ongoing development of dw-link are topics on my blog. In particular, the blog posts tagged with dw-link will be of interest to you.
This repository contains the following directories:
- dw-link: Contains the Arduino sketch that turns your Arduino board into a hardware debugger
- docs: Contains the documentation, in particular the manual
- dw-server: Contains the Python script dw-server.py, which discovers the serial line dw-link is connected to and provides a serial-to-TCP/IP bridge
- examples: Contains two Arduino sketches and a PlatformIO project
- tests: Contains some test cases and a Python script for running them semi-automatically
- pcb: Contains design data (KiCad) for the optional dw-link probe
- testprobe: Contains a sketch to be used to run tests on freshly assembled dw-link probe
- core-mods: Contains all the modifications to the core files necessary to support the generation of debug-friendly object files
- opcodes: Contains a list of legal and illegal opcodes for large and small AVRs as well as C program to generate the lists.
Note that the debugger is a beta release and may contain bugs. If you encounter behavior that you think is wrong, try to be as specific as possible so that I can reproduce the behavior. I have prepared an issue form for that purpose. Current issues, known bugs, and limitations are listed in Section 8 of the manual.
The cover picture was designed based on vector graphics by captainvector at 123RF.