LPT26x-HSF-4MB-Hilink_14.2..../build/config/target_config/common_config.py

512 lines
21 KiB
Python
Raw Normal View History

2025-05-13 22:00:58 +08:00
#!/usr/bin/env python3
# encoding=utf-8
# ============================================================================
# @brief common config of build system
# Copyright (c) HiSilicon (Shanghai) Technologies Co., Ltd. 2022-2022. All rights reserved.
# ============================================================================
component_set = {
'boot_rom': ['hw_sec', 'non_os_libc', 'non_os_isr', 'non_os_osal'],
'libra_public': ['libra_device'],
'std_common_lib': [
"app_version", "build_version", "testsuite", "common_headers", "connectivity",
"cpu_load", "cpu_utils", "irmalloc", "lib_utils", "dfx_log", "dfx_log_reader",
"dfx_panic", "dfx_preserve",
],
"ssb_libs": ["codeloader_ssb", "lib_utils", "jlink_load", "algorithm"],
'boot_common_lib': [
"bootloader", "codeloader", "build_version", "common_headers", 'app_version',
"cpu_utils", "irmalloc", "dfx_panic", "dfx_preserve", 'error_code',
],
'sec': ['hal_sec_common', 'hal_sec_sha', 'hal_sec_trng2', 'hal_sectors',
'sec_common', 'sec_rsa', 'sec_sha', 'sec_trng', "sec_port", "sec_rsa_port",],
'security': ['hal_hash', 'hash', 'hash_port', 'hal_trng', 'trng', 'trng_port', 'hal_pke',
'pke', 'pke_port', 'hal_cipher', 'cipher', 'cipher_port', 'hal_km', 'km', 'km_port'],
'mem': ['memory_core'],
'mem_monitor': ['mem_monitor', 'hal_mem_monitor', 'mem_monitor_port'],
'cpu': ['hal_cpu_core', 'reboot', 'hal_reg_config', 'hal_reboot', 'reboot_port'],
'can': ['can', 'hal_can', 'can_port'],
'watchdog': ['watchdog', 'hal_watchdog', 'watchdog_port'],
'reboot_set':['reboot', 'hal_reboot', 'reboot_port'],
'uart': ['hal_uart', 'uart', 'uart_port'],
'xip_os': ['hal_xip', 'xip_port'],
'xip_nonos': ['hal_xip', 'xip_port'],
'adc': ['hal_adc', 'adc', 'adc_port'],
'ipc': ['hal_ipc_old', 'ipc_old'],
'spi_os': ['hal_spi', 'spi_cmsis'],
'spi_nonos': ['hal_spi', 'spi_nonos'],
'sfc_flash_old': ['sfc_old', 'hal_sfc_old'],
'sfc_flash': ['sfc', 'hal_sfc'],
'dma': ['hal_dma_v100', 'dma', 'dma_port'],
'dmav151': ['hal_dma_v151', 'dma', 'dma_port'],
'dmav120': ['hal_dma_v120', 'dma', 'dma_port'],
'button': ['button', 'button_port'],
'epmu': ['epmu', 'epmu_port'],
'spi': ['spi', 'hal_spi', 'spi_porting'],
'lpc': ['hal_lpc', 'lpc'],
'otp': ['hal_otp', 'otp'],
'i2c': ['hal_i2c', 'i2c', 'i2c_porting'],
'pwm': ['hal_pwm', 'pwm', "pwm_port",],
'mmc': ['hal_mmc', 'mmc'],
'gpio_v150': ['hal_gpio_v150', 'gpio', "gpio_port"],
'gpio_v100': ['hal_gpio_v100', 'gpio', "gpio_port"],
'qspi': ['hal_qspi', 'qspi'],
'hso_log': ["dfx_log", "dfx_log_reader"],
'qdec' : ['hal_qdec', 'qdec', "qdec_port"],
'keyscan' : ['hal_keyscan', 'keyscan', "keyscan_port"],
'usb' : ["usb", "hal_usb", "usb_port"],
'usb_unified' : ['usb_unified', 'usb_unified_open', 'usb_unified_port'],
'pdm' : ['pdm', 'hal_pdm', "pdm_porting", "test_pdm"],
'embed_flash' : ['eflash', 'hal_eflash', 'eflash_port'],
'i2s' : ["i2s"],
'flash' : ["flash", "flash_porting"],
'sio_v150' : ['hal_sio', 'sio_port'],
'sio_v151' : ['hal_sio', 'sio_port'],
'cpu_trace': ['hal_cpu_trace', 'cpu_trace'],
'sdio_slave': ['sdio', 'hal_sdio', 'sdio_port'],
'time_set': ['systick', 'tcxo', 'drv_timer', 'hal_systick', 'hal_tcxo', 'hal_timer', 'rtc_unified', 'hal_rtc_unified', 'rtc_unified_port', 'timer_port', 'systick_port', 'tcxo_port'],
'systick_set':['systick', 'hal_systick', 'systick_port'],
'tcxo_set':['tcxo', 'hal_tcxo', 'tcxo_port'],
'rtc_unified': ['rtc_unified', 'hal_rtc_unified', 'rtc_unified_port'],
'local_stdlib': ['c', 'm', 'posix'],
'audio': ['audio_api', 'audio_core', 'audio_drv', 'audio_sample', 'audio_vendor'],
'bgh': ['bt_host_brandy_service', 'bt_host_brandy_sample', 'bt_host_sdk'],
'bgh-master': ['bt_app', 'bth_sample', 'bth_sdk', 'bg_common', 'bth_audio_manager_wrapper'],
'bgh_audio': ['bt_host_audio_manager_wrapper'],
'media': ['audio_capture', 'audio_manager', 'audio_service', 'audio_stream', 'audio_utils',
'media_sample_wrapper', 'player', 'media_common', 'audio_bluetooth_port', 'audio_hw',
'audio_primary_port','format_hw', 'hmf_demuxer', 'media_hal_common', 'plugin_demuxer_hmf',
'plugin_demuxer_mjpeg', 'plugin_protocol_https', 'audio_port_common', 'codec_hw', 'codec_plugin_vdec',
'camera_codec_hw', 'hdi_camera_intf', 'plugin_demuxer_raw', 'audio_modem_port'],
'media_melody': ['audio_manager', 'audio_service', 'audio_stream', 'audio_utils',
'media_common', 'audio_bluetooth_port', 'audio_hw',
'audio_primary_port', 'media_hal_common', 'audio_port_common', 'haid_manager', 'tone_player', 'tws_manager'],
'media_mini': ['audio_capture', 'audio_manager', 'audio_service', 'audio_stream', 'audio_utils',
'media_sample_wrapper', 'player', 'media_common', 'audio_bluetooth_port', 'audio_hw',
'audio_primary_port','format_hw', 'hmf_demuxer', 'media_hal_common', 'plugin_demuxer_hmf',
'plugin_demuxer_mjpeg', 'plugin_protocol_https', 'audio_port_common', 'plugin_demuxer_raw'],
'media_target4': ['audio_manager', 'audio_service', 'audio_stream', 'audio_utils', 'media_common', 'audio_hw',
'audio_primary_port', 'audio_bluetooth_port', 'audio_modem_port', 'media_hal_common',
'audio_port_common', 'media_sample_wrapper'],
'gpu': ['gfx_rm', 'gpu'],
'gpu_test': ['test_gpu'],
'graphic_uikit': ['cjson_static', 'display_gfx', 'display_gralloc', 'display_layer', 'graphic_input', 'graphic_service',
'freetype_static', 'graphic_ui', 'graphic_utils', 'qrcodegen', 'icu4c', 'harfbuzz', 'uikit_ext'],
'graphic_lvgl': ['display_gfx', 'display_gralloc', 'display_layer', 'graphic_input', 'freetype_static',
'lvgl', 'lvgl_sample', 'lvgl_demos', 'lvgl_proprietary', 'lvgl_service'],
'graphic_lvgl_mini': ['display_gfx', 'display_gralloc', 'display_layer', 'graphic_input', 'freetype_static',
'lvgl', 'lvgl_sample', 'lvgl_demos', 'lvgl_proprietary_mini', 'lvgl_service'],
'graphic_test': ['uikit_test'],
'calendar': ['calendar', 'hal_calendar', 'calendar_port'],
'update_app': ['update_common', 'update_storage', 'update_local', 'update_storage_brandy', 'update_common_brandy', 'lzma_21.07'],
'update_recovery': ['update_common', 'update_local', 'update_common_brandy', 'lzma_21.07'],
'pinctrl': ['pinctrl', 'hal_pinctrl', 'port_pinctrl'],
'pmp_set': ['pmp', 'hal_pmp', 'pmp_port'],
'mips': ['mips', 'hal_mips'],
'dfx_set': ['dfx_diag', "diag_dfx_cmd", 'dfx_panic', 'dfx_preserve', 'dfx_log', 'dfx_log_reader', 'dfx_exception', 'log_file', 'soc_log'],
'app_ux': ['ux_audio', 'ux_bt', 'ux_commu', 'ux_sensor', 'ux_spp', 'ux_cmn_header', 'ux_common'],
'pm_set': ['pm', 'pm_porting', 'pm_sleep', 'pm_sleep_porting', 'pm_veto', 'pm_veto_porting', 'pm_dev', 'pm_dev_porting', 'pm_fsm', 'pm_fsm_porting'],
'pm_pmu_set': ['pm_pmu', 'pm_pmu_porting'],
'pm_clock_set': ['pm_clock', 'pm_clock_porting'],
'ux_manager': ['fsm_box', 'fsm_master', 'fsm_pairing', 'ux_event', 'ux_earphone', 'ux_timer', 'ux_tone_config', 'ux_tone_service', 'ux_led_porting', 'ux_led_config',
'ux_led_frame', 'ux_master', 'at_ux_manager', 'at_ux_register', 'ux_voiceassistant', 'ux_feature'],
'ux_module': ['ux_box', 'ux_button', 'ux_pairing', 'ux_touchpad', 'ux_charge'],
'security_unified': ['hal_security_unified', 'drv_security_unified', 'security_unified_port'],
'efuse_v151': ['efuse_port', 'hal_efuse_v151', 'efuse'],
'efuse_v120': ['efuse', 'hal_efuse_v120', 'efuse_porting'],
'efuse_v100': ['efuse', 'hal_efuse_v100', 'efuse_porting'],
'efuse_v130': ['efuse', 'hal_efuse_v130', 'efuse_port'],
'codec_set': ['l2hc_dec_16k', 'l2hc_dec_48k_10ms', 'l2hc_dec_48k_5ms',
'opus_dec_half_itcm', 'opus_dec_half_flash', 'opus_dec_all_itcm', 'opus_dec_all_flash',
'opus_enc_half_itcm', 'opus_enc_half_flash', 'opus_enc_all_itcm', 'opus_enc_all_flash',
'opus_enc_2.5ms_itcm', 'opus_enc_2.5ms_flash', 'l2hc_enc_16k', 'l2hc_enc_48k_10ms','l2hc_enc_48k_5ms',
'sbc_dec_half_itcm', 'sbc_dec_half_flash', 'sbc_dec_all_itcm', 'sbc_dec_all_flash',
'sbc_enc_half_itcm', 'sbc_enc_half_flash', 'sbc_enc_all_itcm', 'sbc_enc_all_flash'],
'ohos_set' : ['bootstrap', 'samgr', 'ams', 'bms', 'bms_sign_mode', 'ace', 'ace_adapt', 'permission', 'appverify', 'jerryscript','js_player', 'js_audio_captuer','i18n', 'resmgr', 'syspara'],
'wearable_set' : ['nativeabilityfwk', 'nativelauncher', 'ai_voice_service', 'ai_voice_engine_hal', 'ai_voice_audio_stream_wrapper', 'ohos_deps',
'broadcast', 'msg_center', 'msg_center_adapt', 'ohos_startup'],
}
defines_set = {
'libsec_defines': [
"SECUREC_HAVE_WCTOMB=0", "SECUREC_HAVE_MBTOWC=0",
"SECUREC_ENABLE_SCANF_FLOAT=0", "SECUREC_ENABLE_SPRINTF_FLOAT=0"],
'chip_defines': [
"BS25_CHIP_FPGA=0", "BS25_CHIP_V100=0", "BRANDY_CHIP_FPGA=0", "BRANDY_CHIP_V100=0", "SOCMN1_CHIP_FPGA=0",
"SOCMN1_CHIP_V100=0", "SOCMN1_CHIP_V200=0", "LIBRA_CHIP_CS=0", "LIBRA_CHIP_FPGA=0", "SW39_CHIP_FPGA=0",
"TARGET_CHIP_BS25=0", "TARGET_CHIP_BRANDY=0", "TARGET_CHIP_SOCMN1=0", "TARGET_CHIP_SW39=0",
"TARGET_CHIP_LIBRA=0", "CHIP=1", "CHIP_VERSION=1", "CHIP_WS63=0", "SW21_CHIP_FPGA=0",
"TARGET_CHIP_SW21=0", "CHIP_WS53=0", "CONFIG_UART_SUPPORT_TX", "CONFIG_UART_SUPPORT_RX",
"CHIP_BS20=0", "CHIP_BS21=0", "CHIP_BS21A=0", "CHIP_BS21E=0", "CHIP_BS22=0", "CHIP_BS26=0",
],
'version_defines': [],
'libepmu_defines':['EPMU_BUCK_LDO_EN', 'EPMU_RTC_EN', 'EPMU_PWR_KEY_EN', 'EPMU_GPIO_EN', 'EPMU_WDT_EN', 'EPMU_EXTEND_EN'],
}
common_ccflags = [
'-std=gnu99',
'-Wall',
'-Werror',
'-Wextra',
'-Winit-self',
'-Wpointer-arith',
'-Wstrict-prototypes',
'-Wno-type-limits',
'-fno-strict-aliasing',
'-Os',
'-fno-unwind-tables',
]
common_linkflags = [
'-Wl,--gc-section',
'-nostdlib',
'-static',
]
arch_config = {
'riscv70': {
'ccflags': [
'--target=riscv32',
'-march=rv32imfcxlinxma_xlinxmb_xlinxmc',
'-mabi=ilp32f',
'-ffunction-sections',
'-fdata-sections',
'-fno-common',
'-fsigned-char',
'-fstack-protector-strong',
'-mllvm',
'-allow-unalign-ldst=false',
"-Wno-error=out-of-line-declaration",
"-Wno-error=uninitialized",
"-Wno-error=int-conversion",
"-Wno-error=enum-conversion",
"-Wno-error=long-long",
"-Wno-unused-variable",
"-Wno-error=unused-variable",
"-Wno-error=unused-value",
"-Wno-error=unused-function",
"-Wno-error=sign-compare",
"-Wno-error=unused-parameter",
"-Wno-error=tautological-compare",
"-Wno-error=bad-function-cast",
"-Wno-error=incompatible-pointer-types",
"-Wno-error=implicit-function-declaration",
"-Wno-missing-braces",
"-Wno-main-return-type",
"-Wno-unused-command-line-argument",
"-Wno-undef",
'-g',
],
'linkflags': [
'-Wl,--gc-section,--cref,-M',
'-static',
'-nostdlib',
'--target=riscv32',
],
'rom_ccflags': [
'--target=riscv32',
'-march=rv32imfcxlinxma_xlinxmb_xlinxmc',
'-mabi=ilp32f',
'-ffunction-sections',
'-fdata-sections',
'-fno-common',
'-fsigned-char',
'-Wno-error=main'
"-Wno-error=out-of-line-declaration",
"-Wno-error=uninitialized",
"-Wno-error=int-conversion",
"-Wno-error=enum-conversion",
"-Wno-error=long-long",
"-Wno-unused-variable",
"-Wno-error=unused-variable",
"-Wno-error=unused-value",
"-Wno-error=unused-function",
"-Wno-error=sign-compare",
"-Wno-error=unused-parameter",
"-Wno-error=tautological-compare",
"-Wno-error=bad-function-cast",
"-Wno-error=incompatible-pointer-types",
"-Wno-error=implicit-function-declaration",
"-Wno-missing-braces",
"-Wno-main-return-type",
"-Wno-unused-command-line-argument",
"-Wno-undef",
"-g"
],
'std_libs': [
]
},
'riscv32': {
'ccflags': [
'--target=riscv32',
'-march=rv32imc_xlinxma_xlinxmb_xlinxmc_xlinxmd',
'-mabi=ilp32',
'-ffunction-sections',
'-fdata-sections',
'-fno-common',
'-fsigned-char',
'-fstack-protector-strong',
'-mllvm',
'-allow-unalign-ldst=false',
"-Wno-error=out-of-line-declaration",
"-Wno-error=uninitialized",
"-Wno-error=int-conversion",
"-Wno-error=enum-conversion",
"-Wno-error=long-long",
"-Wno-unused-variable",
"-Wno-error=unused-variable",
"-Wno-error=unused-value",
"-Wno-error=unused-function",
"-Wno-error=sign-compare",
"-Wno-error=unused-parameter",
"-Wno-error=tautological-compare",
"-Wno-error=bad-function-cast",
"-Wno-error=incompatible-pointer-types",
"-Wno-error=implicit-function-declaration",
"-Wno-missing-braces",
"-Wno-main-return-type",
"-Wno-unused-command-line-argument",
"-Wno-undef",
'-g',
],
'linkflags': [
'-Wl,--gc-section,--cref,-M',
'-static',
'-nostdlib',
'--target=riscv32',
],
'rom_ccflags': [
'--target=riscv32',
'-march=rv32imc_xlinxma_xlinxmb_xlinxmc_xlinxmd',
'-mabi=ilp32',
'-ffunction-sections',
'-fdata-sections',
'-fno-common',
'-fsigned-char',
'-Wno-error=main'
"-Wno-error=out-of-line-declaration",
"-Wno-error=uninitialized",
"-Wno-error=int-conversion",
"-Wno-error=enum-conversion",
"-Wno-error=long-long",
"-Wno-unused-variable",
"-Wno-error=unused-variable",
"-Wno-error=unused-value",
"-Wno-error=unused-function",
"-Wno-error=sign-compare",
"-Wno-error=unused-parameter",
"-Wno-error=tautological-compare",
"-Wno-error=bad-function-cast",
"-Wno-error=incompatible-pointer-types",
"-Wno-error=implicit-function-declaration",
"-Wno-missing-braces",
"-Wno-main-return-type",
"-Wno-unused-command-line-argument",
"-Wno-undef",
"-g"
],
'std_libs': [
]
},
'cortex_m7':{
'ccflags': [
'-fomit-frame-pointer',
'-ffreestanding',
'-fdata-sections',
'-ffunction-sections',
'-specs=nano.specs',
'-nostdlib',
'-pipe',
'-mno-unaligned-access',
"-fdebug-types-section",
'-Wtrampolines',
'-Wlogical-op',
'-funsigned-char',
'-Wformat=2',
'-Wdate-time',
#'-Wshadow',
'-Wno-return-local-addr',
#'-Wconversion',
#'-Wcast-align',
'-Wfloat-equal',
#'-Wswitch-default',
'-Wvla',
'-Wjump-misses-init',
'-march=armv7-m',
'-mfpu=fpv5-d16',
'-mthumb',
'--specs=nosys.specs',
'-Wno-incompatible-pointer-types',
'-Wno-sign-compare',
"-Wno-error=enum-conversion",
"-Wno-error=uninitialized",
"-Wno-error=int-conversion",
"-Wno-error=long-long",
"-Wno-unused-variable",
"-Wno-error=unused-variable",
"-Wno-error=unused-value",
"-Wno-error=unused-function",
"-Wno-error=sign-compare",
"-Wno-error=unused-parameter",
"-Wno-error=tautological-compare",
"-Wno-error=bad-function-cast",
"-Wno-error=cast-function-type",
"-Wno-error=discarded-qualifiers",
"-Wno-error=missing-field-initializers",
"-Wno-error=incompatible-pointer-types",
"-Wno-error=implicit-function-declaration",
"-Wno-missing-braces",
'-Wno-implicit-function-declaration'
],
'linkflags': [
'-Wl,--gc-section,--cref,--relax,-M',
'-mthumb',
'-flto=16',
'-march=armv7-m',
'-nostdlib'
],
'rom_ccflags': [
'-fomit-frame-pointer',
'-ffreestanding',
'-fdata-sections',
'-ffunction-sections',
'-specs=nano.specs',
'-nostdlib',
'-pipe',
'-mno-unaligned-access',
'-mthumb',
"-fdebug-types-section",
'-Wtrampolines',
'-Wlogical-op',
'-Wjump-misses-init',
'-march=armv7-m',
'-fno-inline-functions-called-once',
'-fno-inline-small-functions',
'--specs=nosys.specs',
],
'std_libs': [
]
},
'riscv31': {
'ccflags': [
'-ffreestanding',
'-fdata-sections',
'-Wno-implicit-fallthrough',
'-ffunction-sections',
'-nostdlib',
'-pipe',
'-mabi=ilp32',
'-march=rv32imc',
'-fno-tree-scev-cprop',
'-fno-common',
'-mpush-pop',
'-msmall-data-limit=0',
'-fno-ipa-ra',
'-Wtrampolines',
'-Wlogical-op',
'-Wjump-misses-init',
"-Wa,-enable-c-lbu-sb",
"-Wa,-enable-c-lhu-sh",
"-fimm-compare",
"-femit-muliadd",
"-fmerge-immshf",
"-femit-uxtb-uxth",
"-femit-lli",
"-femit-clz",
"-fldm-stm-optimize",
'-g',
],
'linkflags': [
"-Wl,--enjal16",
"-nostdlib",
"-g",
],
'rom_ccflags': [
'-ffreestanding',
'-fdata-sections',
'-Wno-implicit-fallthrough',
'-ffunction-sections',
'-nostdlib',
'-pipe',
'-mabi=ilp32',
'-march=rv32imc',
'-fno-tree-scev-cprop',
'-fno-common',
'-mpush-pop',
'-msmall-data-limit=0',
'-fno-ipa-ra',
'-Wtrampolines',
'-Wlogical-op',
'-Wjump-misses-init',
"-Wa,-enable-c-lbu-sb",
"-Wa,-enable-c-lhu-sh",
"-fimm-compare",
"-femit-muliadd",
"-fmerge-immshf",
"-femit-uxtb-uxth",
"-femit-lli",
"-femit-clz",
"-fldm-stm-optimize",
"-g",
],
'std_libs': [
'gcc', 'm', 'c'
]
},
}
arch_family = {
"arm": [
"cortex_m7", "cortex_m3"
],
"riscv": [
"riscv70", "riscv31", "riscv32"
],
}
class CommonConfig:
def __init__(self, arch):
self.arch_config = arch_config[arch]
self.arch_family = ''
for arch_family_name in arch_family:
if arch in arch_family[arch_family_name]:
self.arch_family = arch_family_name
if not self.arch_family:
raise Exception(f"{arch} is not found in arch_family, please add it")
def get_ram_ccflags(self):
temp = []
temp.extend(common_ccflags)
temp.extend(self.arch_config['ccflags'])
return temp
def get_rom_ccflags(self):
return common_ccflags + self.arch_config['rom_ccflags']
def get_definse(self, set_name):
try:
return defines_set[set_name]
except KeyError:
print(f"{set_name} is not in defines_set!!")
raise
def get_linkflags(self):
return common_linkflags + self.arch_config['linkflags']
def get_std_libs(self):
return self.arch_config['std_libs']
def get_arch_family(self):
return self.arch_family
def get_component_set(self, set_name):
try:
return component_set[set_name]
except KeyError:
print(f"{set_name} is not in component_set!!")
raise