diff options
Diffstat (limited to 'meta/classes/populate_sdk_ext.bbclass')
-rw-r--r-- | meta/classes/populate_sdk_ext.bbclass | 148 |
1 files changed, 89 insertions, 59 deletions
diff --git a/meta/classes/populate_sdk_ext.bbclass b/meta/classes/populate_sdk_ext.bbclass index 6079166980..6afc53d284 100644 --- a/meta/classes/populate_sdk_ext.bbclass +++ b/meta/classes/populate_sdk_ext.bbclass | |||
@@ -89,7 +89,14 @@ python copy_buildsystem () { | |||
89 | # Copy in all metadata layers + bitbake (as repositories) | 89 | # Copy in all metadata layers + bitbake (as repositories) |
90 | buildsystem = oe.copy_buildsystem.BuildSystem('extensible SDK', d) | 90 | buildsystem = oe.copy_buildsystem.BuildSystem('extensible SDK', d) |
91 | baseoutpath = d.getVar('SDK_OUTPUT', True) + '/' + d.getVar('SDKPATH', True) | 91 | baseoutpath = d.getVar('SDK_OUTPUT', True) + '/' + d.getVar('SDKPATH', True) |
92 | layers_copied = buildsystem.copy_bitbake_and_layers(baseoutpath + '/layers') | 92 | |
93 | # Determine if we're building a derivative extensible SDK (from devtool build-sdk) | ||
94 | derivative = (d.getVar('SDK_DERIVATIVE', True) or '') == '1' | ||
95 | if derivative: | ||
96 | workspace_name = 'orig-workspace' | ||
97 | else: | ||
98 | workspace_name = None | ||
99 | layers_copied = buildsystem.copy_bitbake_and_layers(baseoutpath + '/layers', workspace_name) | ||
93 | 100 | ||
94 | sdkbblayers = [] | 101 | sdkbblayers = [] |
95 | corebase = os.path.basename(d.getVar('COREBASE', True)) | 102 | corebase = os.path.basename(d.getVar('COREBASE', True)) |
@@ -158,75 +165,81 @@ python copy_buildsystem () { | |||
158 | f.write(' "\n') | 165 | f.write(' "\n') |
159 | 166 | ||
160 | # Create local.conf | 167 | # Create local.conf |
161 | local_conf_whitelist = (d.getVar('SDK_LOCAL_CONF_WHITELIST', True) or '').split() | ||
162 | local_conf_blacklist = (d.getVar('SDK_LOCAL_CONF_BLACKLIST', True) or '').split() | ||
163 | def handle_var(varname, origvalue, op, newlines): | ||
164 | if varname in local_conf_blacklist or (origvalue.strip().startswith('/') and not varname in local_conf_whitelist): | ||
165 | newlines.append('# Removed original setting of %s\n' % varname) | ||
166 | return None, op, 0, True | ||
167 | else: | ||
168 | return origvalue, op, 0, True | ||
169 | varlist = ['[^#=+ ]*'] | ||
170 | builddir = d.getVar('TOPDIR', True) | 168 | builddir = d.getVar('TOPDIR', True) |
171 | with open(builddir + '/conf/local.conf', 'r') as f: | 169 | if derivative: |
172 | oldlines = f.readlines() | 170 | shutil.copyfile(builddir + '/conf/local.conf', baseoutpath + '/conf/local.conf') |
173 | (updated, newlines) = bb.utils.edit_metadata(oldlines, varlist, handle_var) | 171 | else: |
172 | local_conf_whitelist = (d.getVar('SDK_LOCAL_CONF_WHITELIST', True) or '').split() | ||
173 | local_conf_blacklist = (d.getVar('SDK_LOCAL_CONF_BLACKLIST', True) or '').split() | ||
174 | def handle_var(varname, origvalue, op, newlines): | ||
175 | if varname in local_conf_blacklist or (origvalue.strip().startswith('/') and not varname in local_conf_whitelist): | ||
176 | newlines.append('# Removed original setting of %s\n' % varname) | ||
177 | return None, op, 0, True | ||
178 | else: | ||
179 | return origvalue, op, 0, True | ||
180 | varlist = ['[^#=+ ]*'] | ||
181 | with open(builddir + '/conf/local.conf', 'r') as f: | ||
182 | oldlines = f.readlines() | ||
183 | (updated, newlines) = bb.utils.edit_metadata(oldlines, varlist, handle_var) | ||
174 | 184 | ||
175 | with open(baseoutpath + '/conf/local.conf', 'w') as f: | 185 | with open(baseoutpath + '/conf/local.conf', 'w') as f: |
176 | f.write('# WARNING: this configuration has been automatically generated and in\n') | 186 | f.write('# WARNING: this configuration has been automatically generated and in\n') |
177 | f.write('# most cases should not be edited. If you need more flexibility than\n') | 187 | f.write('# most cases should not be edited. If you need more flexibility than\n') |
178 | f.write('# this configuration provides, it is strongly suggested that you set\n') | 188 | f.write('# this configuration provides, it is strongly suggested that you set\n') |
179 | f.write('# up a proper instance of the full build system and use that instead.\n\n') | 189 | f.write('# up a proper instance of the full build system and use that instead.\n\n') |
180 | for line in newlines: | 190 | for line in newlines: |
181 | if line.strip() and not line.startswith('#'): | 191 | if line.strip() and not line.startswith('#'): |
182 | f.write(line) | 192 | f.write(line) |
183 | # Write a newline just in case there's none at the end of the original | 193 | # Write a newline just in case there's none at the end of the original |
184 | f.write('\n') | 194 | f.write('\n') |
185 | 195 | ||
186 | f.write('INHERIT += "%s"\n\n' % 'uninative') | 196 | f.write('INHERIT += "%s"\n\n' % 'uninative') |
187 | f.write('CONF_VERSION = "%s"\n\n' % d.getVar('CONF_VERSION', False)) | 197 | f.write('CONF_VERSION = "%s"\n\n' % d.getVar('CONF_VERSION', False)) |
188 | 198 | ||
189 | # Some classes are not suitable for SDK, remove them from INHERIT | 199 | # Some classes are not suitable for SDK, remove them from INHERIT |
190 | f.write('INHERIT_remove = "%s"\n' % d.getVar('SDK_INHERIT_BLACKLIST', False)) | 200 | f.write('INHERIT_remove = "%s"\n' % d.getVar('SDK_INHERIT_BLACKLIST', False)) |
191 | 201 | ||
192 | # Bypass the default connectivity check if any | 202 | # Bypass the default connectivity check if any |
193 | f.write('CONNECTIVITY_CHECK_URIS = ""\n\n') | 203 | f.write('CONNECTIVITY_CHECK_URIS = ""\n\n') |
194 | 204 | ||
195 | # Ensure locked sstate cache objects are re-used without error | 205 | # Ensure locked sstate cache objects are re-used without error |
196 | f.write('SIGGEN_LOCKEDSIGS_CHECK_LEVEL = "none"\n\n') | 206 | f.write('SIGGEN_LOCKEDSIGS_CHECK_LEVEL = "none"\n\n') |
197 | 207 | ||
198 | # Hide the config information from bitbake output (since it's fixed within the SDK) | 208 | # Hide the config information from bitbake output (since it's fixed within the SDK) |
199 | f.write('BUILDCFG_HEADER = ""\n') | 209 | f.write('BUILDCFG_HEADER = ""\n') |
200 | 210 | ||
201 | # Allow additional config through sdk-extra.conf | 211 | # Allow additional config through sdk-extra.conf |
202 | fn = bb.cookerdata.findConfigFile('sdk-extra.conf', d) | 212 | fn = bb.cookerdata.findConfigFile('sdk-extra.conf', d) |
203 | if fn: | 213 | if fn: |
204 | with open(fn, 'r') as xf: | 214 | with open(fn, 'r') as xf: |
205 | for line in xf: | 215 | for line in xf: |
206 | f.write(line) | 216 | f.write(line) |
207 | 217 | ||
208 | # If you define a sdk_extraconf() function then it can contain additional config | 218 | # If you define a sdk_extraconf() function then it can contain additional config |
209 | # (Though this is awkward; sdk-extra.conf should probably be used instead) | 219 | # (Though this is awkward; sdk-extra.conf should probably be used instead) |
210 | extraconf = (d.getVar('sdk_extraconf', True) or '').strip() | 220 | extraconf = (d.getVar('sdk_extraconf', True) or '').strip() |
211 | if extraconf: | 221 | if extraconf: |
212 | # Strip off any leading / trailing spaces | 222 | # Strip off any leading / trailing spaces |
213 | for line in extraconf.splitlines(): | 223 | for line in extraconf.splitlines(): |
214 | f.write(line.strip() + '\n') | 224 | f.write(line.strip() + '\n') |
215 | 225 | ||
216 | f.write('require conf/locked-sigs.inc\n') | 226 | f.write('require conf/locked-sigs.inc\n') |
217 | 227 | ||
218 | if os.path.exists(builddir + '/conf/auto.conf'): | 228 | if os.path.exists(builddir + '/conf/auto.conf'): |
219 | with open(builddir + '/conf/auto.conf', 'r') as f: | 229 | if derivative: |
220 | oldlines = f.readlines() | 230 | shutil.copyfile(builddir + '/conf/auto.conf', baseoutpath + '/conf/auto.conf') |
221 | (updated, newlines) = bb.utils.edit_metadata(oldlines, varlist, handle_var) | 231 | else: |
222 | with open(baseoutpath + '/conf/auto.conf', 'w') as f: | 232 | with open(builddir + '/conf/auto.conf', 'r') as f: |
223 | f.write('# WARNING: this configuration has been automatically generated and in\n') | 233 | oldlines = f.readlines() |
224 | f.write('# most cases should not be edited. If you need more flexibility than\n') | 234 | (updated, newlines) = bb.utils.edit_metadata(oldlines, varlist, handle_var) |
225 | f.write('# this configuration provides, it is strongly suggested that you set\n') | 235 | with open(baseoutpath + '/conf/auto.conf', 'w') as f: |
226 | f.write('# up a proper instance of the full build system and use that instead.\n\n') | 236 | f.write('# WARNING: this configuration has been automatically generated and in\n') |
227 | for line in newlines: | 237 | f.write('# most cases should not be edited. If you need more flexibility than\n') |
228 | if line.strip() and not line.startswith('#'): | 238 | f.write('# this configuration provides, it is strongly suggested that you set\n') |
229 | f.write(line) | 239 | f.write('# up a proper instance of the full build system and use that instead.\n\n') |
240 | for line in newlines: | ||
241 | if line.strip() and not line.startswith('#'): | ||
242 | f.write(line) | ||
230 | 243 | ||
231 | # Filter the locked signatures file to just the sstate tasks we are interested in | 244 | # Filter the locked signatures file to just the sstate tasks we are interested in |
232 | excluded_targets = d.getVar('SDK_TARGETS', True) | 245 | excluded_targets = d.getVar('SDK_TARGETS', True) |
@@ -253,7 +266,24 @@ python copy_buildsystem () { | |||
253 | lockedsigs_pruned, | 266 | lockedsigs_pruned, |
254 | lockedsigs_copy) | 267 | lockedsigs_copy) |
255 | 268 | ||
256 | if d.getVar('SDK_EXT_TYPE', True) != 'minimal': | 269 | if d.getVar('SDK_EXT_TYPE', True) == 'minimal': |
270 | if derivative: | ||
271 | # Assume the user is not going to set up an additional sstate | ||
272 | # mirror, thus we need to copy the additional artifacts (from | ||
273 | # workspace recipes) into the derivative SDK | ||
274 | lockedsigs_orig = d.getVar('TOPDIR', True) + '/conf/locked-sigs.inc' | ||
275 | if os.path.exists(lockedsigs_orig): | ||
276 | lockedsigs_extra = d.getVar('WORKDIR', True) + '/locked-sigs-extra.inc' | ||
277 | oe.copy_buildsystem.merge_lockedsigs(None, | ||
278 | lockedsigs_orig, | ||
279 | lockedsigs_pruned, | ||
280 | None, | ||
281 | lockedsigs_extra) | ||
282 | oe.copy_buildsystem.create_locked_sstate_cache(lockedsigs_extra, | ||
283 | d.getVar('SSTATE_DIR', True), | ||
284 | sstate_out, d, | ||
285 | fixedlsbstring) | ||
286 | else: | ||
257 | oe.copy_buildsystem.create_locked_sstate_cache(lockedsigs_pruned, | 287 | oe.copy_buildsystem.create_locked_sstate_cache(lockedsigs_pruned, |
258 | d.getVar('SSTATE_DIR', True), | 288 | d.getVar('SSTATE_DIR', True), |
259 | sstate_out, d, | 289 | sstate_out, d, |