This repository has been archived by the owner on Feb 4, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 13
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
### New in v1.7.1 1. Sync with [Arduino WiFiNINA Library v1.7.1](https://github.com/arduino-libraries/WiFiNINA/releases/tag/1.7.1). Using the latest WiFiNINA FW v1.4.1 in [WiFi101-FirmwareUpdater-Plugin v0.10.12](https://github.com/arduino/WiFi101-FirmwareUpdater-Plugin/releases/tag/v0.10.12)
- Loading branch information
1 parent
9c35e7b
commit 3341d77
Showing
3 changed files
with
643 additions
and
0 deletions.
There are no files selected for viewing
230 changes: 230 additions & 0 deletions
230
Packages_Patches/Seeeduino/hardware/samd/1.7.8/platform.txt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,230 @@ | ||
# 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 | ||
|
||
# Arduino SAMD Core and platform. | ||
# | ||
# For more info: | ||
# https://github.com/arduino/Arduino/wiki/Arduino-IDE-1.5---3rd-party-Hardware-specification | ||
|
||
name=Seeed SAMD (32-bits ARM Cortex-M0+ and Cortex-M4) Boards | ||
version=1.7.8 | ||
|
||
# Compile variables | ||
# ----------------- | ||
|
||
compiler.warning_flags=-w | ||
compiler.warning_flags.none=-w | ||
compiler.warning_flags.default= | ||
compiler.warning_flags.more=-Wall -Wno-expansion-to-defined | ||
compiler.warning_flags.all=-Wall -Wextra -Wno-expansion-to-defined | ||
|
||
compiler.path={runtime.tools.arm-none-eabi-gcc-7-2017q4.path}/bin/ | ||
compiler.c.cmd=arm-none-eabi-gcc | ||
compiler.c.flags=-mcpu={build.mcu} -mthumb -c -g -Os {compiler.warning_flags} -std=gnu11 -ffunction-sections -fdata-sections -nostdlib --param max-inline-insns-single=500 -MMD -D__SKETCH_NAME__="""{build.project_name}""" | ||
compiler.c.elf.cmd=arm-none-eabi-g++ | ||
compiler.c.elf.flags=-Os -Wl,--gc-sections -save-temps | ||
compiler.S.cmd=arm-none-eabi-gcc | ||
compiler.S.flags=-c -g -x assembler-with-cpp -MMD | ||
compiler.cpp.cmd=arm-none-eabi-g++ | ||
compiler.cpp.flags=-mcpu={build.mcu} -mthumb -c -g -Os {compiler.warning_flags} -std=gnu++14 -ffunction-sections -fdata-sections -fno-threadsafe-statics -nostdlib --param max-inline-insns-single=500 -fno-rtti -fno-exceptions -MMD -D__SKETCH_NAME__="""{build.project_name}""" | ||
compiler.ar.cmd=arm-none-eabi-ar | ||
compiler.ar.flags=rcs | ||
compiler.objcopy.cmd=arm-none-eabi-objcopy | ||
compiler.objcopy.eep.flags=-O ihex -j .eeprom --set-section-flags=.eeprom=alloc,load --no-change-warnings --change-section-lma .eeprom=0 | ||
compiler.elf2hex.bin.flags=-O binary | ||
compiler.elf2hex.hex.flags=-O ihex -R .eeprom | ||
compiler.elf2hex.cmd=arm-none-eabi-objcopy | ||
compiler.ldflags=-mcpu={build.mcu} -mthumb -Wl,--cref -Wl,--check-sections -Wl,--gc-sections -Wl,--unresolved-symbols=report-all -Wl,--warn-common -Wl,--warn-section-align -u _printf_float -u _scanf_float -Wl,--wrap,_write -u __wrap__write | ||
compiler.size.cmd=arm-none-eabi-size | ||
compiler.define=-DARDUINO= | ||
compiler.readelf.cmd=arm-none-eabi-readelf | ||
|
||
# this can be overriden in boards.txt | ||
build.extra_flags= | ||
build.project_flags= | ||
build.cache_flags= | ||
build.flags.optimize= | ||
build.flags.maxspi= | ||
build.flags.maxqspi= | ||
build.flags.usbstack= | ||
build.flags.debug= | ||
|
||
# These can be overridden in platform.local.txt | ||
compiler.c.extra_flags= | ||
compiler.c.elf.extra_flags= | ||
#compiler.c.elf.extra_flags=-v | ||
compiler.cpp.extra_flags= | ||
compiler.S.extra_flags= | ||
compiler.ar.extra_flags= | ||
compiler.elf2hex.extra_flags= | ||
|
||
compiler.arm.cmsis.c.flags="-I{runtime.tools.CMSIS-5.4.0.path}/CMSIS/Core/Include/" "-I{runtime.tools.CMSIS-5.4.0.path}/CMSIS/DSP/Include/" "-I{runtime.tools.CMSIS-Atmel-1.2.1.path}/CMSIS-Atmel/CMSIS/Device/ATMEL/" | ||
compiler.arm.cmsis.ldflags="-L{runtime.tools.CMSIS-5.4.0.path}/CMSIS/Lib/GCC/" -larm_cortexM0l_math | ||
|
||
compiler.libraries.ldflags= | ||
|
||
# USB Flags | ||
# --------- | ||
build.usb_flags=-DUSB_VID={build.vid} -DUSB_PID={build.pid} -DUSBCON -DUSB_CONFIG_POWER={build.usb_power} '-DUSB_MANUFACTURER={build.usb_manufacturer}' '-DUSB_PRODUCT={build.usb_product}' {build.flags.usbstack} {build.flags.debug} "-I{build.core.path}/TinyUSB" "-I{build.core.path}/TinyUSB/Adafruit_TinyUSB_ArduinoCore" "-I{build.core.path}/TinyUSB/Adafruit_TinyUSB_ArduinoCore/tinyusb/src" | ||
|
||
# Default advertised device power setting in mA | ||
build.usb_power=100 | ||
|
||
# Default usb manufacturer will be replaced at compile time using | ||
# numeric vendor ID if available or by board's specific value. | ||
build.usb_manufacturer="Unknown" | ||
|
||
|
||
# Compile patterns | ||
# ---------------- | ||
|
||
## Compile c files | ||
## KH Add -DBOARD_NAME="{build.board}" | ||
recipe.c.o.pattern="{compiler.path}{compiler.c.cmd}" {compiler.c.flags} -DF_CPU={build.f_cpu} -DARDUINO={runtime.ide.version} -DARDUINO_{build.board} -DBOARD_NAME="{build.board}" -DARDUINO_ARCH_{build.arch} {compiler.c.extra_flags} {build.extra_flags} {build.project_flags} {build.cache_flags} {build.flags.debug} {build.flags.optimize} {build.flags.maxspi} {build.flags.maxqspi} {compiler.arm.cmsis.c.flags} {includes} "{source_file}" -o "{object_file}" | ||
##recipe.c.o.pattern="{compiler.path}{compiler.c.cmd}" {compiler.c.flags} -DF_CPU={build.f_cpu} -DARDUINO={runtime.ide.version} -DARDUINO_{build.board} -DARDUINO_ARCH_{build.arch} {compiler.c.extra_flags} {build.extra_flags} {build.project_flags} {build.cache_flags} {build.flags.debug} {build.flags.optimize} {build.flags.maxspi} {build.flags.maxqspi} {compiler.arm.cmsis.c.flags} {includes} "{source_file}" -o "{object_file}" | ||
|
||
## Compile c++ files | ||
## KH Add -DBOARD_NAME="{build.board}" | ||
recipe.cpp.o.pattern="{compiler.path}{compiler.cpp.cmd}" {compiler.cpp.flags} -DF_CPU={build.f_cpu} -DARDUINO={runtime.ide.version} -DARDUINO_{build.board} -DBOARD_NAME="{build.board}" -DARDUINO_ARCH_{build.arch} {compiler.cpp.extra_flags} {build.extra_flags} {build.project_flags} {build.cache_flags} {build.flags.debug} {build.flags.optimize} {build.flags.maxspi} {build.flags.maxqspi} {build.extra_flags} {build.project_flags} {compiler.arm.cmsis.c.flags} {includes} "{source_file}" -o "{object_file}" | ||
##recipe.cpp.o.pattern="{compiler.path}{compiler.cpp.cmd}" {compiler.cpp.flags} -DF_CPU={build.f_cpu} -DARDUINO={runtime.ide.version} -DARDUINO_{build.board} -DARDUINO_ARCH_{build.arch} {compiler.cpp.extra_flags} {build.extra_flags} {build.project_flags} {build.cache_flags} {build.flags.debug} {build.flags.optimize} {build.flags.maxspi} {build.flags.maxqspi} {build.extra_flags} {build.project_flags} {compiler.arm.cmsis.c.flags} {includes} "{source_file}" -o "{object_file}" | ||
|
||
## Compile S files | ||
## KH Add -DBOARD_NAME="{build.board}" | ||
recipe.S.o.pattern="{compiler.path}{compiler.S.cmd}" {compiler.S.flags} -DF_CPU={build.f_cpu} -DARDUINO={runtime.ide.version} -DARDUINO_{build.board} -DBOARD_NAME="{build.board}" -DARDUINO_ARCH_{build.arch} {compiler.S.extra_flags} {build.extra_flags} {build.project_flags} {build.cache_flags} {compiler.arm.cmsis.c.flags} {includes} "{source_file}" -o "{object_file}" | ||
##recipe.S.o.pattern="{compiler.path}{compiler.S.cmd}" {compiler.S.flags} -DF_CPU={build.f_cpu} -DARDUINO={runtime.ide.version} -DARDUINO_{build.board} -DARDUINO_ARCH_{build.arch} {compiler.S.extra_flags} {build.extra_flags} {build.project_flags} {build.cache_flags} {compiler.arm.cmsis.c.flags} {includes} "{source_file}" -o "{object_file}" | ||
|
||
## Create archives | ||
# archive_file_path is needed for backwards compatibility with IDE 1.6.5 or older, IDE 1.6.6 or newer overrides this value | ||
archive_file_path={build.path}/{archive_file} | ||
recipe.ar.pattern="{compiler.path}{compiler.ar.cmd}" {compiler.ar.flags} {compiler.ar.extra_flags} "{archive_file_path}" "{object_file}" | ||
|
||
## Combine gc-sections, archives, and objects | ||
recipe.c.combine.pattern="{compiler.path}{compiler.c.elf.cmd}" "-L{build.path}" {compiler.c.elf.flags} {compiler.c.elf.extra_flags} "-T{build.variant.path}/{build.ldscript}" "-Wl,-Map,{build.path}/{build.project_name}.map" --specs=nano.specs --specs=nosys.specs {compiler.ldflags} -o "{build.path}/{build.project_name}.elf" {object_files} {compiler.libraries.ldflags} -Wl,--start-group {compiler.arm.cmsis.ldflags} "-L{build.variant.path}" -lm "{build.path}/{archive_file}" -Wl,--end-group | ||
|
||
## Create output (bin file) | ||
recipe.objcopy.bin.pattern="{compiler.path}{compiler.elf2hex.cmd}" {compiler.elf2hex.bin.flags} {compiler.elf2hex.extra_flags} "{build.path}/{build.project_name}.elf" "{build.path}/{build.project_name}.bin" | ||
|
||
## Create output (hex file) | ||
recipe.objcopy.hex.pattern="{compiler.path}{compiler.elf2hex.cmd}" {compiler.elf2hex.hex.flags} {compiler.elf2hex.extra_flags} "{build.path}/{build.project_name}.elf" "{build.path}/{build.project_name}.hex" | ||
|
||
build.preferred_out_format=bin | ||
|
||
## Save hex | ||
recipe.output.tmp_file={build.project_name}.{build.preferred_out_format} | ||
recipe.output.save_file={build.project_name}.{build.variant}.{build.preferred_out_format} | ||
|
||
## Compute size | ||
recipe.size.pattern="{compiler.path}{compiler.size.cmd}" -A "{build.path}/{build.project_name}.elf" | ||
recipe.size.regex=\.text\s+([0-9]+).* | ||
|
||
# | ||
# BOSSA | ||
# | ||
tools.bossac.path={runtime.tools.bossac-1.7.0-arduino3.path} | ||
tools.bossac.cmd=bossac | ||
tools.bossac.cmd.windows=bossac.exe | ||
|
||
tools.bossac.upload.params.verbose=-i -d | ||
tools.bossac.upload.params.quiet= | ||
tools.bossac.upload.pattern="{path}/{cmd}" {upload.verbose} --port={serial.port.file} -U {upload.native_usb} -i -e -w -v "{build.path}/{build.project_name}.bin" -R | ||
|
||
tools.bossac_remote.upload.pattern=/usr/bin/run-bossac {upload.verbose} --port=ttyATH0 -U {upload.native_usb} -e -w -v /tmp/sketch.bin -R | ||
|
||
tools.bossac.network_cmd={runtime.tools.arduinoOTA.path}/bin/arduinoOTA | ||
tools.bossac.upload.network_pattern="{network_cmd}" -address {serial.port} -port 65280 -username arduino -password "{network.password}" -sketch "{build.path}/{build.project_name}.bin" -upload /sketch -b | ||
|
||
# v1.8.0 | ||
|
||
tools.bossac18.path={runtime.tools.bossac-1.8.0-48-gb176eee.path} | ||
tools.bossac18.cmd=bossac | ||
|
||
tools.bossac18.upload.params.verbose=-i -d | ||
tools.bossac18.upload.params.quiet= | ||
tools.bossac18.upload.pattern="{path}/{cmd}" {upload.verbose} --port={serial.port.file} -U -i --offset={upload.offset} -w -v "{build.path}/{build.project_name}.bin" -R | ||
|
||
tools.bossac18.network_cmd={runtime.tools.arduinoOTA.path}/bin/arduinoOTA | ||
tools.bossac18.upload.network_pattern="{network_cmd}" -address {serial.port} -port 65280 -username arduino -password "{network.password}" -sketch "{build.path}/{build.project_name}.bin" -upload /sketch -b | ||
|
||
# | ||
# BOSSA (ignore binary size) | ||
# | ||
tools.bossacI.path={runtime.tools.bossac-1.7.0-arduino3.path} | ||
tools.bossacI.cmd=bossac | ||
tools.bossacI.cmd.windows=bossac.exe | ||
|
||
tools.bossacI.upload.params.verbose=-i -d | ||
tools.bossacI.upload.params.quiet= | ||
tools.bossacI.upload.pattern="{path}/{cmd}" {upload.verbose} --port={serial.port.file} -I -U {upload.native_usb} -i -e -w "{build.path}/{build.project_name}.bin" -R | ||
|
||
tools.bossacI_remote.upload.pattern=/usr/bin/run-bossac {upload.verbose} --port=ttyATH0 -U {upload.native_usb} -e -w -v /tmp/sketch.bin -R | ||
|
||
tools.bossacI.network_cmd={runtime.tools.arduinoOTA.path}/bin/arduinoOTA | ||
tools.bossacI.upload.network_pattern="{network_cmd}" -address {serial.port} -port 65280 -username arduino -password "{network.password}" -sketch "{build.path}/{build.project_name}.bin" -upload /sketch -b | ||
|
||
|
||
# | ||
# OpenOCD sketch upload | ||
# | ||
|
||
tools.openocd.path={runtime.tools.openocd-0.10.0-arduino7.path} | ||
tools.openocd.cmd=bin/openocd | ||
tools.openocd.cmd.windows=bin/openocd.exe | ||
|
||
tools.openocd.upload.params.verbose=-d2 | ||
tools.openocd.upload.params.quiet=-d0 | ||
tools.openocd.upload.pattern="{path}/{cmd}" {upload.verbose} -s "{path}/share/openocd/scripts/" -f "{runtime.platform.path}/variants/{build.variant}/{build.openocdscript}" -c "telnet_port disabled; program {{build.path}/{build.project_name}.bin} verify reset 0x2000; shutdown" | ||
|
||
tools.openocd.network_cmd={runtime.tools.arduinoOTA.path}/bin/arduinoOTA | ||
tools.openocd.upload.network_pattern={network_cmd} -address {serial.port} -port 65280 -username arduino -password "{network.password}" -sketch "{build.path}/{build.project_name}.bin" -upload /sketch -b | ||
|
||
# Program flashes the binary at 0x0000, so use the linker script without_bootloader | ||
tools.openocd.program.params.verbose=-d2 | ||
tools.openocd.program.params.quiet=-d0 | ||
tools.openocd.program.pattern="{path}/{cmd}" {program.verbose} -s "{path}/share/openocd/scripts/" -f "{runtime.platform.path}/variants/{build.variant}/{build.openocdscript}" -c "telnet_port disabled; program {{build.path}/{build.project_name}.elf} verify reset; shutdown" | ||
|
||
tools.openocd.erase.params.verbose=-d3 | ||
tools.openocd.erase.params.quiet=-d0 | ||
tools.openocd.erase.pattern= | ||
|
||
tools.openocd.bootloader.params.verbose=-d2 | ||
tools.openocd.bootloader.params.quiet=-d0 | ||
tools.openocd.bootloader.pattern="{path}/{cmd}" {bootloader.verbose} -s "{path}/share/openocd/scripts/" -f "{runtime.platform.path}/variants/{build.variant}/{build.openocdscript}" -c "telnet_port disabled; init; halt; at91samd bootloader 0; program {{runtime.platform.path}/bootloaders/{bootloader.file}} verify reset; shutdown" | ||
|
||
# | ||
# OpenOCD sketch upload - version with configurable bootloader size | ||
# FIXME: this programmer is a workaround for default options being overwritten by uploadUsingPreferences | ||
# | ||
|
||
tools.openocd-withbootsize.path={runtime.tools.openocd-0.10.0-arduino7.path} | ||
tools.openocd-withbootsize.cmd=bin/openocd | ||
tools.openocd-withbootsize.cmd.windows=bin/openocd.exe | ||
|
||
tools.openocd-withbootsize.upload.params.verbose=-d2 | ||
tools.openocd-withbootsize.upload.params.quiet=-d0 | ||
tools.openocd-withbootsize.upload.pattern="{path}/{cmd}" {upload.verbose} -s "{path}/share/openocd/scripts/" -f "{runtime.platform.path}/variants/{build.variant}/{build.openocdscript}" -c "telnet_port disabled; program {{build.path}/{build.project_name}.bin} verify reset {bootloader.size}; shutdown" | ||
|
||
# Program flashes the binary at 0x0000, so use the linker script without_bootloader | ||
tools.openocd-withbootsize.program.params.verbose=-d2 | ||
tools.openocd-withbootsize.program.params.quiet=-d0 | ||
tools.openocd-withbootsize.program.pattern="{path}/{cmd}" {program.verbose} -s "{path}/share/openocd/scripts/" -f "{runtime.platform.path}/variants/{build.variant}/{build.openocdscript}" -c "telnet_port disabled; program {{build.path}/{build.project_name}.elf} verify reset; shutdown" | ||
|
||
tools.openocd-withbootsize.erase.params.verbose=-d3 | ||
tools.openocd-withbootsize.erase.params.quiet=-d0 | ||
tools.openocd-withbootsize.erase.pattern= | ||
|
||
tools.openocd-withbootsize.bootloader.params.verbose=-d2 | ||
tools.openocd-withbootsize.bootloader.params.quiet=-d0 | ||
tools.openocd-withbootsize.bootloader.pattern="{path}/{cmd}" {bootloader.verbose} -s "{path}/share/openocd/scripts/" -f "{runtime.platform.path}/variants/{build.variant}/{build.openocdscript}" -c "telnet_port disabled; init; halt; at91samd bootloader 0; program {{runtime.platform.path}/bootloaders/{bootloader.file}} verify reset; shutdown" |
165 changes: 165 additions & 0 deletions
165
Packages_Patches/arduino/hardware/samd/1.8.8/cores/Arduino.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,165 @@ | ||
/* | ||
Arduino.h - Main include file for the Arduino SDK | ||
Copyright (c) 2014 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 | ||
*/ | ||
|
||
// KH, This is the fix according to https://github.com/arduino/ArduinoCore-samd/pull/399 | ||
// to avoid notorious compiler error while uing STL (min and max macro error) | ||
// It's terrible Arduino has just released new core and still don't merge the PR | ||
|
||
#ifndef Arduino_h | ||
#define Arduino_h | ||
|
||
#include <stdbool.h> | ||
#include <stdint.h> | ||
#include <stdlib.h> | ||
#include <string.h> | ||
#include <math.h> | ||
|
||
typedef bool boolean; | ||
typedef uint8_t byte; | ||
typedef uint16_t word; | ||
|
||
// some libraries and sketches depend on this AVR stuff, | ||
// assuming Arduino.h or WProgram.h automatically includes it... | ||
// | ||
#include "avr/pgmspace.h" | ||
#include "avr/interrupt.h" | ||
#include "avr/io.h" | ||
|
||
#include "binary.h" | ||
#include "itoa.h" | ||
|
||
#ifdef __cplusplus | ||
extern "C"{ | ||
#endif // __cplusplus | ||
|
||
// Include Atmel headers | ||
#include "sam.h" | ||
|
||
#include "wiring_constants.h" | ||
|
||
#define clockCyclesPerMicrosecond() ( SystemCoreClock / 1000000L ) | ||
#define clockCyclesToMicroseconds(a) ( ((a) * 1000L) / (SystemCoreClock / 1000L) ) | ||
#define microsecondsToClockCycles(a) ( (a) * (SystemCoreClock / 1000000L) ) | ||
|
||
void yield( void ) ; | ||
|
||
/* system functions */ | ||
int main( void ); | ||
void init( void ); | ||
|
||
/* sketch */ | ||
void setup( void ) ; | ||
void loop( void ) ; | ||
|
||
#include "WVariant.h" | ||
|
||
#ifdef __cplusplus | ||
} // extern "C" | ||
#endif | ||
|
||
// The following headers are for C++ only compilation | ||
#ifdef __cplusplus | ||
#include "WCharacter.h" | ||
#include "WString.h" | ||
#include "Tone.h" | ||
#include "WMath.h" | ||
#include "HardwareSerial.h" | ||
#include "pulse.h" | ||
#include <bits/stl_algobase.h> | ||
#endif | ||
|
||
#include "delay.h" | ||
|
||
#ifdef __cplusplus | ||
#include "Uart.h" | ||
#endif | ||
|
||
// Include board variant | ||
#include "variant.h" | ||
#include "wiring.h" | ||
#include "wiring_digital.h" | ||
#include "wiring_analog.h" | ||
#include "wiring_shift.h" | ||
#include "WInterrupts.h" | ||
|
||
#ifndef __cplusplus | ||
// undefine stdlib's abs if encountered | ||
#ifdef abs | ||
#undef abs | ||
#endif // abs | ||
|
||
#define min(a,b) ((a)<(b)?(a):(b)) | ||
#define max(a,b) ((a)>(b)?(a):(b)) | ||
#define abs(x) ((x)>0?(x):-(x)) | ||
#define round(x) ((x)>=0?(long)((x)+0.5):(long)((x)-0.5)) | ||
|
||
#else | ||
//using std::min; | ||
//using std::max; | ||
template<class T, class L> | ||
auto min(const T& a, const L& b) -> decltype((b < a) ? b : a) | ||
{ | ||
return (b < a) ? b : a; | ||
} | ||
|
||
template<class T, class L> | ||
auto max(const T& a, const L& b) -> decltype((b < a) ? b : a) | ||
{ | ||
return (a < b) ? b : a; | ||
} | ||
#endif | ||
|
||
#define constrain(amt,low,high) ((amt)<(low)?(low):((amt)>(high)?(high):(amt))) | ||
#define radians(deg) ((deg)*DEG_TO_RAD) | ||
#define degrees(rad) ((rad)*RAD_TO_DEG) | ||
#define sq(x) ((x)*(x)) | ||
|
||
#define interrupts() __enable_irq() | ||
#define noInterrupts() __disable_irq() | ||
|
||
#define lowByte(w) ((uint8_t) ((w) & 0xff)) | ||
#define highByte(w) ((uint8_t) ((w) >> 8)) | ||
|
||
#define bitRead(value, bit) (((value) >> (bit)) & 0x01) | ||
#define bitSet(value, bit) ((value) |= (1UL << (bit))) | ||
#define bitClear(value, bit) ((value) &= ~(1UL << (bit))) | ||
#define bitWrite(value, bit, bitvalue) (bitvalue ? bitSet(value, bit) : bitClear(value, bit)) | ||
#define bit(b) (1UL << (b)) | ||
|
||
#if (ARDUINO_SAMD_VARIANT_COMPLIANCE >= 10606) | ||
// Interrupts | ||
#define digitalPinToInterrupt(P) ( P ) | ||
#endif | ||
|
||
// Allows publishing the Beta core under samd-beta / arduino organization | ||
#ifndef ARDUINO_ARCH_SAMD | ||
#define ARDUINO_ARCH_SAMD | ||
#endif | ||
|
||
// USB Device | ||
#include "USB/USBDesc.h" | ||
#include "USB/USBCore.h" | ||
#include "USB/USBAPI.h" | ||
#include "USB/USB_host.h" | ||
|
||
#ifdef __cplusplus | ||
#include "USB/CDC.h" | ||
#endif | ||
|
||
#endif // Arduino_h |
Oops, something went wrong.