|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329 |
- # Copyright 2014-present PlatformIO <contact@platformio.org>
- #
- # Licensed under the Apache License, Version 2.0 (the "License");
- # you may not use this file except in compliance with the License.
- # You may obtain a copy of the License at
- #
- # http://www.apache.org/licenses/LICENSE-2.0
- #
- # Unless required by applicable law or agreed to in writing, software
- # distributed under the License is distributed on an "AS IS" BASIS,
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- # See the License for the specific language governing permissions and
- # limitations under the License.
-
- """
- Arduino
-
- Arduino Wiring-based Framework allows writing cross-platform software to
- control devices attached to a wide range of Arduino boards to create all
- kinds of creative coding, interactive objects, spaces or physical experiences.
-
- http://arduino.cc/en/Reference/HomePage
- """
-
- from io import open
- from os import listdir
- from os.path import isdir, isfile, join
-
- from SCons.Script import DefaultEnvironment
-
- env = DefaultEnvironment()
- platform = env.PioPlatform()
-
- FRAMEWORK_DIR = platform.get_package_dir("framework-arduinoteensy-cxx20")
- FRAMEWORK_VERSION = platform.get_package_version("framework-arduinoteensy-cxx20")
- BUILD_CORE = env.BoardConfig().get("build.core")
-
- assert isdir(FRAMEWORK_DIR)
-
- BUILTIN_USB_FLAGS = (
- "USB_SERIAL",
- "USB_DUAL_SERIAL",
- "USB_TRIPLE_SERIAL",
- "USB_KEYBOARDONLY",
- "USB_TOUCHSCREEN",
- "USB_HID_TOUCHSCREEN",
- "USB_HID",
- "USB_SERIAL_HID",
- "USB_MIDI",
- "USB_MIDI4",
- "USB_MIDI16",
- "USB_MIDI_SERIAL",
- "USB_MIDI4_SERIAL",
- "USB_MIDI16_SERIAL",
- "USB_AUDIO",
- "USB_MIDI_AUDIO_SERIAL",
- "USB_MIDI16_AUDIO_SERIAL",
- "USB_MTPDISK",
- "USB_RAWHID",
- "USB_FLIGHTSIM",
- "USB_FLIGHTSIM_JOYSTICK",
- "USB_EVERYTHING",
- "USB_DISABLED",
- )
- if not set(env.get("CPPDEFINES", [])) & set(BUILTIN_USB_FLAGS):
- env.Append(CPPDEFINES=["USB_SERIAL"])
-
- env.Replace(
- SIZEPROGREGEXP=r"^(?:\.text|\.text\.progmem|\.text\.itcm|\.data)\s+([0-9]+).*",
- SIZEDATAREGEXP=r"^(?:\.usbdescriptortable|\.dmabuffers|\.usbbuffers|\.data|\.bss|\.noinit|\.text\.itcm|\.text\.itcm\.padding)\s+([0-9]+).*"
- )
-
- env.Append(
- CPPDEFINES=[
- ("ARDUINO", 10805),
- ("TEENSYDUINO", 149),
- "CORE_TEENSY"
- ],
-
- CPPPATH=[
- join(FRAMEWORK_DIR, "cores", BUILD_CORE)
- ],
-
- LIBSOURCE_DIRS=[
- join(FRAMEWORK_DIR, "libraries")
- ]
- )
-
- if "BOARD" in env and BUILD_CORE == "teensy":
- env.Append(
- ASFLAGS=["-x", "assembler-with-cpp"],
-
- CCFLAGS=[
- "-Os", # optimize for size
- "-Wall", # show warnings
- "-ffunction-sections", # place each function in its own section
- "-fdata-sections",
- "-mmcu=$BOARD_MCU"
- ],
-
- CXXFLAGS=[
- "-fno-exceptions",
- "-felide-constructors",
- "-std=gnu++11",
- "-fpermissive"
- ],
-
- CPPDEFINES=[
- ("F_CPU", "$BOARD_F_CPU"),
- "LAYOUT_US_ENGLISH"
- ],
-
- LINKFLAGS=[
- "-Os",
- "-Wl,--gc-sections,--relax",
- "-mmcu=$BOARD_MCU"
- ],
-
- LIBS=["m"]
- )
- elif "BOARD" in env and BUILD_CORE in ("teensy3", "teensy4", "teensy41"):
- env.Replace(
- AR="arm-none-eabi-gcc-ar",
- RANLIB="$AR"
- )
-
- env.Append(
- ASFLAGS=["-x", "assembler-with-cpp"],
-
- CCFLAGS=[
- "-Wall", # show warnings
- "-ffunction-sections", # place each function in its own section
- "-fdata-sections",
- "-mthumb",
- "-mcpu=%s" % env.BoardConfig().get("build.cpu"),
- "-fsingle-precision-constant"
- ],
-
- CXXFLAGS=[
- "-fno-exceptions",
- "-felide-constructors",
- "-fno-rtti",
- "-std=gnu++20",
- "-Wno-error=narrowing",
- "-fpermissive"
- ],
-
- CPPDEFINES=[
- ("F_CPU", "$BOARD_F_CPU"),
- "LAYOUT_US_ENGLISH"
- ],
-
- RANLIBFLAGS=["-s"],
-
- LINKFLAGS=[
- "-Wl,--gc-sections,--relax",
- "-mthumb",
- "-mcpu=%s" % env.BoardConfig().get("build.cpu"),
- "-Wl,--defsym=__rtc_localtime=$UNIX_TIME",
- "-fsingle-precision-constant"
- ],
-
- LIBS=["m", "stdc++"]
- )
-
- if not env.BoardConfig().get("build.ldscript", ""):
- env.Replace(LDSCRIPT_PATH=env.BoardConfig().get("build.arduino.ldscript", ""))
-
- if env.BoardConfig().id_ in ("teensy35", "teensy36", "teensy40", "teensy41"):
- fpv_version = "4-sp"
- if env.BoardConfig().id_.startswith("teensy4"):
- fpv_version = "5"
-
- env.Append(
- CCFLAGS=[
- "-mfloat-abi=hard",
- "-mfpu=fpv%s-d16" % fpv_version
- ],
-
- LINKFLAGS=[
- "-mfloat-abi=hard",
- "-mfpu=fpv%s-d16" % fpv_version
- ]
- )
-
- # Optimization
- if "TEENSY_OPT_FASTER_LTO" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-O2", "-flto", "-fno-fat-lto-objects"],
- LINKFLAGS=["-O2", "-flto", "-fno-fat-lto-objects", "-fuse-linker-plugin"]
- )
- elif "TEENSY_OPT_FAST" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-O1"],
- LINKFLAGS=["-O1"]
- )
- elif "TEENSY_OPT_FAST_LTO" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-O1", "-flto", "-fno-fat-lto-objects"],
- LINKFLAGS=["-O1", "-flto", "-fno-fat-lto-objects", "-fuse-linker-plugin"]
- )
- elif "TEENSY_OPT_FASTEST" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-O3"],
- LINKFLAGS=["-O3"]
- )
- elif "TEENSY_OPT_FASTEST_LTO" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-O3", "-flto", "-fno-fat-lto-objects"],
- LINKFLAGS=["-O3", "-flto", "-fno-fat-lto-objects", "-fuse-linker-plugin"]
- )
- elif "TEENSY_OPT_FASTEST_PURE_CODE" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-O3", "-mpure-code"],
- CPPDEFINES=["__PURE_CODE__"],
- LINKFLAGS=["-O3", "-mpure-code"]
- )
- elif "TEENSY_OPT_FASTEST_PURE_CODE_LTO" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-O3", "-mpure-code", "-flto", "-fno-fat-lto-objects"],
- CPPDEFINES=["__PURE_CODE__"],
- LINKFLAGS=["-O3", "-mpure-code", "-flto", "-fno-fat-lto-objects", "-fuse-linker-plugin"]
- )
- elif "TEENSY_OPT_DEBUG" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-g", "-Og"],
- LINKFLAGS=["-g", "-Og"]
- )
- elif "TEENSY_OPT_DEBUG_LTO" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-g", "-Og", "-flto", "-fno-fat-lto-objects"],
- LINKFLAGS=["-g", "-Og", "-flto", "-fno-fat-lto-objects", "-fuse-linker-plugin"]
- )
- elif "TEENSY_OPT_SMALLEST_CODE_LTO" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-Os", "--specs=nano.specs", "-flto", "-fno-fat-lto-objects"],
- LINKFLAGS=["-Os", "--specs=nano.specs", "-flto", "-fno-fat-lto-objects", "-fuse-linker-plugin"]
- )
- elif "TEENSY_OPT_FASTER" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-O2"],
- LINKFLAGS=["-O2"]
- )
- elif "TEENSY_OPT_SMALLEST_CODE" in env['CPPDEFINES']:
- env.Append(
- CCFLAGS=["-Os", "--specs=nano.specs"],
- LINKFLAGS=["-Os", "--specs=nano.specs"]
- )
- # default profiles
- else:
- # for Teensy LC => TEENSY_OPT_SMALLEST_CODE
- if env.BoardConfig().id_ == "teensylc":
- env.Append(
- CCFLAGS=["-Os", "--specs=nano.specs"],
- LINKFLAGS=["-Os", "--specs=nano.specs"]
- )
- # for others => TEENSY_OPT_FASTER
- else:
- env.Append(
- CCFLAGS=["-O2"],
- LINKFLAGS=["-O2"]
- )
-
- env.Append(
- ASFLAGS=env.get("CCFLAGS", [])[:]
- )
-
- if "cortex-m" in env.BoardConfig().get("build.cpu", ""):
- board = env.subst("$BOARD")
- math_lib = "arm_cortex%s_math"
- if board in ("teensy35", "teensy36"):
- math_lib = math_lib % "M4lf"
- elif board in ("teensy30", "teensy31"):
- math_lib = math_lib % "M4l"
- elif board.startswith("teensy4"):
- math_lib = math_lib % "M7lfsp"
- else:
- math_lib = math_lib % "M0l"
-
- env.Prepend(LIBS=[math_lib])
-
- # Teensy 2.x Core
- if BUILD_CORE == "teensy":
- env.Append(CPPPATH=[join(FRAMEWORK_DIR, "cores")])
-
- # search relative includes in teensy directories
- core_dir = join(FRAMEWORK_DIR, "cores", "teensy")
- for item in sorted(listdir(core_dir)):
- file_path = join(core_dir, item)
- if not isfile(file_path):
- continue
- content = None
- content_changed = False
- with open(file_path, encoding="latin-1") as fp:
- content = fp.read()
- if '#include "../' in content:
- content_changed = True
- content = content.replace('#include "../', '#include "')
- if not content_changed:
- continue
- with open(file_path, "w", encoding="latin-1") as fp:
- fp.write(content)
- else:
- env.Prepend(LIBPATH=[join(FRAMEWORK_DIR, "cores", BUILD_CORE)])
-
- #
- # Target: Build Core Library
- #
-
- libs = []
-
- if "build.variant" in env.BoardConfig():
- env.Append(
- CPPPATH=[
- join(FRAMEWORK_DIR, "variants",
- env.BoardConfig().get("build.variant"))
- ]
- )
- libs.append(env.BuildLibrary(
- join("$BUILD_DIR", "FrameworkArduinoVariant"),
- join(FRAMEWORK_DIR, "variants", env.BoardConfig().get("build.variant"))
- ))
-
- libs.append(env.BuildLibrary(
- join("$BUILD_DIR", "FrameworkArduino"),
- join(FRAMEWORK_DIR, "cores", BUILD_CORE)
- ))
-
- env.Prepend(LIBS=libs)
|