2019-08-28 01:28:42 +00:00
|
|
|
#
|
|
|
|
# common-cxxflags.py
|
|
|
|
# Convenience script to apply customizations to CPP flags
|
|
|
|
#
|
2022-08-06 06:17:46 +00:00
|
|
|
|
2021-11-04 10:28:42 +00:00
|
|
|
import pioutil
|
|
|
|
if pioutil.is_pio_build():
|
2024-06-14 21:01:34 +00:00
|
|
|
env = pioutil.env
|
2022-08-06 06:17:46 +00:00
|
|
|
|
|
|
|
cxxflags = [
|
|
|
|
# "-Wno-incompatible-pointer-types",
|
|
|
|
# "-Wno-unused-const-variable",
|
|
|
|
# "-Wno-maybe-uninitialized",
|
|
|
|
# "-Wno-sign-compare"
|
|
|
|
]
|
|
|
|
if "teensy" not in env["PIOENV"]:
|
|
|
|
cxxflags += ["-Wno-register"]
|
|
|
|
env.Append(CXXFLAGS=cxxflags)
|
|
|
|
|
|
|
|
#
|
|
|
|
# Add CPU frequency as a compile time constant instead of a runtime variable
|
|
|
|
#
|
|
|
|
def add_cpu_freq():
|
|
|
|
if "BOARD_F_CPU" in env:
|
|
|
|
env["BUILD_FLAGS"].append("-DBOARD_F_CPU=" + env["BOARD_F_CPU"])
|
2021-10-19 10:53:34 +00:00
|
|
|
|
2022-08-06 06:17:46 +00:00
|
|
|
# Useful for JTAG debugging
|
|
|
|
#
|
|
|
|
# It will separate release and debug build folders.
|
|
|
|
# It useful to keep two live versions: a debug version for debugging and another for
|
|
|
|
# release, for flashing when upload is not done automatically by jlink/stlink.
|
|
|
|
# Without this, PIO needs to recompile everything twice for any small change.
|
|
|
|
if env.GetBuildType() == "debug" and env.get("UPLOAD_PROTOCOL") not in ["jlink", "stlink", "custom"]:
|
|
|
|
env["BUILD_DIR"] = "$PROJECT_BUILD_DIR/$PIOENV/debug"
|
2020-10-31 22:14:10 +00:00
|
|
|
|
2022-08-06 06:17:46 +00:00
|
|
|
def on_program_ready(source, target, env):
|
|
|
|
import shutil
|
|
|
|
shutil.copy(target[0].get_abspath(), env.subst("$PROJECT_BUILD_DIR/$PIOENV"))
|
2021-02-26 23:59:28 +00:00
|
|
|
|
2022-08-06 06:17:46 +00:00
|
|
|
env.AddPostAction("$PROGPATH", on_program_ready)
|
2021-02-26 23:59:28 +00:00
|
|
|
|
2022-08-06 06:17:46 +00:00
|
|
|
# On some platform, F_CPU is a runtime variable. Since it's used to convert from ns
|
|
|
|
# to CPU cycles, this adds overhead preventing small delay (in the order of less than
|
|
|
|
# 30 cycles) to be generated correctly. By using a compile time constant instead
|
|
|
|
# the compiler will perform the computation and this overhead will be avoided
|
|
|
|
add_cpu_freq()
|