Configure boot loader after scanning

pull/5909/head
Jimmy Brisson 2018-01-23 17:02:14 -06:00
parent 855d74a968
commit c180324530
2 changed files with 17 additions and 21 deletions

View File

@ -284,26 +284,20 @@ def get_mbed_official_release(version):
return mbed_official_release
def add_regions_to_profile(profile, config, toolchain_class):
def add_regions_to_toolchain(toolchain):
"""Add regions to the build profile, if there are any.
Positional Arguments:
profile - the profile to update
config - the configuration object that owns the region
toolchain_class - the class of the toolchain being used
toolchain - the toolchain to add the region defines to
"""
if not profile:
return
regions = list(config.regions)
regions = list(toolchain.config.regions)
for region in regions:
for define in [(region.name.upper() + "_ADDR", region.start),
(region.name.upper() + "_SIZE", region.size)]:
profile["common"].append("-D%s=0x%x" % define)
active_region = [r for r in regions if r.active][0]
for define in [("MBED_APP_START", active_region.start),
("MBED_APP_SIZE", active_region.size)]:
profile["ld"].append(toolchain_class.make_ld_define(*define))
toolchain.cc.append("-D%s=0x%x" % define)
toolchain.cppc.append("-D%s=0x%x" % define)
if region.active:
toolchain.ld.append(toolchain.make_ld_define(*define))
print("Using regions in this build:")
for region in regions:
print(" Region %s size 0x%x, offset 0x%x"
@ -352,9 +346,6 @@ def prepare_toolchain(src_paths, build_dir, target, toolchain_name,
for key in profile:
profile[key].extend(contents[toolchain_name][key])
if config.has_regions:
add_regions_to_profile(profile, config, cur_tc)
toolchain = cur_tc(target, notify, macros, silent, build_dir=build_dir,
extra_verbose=extra_verbose, build_profile=profile)
@ -439,6 +430,9 @@ def scan_resources(src_paths, toolchain, dependencies_paths=None,
# Set the toolchain's configuration data
toolchain.set_config_data(toolchain.config.get_config_data())
if toolchain.config.has_regions:
add_regions_to_toolchain(toolchain)
if (hasattr(toolchain.target, "release_versions") and
"5" not in toolchain.target.release_versions and
"rtos" in toolchain.config.lib_config_data):

View File

@ -685,17 +685,19 @@ class Config(object):
# Consider the others as overrides
for name, val in overrides.items():
if (name.startswith("target.") and
(unit_kind is "application" or
name in self.__unused_overrides)):
_, attribute = name.split(".")
setattr(self.target, attribute, val)
continue
# Get the full name of the parameter
full_name = ConfigParameter.get_full_name(name, unit_name,
unit_kind, label)
if full_name in params:
params[full_name].set_value(val, unit_name, unit_kind,
label)
elif (name.startswith("target.") and
unit_kind is "application" or
name in self.__unused_overrides):
_, attribute = name.split(".")
setattr(self.target, attribute, val)
else:
self.config_errors.append(
ConfigException(