Howto Code - Blocks and AVR1 - 3 PDF
Howto Code - Blocks and AVR1 - 3 PDF
Howto Code - Blocks and AVR1 - 3 PDF
Codeblocks is an integrated platform that works on Linux, OS X, and MS using the toolchain built by the
script form Bingo. The screenshots are from a pre 8.02 C::B, but I think they are still valid.
It has been written to support User interface programming, write one program, and compile and run on one
or more of the targets.
But it can be used for the AVR as well. The nice thing about this is, that you can do conditional compiling for
the PC only or for the avr target.
When debugging the AVR program on PC with some stubs for the i/o maybe even a display and buttons in a
wxWidget window like I did here. The AVR display is a Lascar SP5-GFX1 monochrome 128 x 64 pixels. I
replaced the display write function with a write to a wxWidget bimap to get it on the PC screen. The buttons
below the “display” simulates two rotary/push buttons in this small object oriented user interface:
wxWidget is like MFC, but multi platform in addition.
The development is speeded up, and you do not wear out your flash while debugging on the PC target.
Install the AVR GCC compiler. I have used the instructions from Bingo600 ( Thanks a lot .-) ) to install the
compiler on my Ubuntu 9.10.
install Code::Blocks
Search the web for install instructions for your operating system. For Ubuntu, just install from Synaptics.
Start Code::Blocks
Select menu Settings->Compiler and debugger...
Click the Copy button and insert “GNU AVR GCC Compiler” in the combobox Selected compiler.
select tab Toolchain executables and fill in values as seen below:
Also select “Debugger settings” and uncheck “Auto build project to ensure up-to-date”
Click OK
Be sure to have /usr/local/avr/bin in our path ( This is valid for my Linux setup )
Now select File->New->Project...
or click “Create a new project” on the startup window of codeblocks
Click Next
Choose the processor from the combobox and check “Run avr-size after build”
Click Finish.
Now add some code to main.c, more files can be added by right clicking in the Management pane and
selecting Add files...
Here is the compiled file, note the Messages pane, the observant reader notice that this project is named test1,
that is because I decided to document my finding after a succesfully created test1:
The debugging has been tested with both the Dragon and the first version of JTAGICEII. It works nicely for
both JTAG and debugWire
Click OK
Here are some other setups necessary:
Select Project->Build options...
Note the line 4 in the post build window, which do the programming of the AVR.
Finally the Settings->Compiler and debugger...
When you have built your program, and the AVR has been programmed and verified in the same step, then in
For using the Dragon as ICE. Or the JTAGICEII with debugwire for a tiny85:
Having seen this message, then click the Debug/Continue button to start the program, or set some
breakpoints. Remember you only have 3 HW breakpoints for your own use.
use
$ netstat -nap | grep 4242
tcp 0 0 127.0.0.1:4242 0.0.0.0:* LISTEN 17426/avarice
If you need to terminate avarice ( normally terminated when stopping the debugger ) use <ctrl> c, not
<ctrl>z.
avarice -2 -r -B 125Khz -W eehhll -j usb ( ee extended buse byte, hh high fuse byte, ll low fuse byte )
I have used some hours to reach so far, and as I have not been able to find other attempts on a howto, I made
this one, and invite others to help solving the remaining issues. Maybe I have missed something.
I strongly feel this is worth the effort, as the code navigation features of Code::Blocks is very powerful. And
this is a cross platform tool. It can be used for an ARM too :-)
My system: