Table of Contents
# NabGCC
Overview
When Mindscape released the files related to the Nabaztag:tag, they released the source code of the firmware running on the Nabaztag:tag. When we tried to use them, we faced some problems:
- The projet uses an old version of the proprietary IDE from IAR (v4.x)
- It does not compile with the new version (v6.x)
- The firmware is too big for the freeware version of IAR (old or new)
- The source code is what I would call a big mess.
- IAR is not well integrated with OpenOCD or GDB (or at least, it was not that easy to use).
- IAR doesn't provide any .elf file to use with GDB, so debugging was nearly impossible.
So, I started a port of the code to be used with GCC. It's called NabGCC :)
Get the sources
It's currently hosted on my personnal GIT server:
git clone git://git.redox.ws/nabgcc.git
New architecture
├── inc # Header files │ ├── hal # Hardware abstraction (Motor, LED, i2c, ...) │ ├── net # Wifi specific (IEEE802.11, hashes, ...) │ ├── usb # USB Host and RT2501usb │ ├── utils # Common tools │ └── vm # Metal Virtual Machine ├── mtl # Metal sources, for the BOOT bytecode ├── openocd # OpenOCD config files │ ├── interface │ │ └── ftdi │ └── target ├── src # Source files │ ├── hal # Hardware abstraction (Motor, LED, i2c, ...) │ ├── net # Wifi specific (IEEE802.11, hashes, ...) │ ├── usb # USB Host and RT2501usb │ ├── utils # Common tools │ └── vm # Metal Virtual Machine ├── sys # System files (CPU and USB Host chip) │ ├── asm # ASM sources for IRQ handlers and CPU initialization │ ├── inc # Header files │ └── src # Source files └── testvm # Test PC software folder, using stubs, to debug the VM ├── src -> ../src └── stubs # Stubs replacing the µC specific parts ├── hal ├── usb └── utils
Compile
Using the makefile in the root folder, you can build the whole firmware project with just:
make
Delete the objects files, and binaries with
make clean
The objects files should be in the obj/
folder, and the binaries in the bin/
folder.
Flash
Assuming you have OpenOCD running and connected to the target, flash a new firmware with
make program
Debug
You can load the firmware in GDB, and then debug your code:
arm-none-eabi-gdb ./bin/NabGCC.elf
Next commands are to be typed in GDB:
tar ext :3333 mon reset init load # And type 'r' to start using this code # Stop with Ctrl + C # and it's like normal debugging !
You can only set two breakpoints, which is quite limited… to delete all the breakpoints, just type 'd' and 'y'.
Happy hacking !