From 3adf8812544a0379291a6c0e39fb73a0c1801a56 Mon Sep 17 00:00:00 2001 From: lady ada Date: Sun, 14 Mar 2021 17:22:49 -0400 Subject: [PATCH 1/2] add new variant --- boards.txt | 49 ++++ .../bootloader-neotrinkey_m0.bin | Bin 0 -> 8192 bytes .../neotrinkey_m0/debug_scripts/variant.gdb | 31 +++ .../gcc/flash_with_bootloader.ld | 216 ++++++++++++++++++ .../gcc/flash_without_bootloader.ld | 214 +++++++++++++++++ .../openocd_scripts/neotrinkey_m0.cfg | 28 +++ variants/neotrinkey_m0/pins_arduino.h | 21 ++ variants/neotrinkey_m0/variant.cpp | 50 ++++ variants/neotrinkey_m0/variant.h | 165 +++++++++++++ 9 files changed, 774 insertions(+) create mode 100644 bootloaders/neotrinkey_m0/bootloader-neotrinkey_m0.bin create mode 100644 variants/neotrinkey_m0/debug_scripts/variant.gdb create mode 100644 variants/neotrinkey_m0/linker_scripts/gcc/flash_with_bootloader.ld create mode 100644 variants/neotrinkey_m0/linker_scripts/gcc/flash_without_bootloader.ld create mode 100644 variants/neotrinkey_m0/openocd_scripts/neotrinkey_m0.cfg create mode 100644 variants/neotrinkey_m0/pins_arduino.h create mode 100644 variants/neotrinkey_m0/variant.cpp create mode 100644 variants/neotrinkey_m0/variant.h diff --git a/boards.txt b/boards.txt index f4173c804..6a2ca5ef8 100644 --- a/boards.txt +++ b/boards.txt @@ -378,6 +378,55 @@ adafruit_qtpy_m0.menu.debug.off=Off adafruit_qtpy_m0.menu.debug.on=On adafruit_qtpy_m0.menu.debug.on.build.flags.debug=-g +# Adafruit NeoPixel Trinkey (SAMD21) +# ------------------------------ +adafruit_neotrinkey_m0.name=Adafruit Neo Trinkey (SAMD21) +adafruit_neotrinkey_m0.vid.0=0x239A +adafruit_neotrinkey_m0.pid.0=0x80EF +adafruit_neotrinkey_m0.vid.1=0x239A +adafruit_neotrinkey_m0.pid.1=0x00EF +adafruit_neotrinkey_m0.vid.1=0x239A +adafruit_neotrinkey_m0.pid.1=0x00F0 +adafruit_neotrinkey_m0.upload.tool=bossac +adafruit_neotrinkey_m0.upload.protocol=sam-ba +adafruit_neotrinkey_m0.upload.maximum_size=262144 +adafruit_neotrinkey_m0.upload.offset=0x2000 +adafruit_neotrinkey_m0.upload.use_1200bps_touch=true +adafruit_neotrinkey_m0.upload.wait_for_upload_port=true +adafruit_neotrinkey_m0.upload.native_usb=true +adafruit_neotrinkey_m0.build.mcu=cortex-m0plus +adafruit_neotrinkey_m0.build.f_cpu=48000000L +adafruit_neotrinkey_m0.build.usb_product="NeoPixel Trinkey M0" +adafruit_neotrinkey_m0.build.usb_manufacturer="Adafruit" +adafruit_neotrinkey_m0.build.board=NEOTRINKEY_M0 +adafruit_neotrinkey_m0.build.core=arduino +adafruit_neotrinkey_m0.build.extra_flags=-DCRYSTALLESS -DADAFRUIT_NEOTRINKEY_M0 -D__SAMD21E18A__ -DARM_MATH_CM0PLUS {build.usb_flags} +adafruit_neotrinkey_m0.build.ldscript=linker_scripts/gcc/flash_with_bootloader.ld +adafruit_neotrinkey_m0.build.openocdscript=openocd_scripts/trinket_m0.cfg +adafruit_neotrinkey_m0.build.variant=neotrinkey_m0 +adafruit_neotrinkey_m0.build.variant_system_lib= +adafruit_neotrinkey_m0.build.vid=0x239A +adafruit_neotrinkey_m0.build.pid=0x80EF +adafruit_neotrinkey_m0.bootloader.tool=openocd +adafruit_neotrinkey_m0.bootloader.file=neotrinkey_m0/bootloader-neotrinkey_m0.bin +adafruit_neotrinkey_m0.menu.opt.small=Small (-Os) (standard) +adafruit_neotrinkey_m0.menu.opt.small.build.flags.optimize=-Os +adafruit_neotrinkey_m0.menu.opt.fast=Fast (-O2) +adafruit_neotrinkey_m0.menu.opt.fast.build.flags.optimize=-O2 +adafruit_neotrinkey_m0.menu.opt.faster=Faster (-O3) +adafruit_neotrinkey_m0.menu.opt.faster.build.flags.optimize=-O3 +adafruit_neotrinkey_m0.menu.opt.fastest=Fastest (-Ofast) +adafruit_neotrinkey_m0.menu.opt.fastest.build.flags.optimize=-Ofast +adafruit_neotrinkey_m0.menu.opt.dragons=Here be dragons (-Ofast -funroll-loops) +adafruit_neotrinkey_m0.menu.opt.dragons.build.flags.optimize=-Ofast -funroll-loops +adafruit_neotrinkey_m0.menu.usbstack.arduino=Arduino +adafruit_neotrinkey_m0.menu.usbstack.tinyusb=TinyUSB +adafruit_neotrinkey_m0.menu.usbstack.tinyusb.build.flags.usbstack=-DUSE_TINYUSB +adafruit_neotrinkey_m0.menu.debug.off=Off +adafruit_neotrinkey_m0.menu.debug.on=On +adafruit_neotrinkey_m0.menu.debug.on.build.flags.debug=-g + + # Adafruit ItsyBitsy M0 (SAMD21) # ------------------------------ adafruit_itsybitsy_m0.name=Adafruit ItsyBitsy M0 diff --git a/bootloaders/neotrinkey_m0/bootloader-neotrinkey_m0.bin b/bootloaders/neotrinkey_m0/bootloader-neotrinkey_m0.bin new file mode 100644 index 0000000000000000000000000000000000000000..faf74ac7de608bb01791516d2173b70e4e082be4 GIT binary patch literal 8192 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 FLASH + + .ARM.extab : + { + *(.ARM.extab* .gnu.linkonce.armextab.*) + } > FLASH + + __exidx_start = .; + .ARM.exidx : + { + *(.ARM.exidx* .gnu.linkonce.armexidx.*) + } > FLASH + __exidx_end = .; + + /* To copy multiple ROM to RAM sections, + * uncomment .copy.table section and, + * define __STARTUP_COPY_MULTIPLE in startup_ARMCMx.S */ + /* + .copy.table : + { + . = ALIGN(4); + __copy_table_start__ = .; + LONG (__etext) + LONG (__data_start__) + LONG (__data_end__ - __data_start__) + LONG (__etext2) + LONG (__data2_start__) + LONG (__data2_end__ - __data2_start__) + __copy_table_end__ = .; + } > FLASH + */ + + /* To clear multiple BSS sections, + * uncomment .zero.table section and, + * define __STARTUP_CLEAR_BSS_MULTIPLE in startup_ARMCMx.S */ + /* + .zero.table : + { + . = ALIGN(4); + __zero_table_start__ = .; + LONG (__bss_start__) + LONG (__bss_end__ - __bss_start__) + LONG (__bss2_start__) + LONG (__bss2_end__ - __bss2_start__) + __zero_table_end__ = .; + } > FLASH + */ + + __etext = .; + + .data : AT (__etext) + { + __data_start__ = .; + *(vtable) + *(.data*) + + . = ALIGN(4); + /* preinit data */ + PROVIDE_HIDDEN (__preinit_array_start = .); + KEEP(*(.preinit_array)) + PROVIDE_HIDDEN (__preinit_array_end = .); + + . = ALIGN(4); + /* init data */ + PROVIDE_HIDDEN (__init_array_start = .); + KEEP(*(SORT(.init_array.*))) + KEEP(*(.init_array)) + PROVIDE_HIDDEN (__init_array_end = .); + + + . = ALIGN(4); + /* finit data */ + PROVIDE_HIDDEN (__fini_array_start = .); + KEEP(*(SORT(.fini_array.*))) + KEEP(*(.fini_array)) + PROVIDE_HIDDEN (__fini_array_end = .); + + KEEP(*(.jcr*)) + . = ALIGN(16); + /* All data end */ + __data_end__ = .; + + } > RAM + + .bss : + { + . = ALIGN(4); + __bss_start__ = .; + *(.bss*) + *(COMMON) + . = ALIGN(4); + __bss_end__ = .; + } > RAM + + .heap (COPY): + { + __end__ = .; + PROVIDE(end = .); + *(.heap*) + __HeapLimit = .; + } > RAM + + /* .stack_dummy section doesn't contains any symbols. It is only + * used for linker to calculate size of stack sections, and assign + * values to stack symbols later */ + .stack_dummy (COPY): + { + *(.stack*) + } > RAM + + /* Set stack top to end of RAM, and stack limit move down by + * size of stack_dummy section */ + __StackTop = ORIGIN(RAM) + LENGTH(RAM); + __StackLimit = __StackTop - SIZEOF(.stack_dummy); + PROVIDE(__stack = __StackTop); + + __ram_end__ = ORIGIN(RAM) + LENGTH(RAM) -1 ; + + /* Check if data + heap + stack exceeds RAM limit */ + ASSERT(__StackLimit >= __HeapLimit, "region RAM overflowed with stack") +} diff --git a/variants/neotrinkey_m0/linker_scripts/gcc/flash_without_bootloader.ld b/variants/neotrinkey_m0/linker_scripts/gcc/flash_without_bootloader.ld new file mode 100644 index 000000000..ebeeee37f --- /dev/null +++ b/variants/neotrinkey_m0/linker_scripts/gcc/flash_without_bootloader.ld @@ -0,0 +1,214 @@ +/* + Copyright (c) 2014-2015 Arduino LLC. All right reserved. + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + See the GNU Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +*/ + +/* Linker script to configure memory regions. + * Need modifying for a specific board. + * FLASH.ORIGIN: starting address of flash + * FLASH.LENGTH: length of flash + * RAM.ORIGIN: starting address of RAM bank 0 + * RAM.LENGTH: length of RAM bank 0 + */ +MEMORY +{ + FLASH (rx) : ORIGIN = 0x00000000, LENGTH = 0x00040000 + RAM (rwx) : ORIGIN = 0x20000000, LENGTH = 0x00008000 +} + +/* Linker script to place sections and symbol values. Should be used together + * with other linker script that defines memory regions FLASH and RAM. + * It references following symbols, which must be defined in code: + * Reset_Handler : Entry of reset handler + * + * It defines following symbols, which code can use without definition: + * __exidx_start + * __exidx_end + * __copy_table_start__ + * __copy_table_end__ + * __zero_table_start__ + * __zero_table_end__ + * __etext + * __data_start__ + * __preinit_array_start + * __preinit_array_end + * __init_array_start + * __init_array_end + * __fini_array_start + * __fini_array_end + * __data_end__ + * __bss_start__ + * __bss_end__ + * __end__ + * end + * __HeapLimit + * __StackLimit + * __StackTop + * __stack + * __ram_end__ + */ +ENTRY(Reset_Handler) + +SECTIONS +{ + .text : + { + __text_start__ = .; + + KEEP(*(.isr_vector)) + *(.text*) + + KEEP(*(.init)) + KEEP(*(.fini)) + + /* .ctors */ + *crtbegin.o(.ctors) + *crtbegin?.o(.ctors) + *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors) + *(SORT(.ctors.*)) + *(.ctors) + + /* .dtors */ + *crtbegin.o(.dtors) + *crtbegin?.o(.dtors) + *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors) + *(SORT(.dtors.*)) + *(.dtors) + + *(.rodata*) + + KEEP(*(.eh_frame*)) + } > FLASH + + .ARM.extab : + { + *(.ARM.extab* .gnu.linkonce.armextab.*) + } > FLASH + + __exidx_start = .; + .ARM.exidx : + { + *(.ARM.exidx* .gnu.linkonce.armexidx.*) + } > FLASH + __exidx_end = .; + + /* To copy multiple ROM to RAM sections, + * uncomment .copy.table section and, + * define __STARTUP_COPY_MULTIPLE in startup_ARMCMx.S */ + /* + .copy.table : + { + . = ALIGN(4); + __copy_table_start__ = .; + LONG (__etext) + LONG (__data_start__) + LONG (__data_end__ - __data_start__) + LONG (__etext2) + LONG (__data2_start__) + LONG (__data2_end__ - __data2_start__) + __copy_table_end__ = .; + } > FLASH + */ + + /* To clear multiple BSS sections, + * uncomment .zero.table section and, + * define __STARTUP_CLEAR_BSS_MULTIPLE in startup_ARMCMx.S */ + /* + .zero.table : + { + . = ALIGN(4); + __zero_table_start__ = .; + LONG (__bss_start__) + LONG (__bss_end__ - __bss_start__) + LONG (__bss2_start__) + LONG (__bss2_end__ - __bss2_start__) + __zero_table_end__ = .; + } > FLASH + */ + + __etext = .; + + .data : AT (__etext) + { + __data_start__ = .; + *(vtable) + *(.data*) + + . = ALIGN(4); + /* preinit data */ + PROVIDE_HIDDEN (__preinit_array_start = .); + KEEP(*(.preinit_array)) + PROVIDE_HIDDEN (__preinit_array_end = .); + + . = ALIGN(4); + /* init data */ + PROVIDE_HIDDEN (__init_array_start = .); + KEEP(*(SORT(.init_array.*))) + KEEP(*(.init_array)) + PROVIDE_HIDDEN (__init_array_end = .); + + + . = ALIGN(4); + /* finit data */ + PROVIDE_HIDDEN (__fini_array_start = .); + KEEP(*(SORT(.fini_array.*))) + KEEP(*(.fini_array)) + PROVIDE_HIDDEN (__fini_array_end = .); + + KEEP(*(.jcr*)) + . = ALIGN(16); + /* All data end */ + __data_end__ = .; + + } > RAM + + .bss : + { + . = ALIGN(4); + __bss_start__ = .; + *(.bss*) + *(COMMON) + . = ALIGN(4); + __bss_end__ = .; + } > RAM + + .heap (COPY): + { + __end__ = .; + PROVIDE(end = .); + *(.heap*) + __HeapLimit = .; + } > RAM + + /* .stack_dummy section doesn't contains any symbols. It is only + * used for linker to calculate size of stack sections, and assign + * values to stack symbols later */ + .stack_dummy (COPY): + { + *(.stack*) + } > RAM + + /* Set stack top to end of RAM, and stack limit move down by + * size of stack_dummy section */ + __StackTop = ORIGIN(RAM) + LENGTH(RAM) ; + __StackLimit = __StackTop - SIZEOF(.stack_dummy); + PROVIDE(__stack = __StackTop); + + __ram_end__ = ORIGIN(RAM) + LENGTH(RAM) -1 ; + + /* Check if data + heap + stack exceeds RAM limit */ + ASSERT(__StackLimit >= __HeapLimit, "region RAM overflowed with stack") +} diff --git a/variants/neotrinkey_m0/openocd_scripts/neotrinkey_m0.cfg b/variants/neotrinkey_m0/openocd_scripts/neotrinkey_m0.cfg new file mode 100644 index 000000000..e4c3f81dc --- /dev/null +++ b/variants/neotrinkey_m0/openocd_scripts/neotrinkey_m0.cfg @@ -0,0 +1,28 @@ +# +# Adafruit ItsyBitsy M0 OpenOCD script. +# +# Copyright (c) 2014-2015 Arduino LLC. All right reserved. +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +# See the GNU Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +# + +# chip name +set CHIPNAME at91samd21e18 +set ENDIAN little + +# choose a port here +set telnet_port 0 + +source [find target/at91samdXX.cfg] diff --git a/variants/neotrinkey_m0/pins_arduino.h b/variants/neotrinkey_m0/pins_arduino.h new file mode 100644 index 000000000..db0e40c3d --- /dev/null +++ b/variants/neotrinkey_m0/pins_arduino.h @@ -0,0 +1,21 @@ +/* + Copyright (c) 2014-2015 Arduino LLC. All right reserved. + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + See the GNU Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +*/ + +// API compatibility +#include "variant.h" + diff --git a/variants/neotrinkey_m0/variant.cpp b/variants/neotrinkey_m0/variant.cpp new file mode 100644 index 000000000..150034974 --- /dev/null +++ b/variants/neotrinkey_m0/variant.cpp @@ -0,0 +1,50 @@ +/* + Copyright (c) 2014-2015 Arduino LLC. All right reserved. + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + See the GNU Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +*/ + +#include "variant.h" +#include "Arduino.h" +/* + * Pins descriptions + */ +const PinDescription g_APinDescription[]= +{ + // NeoPixels + { PORTA, 5, PIO_ANALOG, (PIN_ATTR_DIGITAL|PIN_ATTR_ANALOG|PIN_ATTR_PWM|PIN_ATTR_TIMER), ADC_Channel5, PWM0_CH1, TCC0_CH1, EXTERNAL_INT_5 }, + + // Touch Pin 1 + { PORTA, 3, PIO_ANALOG, (PIN_ATTR_DIGITAL|PIN_ATTR_ANALOG), ADC_Channel1, NOT_ON_PWM, NOT_ON_TIMER, EXTERNAL_INT_3 }, + + // Touch Pin 2 + { PORTA, 7, PIO_ANALOG, (PIN_ATTR_DIGITAL|PIN_ATTR_ANALOG|PIN_ATTR_PWM|PIN_ATTR_TIMER), ADC_Channel7, PWM1_CH1, TCC1_CH1, EXTERNAL_INT_7 }, + + // USB pins + { PORTA, 28, PIO_COM, PIN_ATTR_NONE, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER, EXTERNAL_INT_NONE }, // USB Host enable + { PORTA, 24, PIO_COM, PIN_ATTR_NONE, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER, EXTERNAL_INT_NONE }, // USB/DM + { PORTA, 25, PIO_COM, PIN_ATTR_NONE, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER, EXTERNAL_INT_NONE }, // USB/DP + + // Fake DAC pin just so we can compile stuff + { PORTA, 2, PIO_ANALOG, (PIN_ATTR_DIGITAL|PIN_ATTR_ANALOG|PIN_ATTR_PWM|PIN_ATTR_TIMER), ADC_Channel0, PWM2_CH0, TCC2_CH0, EXTERNAL_INT_2 }, // A0 / D0 / DAC +} ; + +const void* g_apTCInstances[TCC_INST_NUM+TC_INST_NUM]={ TCC0, TCC1, TCC2, TC3, TC4, TC5 } ; + +// Multi-serial objects instantiation +SERCOM sercom0( SERCOM0 ) ; +SERCOM sercom1( SERCOM1 ) ; +SERCOM sercom2( SERCOM2 ) ; +SERCOM sercom3( SERCOM3 ) ; diff --git a/variants/neotrinkey_m0/variant.h b/variants/neotrinkey_m0/variant.h new file mode 100644 index 000000000..9efd0eda0 --- /dev/null +++ b/variants/neotrinkey_m0/variant.h @@ -0,0 +1,165 @@ +/* + Copyright (c) 2014-2015 Arduino LLC. All right reserved. + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + See the GNU Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +*/ + +#ifndef _VARIANT_NEOTRINKEY_ZERO_ +#define _VARIANT_NEOTRINKEY_ZERO_ + +// The definitions here needs a SAMD core >=1.6.10 +#define ARDUINO_SAMD_VARIANT_COMPLIANCE 10610 + +/*---------------------------------------------------------------------------- + * Definitions + *----------------------------------------------------------------------------*/ + +/** Frequency of the board main oscillator */ +#define VARIANT_MAINOSC (32768ul) + +/** Master clock frequency */ +#define VARIANT_MCK (F_CPU) + +/*---------------------------------------------------------------------------- + * Headers + *----------------------------------------------------------------------------*/ + +#include "WVariant.h" + +#ifdef __cplusplus +#include "SERCOM.h" +#include "Uart.h" +#endif // __cplusplus + +#ifdef __cplusplus +extern "C" +{ +#endif // __cplusplus + +/*---------------------------------------------------------------------------- + * Pins + *----------------------------------------------------------------------------*/ + +// Number of pins defined in PinDescription array +#define PINS_COUNT (7u) +#define NUM_DIGITAL_PINS (7u) +#define NUM_ANALOG_INPUTS (3u) +#define NUM_ANALOG_OUTPUTS (1u) +#define analogInputToDigitalPin(p) (p) + +#define digitalPinToPort(P) ( &(PORT->Group[g_APinDescription[P].ulPort]) ) +#define digitalPinToBitMask(P) ( 1 << g_APinDescription[P].ulPin ) +//#define analogInPinToBit(P) ( ) +#define portOutputRegister(port) ( &(port->OUT.reg) ) +#define portInputRegister(port) ( &(port->IN.reg) ) +#define portModeRegister(port) ( &(port->DIR.reg) ) +#define digitalPinHasPWM(P) ( g_APinDescription[P].ulPWMChannel != NOT_ON_PWM || g_APinDescription[P].ulTCChannel != NOT_ON_TIMER ) + +/* + * digitalPinToTimer(..) is AVR-specific and is not defined for SAMD + * architecture. If you need to check if a pin supports PWM you must + * use digitalPinHasPWM(..). + * + * https://github.com/arduino/Arduino/issues/1833 + */ +// #define digitalPinToTimer(P) + +// LEDs +#define PIN_NEOPIXEL (0u) + +/* + * Analog pins + */ +#define PIN_A0 (6ul) +#define PIN_A1 (1) +#define PIN_A2 (2) +#define PIN_DAC0 PIN_A0 + +static const uint8_t A0 = PIN_A0; +static const uint8_t A1 = PIN_A1; +static const uint8_t A2 = PIN_A2; + +#define ADC_RESOLUTION 12 + + +/* + * SPI Interfaces + */ +#define SPI_INTERFACES_COUNT 0 + +/* + * Wire Interfaces + */ +#define WIRE_INTERFACES_COUNT 0 + +/* + * USB + */ +#define PIN_USB_HOST_ENABLE (3ul) +#define PIN_USB_DM (4ul) +#define PIN_USB_DP (5ul) +/* + * I2S Interfaces + */ +#define I2S_INTERFACES_COUNT 0 + + +#ifdef __cplusplus +} +#endif + +/*---------------------------------------------------------------------------- + * Arduino objects - C++ only + *----------------------------------------------------------------------------*/ + +#ifdef __cplusplus + +/* ========================= + * ===== SERCOM DEFINITION + * ========================= +*/ +extern SERCOM sercom0; +extern SERCOM sercom1; +extern SERCOM sercom2; +extern SERCOM sercom3; +extern SERCOM sercom4; +extern SERCOM sercom5; + + +#endif + +// These serial port names are intended to allow libraries and architecture-neutral +// sketches to automatically default to the correct port name for a particular type +// of use. For example, a GPS module would normally connect to SERIAL_PORT_HARDWARE_OPEN, +// the first hardware serial port whose RX/TX pins are not dedicated to another use. +// +// SERIAL_PORT_MONITOR Port which normally prints to the Arduino Serial Monitor +// +// SERIAL_PORT_USBVIRTUAL Port which is USB virtual serial +// +// SERIAL_PORT_LINUXBRIDGE Port which connects to a Linux system via Bridge library +// +// SERIAL_PORT_HARDWARE Hardware serial port, physical RX & TX pins. +// +// SERIAL_PORT_HARDWARE_OPEN Hardware serial ports which are open for use. Their RX & TX +// pins are NOT connected to anything by default. +#define SERIAL_PORT_USBVIRTUAL Serial +#define SERIAL_PORT_MONITOR Serial +// Serial has no physical pins broken out, so it's not listed as HARDWARE port +#define SERIAL_PORT_HARDWARE Serial1 +#define SERIAL_PORT_HARDWARE_OPEN Serial1 + +#endif /* _VARIANT_ARDUINO_ZERO_ */ + From af4f2cb75c9c0db886ed503f964bbdcc765a92ca Mon Sep 17 00:00:00 2001 From: lady ada Date: Mon, 15 Mar 2021 12:13:48 -0400 Subject: [PATCH 2/2] typo fixes! --- boards.txt | 2 +- variants/neotrinkey_m0/variant.h | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/boards.txt b/boards.txt index 6a2ca5ef8..64b317d94 100644 --- a/boards.txt +++ b/boards.txt @@ -402,7 +402,7 @@ adafruit_neotrinkey_m0.build.board=NEOTRINKEY_M0 adafruit_neotrinkey_m0.build.core=arduino adafruit_neotrinkey_m0.build.extra_flags=-DCRYSTALLESS -DADAFRUIT_NEOTRINKEY_M0 -D__SAMD21E18A__ -DARM_MATH_CM0PLUS {build.usb_flags} adafruit_neotrinkey_m0.build.ldscript=linker_scripts/gcc/flash_with_bootloader.ld -adafruit_neotrinkey_m0.build.openocdscript=openocd_scripts/trinket_m0.cfg +adafruit_neotrinkey_m0.build.openocdscript=openocd_scripts/neotrinkey_m0.cfg adafruit_neotrinkey_m0.build.variant=neotrinkey_m0 adafruit_neotrinkey_m0.build.variant_system_lib= adafruit_neotrinkey_m0.build.vid=0x239A diff --git a/variants/neotrinkey_m0/variant.h b/variants/neotrinkey_m0/variant.h index 9efd0eda0..3da948ce1 100644 --- a/variants/neotrinkey_m0/variant.h +++ b/variants/neotrinkey_m0/variant.h @@ -78,6 +78,7 @@ extern "C" // LEDs #define PIN_NEOPIXEL (0u) +#define NUM_NEOPIXEL (4u) /* * Analog pins