Skip to content

PlatformIO library that automatically downloads Atmel Start generated code

Notifications You must be signed in to change notification settings

zeroisnan/AtmelStart_PlatformIO

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Using platform io as an IDE for ASF4 projects

ASF4 is a collection of software components such as peripheral drivers, middleware, and software applications provided by Microchip. The framework supports the Microchip's SAM family of microcontrollers.

Atmel START is a web-based software configuration tool, which helps you get started with MCU development. Atmel START allows you to select and configure software components (from ASF4 and AVR Code), such as drivers and middleware to tailor your embedded application in a usable and optimized manner. Once an optimized software configuration is done, you can download the generated code project and open it in the IDE of your choice, including Studio 7, IAR Embedded Workbench®, Keil® μVision®, or simply generate a makefile.

This tutorial explains how to open an Atmel START project in platformIO IDE.

Start a new project

  1. Go to Atmel START and create a new project. Choose your mcu and configure all the software libraries you need.
  2. Save and Download the configuration file as a [project name].atstart in a new project folder.
  3. Start a new platformio project in that project folder with platformio init
  4. Create a custom board like explained here. You can start from the myboard.json file in the examples folder or another existing board. It is important to not have a "ldscript" tag defined in the "build" section. The atmel start project will contain a new linker script.
  5. Define an environment in platformio.ini file that contains at least the following settings:
[env:myEnvironment]
platform = atmelsam
board = myboard ; custom board as created in step 4
atstart_file = myAtStartProject.atstart ; name of the downloaded atstart file from step 3
lib_deps = https://github.com/JelleRoets/AtmelStart_PlatformIO ; library that will download and include all ASF libraries as configured in the atstart file
lib_archive = no ; prevents archiving ASF library to avoid linking problems
  1. From the moment you save the ini file (or run platformio run for the first time) it will download the package in .pio/libdeps/[env]/AtmelStart_PlatformIO/packages/[someHash]
  2. Go find a main.c file in that package and copy it to the project src folder as main.cpp and start editing.

Now you should be all set to further extend your project, compile, upload and debug your project with all features from platformIO.

Examples

You can find an ArduinoZeroASF example, where I use Atmel Start and ASF4 libraries to create and debug a blink example project for the Arduino Zero. You can simply do platformio run and / or platformio run --target upload (Note that uploading the binary with a debugger to the arduino zero will remove the existing bootloader).

Some background info

The magic happens by an extra script in the AtmelStart_PlatformIO. This script will download the package according to the given atstart file. It will include all headers and compile all library files when compiling the project. Everytime the .atstart file changes (when you updated your config in the web based atmel START tool) it will download a new package and use the (converted) .atstart file as a hash.

TODO

  • automatically update the custom board file when chosing a different mcu. It should not only update the mcu name but also the openocd name and target, find the corresponding svd file (e.g. downloading it from: http://packs.download.atmel.com/ ) and update the ram size
  • add a custom task / command to easily go to the online Atmel START tool with the current .atstart file preloaded (not sure if there is an atmel start rest api for this...)
  • atmel start rest api contains a bug that sets all clock frequencies in the peripheral_clk_config.h file to 0. This results in incorrect configuration of the components. When you download the atstart package directly from the atmel start web tool peripheral_clk_config.h is correctly populated.
  • Althoug the build.libArchive flag is set to false in the library.json file, it does seems to archive the ASF code due to a bug in platform IO, which breaks the linking. So make sure to set the lib_archive = no in the platformio.ini instead

Credits:

About

PlatformIO library that automatically downloads Atmel Start generated code

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%