Base project and toolchain for AVR assembly programming in Linux.
This is inspired by the lack of resources available for programmers using Unix like systems and wanting to get into the AVR assembly world. We've been through that, so we decided to create a base project, together with the documentation of the issues we found in the path for those who may come after us.
This project will help you code, debug and upload projects based on Arduino AVR
from your favourite Unix OS. We use avr-*
cross-compiler tool chain, spanning
avr-gcc
, avr-ld
, avr-gdb
, avr-objcpy
and avrdude
. Together with that,
we include a /docs
folder with tools and tips on how to run and use each of
those.
This repository provides:
- A Makefile with targets for compiling, debugging and uploading avr assembly
code. (
/src
) - A header (.h) file with some helper macros for your code. (
/src
) - Some examples on how to code with
avr-gcc
conventions. (/src
) - Documentation explaining how to use all the above. (
/docs
) - A Vagrantfile to set up a virtual machine with all the tools installed.
To install all the dependencies needed to start using this base project, simply run the following command:
sudo apt-get install -y gcc-avr avr-libc avrdude libtool texinfo elfutils \
libglu1-mesa-dev freeglut3-dev gdb-avr libelf-dev
If you want to also be able to debug your programs, you will need an AVR
architecture simulator. The provided Makefile uses
simavr
, and you can install it as
follows (unluckily, the project needs to be build from source as there are no
binaries uploaded to the repositories):
git clone https://github.com/buserror/simavr /tmp/simavr
cd /tmp/simavr
sudo make install RELEASE=1
This will create several simavr
folders under /usr/local/bin
and
/usr/local/include
. Remove them to uninstall.
The provided makefile has two targets to compile the source code. It expects the source files to have the .S extension. The makefile is able to generate two types of binaries: ihex and elf formats. The first one is used to upload the program to the MCU; the latter to use gdb and inspect capabilities.
It is important to note that only one .S can be built at a time, meaning there
is no linking of binaries. All dependencies can be managed using #include
directives of avr-gcc
compiler.
To build a specific source.S
file into an ihex binary simply run:
make source.hex
To build the elf version of the binary instead run:
make source.elf
Lastly, the default target make all
will attempt to build all .S files
individually.
To upload the code from a compiled source.S
, first plug the board to an USB
and then run:
sudo make upload-source
This will attempt to upload the ihex binary to the device at /dev/ttyACM0
,
which should be fine if the board is the only device connected. Check the
makefile if you need to change that, or if you need to change the programmer
(avrdude
-c
flag).
The makefile provides two features to debug and inspect the generated code: the
equivalent to objdump
to inspect the compiled code, and the equivalent to
gdb
for general purpose debugging.
To get a dump of the generated binary (compiled from source.S
file) simply run:
make inspect-source
This will output a dump of the assembly code, with all the constants replaced, useful to check whether the registers and port constants were replaced correctly. This target will recompile the code if it was changed since last inspection.
The second feature is gdb debugging. This is achieved by running the code on a
AVR architecture emulator, sim-avr
, and then attaching gdb to that process.
To use this feature you will need to start the simulator with:
make sim-gdb-source
After that it will wait for a gdb session to be attached, which can be done with the following command from another terminal:
make gdb-source
This will prompt you with a gdb terminal ready to start debugging the program.
More information on debugging with avr-gdb
can be found in here.
This repo has been tested successfully with the following OSs:
- Debian 9 (Stretch), x86_64
- Ubuntu 16.04.5 LTS (Xenial), x86_64
The MCU used successfully uploaded were
- atmega2560 (Arduino Mega rev3)
- atmega328p (Arduino Uno)
Let us know if you manage to get it working in other environments!
Any bugs, suggestions and improvements are always welcome so feel free to open an issue or submitting a PR. Let us know if you tested our repos in any new MCU or base OS, and the problems you may have stumbled upon so we can keep this growing.
Maintainers:
- Juan Manuel Fresia <juanmanuelfresia@gmail.com>
Contributors:
- Ana Czarnitzki
- Alejandro Gracía