@@ -117,7 +117,7 @@ def get_full_name(name, unit_name, unit_kind, label=None,
117
117
unit_name , unit_kind , label )))
118
118
prefix = temp [0 ]
119
119
# Check if the given parameter prefix matches the expected prefix
120
- if (unit_kind == "library" and prefix != unit_name ) or \
120
+ if (unit_kind == "library" and prefix not in [ unit_name , "target" ] ) or \
121
121
(unit_kind == "target" and prefix != "target" ):
122
122
raise ConfigException (
123
123
"Invalid prefix '%s' for parameter name '%s' in '%s'" %
@@ -857,7 +857,7 @@ def get_target_config_data(self):
857
857
params [full_name ].set_value (val , tname , "target" )
858
858
return params
859
859
860
- def get_lib_config_data (self ):
860
+ def get_lib_config_data (self , target_data ):
861
861
""" Read and interpret configuration data defined by libraries. It is
862
862
assumed that "add_config_files" above was already called and the library
863
863
configuration data exists in self.lib_config_data
@@ -866,7 +866,7 @@ def get_lib_config_data(self):
866
866
"""
867
867
all_params , macros = {}, {}
868
868
for lib_name , lib_data in self .lib_config_data .items ():
869
- all_params .update (self ._process_config_and_overrides (lib_data , {} ,
869
+ all_params .update (self ._process_config_and_overrides (lib_data , target_data ,
870
870
lib_name ,
871
871
"library" ))
872
872
_process_macros (lib_data .get ("macros" , []), macros , lib_name ,
@@ -901,9 +901,8 @@ def get_config_data(self):
901
901
Arguments: None
902
902
"""
903
903
all_params = self .get_target_config_data ()
904
- lib_params , macros = self .get_lib_config_data ()
905
- all_params .update (lib_params )
906
- self .get_app_config_data (all_params , macros )
904
+ lib_params , macros = self .get_lib_config_data (all_params )
905
+ self .get_app_config_data (lib_params , macros )
907
906
return all_params , macros
908
907
909
908
@staticmethod
0 commit comments