From 551dca63e14f782e95f63be308266862b696a375 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Tue, 6 Mar 2018 12:33:30 +1100 Subject: [PATCH] HAL_ChibiOS: added build information for each MCU this abstracts the build information for each MCU, so that hwdef.dat can control the build process of ChibiOS --- .../hwdef/common/chibios_board.mk | 4 +-- .../hwdef/scripts/STM32F405xx.py | 12 +++++++ .../hwdef/scripts/STM32F412Rx.py | 6 ++++ .../hwdef/scripts/STM32F427xx.py | 10 ++++-- .../hwdef/scripts/chibios_hwdef.py | 33 ++++++++++++++----- 5 files changed, 53 insertions(+), 12 deletions(-) diff --git a/libraries/AP_HAL_ChibiOS/hwdef/common/chibios_board.mk b/libraries/AP_HAL_ChibiOS/hwdef/common/chibios_board.mk index 0f9f7bcd67..5738e31c14 100644 --- a/libraries/AP_HAL_ChibiOS/hwdef/common/chibios_board.mk +++ b/libraries/AP_HAL_ChibiOS/hwdef/common/chibios_board.mk @@ -92,10 +92,10 @@ PROJECT = ch # Imported source files and paths # Startup files. -include $(CHIBIOS)/os/common/startup/ARMCMx/compilers/GCC/mk/startup_stm32f4xx.mk +include $(CHIBIOS)/$(CHIBIOS_STARTUP_MK) # HAL-OSAL files (optional). include $(CHIBIOS)/os/hal/hal.mk -include $(CHIBIOS)/os/hal/ports/STM32/STM32F4xx/platform.mk +include $(CHIBIOS)/$(CHIBIOS_PLATFORM_MK) include $(CHIBIOS)/os/hal/osal/rt/osal.mk # RTOS files (optional). include $(CHIBIOS)/os/rt/rt.mk diff --git a/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F405xx.py b/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F405xx.py index 2a3f6b9d11..f0b7e3a7ea 100644 --- a/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F405xx.py +++ b/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F405xx.py @@ -1,3 +1,15 @@ +#!/usr/bin/env python +''' +these tables are generated from the STM32 datasheets for the +STM32F40x +''' + +# additional build information for ChibiOS +build = { + "CHIBIOS_STARTUP_MK" : "os/common/startup/ARMCMx/compilers/GCC/mk/startup_stm32f4xx.mk", + "CHIBIOS_PLATFORM_MK" : "os/hal/ports/STM32/STM32F4xx/platform.mk" + } + AltFunction_map = { # format is PIN:FUNCTION : AFNUM # extracted from tabula-AF-F405.csv diff --git a/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F412Rx.py b/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F412Rx.py index 79db33903d..47f7f4f388 100644 --- a/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F412Rx.py +++ b/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F412Rx.py @@ -4,6 +4,12 @@ these tables are generated from the STM32 datasheet RM0402 in en.DM00180369.pdf STM32F412 ''' +# additional build information for ChibiOS +build = { + "CHIBIOS_STARTUP_MK" : "os/common/startup/ARMCMx/compilers/GCC/mk/startup_stm32f4xx.mk", + "CHIBIOS_PLATFORM_MK" : "os/hal/ports/STM32/STM32F4xx/platform.mk" +} + DMA_Map = { # format is (DMA_TABLE, StreamNum, Channel) # extracted from tabula-stm32f412-ref-manual-196.csv diff --git a/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F427xx.py b/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F427xx.py index 08feeb2785..08c09317ed 100644 --- a/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F427xx.py +++ b/libraries/AP_HAL_ChibiOS/hwdef/scripts/STM32F427xx.py @@ -1,9 +1,15 @@ #!/usr/bin/env python ''' -these tables are generated from the STM32 datasheet DM00071990.pdf for the -STM32F427 and STM32F4279 +these tables are generated from the STM32 datasheets for the +STM32F42x ''' +# additional build information for ChibiOS +build = { + "CHIBIOS_STARTUP_MK" : "os/common/startup/ARMCMx/compilers/GCC/mk/startup_stm32f4xx.mk", + "CHIBIOS_PLATFORM_MK" : "os/hal/ports/STM32/STM32F4xx/platform.mk" + } + DMA_Map = { # format is (DMA_TABLE, StreamNum, Channel) # extracted from tabula-STM32F4x7-dma.csv diff --git a/libraries/AP_HAL_ChibiOS/hwdef/scripts/chibios_hwdef.py b/libraries/AP_HAL_ChibiOS/hwdef/scripts/chibios_hwdef.py index 6981aa69a3..d75384e584 100755 --- a/libraries/AP_HAL_ChibiOS/hwdef/scripts/chibios_hwdef.py +++ b/libraries/AP_HAL_ChibiOS/hwdef/scripts/chibios_hwdef.py @@ -60,6 +60,9 @@ alllines = [] # allow for extra env vars env_vars = {} +# build flags for ChibiOS makefiles +build_flags = [] + mcu_type = None @@ -78,15 +81,19 @@ def error(str): sys.exit(1) -def get_alt_function(mcu, pin, function): - '''return alternative function number for a pin''' +def get_mcu_lib(mcu): + '''get library file for the chosen MCU''' import importlib try: - lib = importlib.import_module(mcu) - alt_map = lib.AltFunction_map + return importlib.import_module(mcu) except ImportError: error("Unable to find module for MCU %s" % mcu) +def get_alt_function(mcu, pin, function): + '''return alternative function number for a pin''' + lib = get_mcu_lib(mcu) + alt_map = lib.AltFunction_map + if function and function.endswith("_RTS") and ( function.startswith('USART') or function.startswith('UART')): # we do software RTS @@ -317,10 +324,10 @@ def write_mcu_config(f): f.write('// SDIO available, enable POSIX filesystem support\n') f.write('#define USE_POSIX\n\n') f.write('#define HAL_USE_SDC TRUE\n') - env_vars['CHIBIOS_FATFS_FLAG'] = 'USE_FATFS=yes' + build_flags.append('USE_FATFS=yes') else: f.write('#define HAL_USE_SDC FALSE\n') - env_vars['CHIBIOS_FATFS_FLAG'] = 'USE_FATFS=no' + build_flags.append('USE_FATFS=no') if 'OTG1' in bytype: f.write('#define STM32_USB_USE_OTG1 TRUE\n') f.write('#define HAL_USE_USB TRUE\n') @@ -348,6 +355,11 @@ def write_mcu_config(f): f.write('#define CCM_RAM_SIZE %u\n' % ccm_size) f.write('\n') + lib = get_mcu_lib(mcu_type) + build_info = lib.build + # setup build variables + for v in build_info.keys(): + build_flags.append('%s=%s' % (v, build_info[v])) def write_ldscript(fname): '''write ldscript.ld for this board''' @@ -952,6 +964,12 @@ def build_peripheral_list(): return peripherals +def write_env_py(filename): + '''write out env.py for environment variables to control the build process''' + # CHIBIOS_BUILD_FLAGS is passed to the ChibiOS makefile + env_vars['CHIBIOS_BUILD_FLAGS'] = ' '.join(build_flags) + pickle.dump(env_vars, open(filename, "wb")) + def process_line(line): '''process one line of pin definition file''' global allpins @@ -1065,6 +1083,5 @@ write_ldscript(os.path.join(outdir, "ldscript.ld")) # exist in the same directory as the ldscript.ld file we generate. copy_common_linkerscript(outdir, args.hwdef) -# write out env.py -pickle.dump(env_vars, open(os.path.join(outdir, "env.py"), "wb")) +write_env_py(os.path.join(outdir, "env.py"))