mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 09:58:28 -04:00
a62c50fb21
- Fix issue where linker fails with Xcode 15.3. - Add check for CC_VERSION. Signed-off-by: Rhys Mainwaring <rhys.mainwaring@me.com>
1611 lines
52 KiB
Python
1611 lines
52 KiB
Python
# encoding: utf-8
|
|
|
|
from collections import OrderedDict
|
|
import re
|
|
import sys, os
|
|
import fnmatch
|
|
|
|
import waflib
|
|
from waflib import Utils
|
|
from waflib.Configure import conf
|
|
import json
|
|
_board_classes = {}
|
|
_board = None
|
|
|
|
class BoardMeta(type):
|
|
def __init__(cls, name, bases, dct):
|
|
super(BoardMeta, cls).__init__(name, bases, dct)
|
|
|
|
if 'abstract' not in cls.__dict__:
|
|
cls.abstract = False
|
|
if cls.abstract:
|
|
return
|
|
|
|
if not hasattr(cls, 'toolchain'):
|
|
cls.toolchain = 'native'
|
|
|
|
board_name = getattr(cls, 'name', name)
|
|
if board_name in _board_classes:
|
|
raise Exception('board named %s already exists' % board_name)
|
|
_board_classes[board_name] = cls
|
|
|
|
class Board:
|
|
abstract = True
|
|
|
|
def __init__(self):
|
|
self.with_can = False
|
|
|
|
def configure(self, cfg):
|
|
cfg.env.TOOLCHAIN = cfg.options.toolchain or self.toolchain
|
|
cfg.env.ROMFS_FILES = []
|
|
cfg.load('toolchain')
|
|
cfg.load('cxx_checks')
|
|
|
|
env = waflib.ConfigSet.ConfigSet()
|
|
def srcpath(path):
|
|
return cfg.srcnode.make_node(path).abspath()
|
|
env.SRCROOT = srcpath('')
|
|
self.configure_env(cfg, env)
|
|
|
|
# Setup scripting:
|
|
env.DEFINES.update(
|
|
LUA_32BITS = 1,
|
|
)
|
|
|
|
env.AP_LIBRARIES += [
|
|
'AP_Scripting',
|
|
'AP_Scripting/lua/src',
|
|
]
|
|
|
|
if cfg.options.enable_scripting:
|
|
env.DEFINES.update(
|
|
AP_SCRIPTING_ENABLED = 1,
|
|
)
|
|
elif cfg.options.disable_scripting:
|
|
env.DEFINES.update(
|
|
AP_SCRIPTING_ENABLED = 0,
|
|
)
|
|
|
|
# allow GCS disable for AP_DAL example
|
|
if cfg.options.no_gcs:
|
|
env.CXXFLAGS += ['-DHAL_GCS_ENABLED=0']
|
|
|
|
# configurations for XRCE-DDS
|
|
if cfg.options.enable_dds:
|
|
cfg.recurse('libraries/AP_DDS')
|
|
env.ENABLE_DDS = True
|
|
env.AP_LIBRARIES += [
|
|
'AP_DDS'
|
|
]
|
|
env.DEFINES.update(AP_DDS_ENABLED = 1)
|
|
# check for microxrceddsgen
|
|
cfg.find_program('microxrceddsgen',mandatory=True)
|
|
else:
|
|
env.ENABLE_DDS = False
|
|
env.DEFINES.update(AP_DDS_ENABLED = 0)
|
|
|
|
# setup for supporting onvif cam control
|
|
if cfg.options.enable_onvif:
|
|
cfg.recurse('libraries/AP_ONVIF')
|
|
env.ENABLE_ONVIF = True
|
|
env.ROMFS_FILES += [('scripts/ONVIF_Camera_Control.lua',
|
|
'libraries/AP_Scripting/applets/ONVIF_Camera_Control.lua')]
|
|
env.DEFINES.update(
|
|
ENABLE_ONVIF=1,
|
|
SCRIPTING_ENABLE_DEFAULT=1,
|
|
)
|
|
env.AP_LIBRARIES += [
|
|
'AP_ONVIF'
|
|
]
|
|
else:
|
|
env.ENABLE_ONVIF = False
|
|
env.DEFINES.update(
|
|
ENABLE_ONVIF=0,
|
|
)
|
|
|
|
# allow enable of OpenDroneID for any board
|
|
if cfg.options.enable_opendroneid:
|
|
env.ENABLE_OPENDRONEID = True
|
|
env.DEFINES.update(
|
|
AP_OPENDRONEID_ENABLED=1,
|
|
)
|
|
cfg.msg("Enabled OpenDroneID", 'yes')
|
|
else:
|
|
cfg.msg("Enabled OpenDroneID", 'no', color='YELLOW')
|
|
|
|
# allow enable of firmware ID checking for any board
|
|
if cfg.options.enable_check_firmware:
|
|
env.CHECK_FIRMWARE_ENABLED = True
|
|
env.DEFINES.update(
|
|
AP_CHECK_FIRMWARE_ENABLED=1,
|
|
)
|
|
cfg.msg("Enabled firmware ID checking", 'yes')
|
|
else:
|
|
cfg.msg("Enabled firmware ID checking", 'no', color='YELLOW')
|
|
|
|
if cfg.options.enable_gps_logging:
|
|
env.DEFINES.update(
|
|
AP_GPS_DEBUG_LOGGING_ENABLED=1,
|
|
)
|
|
cfg.msg("GPS Debug Logging", 'yes')
|
|
else:
|
|
cfg.msg("GPS Debug Logging", 'no', color='YELLOW')
|
|
|
|
# allow enable of custom controller for any board
|
|
# enabled on sitl by default
|
|
if (cfg.options.enable_custom_controller or self.get_name() == "sitl") and not cfg.options.no_gcs:
|
|
env.ENABLE_CUSTOM_CONTROLLER = True
|
|
env.DEFINES.update(
|
|
AP_CUSTOMCONTROL_ENABLED=1,
|
|
)
|
|
env.AP_LIBRARIES += [
|
|
'AC_CustomControl'
|
|
]
|
|
cfg.msg("Enabled custom controller", 'yes')
|
|
else:
|
|
env.DEFINES.update(
|
|
AP_CUSTOMCONTROL_ENABLED=0,
|
|
)
|
|
cfg.msg("Enabled custom controller", 'no', color='YELLOW')
|
|
|
|
if cfg.options.enable_ppp:
|
|
env.CXXFLAGS += ['-DAP_NETWORKING_BACKEND_PPP=1']
|
|
|
|
if cfg.options.disable_networking:
|
|
env.CXXFLAGS += ['-DAP_NETWORKING_ENABLED=0']
|
|
|
|
if cfg.options.enable_networking_tests:
|
|
env.CXXFLAGS += ['-DAP_NETWORKING_TESTS_ENABLED=1']
|
|
|
|
d = env.get_merged_dict()
|
|
# Always prepend so that arguments passed in the command line get
|
|
# the priority.
|
|
for k, val in d.items():
|
|
# Dictionaries (like 'DEFINES') are converted to lists to
|
|
# conform to waf conventions.
|
|
if isinstance(val, dict):
|
|
keys = list(val.keys())
|
|
if not isinstance(val, OrderedDict):
|
|
keys.sort()
|
|
val = ['%s=%s' % (vk, val[vk]) for vk in keys]
|
|
|
|
if k in cfg.env and isinstance(cfg.env[k], list):
|
|
cfg.env.prepend_value(k, val)
|
|
else:
|
|
cfg.env[k] = val
|
|
|
|
cfg.ap_common_checks()
|
|
|
|
cfg.env.prepend_value('INCLUDES', [
|
|
cfg.srcnode.find_dir('libraries/AP_Common/missing').abspath()
|
|
])
|
|
if os.path.exists(os.path.join(env.SRCROOT, '.vscode/c_cpp_properties.json')):
|
|
# change c_cpp_properties.json configure the VSCode Intellisense env
|
|
c_cpp_properties = json.load(open(os.path.join(env.SRCROOT, '.vscode/c_cpp_properties.json')))
|
|
for config in c_cpp_properties['configurations']:
|
|
config['compileCommands'] = "${workspaceFolder}/build/%s/compile_commands.json" % self.get_name()
|
|
json.dump(c_cpp_properties, open(os.path.join(env.SRCROOT, './.vscode/c_cpp_properties.json'), 'w'), indent=4)
|
|
cfg.msg("Configured VSCode Intellisense", 'yes')
|
|
else:
|
|
cfg.msg("Configured VSCode Intellisense:", 'no', color='YELLOW')
|
|
|
|
def cc_version_gte(self, cfg, want_major, want_minor):
|
|
(major, minor, patchlevel) = cfg.env.CC_VERSION
|
|
return (int(major) > want_major or
|
|
(int(major) == want_major and int(minor) >= want_minor))
|
|
|
|
def configure_env(self, cfg, env):
|
|
# Use a dictionary instead of the convetional list for definitions to
|
|
# make easy to override them. Convert back to list before consumption.
|
|
env.DEFINES = {}
|
|
|
|
# potentially set extra defines from an environment variable:
|
|
if cfg.options.define is not None:
|
|
for (n, v) in [d.split("=") for d in cfg.options.define]:
|
|
cfg.msg("Defining: %s" % (n, ), v)
|
|
env.CFLAGS += ['-D%s=%s' % (n, v)]
|
|
env.CXXFLAGS += ['-D%s=%s' % (n, v)]
|
|
|
|
env.CFLAGS += [
|
|
'-ffunction-sections',
|
|
'-fdata-sections',
|
|
'-fsigned-char',
|
|
|
|
'-Wall',
|
|
'-Wextra',
|
|
'-Werror=format',
|
|
'-Wpointer-arith',
|
|
'-Wcast-align',
|
|
'-Wno-missing-field-initializers',
|
|
'-Wno-unused-parameter',
|
|
'-Wno-redundant-decls',
|
|
'-Wno-unknown-pragmas',
|
|
'-Wno-trigraphs',
|
|
'-Werror=shadow',
|
|
'-Werror=return-type',
|
|
'-Werror=unused-result',
|
|
'-Werror=unused-variable',
|
|
'-Werror=narrowing',
|
|
'-Werror=attributes',
|
|
'-Werror=overflow',
|
|
'-Werror=parentheses',
|
|
'-Werror=format-extra-args',
|
|
'-Werror=ignored-qualifiers',
|
|
'-Werror=undef',
|
|
'-DARDUPILOT_BUILD',
|
|
]
|
|
|
|
if cfg.options.scripting_checks:
|
|
env.DEFINES.update(
|
|
AP_SCRIPTING_CHECKS = 1,
|
|
)
|
|
|
|
cfg.msg("CXX Compiler", "%s %s" % (cfg.env.COMPILER_CXX, ".".join(cfg.env.CC_VERSION)))
|
|
|
|
if cfg.options.assert_cc_version:
|
|
cfg.msg("Checking compiler", "%s %s" % (cfg.options.assert_cc_version, ".".join(cfg.env.CC_VERSION)))
|
|
have_version = cfg.env.COMPILER_CXX+"-"+'.'.join(list(cfg.env.CC_VERSION))
|
|
want_version = cfg.options.assert_cc_version
|
|
if have_version != want_version:
|
|
cfg.fatal("cc version mismatch: %s should be %s" % (have_version, want_version))
|
|
|
|
if 'clang' in cfg.env.COMPILER_CC:
|
|
env.CFLAGS += [
|
|
'-fcolor-diagnostics',
|
|
'-Wno-gnu-designator',
|
|
'-Wno-inconsistent-missing-override',
|
|
'-Wno-mismatched-tags',
|
|
'-Wno-gnu-variable-sized-type-not-at-end',
|
|
'-Werror=implicit-fallthrough',
|
|
'-cl-single-precision-constant',
|
|
]
|
|
env.CXXFLAGS += [
|
|
'-cl-single-precision-constant',
|
|
]
|
|
else:
|
|
env.CFLAGS += [
|
|
'-Wno-format-contains-nul',
|
|
'-fsingle-precision-constant', # force const vals to be float , not double. so 100.0 means 100.0f
|
|
]
|
|
if self.cc_version_gte(cfg, 7, 4):
|
|
env.CXXFLAGS += [
|
|
'-Werror=implicit-fallthrough',
|
|
]
|
|
env.CXXFLAGS += [
|
|
'-fcheck-new',
|
|
'-fsingle-precision-constant',
|
|
]
|
|
|
|
if cfg.env.DEBUG:
|
|
env.CFLAGS += [
|
|
'-g',
|
|
'-O0',
|
|
]
|
|
env.DEFINES.update(
|
|
HAL_DEBUG_BUILD = 1,
|
|
)
|
|
elif cfg.options.debug_symbols:
|
|
env.CFLAGS += [
|
|
'-g',
|
|
]
|
|
if cfg.env.COVERAGE:
|
|
env.CFLAGS += [
|
|
'-fprofile-arcs',
|
|
'-ftest-coverage',
|
|
]
|
|
env.CXXFLAGS += [
|
|
'-fprofile-arcs',
|
|
'-ftest-coverage',
|
|
]
|
|
env.LINKFLAGS += [
|
|
'-lgcov',
|
|
'-coverage',
|
|
]
|
|
env.DEFINES.update(
|
|
HAL_COVERAGE_BUILD = 1,
|
|
)
|
|
|
|
if cfg.options.bootloader:
|
|
# don't let bootloaders try and pull scripting in
|
|
cfg.options.disable_scripting = True
|
|
if cfg.options.signed_fw:
|
|
env.DEFINES.update(
|
|
ENABLE_HEAP = 1,
|
|
)
|
|
else:
|
|
env.DEFINES.update(
|
|
ENABLE_HEAP = 1,
|
|
)
|
|
|
|
if cfg.options.enable_math_check_indexes:
|
|
env.CXXFLAGS += ['-DMATH_CHECK_INDEXES']
|
|
|
|
if cfg.options.private_key:
|
|
env.PRIVATE_KEY = cfg.options.private_key
|
|
|
|
env.CXXFLAGS += [
|
|
'-std=gnu++11',
|
|
|
|
'-fdata-sections',
|
|
'-ffunction-sections',
|
|
'-fno-exceptions',
|
|
'-fsigned-char',
|
|
|
|
'-Wall',
|
|
'-Wextra',
|
|
'-Wpointer-arith',
|
|
'-Wno-unused-parameter',
|
|
'-Wno-missing-field-initializers',
|
|
'-Wno-reorder',
|
|
'-Wno-redundant-decls',
|
|
'-Wno-unknown-pragmas',
|
|
'-Wno-expansion-to-defined',
|
|
'-Werror=cast-align',
|
|
'-Werror=attributes',
|
|
'-Werror=format-security',
|
|
'-Werror=format-extra-args',
|
|
'-Werror=enum-compare',
|
|
'-Werror=format',
|
|
'-Werror=array-bounds',
|
|
'-Werror=uninitialized',
|
|
'-Werror=init-self',
|
|
'-Werror=narrowing',
|
|
'-Werror=return-type',
|
|
'-Werror=switch',
|
|
'-Werror=sign-compare',
|
|
'-Werror=type-limits',
|
|
'-Werror=undef',
|
|
'-Werror=unused-result',
|
|
'-Werror=shadow',
|
|
'-Werror=unused-value',
|
|
'-Werror=unused-variable',
|
|
'-Werror=delete-non-virtual-dtor',
|
|
'-Wfatal-errors',
|
|
'-Wno-trigraphs',
|
|
'-Werror=parentheses',
|
|
'-DARDUPILOT_BUILD',
|
|
'-Wuninitialized',
|
|
'-Warray-bounds',
|
|
]
|
|
|
|
if 'clang++' in cfg.env.COMPILER_CXX:
|
|
env.CXXFLAGS += [
|
|
'-fcolor-diagnostics',
|
|
|
|
'-Werror=address-of-packed-member',
|
|
|
|
'-Werror=inconsistent-missing-override',
|
|
'-Werror=overloaded-virtual',
|
|
|
|
# catch conversion issues:
|
|
'-Werror=bitfield-enum-conversion',
|
|
'-Werror=bool-conversion',
|
|
'-Werror=constant-conversion',
|
|
'-Werror=enum-conversion',
|
|
'-Werror=int-conversion',
|
|
'-Werror=literal-conversion',
|
|
'-Werror=non-literal-null-conversion',
|
|
'-Werror=null-conversion',
|
|
'-Werror=objc-literal-conversion',
|
|
# '-Werror=shorten-64-to-32', # ARRAY_SIZE() creates this all over the place as the caller typically takes a uint32_t not a size_t
|
|
'-Werror=string-conversion',
|
|
# '-Werror=sign-conversion', # can't use as we assign into AP_Int8 from uint8_ts
|
|
|
|
'-Wno-gnu-designator',
|
|
'-Wno-mismatched-tags',
|
|
'-Wno-gnu-variable-sized-type-not-at-end',
|
|
'-Werror=implicit-fallthrough',
|
|
]
|
|
else:
|
|
env.CXXFLAGS += [
|
|
'-Wno-format-contains-nul',
|
|
'-Werror=unused-but-set-variable'
|
|
]
|
|
if self.cc_version_gte(cfg, 5, 2):
|
|
env.CXXFLAGS += [
|
|
'-Werror=suggest-override',
|
|
]
|
|
if self.cc_version_gte(cfg, 7, 4):
|
|
env.CXXFLAGS += [
|
|
'-Werror=implicit-fallthrough',
|
|
'-Werror=maybe-uninitialized',
|
|
'-Werror=duplicated-cond',
|
|
]
|
|
if self.cc_version_gte(cfg, 8, 4):
|
|
env.CXXFLAGS += [
|
|
'-Werror=sizeof-pointer-div',
|
|
]
|
|
|
|
if cfg.options.Werror:
|
|
errors = ['-Werror',
|
|
'-Werror=missing-declarations',
|
|
'-Werror=float-equal',
|
|
'-Werror=undef',
|
|
]
|
|
env.CFLAGS += errors
|
|
env.CXXFLAGS += errors
|
|
|
|
if cfg.env.DEBUG:
|
|
env.CXXFLAGS += [
|
|
'-g',
|
|
'-O0',
|
|
]
|
|
|
|
if cfg.env.DEST_OS == 'darwin':
|
|
if self.cc_version_gte(cfg, 15, 0):
|
|
env.LINKFLAGS += [
|
|
'-Wl,-dead_strip,-ld_classic',
|
|
]
|
|
else:
|
|
env.LINKFLAGS += [
|
|
'-Wl,-dead_strip',
|
|
]
|
|
else:
|
|
env.LINKFLAGS += [
|
|
'-fno-exceptions',
|
|
'-Wl,--gc-sections',
|
|
]
|
|
|
|
if self.with_can:
|
|
# for both AP_Perip and main fw enable deadlines
|
|
env.DEFINES.update(CANARD_ENABLE_DEADLINE = 1)
|
|
|
|
if not cfg.env.AP_PERIPH:
|
|
env.AP_LIBRARIES += [
|
|
'AP_DroneCAN',
|
|
'modules/DroneCAN/libcanard/*.c',
|
|
]
|
|
if cfg.options.enable_dronecan_tests:
|
|
env.DEFINES.update(AP_TEST_DRONECAN_DRIVERS = 1)
|
|
|
|
env.DEFINES.update(
|
|
DRONECAN_CXX_WRAPPERS = 1,
|
|
USE_USER_HELPERS = 1,
|
|
CANARD_ALLOCATE_SEM=1
|
|
)
|
|
|
|
|
|
|
|
if cfg.options.build_dates:
|
|
env.build_dates = True
|
|
|
|
# We always want to use PRI format macros
|
|
cfg.define('__STDC_FORMAT_MACROS', 1)
|
|
|
|
if cfg.options.enable_ekf2:
|
|
env.CXXFLAGS += ['-DHAL_NAVEKF2_AVAILABLE=1']
|
|
|
|
if cfg.options.disable_ekf3:
|
|
env.CXXFLAGS += ['-DHAL_NAVEKF3_AVAILABLE=0']
|
|
|
|
if cfg.options.postype_single:
|
|
env.CXXFLAGS += ['-DHAL_WITH_POSTYPE_DOUBLE=0']
|
|
|
|
if cfg.options.osd or cfg.options.osd_fonts:
|
|
env.CXXFLAGS += ['-DOSD_ENABLED=1', '-DHAL_MSP_ENABLED=1']
|
|
|
|
if cfg.options.osd_fonts:
|
|
for f in os.listdir('libraries/AP_OSD/fonts'):
|
|
if fnmatch.fnmatch(f, "font*bin"):
|
|
env.ROMFS_FILES += [(f,'libraries/AP_OSD/fonts/'+f)]
|
|
|
|
if cfg.options.ekf_double:
|
|
env.CXXFLAGS += ['-DHAL_WITH_EKF_DOUBLE=1']
|
|
|
|
if cfg.options.ekf_single:
|
|
env.CXXFLAGS += ['-DHAL_WITH_EKF_DOUBLE=0']
|
|
|
|
if cfg.options.consistent_builds:
|
|
# squash all line numbers to be the number 17
|
|
env.CXXFLAGS += [
|
|
"-D__AP_LINE__=17",
|
|
]
|
|
else:
|
|
env.CXXFLAGS += [
|
|
"-D__AP_LINE__=__LINE__",
|
|
]
|
|
|
|
# add files from ROMFS_custom
|
|
custom_dir = 'ROMFS_custom'
|
|
if os.path.exists(custom_dir):
|
|
for root, subdirs, files in os.walk(custom_dir):
|
|
for f in files:
|
|
if fnmatch.fnmatch(f,"*~"):
|
|
# exclude emacs tmp files
|
|
continue
|
|
fname = root[len(custom_dir)+1:]+"/"+f
|
|
env.ROMFS_FILES += [(fname,root+"/"+f)]
|
|
|
|
def pre_build(self, bld):
|
|
'''pre-build hook that gets called before dynamic sources'''
|
|
if bld.env.ROMFS_FILES:
|
|
self.embed_ROMFS_files(bld)
|
|
|
|
def build(self, bld):
|
|
bld.ap_version_append_str('GIT_VERSION', bld.git_head_hash(short=True))
|
|
bld.ap_version_append_int('GIT_VERSION_INT', int("0x" + bld.git_head_hash(short=True), base=16))
|
|
bld.ap_version_append_str('AP_BUILD_ROOT', bld.srcnode.abspath())
|
|
import time
|
|
ltime = time.localtime()
|
|
if bld.env.build_dates:
|
|
bld.ap_version_append_int('BUILD_DATE_YEAR', ltime.tm_year)
|
|
bld.ap_version_append_int('BUILD_DATE_MONTH', ltime.tm_mon)
|
|
bld.ap_version_append_int('BUILD_DATE_DAY', ltime.tm_mday)
|
|
|
|
def embed_ROMFS_files(self, ctx):
|
|
'''embed some files using AP_ROMFS'''
|
|
import embed
|
|
header = ctx.bldnode.make_node('ap_romfs_embedded.h').abspath()
|
|
if not embed.create_embedded_h(header, ctx.env.ROMFS_FILES, ctx.env.ROMFS_UNCOMPRESSED):
|
|
ctx.fatal("Failed to created ap_romfs_embedded.h")
|
|
|
|
Board = BoardMeta('Board', Board.__bases__, dict(Board.__dict__))
|
|
|
|
def add_dynamic_boards_chibios():
|
|
'''add boards based on existance of hwdef.dat in subdirectories for ChibiOS'''
|
|
dirname, dirlist, filenames = next(os.walk('libraries/AP_HAL_ChibiOS/hwdef'))
|
|
for d in dirlist:
|
|
if d in _board_classes.keys():
|
|
continue
|
|
hwdef = os.path.join(dirname, d, 'hwdef.dat')
|
|
if os.path.exists(hwdef):
|
|
newclass = type(d, (chibios,), {'name': d})
|
|
|
|
@conf
|
|
def get_chibios_board_cls(ctx, name, hwdef):
|
|
if name in _board_classes.keys():
|
|
_board_classes[name].hwdef = hwdef
|
|
return _board_classes[name]
|
|
newclass = type(name, (chibios,), {'name': name})
|
|
newclass.hwdef = hwdef
|
|
return newclass
|
|
|
|
def add_dynamic_boards_esp32():
|
|
'''add boards based on existance of hwdef.dat in subdirectories for ESP32'''
|
|
dirname, dirlist, filenames = next(os.walk('libraries/AP_HAL_ESP32/hwdef'))
|
|
for d in dirlist:
|
|
if d in _board_classes.keys():
|
|
continue
|
|
hwdef = os.path.join(dirname, d, 'hwdef.dat')
|
|
if os.path.exists(hwdef):
|
|
mcu_esp32s3 = True if (d[0:7] == "esp32s3") else False
|
|
if mcu_esp32s3:
|
|
newclass = type(d, (esp32s3,), {'name': d})
|
|
else:
|
|
newclass = type(d, (esp32,), {'name': d})
|
|
|
|
def get_boards_names():
|
|
add_dynamic_boards_chibios()
|
|
add_dynamic_boards_esp32()
|
|
|
|
return sorted(list(_board_classes.keys()), key=str.lower)
|
|
|
|
def get_ap_periph_boards():
|
|
'''Add AP_Periph boards based on existance of periph keywork in hwdef.dat or board name'''
|
|
list_ap = [s for s in list(_board_classes.keys()) if "periph" in s]
|
|
dirname, dirlist, filenames = next(os.walk('libraries/AP_HAL_ChibiOS/hwdef'))
|
|
for d in dirlist:
|
|
if d in list_ap:
|
|
continue
|
|
hwdef = os.path.join(dirname, d, 'hwdef.dat')
|
|
if os.path.exists(hwdef):
|
|
with open(hwdef, "r") as f:
|
|
content = f.read()
|
|
if 'AP_PERIPH' in content:
|
|
list_ap.append(d)
|
|
continue
|
|
# process any include lines:
|
|
m = re.match(r"include\s+([^\s]*)", content)
|
|
if m is None:
|
|
continue
|
|
include_path = os.path.join(os.path.dirname(hwdef), m.group(1))
|
|
with open(include_path, "r") as g:
|
|
content = g.read()
|
|
if 'AP_PERIPH' in content:
|
|
list_ap.append(d)
|
|
continue
|
|
|
|
list_ap = list(set(list_ap))
|
|
return list_ap
|
|
|
|
def get_removed_boards():
|
|
'''list of boards which have been removed'''
|
|
return sorted(['px4-v1', 'px4-v2', 'px4-v3', 'px4-v4', 'px4-v4pro'])
|
|
|
|
@conf
|
|
def get_board(ctx):
|
|
global _board
|
|
if not _board:
|
|
if not ctx.env.BOARD:
|
|
ctx.fatal('BOARD environment variable must be set before first call to get_board()')
|
|
if ctx.env.BOARD in get_removed_boards():
|
|
ctx.fatal('''
|
|
The board target %s has been removed from ArduPilot with the removal of NuttX support and HAL_PX4.
|
|
|
|
Please use a replacement build as follows:
|
|
|
|
px4-v2 Use Pixhawk1 build
|
|
px4-v3 Use Pixhawk1 or CubeBlack builds
|
|
px4-v4 Use Pixracer build
|
|
px4-v4pro Use DrotekP3Pro build
|
|
''' % ctx.env.BOARD)
|
|
|
|
boards = _board_classes.keys()
|
|
if ctx.env.BOARD not in boards:
|
|
ctx.fatal("Invalid board '%s': choices are %s" % (ctx.env.BOARD, ', '.join(sorted(boards, key=str.lower))))
|
|
_board = _board_classes[ctx.env.BOARD]()
|
|
return _board
|
|
|
|
# NOTE: Keeping all the board definitions together so we can easily
|
|
# identify opportunities to simplify common flags. In the future might
|
|
# be worthy to keep board definitions in files of their own.
|
|
|
|
class sitl(Board):
|
|
|
|
def __init__(self):
|
|
self.with_can = True
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(sitl, self).configure_env(cfg, env)
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD = 'HAL_BOARD_SITL',
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_NONE',
|
|
AP_SCRIPTING_CHECKS = 1, # SITL should always do runtime scripting checks
|
|
AP_BARO_PROBE_EXTERNAL_I2C_BUSES = 1,
|
|
)
|
|
|
|
env.BOARD_CLASS = "SITL"
|
|
|
|
cfg.define('AP_SIM_ENABLED', 1)
|
|
cfg.define('HAL_WITH_SPI', 1)
|
|
cfg.define('HAL_WITH_RAMTRON', 1)
|
|
cfg.define('AP_GENERATOR_RICHENPOWER_ENABLED', 1)
|
|
cfg.define('AP_OPENDRONEID_ENABLED', 1)
|
|
cfg.define('AP_SIGNED_FIRMWARE', 0)
|
|
|
|
cfg.define('AP_NOTIFY_LP5562_BUS', 2)
|
|
cfg.define('AP_NOTIFY_LP5562_ADDR', 0x30)
|
|
|
|
try:
|
|
env.CXXFLAGS.remove('-DHAL_NAVEKF2_AVAILABLE=0')
|
|
except ValueError:
|
|
pass
|
|
env.CXXFLAGS += ['-DHAL_NAVEKF2_AVAILABLE=1']
|
|
|
|
if self.with_can:
|
|
cfg.define('HAL_NUM_CAN_IFACES', 2)
|
|
env.DEFINES.update(CANARD_MULTI_IFACE=1,
|
|
CANARD_IFACE_ALL = 0x3,
|
|
CANARD_ENABLE_CANFD = 1,
|
|
CANARD_ENABLE_ASSERTS = 1)
|
|
if not cfg.options.force_32bit:
|
|
# needed for cygwin
|
|
env.CXXFLAGS += [ '-DCANARD_64_BIT=1' ]
|
|
env.CFLAGS += [ '-DCANARD_64_BIT=1' ]
|
|
if Utils.unversioned_sys_platform().startswith("linux"):
|
|
cfg.define('HAL_CAN_WITH_SOCKETCAN', 1)
|
|
else:
|
|
cfg.define('HAL_CAN_WITH_SOCKETCAN', 0)
|
|
|
|
env.CXXFLAGS += [
|
|
'-Werror=float-equal',
|
|
'-Werror=missing-declarations',
|
|
]
|
|
|
|
if not cfg.options.disable_networking and not 'clang' in cfg.env.COMPILER_CC:
|
|
# lwip doesn't build with clang
|
|
env.CXXFLAGS += ['-DAP_NETWORKING_ENABLED=1']
|
|
|
|
if cfg.options.ubsan or cfg.options.ubsan_abort:
|
|
env.CXXFLAGS += [
|
|
"-fsanitize=undefined",
|
|
"-fsanitize=float-cast-overflow",
|
|
"-DUBSAN_ENABLED",
|
|
]
|
|
env.LINKFLAGS += [
|
|
"-fsanitize=undefined",
|
|
"-lubsan",
|
|
]
|
|
|
|
if cfg.options.ubsan_abort:
|
|
env.CXXFLAGS += [
|
|
"-fno-sanitize-recover"
|
|
]
|
|
|
|
if not cfg.env.DEBUG:
|
|
env.CXXFLAGS += [
|
|
'-O3',
|
|
]
|
|
|
|
if 'clang++' in cfg.env.COMPILER_CXX and cfg.options.asan:
|
|
env.CXXFLAGS += [
|
|
'-fsanitize=address',
|
|
'-fno-omit-frame-pointer',
|
|
]
|
|
|
|
env.LIB += [
|
|
'm',
|
|
]
|
|
|
|
cfg.check_librt(env)
|
|
cfg.check_feenableexcept()
|
|
|
|
env.LINKFLAGS += ['-pthread',]
|
|
|
|
if cfg.env.DEBUG and 'clang++' in cfg.env.COMPILER_CXX and cfg.options.asan:
|
|
env.LINKFLAGS += ['-fsanitize=address']
|
|
|
|
env.AP_LIBRARIES += [
|
|
'AP_HAL_SITL',
|
|
'AP_CSVReader',
|
|
]
|
|
|
|
env.AP_LIBRARIES += [
|
|
'SITL',
|
|
]
|
|
|
|
if cfg.options.enable_sfml:
|
|
if not cfg.check_SFML(env):
|
|
cfg.fatal("Failed to find SFML libraries")
|
|
|
|
if cfg.options.enable_sfml_joystick:
|
|
if not cfg.check_SFML(env):
|
|
cfg.fatal("Failed to find SFML libraries")
|
|
env.CXXFLAGS += ['-DSFML_JOYSTICK']
|
|
|
|
if cfg.options.sitl_osd:
|
|
env.CXXFLAGS += ['-DWITH_SITL_OSD','-DOSD_ENABLED=1']
|
|
for f in os.listdir('libraries/AP_OSD/fonts'):
|
|
if fnmatch.fnmatch(f, "font*bin"):
|
|
env.ROMFS_FILES += [(f,'libraries/AP_OSD/fonts/'+f)]
|
|
|
|
for f in os.listdir('Tools/autotest/models'):
|
|
if fnmatch.fnmatch(f, "*.json") or fnmatch.fnmatch(f, "*.parm"):
|
|
env.ROMFS_FILES += [('models/'+f,'Tools/autotest/models/'+f)]
|
|
|
|
# include locations.txt so SITL on windows can lookup by name
|
|
env.ROMFS_FILES += [('locations.txt','Tools/autotest/locations.txt')]
|
|
|
|
# embed any scripts from ROMFS/scripts
|
|
if os.path.exists('ROMFS/scripts'):
|
|
for f in os.listdir('ROMFS/scripts'):
|
|
if fnmatch.fnmatch(f, "*.lua"):
|
|
env.ROMFS_FILES += [('scripts/'+f,'ROMFS/scripts/'+f)]
|
|
|
|
if len(env.ROMFS_FILES) > 0:
|
|
env.CXXFLAGS += ['-DHAL_HAVE_AP_ROMFS_EMBEDDED_H']
|
|
|
|
if cfg.options.sitl_rgbled:
|
|
env.CXXFLAGS += ['-DWITH_SITL_RGBLED']
|
|
|
|
if cfg.options.enable_sfml_audio:
|
|
if not cfg.check_SFML_Audio(env):
|
|
cfg.fatal("Failed to find SFML Audio libraries")
|
|
env.CXXFLAGS += ['-DWITH_SITL_TONEALARM']
|
|
|
|
if cfg.env.DEST_OS == 'cygwin':
|
|
env.LIB += [
|
|
'winmm',
|
|
]
|
|
|
|
if Utils.unversioned_sys_platform() == 'cygwin':
|
|
env.CXXFLAGS += ['-DCYGWIN_BUILD']
|
|
|
|
if 'clang++' in cfg.env.COMPILER_CXX:
|
|
print("Disabling SLP for clang++")
|
|
env.CXXFLAGS += [
|
|
'-fno-slp-vectorize' # compiler bug when trying to use SLP
|
|
]
|
|
|
|
if cfg.options.force_32bit:
|
|
# 32bit platform flags
|
|
env.CXXFLAGS += [
|
|
'-m32',
|
|
]
|
|
env.CFLAGS += [
|
|
'-m32',
|
|
]
|
|
env.LDFLAGS += [
|
|
'-m32',
|
|
]
|
|
|
|
# whitelist of compilers which we should build with -Werror
|
|
gcc_whitelist = frozenset([
|
|
('11','3','0'),
|
|
('11','4','0'),
|
|
('12','1','0'),
|
|
])
|
|
|
|
# initialise werr_enabled from defaults:
|
|
werr_enabled = bool('g++' in cfg.env.COMPILER_CXX and cfg.env.CC_VERSION in gcc_whitelist)
|
|
|
|
# now process overrides to that default:
|
|
if (cfg.options.Werror is not None and
|
|
cfg.options.Werror == cfg.options.disable_Werror):
|
|
cfg.fatal("Asked to both enable and disable Werror")
|
|
|
|
if cfg.options.Werror is not None:
|
|
werr_enabled = cfg.options.Werror
|
|
elif cfg.options.disable_Werror is not None:
|
|
werr_enabled = not cfg.options.disable_Werror
|
|
|
|
if werr_enabled:
|
|
cfg.msg("Enabling -Werror", "yes")
|
|
if '-Werror' not in env.CXXFLAGS:
|
|
env.CXXFLAGS += [ '-Werror' ]
|
|
else:
|
|
cfg.msg("Enabling -Werror", "no")
|
|
if '-Werror' in env.CXXFLAGS:
|
|
env.CXXFLAGS.remove('-Werror')
|
|
|
|
def get_name(self):
|
|
return self.__class__.__name__
|
|
|
|
|
|
class sitl_periph(sitl):
|
|
def configure_env(self, cfg, env):
|
|
cfg.env.AP_PERIPH = 1
|
|
super(sitl_periph, self).configure_env(cfg, env)
|
|
env.DEFINES.update(
|
|
HAL_BUILD_AP_PERIPH = 1,
|
|
PERIPH_FW = 1,
|
|
HAL_RAM_RESERVE_START = 0,
|
|
|
|
CANARD_ENABLE_CANFD = 1,
|
|
CANARD_ENABLE_TAO_OPTION = 1,
|
|
CANARD_MULTI_IFACE = 1,
|
|
|
|
# FIXME: SITL library should not be using AP_AHRS:
|
|
AP_AHRS_ENABLED = 1,
|
|
AP_AHRS_BACKEND_DEFAULT_ENABLED = 0,
|
|
AP_AHRS_DCM_ENABLED = 1, # need a default backend
|
|
HAL_EXTERNAL_AHRS_ENABLED = 0,
|
|
|
|
HAL_MAVLINK_BINDINGS_ENABLED = 1,
|
|
|
|
AP_AIRSPEED_AUTOCAL_ENABLE = 0,
|
|
AP_CAN_SLCAN_ENABLED = 0,
|
|
AP_ICENGINE_ENABLED = 0,
|
|
AP_MISSION_ENABLED = 0,
|
|
AP_RCPROTOCOL_ENABLED = 0,
|
|
AP_RTC_ENABLED = 0,
|
|
AP_SCHEDULER_ENABLED = 0,
|
|
AP_SCRIPTING_ENABLED = 0,
|
|
AP_STATS_ENABLED = 0,
|
|
AP_UART_MONITOR_ENABLED = 1,
|
|
COMPASS_CAL_ENABLED = 0,
|
|
COMPASS_LEARN_ENABLED = 0,
|
|
COMPASS_MOT_ENABLED = 0,
|
|
HAL_CAN_DEFAULT_NODE_ID = 0,
|
|
HAL_CANMANAGER_ENABLED = 0,
|
|
HAL_GCS_ENABLED = 0,
|
|
HAL_GENERATOR_ENABLED = 0,
|
|
HAL_LOGGING_ENABLED = 0,
|
|
HAL_LOGGING_MAVLINK_ENABLED = 0,
|
|
HAL_PROXIMITY_ENABLED = 0,
|
|
HAL_RALLY_ENABLED = 0,
|
|
HAL_SUPPORT_RCOUT_SERIAL = 0,
|
|
AP_TERRAIN_AVAILABLE = 0,
|
|
)
|
|
|
|
try:
|
|
env.CXXFLAGS.remove('-DHAL_NAVEKF2_AVAILABLE=1')
|
|
except ValueError:
|
|
pass
|
|
env.CXXFLAGS += ['-DHAL_NAVEKF2_AVAILABLE=0']
|
|
|
|
class sitl_periph_universal(sitl_periph):
|
|
def configure_env(self, cfg, env):
|
|
super(sitl_periph_universal, self).configure_env(cfg, env)
|
|
env.DEFINES.update(
|
|
CAN_APP_NODE_NAME = '"org.ardupilot.ap_periph_universal"',
|
|
APJ_BOARD_ID = 100,
|
|
|
|
HAL_PERIPH_ENABLE_GPS = 1,
|
|
HAL_PERIPH_ENABLE_AIRSPEED = 1,
|
|
HAL_PERIPH_ENABLE_MAG = 1,
|
|
HAL_PERIPH_ENABLE_BARO = 1,
|
|
HAL_PERIPH_ENABLE_RANGEFINDER = 1,
|
|
HAL_PERIPH_ENABLE_BATTERY = 1,
|
|
HAL_PERIPH_ENABLE_EFI = 1,
|
|
HAL_PERIPH_ENABLE_RPM = 1,
|
|
HAL_PERIPH_ENABLE_RC_OUT = 1,
|
|
HAL_PERIPH_ENABLE_ADSB = 1,
|
|
HAL_PERIPH_ENABLE_SERIAL_OPTIONS = 1,
|
|
AP_AIRSPEED_ENABLED = 1,
|
|
AP_BATTERY_ESC_ENABLED = 1,
|
|
HAL_PWM_COUNT = 32,
|
|
HAL_WITH_ESC_TELEM = 1,
|
|
AP_TERRAIN_AVAILABLE = 1,
|
|
)
|
|
|
|
class sitl_periph_gps(sitl_periph):
|
|
def configure_env(self, cfg, env):
|
|
cfg.env.AP_PERIPH = 1
|
|
super(sitl_periph_gps, self).configure_env(cfg, env)
|
|
env.DEFINES.update(
|
|
HAL_BUILD_AP_PERIPH = 1,
|
|
PERIPH_FW = 1,
|
|
CAN_APP_NODE_NAME = '"org.ardupilot.ap_periph_gps"',
|
|
APJ_BOARD_ID = 101,
|
|
|
|
HAL_PERIPH_ENABLE_GPS = 1,
|
|
)
|
|
|
|
class esp32(Board):
|
|
abstract = True
|
|
toolchain = 'xtensa-esp32-elf'
|
|
def configure_env(self, cfg, env):
|
|
env.BOARD_CLASS = "ESP32"
|
|
|
|
def expand_path(p):
|
|
print("USING EXPRESSIF IDF:"+str(env.idf))
|
|
return cfg.root.find_dir(env.IDF+p).abspath()
|
|
try:
|
|
env.IDF = os.environ['IDF_PATH']
|
|
except:
|
|
env.IDF = cfg.srcnode.abspath()+"/modules/esp_idf"
|
|
|
|
super(esp32, self).configure_env(cfg, env)
|
|
cfg.load('esp32')
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD = 'HAL_BOARD_ESP32',
|
|
)
|
|
|
|
tt = self.name[5:] #leave off 'esp32' so we just get 'buzz','diy','icarus, etc
|
|
|
|
# this makes sure we get the correct subtype
|
|
env.DEFINES.update(
|
|
ENABLE_HEAP = 0,
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_ESP32_%s' % tt.upper() ,
|
|
HAL_HAVE_HARDWARE_DOUBLE = '1',
|
|
)
|
|
|
|
if self.name.endswith("empty"):
|
|
# for empty targets build as SIM-on-HW
|
|
env.DEFINES.update(AP_SIM_ENABLED = 1)
|
|
env.AP_LIBRARIES += [
|
|
'SITL',
|
|
]
|
|
else:
|
|
env.DEFINES.update(AP_SIM_ENABLED = 0)
|
|
|
|
env.AP_LIBRARIES += [
|
|
'AP_HAL_ESP32',
|
|
]
|
|
|
|
env.CFLAGS += [
|
|
'-fno-inline-functions',
|
|
'-mlongcalls',
|
|
'-fsingle-precision-constant',
|
|
]
|
|
env.CFLAGS.remove('-Werror=undef')
|
|
|
|
env.CXXFLAGS += ['-mlongcalls',
|
|
'-Os',
|
|
'-g',
|
|
'-ffunction-sections',
|
|
'-fdata-sections',
|
|
'-fno-exceptions',
|
|
'-fno-rtti',
|
|
'-nostdlib',
|
|
'-fstrict-volatile-bitfields',
|
|
'-Wno-sign-compare',
|
|
'-fno-inline-functions',
|
|
'-mlongcalls',
|
|
'-fsingle-precision-constant', # force const vals to be float , not double. so 100.0 means 100.0f
|
|
'-fno-threadsafe-statics',
|
|
'-DCYGWIN_BUILD']
|
|
env.CXXFLAGS.remove('-Werror=undef')
|
|
env.CXXFLAGS.remove('-Werror=shadow')
|
|
|
|
|
|
env.INCLUDES += [
|
|
cfg.srcnode.find_dir('libraries/AP_HAL_ESP32/boards').abspath(),
|
|
]
|
|
env.AP_PROGRAM_AS_STLIB = True
|
|
#if cfg.options.enable_profile:
|
|
# env.CXXFLAGS += ['-pg',
|
|
# '-DENABLE_PROFILE=1']
|
|
def pre_build(self, bld):
|
|
'''pre-build hook that gets called before dynamic sources'''
|
|
from waflib.Context import load_tool
|
|
module = load_tool('esp32', [], with_sys_path=True)
|
|
fun = getattr(module, 'pre_build', None)
|
|
if fun:
|
|
fun(bld)
|
|
super(esp32, self).pre_build(bld)
|
|
|
|
|
|
def build(self, bld):
|
|
super(esp32, self).build(bld)
|
|
bld.load('esp32')
|
|
|
|
def get_name(self):
|
|
return self.__class__.__name__
|
|
|
|
class esp32s3(esp32):
|
|
abstract = True
|
|
toolchain = 'xtensa-esp32s3-elf'
|
|
|
|
class chibios(Board):
|
|
abstract = True
|
|
toolchain = 'arm-none-eabi'
|
|
|
|
def configure_env(self, cfg, env):
|
|
if hasattr(self, 'hwdef'):
|
|
cfg.env.HWDEF = self.hwdef
|
|
super(chibios, self).configure_env(cfg, env)
|
|
|
|
cfg.load('chibios')
|
|
env.BOARD = self.name
|
|
env.BOARD_CLASS = "ChibiOS"
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD = 'HAL_BOARD_CHIBIOS',
|
|
HAVE_STD_NULLPTR_T = 0,
|
|
USE_LIBC_REALLOC = 0,
|
|
)
|
|
|
|
env.AP_LIBRARIES += [
|
|
'AP_HAL_ChibiOS',
|
|
]
|
|
|
|
# make board name available for USB IDs
|
|
env.CHIBIOS_BOARD_NAME = 'HAL_BOARD_NAME="%s"' % self.name
|
|
env.HAL_MAX_STACK_FRAME_SIZE = 'HAL_MAX_STACK_FRAME_SIZE=%d' % 1300 # set per Wframe-larger-than, ensure its same
|
|
env.CFLAGS += cfg.env.CPU_FLAGS + [
|
|
'-Wlogical-op',
|
|
'-Wframe-larger-than=1300',
|
|
'-Wno-attributes',
|
|
'-fno-exceptions',
|
|
'-Wall',
|
|
'-Wextra',
|
|
'-Wno-sign-compare',
|
|
'-Wfloat-equal',
|
|
'-Wpointer-arith',
|
|
'-Wmissing-declarations',
|
|
'-Wno-unused-parameter',
|
|
'-Werror=array-bounds',
|
|
'-Wfatal-errors',
|
|
'-Werror=uninitialized',
|
|
'-Werror=init-self',
|
|
'-Werror=unused-but-set-variable',
|
|
'-Wno-missing-field-initializers',
|
|
'-Wno-trigraphs',
|
|
'-fno-strict-aliasing',
|
|
'-fomit-frame-pointer',
|
|
'-falign-functions=16',
|
|
'-ffunction-sections',
|
|
'-fdata-sections',
|
|
'-fno-strength-reduce',
|
|
'-fno-builtin-printf',
|
|
'-fno-builtin-fprintf',
|
|
'-fno-builtin-vprintf',
|
|
'-fno-builtin-vfprintf',
|
|
'-fno-builtin-puts',
|
|
'-mno-thumb-interwork',
|
|
'-mthumb',
|
|
'--specs=nano.specs',
|
|
'--specs=nosys.specs',
|
|
'-D__USE_CMSIS',
|
|
'-Werror=deprecated-declarations',
|
|
'-DNDEBUG=1'
|
|
]
|
|
if not cfg.options.Werror:
|
|
env.CFLAGS += [
|
|
'-Wno-error=double-promotion',
|
|
'-Wno-error=missing-declarations',
|
|
'-Wno-error=float-equal',
|
|
'-Wno-error=cpp',
|
|
]
|
|
|
|
env.CXXFLAGS += env.CFLAGS + [
|
|
'-fno-rtti',
|
|
'-fno-threadsafe-statics',
|
|
]
|
|
env.CFLAGS += [
|
|
'-std=c11'
|
|
]
|
|
|
|
if Utils.unversioned_sys_platform() == 'cygwin':
|
|
env.CXXFLAGS += ['-DCYGWIN_BUILD']
|
|
|
|
bldnode = cfg.bldnode.make_node(self.name)
|
|
env.BUILDROOT = bldnode.make_node('').abspath()
|
|
|
|
env.LINKFLAGS = cfg.env.CPU_FLAGS + [
|
|
'-fomit-frame-pointer',
|
|
'-falign-functions=16',
|
|
'-ffunction-sections',
|
|
'-fdata-sections',
|
|
'-u_port_lock',
|
|
'-u_port_unlock',
|
|
'-u_exit',
|
|
'-u_kill',
|
|
'-u_getpid',
|
|
'-u_errno',
|
|
'-uchThdExit',
|
|
'-fno-common',
|
|
'-nostartfiles',
|
|
'-mno-thumb-interwork',
|
|
'-mthumb',
|
|
'--specs=nano.specs',
|
|
'--specs=nosys.specs',
|
|
'-L%s' % env.BUILDROOT,
|
|
'-L%s' % cfg.srcnode.make_node('modules/ChibiOS/os/common/startup/ARMCMx/compilers/GCC/ld/').abspath(),
|
|
'-L%s' % cfg.srcnode.make_node('libraries/AP_HAL_ChibiOS/hwdef/common/').abspath(),
|
|
'-Wl,-Map,Linker.map,%s--cref,--gc-sections,--no-warn-mismatch,--library-path=/ld,--script=ldscript.ld,--defsym=__process_stack_size__=%s,--defsym=__main_stack_size__=%s' % ("--print-memory-usage," if cfg.env.EXT_FLASH_SIZE_MB > 0 and cfg.env.INT_FLASH_PRIMARY == 0 else "", cfg.env.PROCESS_STACK, cfg.env.MAIN_STACK)
|
|
]
|
|
|
|
if cfg.env.DEBUG:
|
|
env.CFLAGS += [
|
|
'-gdwarf-4',
|
|
'-g3',
|
|
]
|
|
env.LINKFLAGS += [
|
|
'-gdwarf-4',
|
|
'-g3',
|
|
]
|
|
|
|
if cfg.env.COMPILER_CXX == "g++":
|
|
if not self.cc_version_gte(cfg, 10, 2):
|
|
# require at least 10.2 compiler
|
|
cfg.fatal("ChibiOS build requires g++ version 10.2.1 or later, found %s" % '.'.join(cfg.env.CC_VERSION))
|
|
|
|
if cfg.env.ENABLE_ASSERTS:
|
|
cfg.msg("Enabling ChibiOS asserts", "yes")
|
|
env.CFLAGS += [ '-DHAL_CHIBIOS_ENABLE_ASSERTS' ]
|
|
env.CXXFLAGS += [ '-DHAL_CHIBIOS_ENABLE_ASSERTS' ]
|
|
else:
|
|
cfg.msg("Enabling ChibiOS asserts", "no")
|
|
|
|
|
|
if cfg.env.SAVE_TEMPS:
|
|
env.CXXFLAGS += [ '-S', '-save-temps=obj' ]
|
|
|
|
if cfg.options.disable_watchdog:
|
|
cfg.msg("Disabling Watchdog", "yes")
|
|
env.CFLAGS += [ '-DDISABLE_WATCHDOG' ]
|
|
env.CXXFLAGS += [ '-DDISABLE_WATCHDOG' ]
|
|
else:
|
|
cfg.msg("Disabling Watchdog", "no")
|
|
|
|
if cfg.env.ENABLE_MALLOC_GUARD:
|
|
cfg.msg("Enabling malloc guard", "yes")
|
|
env.CFLAGS += [ '-DHAL_CHIBIOS_ENABLE_MALLOC_GUARD' ]
|
|
env.CXXFLAGS += [ '-DHAL_CHIBIOS_ENABLE_MALLOC_GUARD' ]
|
|
else:
|
|
cfg.msg("Enabling malloc guard", "no")
|
|
|
|
if cfg.env.ENABLE_STATS:
|
|
cfg.msg("Enabling ChibiOS thread statistics", "yes")
|
|
env.CFLAGS += [ '-DHAL_ENABLE_THREAD_STATISTICS' ]
|
|
env.CXXFLAGS += [ '-DHAL_ENABLE_THREAD_STATISTICS' ]
|
|
else:
|
|
cfg.msg("Enabling ChibiOS thread statistics", "no")
|
|
|
|
if cfg.env.SIM_ENABLED:
|
|
env.DEFINES.update(
|
|
AP_SIM_ENABLED = 1,
|
|
)
|
|
env.AP_LIBRARIES += [
|
|
'SITL',
|
|
]
|
|
else:
|
|
env.DEFINES.update(
|
|
AP_SIM_ENABLED = 0,
|
|
)
|
|
|
|
env.LIB += ['gcc', 'm']
|
|
|
|
env.GIT_SUBMODULES += [
|
|
'ChibiOS',
|
|
]
|
|
|
|
env.INCLUDES += [
|
|
cfg.srcnode.find_dir('libraries/AP_GyroFFT/CMSIS_5/include').abspath(),
|
|
cfg.srcnode.find_dir('modules/lwip/src/include/compat/posix').abspath()
|
|
]
|
|
|
|
# whitelist of compilers which we should build with -Werror
|
|
gcc_whitelist = frozenset([
|
|
('4','9','3'),
|
|
('6','3','1'),
|
|
('9','2','1'),
|
|
('9','3','1'),
|
|
('10','2','1'),
|
|
('11','3','0'),
|
|
('11','4','0'),
|
|
])
|
|
|
|
if cfg.env.HAL_CANFD_SUPPORTED:
|
|
env.DEFINES.update(CANARD_ENABLE_CANFD=1)
|
|
else:
|
|
env.DEFINES.update(CANARD_ENABLE_TAO_OPTION=1)
|
|
if not cfg.options.bootloader and cfg.env.HAL_NUM_CAN_IFACES:
|
|
if int(cfg.env.HAL_NUM_CAN_IFACES) >= 1:
|
|
env.DEFINES.update(CANARD_IFACE_ALL=(1<<int(cfg.env.HAL_NUM_CAN_IFACES))-1)
|
|
if cfg.options.Werror or cfg.env.CC_VERSION in gcc_whitelist:
|
|
cfg.msg("Enabling -Werror", "yes")
|
|
if '-Werror' not in env.CXXFLAGS:
|
|
env.CXXFLAGS += [ '-Werror' ]
|
|
else:
|
|
cfg.msg("Enabling -Werror", "no")
|
|
|
|
if cfg.options.signed_fw:
|
|
cfg.define('AP_SIGNED_FIRMWARE', 1)
|
|
env.CFLAGS += [
|
|
'-DAP_SIGNED_FIRMWARE=1',
|
|
]
|
|
else:
|
|
cfg.define('AP_SIGNED_FIRMWARE', 0)
|
|
env.CFLAGS += [
|
|
'-DAP_SIGNED_FIRMWARE=0',
|
|
]
|
|
|
|
try:
|
|
import intelhex
|
|
env.HAVE_INTEL_HEX = True
|
|
cfg.msg("Checking for intelhex module:", 'OK')
|
|
except Exception:
|
|
cfg.msg("Checking for intelhex module:", 'disabled', color='YELLOW')
|
|
env.HAVE_INTEL_HEX = False
|
|
|
|
def build(self, bld):
|
|
super(chibios, self).build(bld)
|
|
bld.ap_version_append_str('CHIBIOS_GIT_VERSION', bld.git_submodule_head_hash('ChibiOS', short=True))
|
|
bld.load('chibios')
|
|
|
|
def pre_build(self, bld):
|
|
'''pre-build hook that gets called before dynamic sources'''
|
|
from waflib.Context import load_tool
|
|
module = load_tool('chibios', [], with_sys_path=True)
|
|
fun = getattr(module, 'pre_build', None)
|
|
if fun:
|
|
fun(bld)
|
|
super(chibios, self).pre_build(bld)
|
|
|
|
def get_name(self):
|
|
return self.name
|
|
|
|
class linux(Board):
|
|
def __init__(self):
|
|
if self.toolchain == 'native':
|
|
self.with_can = True
|
|
else:
|
|
self.with_can = False
|
|
|
|
def configure_env(self, cfg, env):
|
|
if cfg.options.board == 'linux':
|
|
self.with_can = True
|
|
super(linux, self).configure_env(cfg, env)
|
|
|
|
env.BOARD_CLASS = "LINUX"
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD = 'HAL_BOARD_LINUX',
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_NONE',
|
|
AP_SIM_ENABLED = 0,
|
|
)
|
|
|
|
if not cfg.env.DEBUG:
|
|
env.CXXFLAGS += [
|
|
'-O3',
|
|
]
|
|
|
|
env.LIB += [
|
|
'm',
|
|
]
|
|
|
|
cfg.check_librt(env)
|
|
cfg.check_lttng(env)
|
|
cfg.check_libdl(env)
|
|
cfg.check_libiio(env)
|
|
|
|
env.LINKFLAGS += ['-pthread',]
|
|
env.AP_LIBRARIES += [
|
|
'AP_HAL_Linux',
|
|
]
|
|
|
|
if cfg.options.force_32bit:
|
|
env.DEFINES.update(
|
|
HAL_FORCE_32BIT = 1,
|
|
)
|
|
# 32bit platform flags
|
|
cfg.env.CXXFLAGS += [
|
|
'-m32',
|
|
]
|
|
cfg.env.CFLAGS += [
|
|
'-m32',
|
|
]
|
|
cfg.env.LDFLAGS += [
|
|
'-m32',
|
|
]
|
|
else:
|
|
env.DEFINES.update(
|
|
HAL_FORCE_32BIT = 0,
|
|
)
|
|
if self.with_can and cfg.options.board == 'linux':
|
|
cfg.env.HAL_NUM_CAN_IFACES = 2
|
|
cfg.define('HAL_NUM_CAN_IFACES', 2)
|
|
cfg.define('HAL_CANFD_SUPPORTED', 1)
|
|
cfg.define('CANARD_ENABLE_CANFD', 1)
|
|
|
|
if self.with_can:
|
|
env.DEFINES.update(CANARD_MULTI_IFACE=1,
|
|
CANARD_IFACE_ALL = 0x3)
|
|
|
|
if cfg.options.apstatedir:
|
|
cfg.define('AP_STATEDIR', cfg.options.apstatedir)
|
|
|
|
defaults_file = 'libraries/AP_HAL_Linux/boards/%s/defaults.parm' % self.get_name()
|
|
if os.path.exists(defaults_file):
|
|
env.ROMFS_FILES += [('defaults.parm', defaults_file)]
|
|
env.DEFINES.update(
|
|
HAL_PARAM_DEFAULTS_PATH='"@ROMFS/defaults.parm"',
|
|
)
|
|
if len(env.ROMFS_FILES) > 0:
|
|
env.CXXFLAGS += ['-DHAL_HAVE_AP_ROMFS_EMBEDDED_H']
|
|
|
|
def build(self, bld):
|
|
super(linux, self).build(bld)
|
|
if bld.options.upload:
|
|
waflib.Options.commands.append('rsync')
|
|
# Avoid infinite recursion
|
|
bld.options.upload = False
|
|
|
|
def get_name(self):
|
|
# get name of class
|
|
return self.__class__.__name__
|
|
|
|
|
|
class navigator(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(navigator, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE='HAL_BOARD_SUBTYPE_LINUX_NAVIGATOR',
|
|
)
|
|
|
|
class erleboard(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(erleboard, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_ERLEBOARD',
|
|
)
|
|
|
|
class navio(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(navio, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_NAVIO',
|
|
)
|
|
|
|
class navio2(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(navio2, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_NAVIO2',
|
|
)
|
|
|
|
class edge(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def __init__(self):
|
|
self.with_can = True
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(edge, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_EDGE',
|
|
)
|
|
|
|
class zynq(linux):
|
|
toolchain = 'arm-xilinx-linux-gnueabi'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(zynq, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_ZYNQ',
|
|
)
|
|
|
|
class ocpoc_zynq(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(ocpoc_zynq, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_OCPOC_ZYNQ',
|
|
)
|
|
|
|
class bbbmini(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def __init__(self):
|
|
self.with_can = True
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(bbbmini, self).configure_env(cfg, env)
|
|
cfg.env.HAL_NUM_CAN_IFACES = 1
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_BBBMINI',
|
|
)
|
|
|
|
class blue(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def __init__(self):
|
|
self.with_can = True
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(blue, self).configure_env(cfg, env)
|
|
cfg.env.HAL_NUM_CAN_IFACES = 1
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_BLUE',
|
|
)
|
|
|
|
class pocket(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def __init__(self):
|
|
self.with_can = True
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(pocket, self).configure_env(cfg, env)
|
|
cfg.env.HAL_NUM_CAN_IFACES = 1
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_POCKET',
|
|
)
|
|
|
|
class pxf(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(pxf, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_PXF',
|
|
)
|
|
|
|
class bebop(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(bebop, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_BEBOP',
|
|
)
|
|
|
|
class vnav(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(vnav, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_VNAV',
|
|
)
|
|
|
|
class disco(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(disco, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_DISCO',
|
|
)
|
|
|
|
class erlebrain2(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(erlebrain2, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_ERLEBRAIN2',
|
|
)
|
|
|
|
class bhat(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(bhat, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_BH',
|
|
)
|
|
|
|
class dark(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(dark, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_DARK',
|
|
)
|
|
|
|
class pxfmini(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(pxfmini, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_PXFMINI',
|
|
)
|
|
|
|
class aero(linux):
|
|
def __init__(self):
|
|
self.with_can = True
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(aero, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_AERO',
|
|
)
|
|
|
|
class rst_zynq(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(rst_zynq, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_RST_ZYNQ',
|
|
)
|
|
|
|
class obal(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(obal, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_OBAL_V1',
|
|
)
|
|
|
|
class canzero(linux):
|
|
toolchain = 'arm-linux-gnueabihf'
|
|
|
|
def __init__(self):
|
|
self.with_can = True
|
|
|
|
def configure_env(self, cfg, env):
|
|
super(canzero, self).configure_env(cfg, env)
|
|
|
|
env.DEFINES.update(
|
|
CONFIG_HAL_BOARD_SUBTYPE = 'HAL_BOARD_SUBTYPE_LINUX_CANZERO',
|
|
)
|
|
|
|
class SITL_static(sitl):
|
|
def configure_env(self, cfg, env):
|
|
super(SITL_static, self).configure_env(cfg, env)
|
|
cfg.env.STATIC_LINKING = True
|
|
|
|
class SITL_x86_64_linux_gnu(SITL_static):
|
|
toolchain = 'x86_64-linux-gnu'
|
|
|
|
class SITL_arm_linux_gnueabihf(SITL_static):
|
|
toolchain = 'arm-linux-gnueabihf'
|