Hardware for debugging

There are 3 hardware options. Firmware for CH552 can be found in the github repo. Source code is located in the CH55xduino repo.

Using CH552 breakout board and ATmega328P on Breadboard

Debug Arduino on Breadboard

Using CH552 breakout board and Arduino Uno board

Debug Arduino Uno board

There is a 100nF auto-reset capacitor on the serial adapter side of the jumper. And that capacitor will absorb the high frequency debug signal. So we need to cut the jumper for debugging. The jumper can be connected with a drop of solder after debugging to restore the auto-reset feature.

Using All in One board

Debug on All in One board

CH552 pinout and ATmega328P connection

CH552ATmega328PFunctionality
P11RSTISP/DEBUG
P15D11 (MOSI)ISP
P16D12 (MISO)ISP
P17D13 (SCK)ISP
P30D1 (TX)Serial
P31D0 (RX)Serial
5V5VPower
GNDGNDPower

ch552 pinout

Software for debugging

Install driver for Windows user

The debugger does not need any driver for Mac OS. But it does need LibUSB driver for the debugging/programming interface on Windows. Using Zadig to install the libusb-win32 driver.

Install driver on Windows

Burn the bootloader to reset Arduino firmware and fuse

Select Arduino Uno from the Tools->Board menu, and USBtinyISP as the Tools->Programmer

Then select Burn Bootloader.

If you are able to burn the bootloader, it means the hardware set is ready to be debugged. Your Arduino is also ready to be used as a regular Arduino Uno.

Note if the Arduino has been debugged before burning the bootloader, your first burn attempt will fail, but the debugger will kick the Arduino out of debugging mode. Your second attempt will be successful. Also replug your board afterward, because Arduino can not enter debug mode again in the same power cycle that you unprogram the DWEN fuse.

burn Bootloader

Add board support

In Arduino Preferences, Click button on the right of the Additional Boards Manager URLs

Add:

https://raw.githubusercontent.com/DeqingSun/unoDebugTestPackage/main/package_uno_debug_index.json

add board Url

Open Boards Manager from Tools->Boards: "Whatever"->Boards Manager

In the Boards Manager, Find Arduino 8-bit with Debug. Install it.

install board

Start Debugging

Open BlinkUno.ino with Arduino IDE 2.0.0.

Click Select Board, if your board is already plugged in, you should be able to set the board and port automatically.

Or you can manually set the board and port.

select board

Click Verify icon then click the Start debugging icon.

Your board should be able to enter debug mode and pause on start.

If you encounter an error. Try to replug the board and debug again.

If it still does not work, try to:

  1. Replug the board.
  2. Try to burn the bootloader again. (try 2nd time if debugged before).
  3. Replug the board.
  4. Try to debug again.

start debugging

Then you should be able to debug the code.

debug in progress

Update Code in Debugging

When you modify the Arduino code and want to update the code within the Arduino chip, you can stop debugging, click Verify icon then click the Start debugging icon. The debugger will automatically send the new compiled binary to the Arduino chip through the debugging interface.

Note you can not use the regular upload button in Debugging mode, because the bootloader is disabled.

Quit Debugging and restore bootloader

When you finish debugging, first stop debugging. Then burn the bootloader twice and the board will quit debugging mode and restore the regular Arduino Uno bootloader.

The first bootloader burn will fail for sure, but the debugging probe (CH552) will send a quit signal to ATmega328P and enable the ISP interface, then the second bootloader burn will be successful. A power cycle is recommended after the successful burn if you want to debug again later.

Acknowledgment

The DebugWire protocol investigation and documentation by RikusW. The DebugWire protocol is the foundation to debug the ATmega328P.

dwire-debug project from David C W Brown. The dwire-debug acts as debugger server for avr-gdb. The dwire-debug binary in this repo was compiled with this branch with some hack mentioned in the Arduino IDE issue. The DigiSpark/ATTiny85 firmware in dwire-debug project also helped a lot in developing the CH552 firmware.

USBTINY PID/VID usage permission from Limor Fried for class teaching usage. The PID/VID usage create seamless experience with existing bootloader burning feature in the Arduino IDE.

Pre-compiled avr-gdb from Microchip website.