circuitpython/atmel-samd
Scott Shawcroft 1fa4c20c27 atmel-samd: Add Micro Trace Buffer support to the debug build.
The Micro Trace Buffer records the history of the pc and can be used
to debug hard faults even when the stack trace is useless.
2016-10-04 16:13:33 -07:00
..
asf atmel-samd: Add Micro Trace Buffer support to the debug build. 2016-10-04 16:13:33 -07:00
boards atmel-samd: Support raw repl and soft reset to support ampy. 2016-09-15 17:01:19 -07:00
common-hal/modules atmel-samd: Add I2C support. 2016-09-13 11:46:22 -07:00
tools atmel-samd: Update bossac_osx with one that works. 2016-10-03 12:57:06 -04:00
.gitattributes Include the precompiled math library from ASF. 2016-09-07 14:35:40 -07:00
.gitignore Blinking the LED works. Clocks should be set up correctly. 2016-08-22 23:53:11 -07:00
Makefile atmel-samd: Add Micro Trace Buffer support to the debug build. 2016-10-04 16:13:33 -07:00
README.md atmel-samd: Update bossac_osx with one that works. 2016-10-03 12:57:06 -04:00
builtin_open.c atmel/samd: Add filesystem support. 64k is stored in flash. 2016-09-02 17:00:30 -07:00
fatfs_port.c atmel/samd: Add filesystem support. 64k is stored in flash. 2016-09-02 17:00:30 -07:00
frozentest.mpy Compiled and linked SAMD21x18 version successfully. 2016-08-22 23:53:10 -07:00
frozentest.py Compiled and linked SAMD21x18 version successfully. 2016-08-22 23:53:10 -07:00
main.c atmel-samd: Add Micro Trace Buffer support to the debug build. 2016-10-04 16:13:33 -07:00
modmachine.c atmel-samd: Remove module name from struct. 2016-09-26 15:02:16 -07:00
modmachine_adc.c atmel-samd: Rename module classes so they don't conflict with names from ASF. 2016-08-28 00:02:05 -07:00
modmachine_adc.h atmel-samd: Rename module classes so they don't conflict with names from ASF. 2016-08-28 00:02:05 -07:00
modmachine_dac.c atmel-samd: Rename module classes so they don't conflict with names from ASF. 2016-08-28 00:02:05 -07:00
modmachine_dac.h atmel-samd: Rename module classes so they don't conflict with names from ASF. 2016-08-28 00:02:05 -07:00
modmachine_pin.c atmel-samd: Rename module classes so they don't conflict with names from ASF. 2016-08-28 00:02:05 -07:00
modmachine_pin.h atmel-samd: Add I2C support. 2016-09-13 11:46:22 -07:00
modmachine_pwm.c atmel/samd: Add basic PWM support which only allows for changing the duty. 2016-08-30 13:10:52 -07:00
modmachine_pwm.h atmel/samd: Add basic PWM support which only allows for changing the duty. 2016-08-30 13:10:52 -07:00
moduos.c atmel-samd: Remove module name from struct. 2016-09-26 15:02:16 -07:00
modutime.c atmel-samd: Remove module name from struct. 2016-09-26 15:02:16 -07:00
mpconfigport.h atmel-samd21: Support loading mpy files. 2016-09-26 15:43:52 -07:00
mphalport.c atmel-samd: Support ampy get and fix USB dropping characters. 2016-09-21 15:13:37 -07:00
mphalport.h atmel/samd: Support CTRL-C on USB. This won't escape native code but it will cause Python code to stop. 2016-08-31 00:11:56 -07:00
pin_defs_samd.c atmel-samd: Support Digital IO pins. 2016-08-24 17:38:08 -07:00
pin_named_pins.c atmel-samd: Rename module classes so they don't conflict with names from ASF. 2016-08-28 00:02:05 -07:00
qstrdefsport.h Compiled and linked SAMD21x18 version successfully. 2016-08-22 23:53:10 -07:00
storage.c atmel/samd: Add filesystem support. 64k is stored in flash. 2016-09-02 17:00:30 -07:00
storage.h atmel/samd: Add filesystem support. 64k is stored in flash. 2016-09-02 17:00:30 -07:00
uart.c Add support for REPL on Arduino Zero through EDBG via UART. 2016-08-23 16:47:53 -07:00
uart.h Add support for REPL on Arduino Zero through EDBG via UART. 2016-08-23 16:47:53 -07:00

README.md

SAMD21x18

This port is intended to be a full featured MicroPython port for SAMD21x18 based development boards including the Arduino Zero, Adafruit Feather M0 and Adafruit M0 BLE.

Building

The Makefile has the ability to build for a SAMD21x18, and by default includes some start-up code and also enables a UART for communication. To build:

make CROSS=1

It will build for the Arduino Zero by default. You may change it by setting BOARD. For example:

make CROSS=1 BOARD=feather_m0_ble

Board names are the directory names in the boards folder.

Deploying

Arduino Bootloader

If your board has an existing Arduino bootloader on it then you can use bossac to flash MicroPython. First, activate the bootloader. On Adafruit Feathers you can double click the reset button and the #13 will fade in and out. Finally, run bossac:

tools/bossac_osx -e -w -v -b -R build-feather_m0_ble/firmware.bin

No Bootloader via GDB

This method works for loading MicroPython onto the Arduino Zero via the programming port rather than the native USB port.

Note: These instructions are tested on Mac OSX and will vary for different platforms.

openocd -f ~/Library/Arduino15/packages/arduino/hardware/samd/1.6.6/variants/arduino_zero/openocd_scripts/arduino_zero.cfg

In another terminal from micropython/atmel-samd:

arm-none-eabi-gdb build-arduino_zero/firmware.elf
(gdb) tar ext :3333
...
(gdb) load
...
(gdb) monitor reset init
...
(gdb) continue

Connecting

All boards are currently configured to work over USB rather than UART. To connect to it from OSX do something like this:

screen /dev/tty.usbmodem142422 115200

You may not see a prompt immediately because it doesn't know you connected. To get one either hit enter to get >>> or do CTRL-B to get the full header.