diff options
Diffstat (limited to 'scripts/lib/devtool/build_image.py')
-rw-r--r-- | scripts/lib/devtool/build_image.py | 79 |
1 files changed, 57 insertions, 22 deletions
diff --git a/scripts/lib/devtool/build_image.py b/scripts/lib/devtool/build_image.py index ff764fa833..e51d766474 100644 --- a/scripts/lib/devtool/build_image.py +++ b/scripts/lib/devtool/build_image.py | |||
@@ -25,6 +25,9 @@ from devtool import exec_build_env_command, setup_tinfoil, parse_recipe, Devtool | |||
25 | 25 | ||
26 | logger = logging.getLogger('devtool') | 26 | logger = logging.getLogger('devtool') |
27 | 27 | ||
28 | class TargetNotImageError(Exception): | ||
29 | pass | ||
30 | |||
28 | def _get_packages(tinfoil, workspace, config): | 31 | def _get_packages(tinfoil, workspace, config): |
29 | """Get list of packages from recipes in the workspace.""" | 32 | """Get list of packages from recipes in the workspace.""" |
30 | result = [] | 33 | result = [] |
@@ -51,6 +54,24 @@ def build_image(args, config, basepath, workspace): | |||
51 | if not image: | 54 | if not image: |
52 | raise DevtoolError('Unable to determine image to build, please specify one') | 55 | raise DevtoolError('Unable to determine image to build, please specify one') |
53 | 56 | ||
57 | try: | ||
58 | if args.add_packages: | ||
59 | add_packages = args.add_packages.split(',') | ||
60 | else: | ||
61 | add_packages = None | ||
62 | result, outputdir = build_image_task(config, basepath, workspace, image, add_packages) | ||
63 | except TargetNotImageError: | ||
64 | if auto_image: | ||
65 | raise DevtoolError('Unable to determine image to build, please specify one') | ||
66 | else: | ||
67 | raise DevtoolError('Specified recipe %s is not an image recipe' % image) | ||
68 | |||
69 | if result == 0: | ||
70 | logger.info('Successfully built %s. You can find output files in %s' | ||
71 | % (image, outputdir)) | ||
72 | return result | ||
73 | |||
74 | def build_image_task(config, basepath, workspace, image, add_packages=None, task=None, extra_append=None): | ||
54 | appendfile = os.path.join(config.workspace_path, 'appends', | 75 | appendfile = os.path.join(config.workspace_path, 'appends', |
55 | '%s.bbappend' % image) | 76 | '%s.bbappend' % image) |
56 | 77 | ||
@@ -63,46 +84,60 @@ def build_image(args, config, basepath, workspace): | |||
63 | rd = parse_recipe(config, tinfoil, image, True) | 84 | rd = parse_recipe(config, tinfoil, image, True) |
64 | if not rd: | 85 | if not rd: |
65 | # Error already shown | 86 | # Error already shown |
66 | return 1 | 87 | return (1, None) |
67 | if not bb.data.inherits_class('image', rd): | 88 | if not bb.data.inherits_class('image', rd): |
68 | if auto_image: | 89 | raise TargetNotImageError() |
69 | raise DevtoolError('Unable to determine image to build, please specify one') | ||
70 | else: | ||
71 | raise DevtoolError('Specified recipe %s is not an image recipe' % image) | ||
72 | 90 | ||
91 | outputdir = None | ||
73 | try: | 92 | try: |
74 | if workspace or args.add_packages: | 93 | if workspace or add_packages: |
75 | if args.add_packages: | 94 | if add_packages: |
76 | packages = args.add_packages.split(',') | 95 | packages = add_packages |
77 | else: | 96 | else: |
78 | packages = _get_packages(tinfoil, workspace, config) | 97 | packages = _get_packages(tinfoil, workspace, config) |
79 | if packages: | 98 | else: |
80 | with open(appendfile, 'w') as afile: | 99 | packages = None |
100 | if not task: | ||
101 | if not packages and not add_packages and workspace: | ||
102 | logger.warning('No recipes in workspace, building image %s unmodified', image) | ||
103 | elif not packages: | ||
104 | logger.warning('No packages to add, building image %s unmodified', image) | ||
105 | |||
106 | if packages or extra_append: | ||
107 | bb.utils.mkdirhier(os.path.dirname(appendfile)) | ||
108 | with open(appendfile, 'w') as afile: | ||
109 | if packages: | ||
81 | # include packages from workspace recipes into the image | 110 | # include packages from workspace recipes into the image |
82 | afile.write('IMAGE_INSTALL_append = " %s"\n' % ' '.join(packages)) | 111 | afile.write('IMAGE_INSTALL_append = " %s"\n' % ' '.join(packages)) |
83 | logger.info('Building image %s with the following ' | 112 | if not task: |
84 | 'additional packages: %s', image, ' '.join(packages)) | 113 | logger.info('Building image %s with the following ' |
85 | else: | 114 | 'additional packages: %s', image, ' '.join(packages)) |
86 | logger.warning('No packages to add, building image %s unmodified', image) | 115 | if extra_append: |
116 | for line in extra_append: | ||
117 | afile.write('%s\n' % line) | ||
118 | |||
119 | if task in ['populate_sdk', 'populate_sdk_ext']: | ||
120 | outputdir = rd.getVar('SDK_DEPLOY', True) | ||
87 | else: | 121 | else: |
88 | logger.warning('No recipes in workspace, building image %s unmodified', image) | 122 | outputdir = rd.getVar('DEPLOY_DIR_IMAGE', True) |
89 | |||
90 | deploy_dir_image = tinfoil.config_data.getVar('DEPLOY_DIR_IMAGE', True) | ||
91 | 123 | ||
92 | tinfoil.shutdown() | 124 | tinfoil.shutdown() |
93 | 125 | ||
94 | # run bitbake to build image | 126 | options = '' |
127 | if task: | ||
128 | options += '-c %s' % task | ||
129 | |||
130 | # run bitbake to build image (or specified task) | ||
95 | try: | 131 | try: |
96 | exec_build_env_command(config.init_path, basepath, | 132 | exec_build_env_command(config.init_path, basepath, |
97 | 'bitbake %s' % image, watch=True) | 133 | 'bitbake %s %s' % (options, image), watch=True) |
98 | except ExecutionError as err: | 134 | except ExecutionError as err: |
99 | return err.exitcode | 135 | return (err.exitcode, None) |
100 | finally: | 136 | finally: |
101 | if os.path.isfile(appendfile): | 137 | if os.path.isfile(appendfile): |
102 | os.unlink(appendfile) | 138 | os.unlink(appendfile) |
139 | return (0, outputdir) | ||
103 | 140 | ||
104 | logger.info('Successfully built %s. You can find output files in %s' | ||
105 | % (image, deploy_dir_image)) | ||
106 | 141 | ||
107 | def register_commands(subparsers, context): | 142 | def register_commands(subparsers, context): |
108 | """Register devtool subcommands from the build-image plugin""" | 143 | """Register devtool subcommands from the build-image plugin""" |