Andrew Geissler | f034379 | 2020-11-18 10:42:21 -0600 | [diff] [blame] | 1 | .. SPDX-License-Identifier: CC-BY-SA-2.0-UK |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 2 | |
| 3 | ************************** |
| 4 | Source Directory Structure |
| 5 | ************************** |
| 6 | |
| 7 | The :term:`Source Directory` consists of numerous files, |
| 8 | directories and subdirectories; understanding their locations and |
| 9 | contents is key to using the Yocto Project effectively. This chapter |
| 10 | describes the Source Directory and gives information about those files |
| 11 | and directories. |
| 12 | |
| 13 | For information on how to establish a local Source Directory on your |
| 14 | development system, see the |
Andrew Geissler | 09209ee | 2020-12-13 08:44:15 -0600 | [diff] [blame] | 15 | ":ref:`dev-manual/start:locating yocto project source files`" |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 16 | section in the Yocto Project Development Tasks Manual. |
| 17 | |
| 18 | .. note:: |
| 19 | |
| 20 | The OpenEmbedded build system does not support file or directory |
| 21 | names that contain spaces. Be sure that the Source Directory you use |
| 22 | does not contain these types of names. |
| 23 | |
| 24 | .. _structure-core: |
| 25 | |
| 26 | Top-Level Core Components |
| 27 | ========================= |
| 28 | |
| 29 | This section describes the top-level components of the :term:`Source Directory`. |
| 30 | |
| 31 | .. _structure-core-bitbake: |
| 32 | |
| 33 | ``bitbake/`` |
| 34 | ------------ |
| 35 | |
| 36 | This directory includes a copy of BitBake for ease of use. The copy |
| 37 | usually matches the current stable BitBake release from the BitBake |
| 38 | project. BitBake, a :term:`Metadata` interpreter, reads the |
| 39 | Yocto Project Metadata and runs the tasks defined by that data. Failures |
| 40 | are usually caused by errors in your Metadata and not from BitBake |
William A. Kennington III | ac69b48 | 2021-06-02 12:28:27 -0700 | [diff] [blame] | 41 | itself. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 42 | |
| 43 | When you run the ``bitbake`` command, the main BitBake executable (which |
| 44 | resides in the ``bitbake/bin/`` directory) starts. Sourcing the |
| 45 | environment setup script (i.e. :ref:`structure-core-script`) places |
| 46 | the ``scripts/`` and ``bitbake/bin/`` directories (in that order) into |
| 47 | the shell's ``PATH`` environment variable. |
| 48 | |
| 49 | For more information on BitBake, see the :doc:`BitBake User Manual |
| 50 | <bitbake:index>`. |
| 51 | |
| 52 | .. _structure-core-build: |
| 53 | |
| 54 | ``build/`` |
| 55 | ---------- |
| 56 | |
| 57 | This directory contains user configuration files and the output |
| 58 | generated by the OpenEmbedded build system in its standard configuration |
| 59 | where the source tree is combined with the output. The :term:`Build Directory` |
Patrick Williams | 2390b1b | 2022-11-03 13:47:49 -0500 | [diff] [blame] | 60 | is created initially when you ``source`` the OpenEmbedded build environment |
| 61 | setup script (i.e. :ref:`structure-core-script`). |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 62 | |
| 63 | It is also possible to place output and configuration files in a |
| 64 | directory separate from the :term:`Source Directory` by |
| 65 | providing a directory name when you ``source`` the setup script. For |
| 66 | information on separating output from your local Source Directory files |
| 67 | (commonly described as an "out of tree" build), see the |
| 68 | ":ref:`structure-core-script`" section. |
| 69 | |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 70 | See the ":ref:`The Build Directory --- build/ <structure-build>`" section for details |
| 71 | about the contents of the :term:`Build Directory`. |
| 72 | |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 73 | .. _handbook: |
| 74 | |
| 75 | ``documentation/`` |
| 76 | ------------------ |
| 77 | |
| 78 | This directory holds the source for the Yocto Project documentation as |
| 79 | well as templates and tools that allow you to generate PDF and HTML |
| 80 | versions of the manuals. Each manual is contained in its own sub-folder; |
| 81 | for example, the files for this reference manual reside in the |
| 82 | ``ref-manual/`` directory. |
| 83 | |
| 84 | .. _structure-core-meta: |
| 85 | |
| 86 | ``meta/`` |
| 87 | --------- |
| 88 | |
| 89 | This directory contains the minimal, underlying OpenEmbedded-Core |
| 90 | metadata. The directory holds recipes, common classes, and machine |
| 91 | configuration for strictly emulated targets (``qemux86``, ``qemuarm``, |
| 92 | and so forth.) |
| 93 | |
| 94 | .. _structure-core-meta-poky: |
| 95 | |
| 96 | ``meta-poky/`` |
| 97 | -------------- |
| 98 | |
| 99 | Designed above the ``meta/`` content, this directory adds just enough |
| 100 | metadata to define the Poky reference distribution. |
| 101 | |
| 102 | .. _structure-core-meta-yocto-bsp: |
| 103 | |
| 104 | ``meta-yocto-bsp/`` |
| 105 | ------------------- |
| 106 | |
| 107 | This directory contains the Yocto Project reference hardware Board |
| 108 | Support Packages (BSPs). For more information on BSPs, see the |
Andrew Geissler | 09209ee | 2020-12-13 08:44:15 -0600 | [diff] [blame] | 109 | :doc:`/bsp-guide/index`. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 110 | |
| 111 | .. _structure-meta-selftest: |
| 112 | |
| 113 | ``meta-selftest/`` |
| 114 | ------------------ |
| 115 | |
| 116 | This directory adds additional recipes and append files used by the |
| 117 | OpenEmbedded selftests to verify the behavior of the build system. You |
| 118 | do not have to add this layer to your ``bblayers.conf`` file unless you |
| 119 | want to run the selftests. |
| 120 | |
| 121 | .. _structure-meta-skeleton: |
| 122 | |
| 123 | ``meta-skeleton/`` |
| 124 | ------------------ |
| 125 | |
| 126 | This directory contains template recipes for BSP and kernel development. |
| 127 | |
| 128 | .. _structure-core-scripts: |
| 129 | |
| 130 | ``scripts/`` |
| 131 | ------------ |
| 132 | |
| 133 | This directory contains various integration scripts that implement extra |
| 134 | functionality in the Yocto Project environment (e.g. QEMU scripts). The |
| 135 | :ref:`structure-core-script` script prepends this directory to the |
| 136 | shell's ``PATH`` environment variable. |
| 137 | |
| 138 | The ``scripts`` directory has useful scripts that assist in contributing |
| 139 | back to the Yocto Project, such as ``create-pull-request`` and |
| 140 | ``send-pull-request``. |
| 141 | |
| 142 | .. _structure-core-script: |
| 143 | |
| 144 | ``oe-init-build-env`` |
| 145 | --------------------- |
| 146 | |
| 147 | This script sets up the OpenEmbedded build environment. Running this |
| 148 | script with the ``source`` command in a shell makes changes to ``PATH`` |
| 149 | and sets other core BitBake variables based on the current working |
| 150 | directory. You need to run an environment setup script before running |
| 151 | BitBake commands. The script uses other scripts within the ``scripts`` |
| 152 | directory to do the bulk of the work. |
| 153 | |
| 154 | When you run this script, your Yocto Project environment is set up, a |
Patrick Williams | 2390b1b | 2022-11-03 13:47:49 -0500 | [diff] [blame] | 155 | :term:`Build Directory` is created, your working directory becomes the |
| 156 | :term:`Build Directory`, and you are presented with some simple |
| 157 | suggestions as to what to do next, including a list of some possible |
| 158 | targets to build. Here is an example:: |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 159 | |
| 160 | $ source oe-init-build-env |
| 161 | |
| 162 | ### Shell environment set up for builds. ### |
| 163 | |
| 164 | You can now run 'bitbake <target>' |
| 165 | |
| 166 | Common targets are: |
| 167 | core-image-minimal |
| 168 | core-image-sato |
| 169 | meta-toolchain |
| 170 | meta-ide-support |
| 171 | |
Andrew Geissler | 3b8a17c | 2021-04-15 15:55:55 -0500 | [diff] [blame] | 172 | You can also run generated QEMU images with a command like 'runqemu qemux86-64' |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 173 | |
| 174 | The default output of the ``oe-init-build-env`` script is from the |
Patrick Williams | 03514f1 | 2024-04-05 07:04:11 -0500 | [diff] [blame] | 175 | ``conf-summary.txt`` and ``conf-notes.txt`` files, which are found in the ``meta-poky`` directory |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 176 | within the :term:`Source Directory`. If you design a |
Patrick Williams | 03514f1 | 2024-04-05 07:04:11 -0500 | [diff] [blame] | 177 | custom distribution, you can include your own versions of these |
| 178 | configuration files where you can provide a brief summary and detailed usage |
| 179 | notes, such as a list of the targets defined by your distribution. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 180 | See the |
Andrew Geissler | 517393d | 2023-01-13 08:55:19 -0600 | [diff] [blame] | 181 | ":ref:`dev-manual/custom-template-configuration-directory:creating a custom template configuration directory`" |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 182 | section in the Yocto Project Development Tasks Manual for more |
| 183 | information. |
| 184 | |
Patrick Williams | 2390b1b | 2022-11-03 13:47:49 -0500 | [diff] [blame] | 185 | By default, running this script without a :term:`Build Directory` argument |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 186 | creates the ``build/`` directory in your current working directory. If |
Patrick Williams | 2390b1b | 2022-11-03 13:47:49 -0500 | [diff] [blame] | 187 | you provide a :term:`Build Directory` argument when you ``source`` the script, |
| 188 | you direct the OpenEmbedded build system to create a :term:`Build Directory` of |
| 189 | your choice. For example, the following command creates a |
| 190 | :term:`Build Directory` named ``mybuilds/`` that is outside of the |
| 191 | :term:`Source Directory`:: |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 192 | |
Andrew Geissler | 4c19ea1 | 2020-10-27 13:52:24 -0500 | [diff] [blame] | 193 | $ source oe-init-build-env ~/mybuilds |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 194 | |
| 195 | The OpenEmbedded build system uses the template configuration files, which |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 196 | are found by default in the ``meta-poky/conf/templates/default`` directory in the Source |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 197 | Directory. See the |
Andrew Geissler | 517393d | 2023-01-13 08:55:19 -0600 | [diff] [blame] | 198 | ":ref:`dev-manual/custom-template-configuration-directory:creating a custom template configuration directory`" |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 199 | section in the Yocto Project Development Tasks Manual for more |
| 200 | information. |
| 201 | |
| 202 | .. note:: |
| 203 | |
| 204 | The OpenEmbedded build system does not support file or directory |
Andrew Geissler | 4c19ea1 | 2020-10-27 13:52:24 -0500 | [diff] [blame] | 205 | names that contain spaces. If you attempt to run the ``oe-init-build-env`` |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 206 | script from a Source Directory that contains spaces in either the |
| 207 | filenames or directory names, the script returns an error indicating |
| 208 | no such file or directory. Be sure to use a Source Directory free of |
| 209 | names containing spaces. |
| 210 | |
| 211 | .. _structure-basic-top-level: |
| 212 | |
| 213 | ``LICENSE, README, and README.hardware`` |
| 214 | ---------------------------------------- |
| 215 | |
| 216 | These files are standard top-level files. |
| 217 | |
| 218 | .. _structure-build: |
| 219 | |
Andrew Geissler | 615f2f1 | 2022-07-15 14:00:58 -0500 | [diff] [blame] | 220 | The Build Directory --- ``build/`` |
| 221 | ================================== |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 222 | |
Patrick Williams | 2390b1b | 2022-11-03 13:47:49 -0500 | [diff] [blame] | 223 | The OpenEmbedded build system creates the :term:`Build Directory` when you run |
| 224 | the build environment setup script :ref:`structure-core-script`. If you do not |
| 225 | give the :term:`Build Directory` a specific name when you run the setup script, |
| 226 | the name defaults to ``build/``. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 227 | |
| 228 | For subsequent parsing and processing, the name of the Build directory |
| 229 | is available via the :term:`TOPDIR` variable. |
| 230 | |
| 231 | .. _structure-build-buildhistory: |
| 232 | |
| 233 | ``build/buildhistory/`` |
| 234 | ----------------------- |
| 235 | |
| 236 | The OpenEmbedded build system creates this directory when you enable |
Andrew Geissler | 517393d | 2023-01-13 08:55:19 -0600 | [diff] [blame] | 237 | build history via the :ref:`ref-classes-buildhistory` class file. The directory |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 238 | organizes build information into image, packages, and SDK |
| 239 | subdirectories. For information on the build history feature, see the |
Andrew Geissler | 517393d | 2023-01-13 08:55:19 -0600 | [diff] [blame] | 240 | ":ref:`dev-manual/build-quality:maintaining build output quality`" |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 241 | section in the Yocto Project Development Tasks Manual. |
| 242 | |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 243 | .. _structure-build-cache: |
| 244 | |
| 245 | ``build/cache/`` |
| 246 | ---------------- |
| 247 | |
| 248 | This directory contains several internal files used by the OpenEmbedded |
| 249 | build system. |
| 250 | |
| 251 | It also contains ``sanity_info``, a text file keeping track of important |
| 252 | build information such as the values of :term:`TMPDIR`, :term:`SSTATE_DIR`, |
| 253 | as well as the name and version of the host distribution. |
| 254 | |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 255 | .. _structure-build-conf-local.conf: |
| 256 | |
| 257 | ``build/conf/local.conf`` |
| 258 | ------------------------- |
| 259 | |
| 260 | This configuration file contains all the local user configurations for |
| 261 | your build environment. The ``local.conf`` file contains documentation |
| 262 | on the various configuration options. Any variable set here overrides |
| 263 | any variable set elsewhere within the environment unless that variable |
| 264 | is hard-coded within a file (e.g. by using '=' instead of '?='). Some |
| 265 | variables are hard-coded for various reasons but such variables are |
| 266 | relatively rare. |
| 267 | |
| 268 | At a minimum, you would normally edit this file to select the target |
Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 269 | :term:`MACHINE`, which package types you wish to use |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 270 | (:term:`PACKAGE_CLASSES`), and the location from |
Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 271 | which you want to access downloaded files (:term:`DL_DIR`). |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 272 | |
| 273 | If ``local.conf`` is not present when you start the build, the |
| 274 | OpenEmbedded build system creates it from ``local.conf.sample`` when you |
| 275 | ``source`` the top-level build environment setup script |
| 276 | :ref:`structure-core-script`. |
| 277 | |
| 278 | The source ``local.conf.sample`` file used depends on the |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 279 | :term:`TEMPLATECONF` script variable, which defaults to ``meta-poky/conf/templates/default`` |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 280 | when you are building from the Yocto Project development environment, |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 281 | and to ``meta/conf/templates/default`` when you are building from the OpenEmbedded-Core |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 282 | environment. Because the script variable points to the source of the |
| 283 | ``local.conf.sample`` file, this implies that you can configure your |
| 284 | build environment from any layer by setting the variable in the |
Andrew Geissler | c926e17 | 2021-05-07 16:11:35 -0500 | [diff] [blame] | 285 | top-level build environment setup script as follows:: |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 286 | |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 287 | TEMPLATECONF=your_layer/conf/templates/your_template_name |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 288 | |
| 289 | Once the build process gets the sample |
| 290 | file, it uses ``sed`` to substitute final |
| 291 | ``${``\ :term:`OEROOT`\ ``}`` values for all |
| 292 | ``##OEROOT##`` values. |
| 293 | |
| 294 | .. note:: |
| 295 | |
Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 296 | You can see how the :term:`TEMPLATECONF` variable is used by looking at the |
William A. Kennington III | ac69b48 | 2021-06-02 12:28:27 -0700 | [diff] [blame] | 297 | ``scripts/oe-setup-builddir`` script in the :term:`Source Directory`. |
Andrew Geissler | 4c19ea1 | 2020-10-27 13:52:24 -0500 | [diff] [blame] | 298 | You can find the Yocto Project version of the ``local.conf.sample`` file in |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 299 | the ``meta-poky/conf/templates/default`` directory. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 300 | |
| 301 | .. _structure-build-conf-bblayers.conf: |
| 302 | |
| 303 | ``build/conf/bblayers.conf`` |
| 304 | ---------------------------- |
| 305 | |
| 306 | This configuration file defines |
Andrew Geissler | 517393d | 2023-01-13 08:55:19 -0600 | [diff] [blame] | 307 | :ref:`layers <dev-manual/layers:understanding and creating layers>`, |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 308 | which are directory trees, traversed (or walked) by BitBake. The |
| 309 | ``bblayers.conf`` file uses the :term:`BBLAYERS` |
| 310 | variable to list the layers BitBake tries to find. |
| 311 | |
| 312 | If ``bblayers.conf`` is not present when you start the build, the |
| 313 | OpenEmbedded build system creates it from ``bblayers.conf.sample`` when |
| 314 | you ``source`` the top-level build environment setup script (i.e. |
| 315 | :ref:`structure-core-script`). |
| 316 | |
| 317 | As with the ``local.conf`` file, the source ``bblayers.conf.sample`` |
Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 318 | file used depends on the :term:`TEMPLATECONF` script variable, which |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 319 | defaults to ``meta-poky/conf/templates/default`` when you are building from the Yocto |
| 320 | Project development environment, and to ``meta/conf/templates/default`` when you are |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 321 | building from the OpenEmbedded-Core environment. Because the script |
| 322 | variable points to the source of the ``bblayers.conf.sample`` file, this |
| 323 | implies that you can base your build from any layer by setting the |
Andrew Geissler | c926e17 | 2021-05-07 16:11:35 -0500 | [diff] [blame] | 324 | variable in the top-level build environment setup script as follows:: |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 325 | |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 326 | TEMPLATECONF=your_layer/conf/templates/your_template_name |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 327 | |
| 328 | Once the build process gets the sample file, it uses ``sed`` to substitute final |
| 329 | ``${``\ :term:`OEROOT`\ ``}`` values for all ``##OEROOT##`` values. |
| 330 | |
| 331 | .. note:: |
| 332 | |
Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 333 | You can see how the :term:`TEMPLATECONF` variable is defined by the ``scripts/oe-setup-builddir`` |
Andrew Geissler | 4c19ea1 | 2020-10-27 13:52:24 -0500 | [diff] [blame] | 334 | script in the :term:`Source Directory`. You can find the Yocto Project |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 335 | version of the ``bblayers.conf.sample`` file in the ``meta-poky/conf/templates/default`` |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 336 | directory. |
| 337 | |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 338 | .. _structure-build-downloads: |
| 339 | |
| 340 | ``build/downloads/`` |
| 341 | -------------------- |
| 342 | |
| 343 | This directory contains downloaded upstream source tarballs. You can |
| 344 | reuse the directory for multiple builds or move the directory to another |
| 345 | location. You can control the location of this directory through the |
Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 346 | :term:`DL_DIR` variable. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 347 | |
| 348 | .. _structure-build-sstate-cache: |
| 349 | |
| 350 | ``build/sstate-cache/`` |
| 351 | ----------------------- |
| 352 | |
| 353 | This directory contains the shared state cache. You can reuse the |
| 354 | directory for multiple builds or move the directory to another location. |
| 355 | You can control the location of this directory through the |
Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 356 | :term:`SSTATE_DIR` variable. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 357 | |
| 358 | .. _structure-build-tmp: |
| 359 | |
| 360 | ``build/tmp/`` |
| 361 | -------------- |
| 362 | |
| 363 | The OpenEmbedded build system creates and uses this directory for all |
| 364 | the build system's output. The :term:`TMPDIR` variable |
| 365 | points to this directory. |
| 366 | |
| 367 | BitBake creates this directory if it does not exist. As a last resort, |
| 368 | to clean up a build and start it from scratch (other than the |
| 369 | downloads), you can remove everything in the ``tmp`` directory or get |
| 370 | rid of the directory completely. If you do, you should also completely |
| 371 | remove the ``build/sstate-cache`` directory. |
| 372 | |
| 373 | .. _structure-build-tmp-buildstats: |
| 374 | |
| 375 | ``build/tmp/buildstats/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 376 | ~~~~~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 377 | |
Andrew Geissler | 517393d | 2023-01-13 08:55:19 -0600 | [diff] [blame] | 378 | This directory stores the build statistics as generated by the |
| 379 | :ref:`ref-classes-buildstats` class. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 380 | |
| 381 | .. _structure-build-tmp-cache: |
| 382 | |
| 383 | ``build/tmp/cache/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 384 | ~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 385 | |
| 386 | When BitBake parses the metadata (recipes and configuration files), it |
| 387 | caches the results in ``build/tmp/cache/`` to speed up future builds. |
| 388 | The results are stored on a per-machine basis. |
| 389 | |
| 390 | During subsequent builds, BitBake checks each recipe (together with, for |
| 391 | example, any files included or appended to it) to see if they have been |
| 392 | modified. Changes can be detected, for example, through file |
| 393 | modification time (mtime) changes and hashing of file contents. If no |
| 394 | changes to the file are detected, then the parsed result stored in the |
| 395 | cache is reused. If the file has changed, it is reparsed. |
| 396 | |
| 397 | .. _structure-build-tmp-deploy: |
| 398 | |
| 399 | ``build/tmp/deploy/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 400 | ~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 401 | |
| 402 | This directory contains any "end result" output from the OpenEmbedded |
| 403 | build process. The :term:`DEPLOY_DIR` variable points |
| 404 | to this directory. For more detail on the contents of the ``deploy`` |
| 405 | directory, see the |
Andrew Geissler | 09209ee | 2020-12-13 08:44:15 -0600 | [diff] [blame] | 406 | ":ref:`overview-manual/concepts:images`" and |
| 407 | ":ref:`overview-manual/concepts:application development sdk`" sections in the Yocto |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 408 | Project Overview and Concepts Manual. |
| 409 | |
| 410 | .. _structure-build-tmp-deploy-deb: |
| 411 | |
| 412 | ``build/tmp/deploy/deb/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 413 | ^^^^^^^^^^^^^^^^^^^^^^^^^ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 414 | |
| 415 | This directory receives any ``.deb`` packages produced by the build |
| 416 | process. The packages are sorted into feeds for different architecture |
| 417 | types. |
| 418 | |
| 419 | .. _structure-build-tmp-deploy-rpm: |
| 420 | |
| 421 | ``build/tmp/deploy/rpm/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 422 | ^^^^^^^^^^^^^^^^^^^^^^^^^ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 423 | |
| 424 | This directory receives any ``.rpm`` packages produced by the build |
| 425 | process. The packages are sorted into feeds for different architecture |
| 426 | types. |
| 427 | |
| 428 | .. _structure-build-tmp-deploy-ipk: |
| 429 | |
| 430 | ``build/tmp/deploy/ipk/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 431 | ^^^^^^^^^^^^^^^^^^^^^^^^^ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 432 | |
| 433 | This directory receives ``.ipk`` packages produced by the build process. |
| 434 | |
| 435 | .. _structure-build-tmp-deploy-licenses: |
| 436 | |
| 437 | ``build/tmp/deploy/licenses/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 438 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 439 | |
| 440 | This directory receives package licensing information. For example, the |
| 441 | directory contains sub-directories for ``bash``, ``busybox``, and |
| 442 | ``glibc`` (among others) that in turn contain appropriate ``COPYING`` |
| 443 | license files with other licensing information. For information on |
| 444 | licensing, see the |
Andrew Geissler | 517393d | 2023-01-13 08:55:19 -0600 | [diff] [blame] | 445 | ":ref:`dev-manual/licenses:maintaining open source license compliance during your product's lifecycle`" |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 446 | section in the Yocto Project Development Tasks Manual. |
| 447 | |
| 448 | .. _structure-build-tmp-deploy-images: |
| 449 | |
| 450 | ``build/tmp/deploy/images/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 451 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 452 | |
| 453 | This directory is populated with the basic output objects of the build |
| 454 | (think of them as the "generated artifacts" of the build process), |
| 455 | including things like the boot loader image, kernel, root filesystem and |
| 456 | more. If you want to flash the resulting image from a build onto a |
| 457 | device, look here for the necessary components. |
| 458 | |
| 459 | Be careful when deleting files in this directory. You can safely delete |
| 460 | old images from this directory (e.g. ``core-image-*``). However, the |
| 461 | kernel (``*zImage*``, ``*uImage*``, etc.), bootloader and other |
| 462 | supplementary files might be deployed here prior to building an image. |
| 463 | Because these files are not directly produced from the image, if you |
| 464 | delete them they will not be automatically re-created when you build the |
| 465 | image again. |
| 466 | |
| 467 | If you do accidentally delete files here, you will need to force them to |
| 468 | be re-created. In order to do that, you will need to know the target |
| 469 | that produced them. For example, these commands rebuild and re-create |
Andrew Geissler | c926e17 | 2021-05-07 16:11:35 -0500 | [diff] [blame] | 470 | the kernel files:: |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 471 | |
| 472 | $ bitbake -c clean virtual/kernel |
| 473 | $ bitbake virtual/kernel |
| 474 | |
| 475 | .. _structure-build-tmp-deploy-sdk: |
| 476 | |
| 477 | ``build/tmp/deploy/sdk/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 478 | ^^^^^^^^^^^^^^^^^^^^^^^^^ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 479 | |
| 480 | The OpenEmbedded build system creates this directory to hold toolchain |
| 481 | installer scripts which, when executed, install the sysroot that matches |
| 482 | your target hardware. You can find out more about these installers in |
Andrew Geissler | 09209ee | 2020-12-13 08:44:15 -0600 | [diff] [blame] | 483 | the ":ref:`sdk-manual/appendix-obtain:building an sdk installer`" |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 484 | section in the Yocto Project Application Development and the Extensible |
| 485 | Software Development Kit (eSDK) manual. |
| 486 | |
| 487 | .. _structure-build-tmp-sstate-control: |
| 488 | |
| 489 | ``build/tmp/sstate-control/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 490 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 491 | |
| 492 | The OpenEmbedded build system uses this directory for the shared state |
| 493 | manifest files. The shared state code uses these files to record the |
| 494 | files installed by each sstate task so that the files can be removed |
| 495 | when cleaning the recipe or when a newer version is about to be |
| 496 | installed. The build system also uses the manifests to detect and |
| 497 | produce a warning when files from one task are overwriting those from |
| 498 | another. |
| 499 | |
| 500 | .. _structure-build-tmp-sysroots-components: |
| 501 | |
| 502 | ``build/tmp/sysroots-components/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 503 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 504 | |
| 505 | This directory is the location of the sysroot contents that the task |
| 506 | :ref:`ref-tasks-prepare_recipe_sysroot` |
| 507 | links or copies into the recipe-specific sysroot for each recipe listed |
| 508 | in :term:`DEPENDS`. Population of this directory is |
| 509 | handled through shared state, while the path is specified by the |
| 510 | :term:`COMPONENTS_DIR` variable. Apart from a few |
| 511 | unusual circumstances, handling of the ``sysroots-components`` directory |
| 512 | should be automatic, and recipes should not directly reference |
| 513 | ``build/tmp/sysroots-components``. |
| 514 | |
| 515 | .. _structure-build-tmp-sysroots: |
| 516 | |
| 517 | ``build/tmp/sysroots/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 518 | ~~~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 519 | |
| 520 | Previous versions of the OpenEmbedded build system used to create a |
William A. Kennington III | ac69b48 | 2021-06-02 12:28:27 -0700 | [diff] [blame] | 521 | global shared sysroot per machine along with a native sysroot. Since |
| 522 | the 2.3 version of the Yocto Project, there are sysroots in |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 523 | recipe-specific :term:`WORKDIR` directories. Thus, the |
| 524 | ``build/tmp/sysroots/`` directory is unused. |
| 525 | |
| 526 | .. note:: |
| 527 | |
Andrew Geissler | 4c19ea1 | 2020-10-27 13:52:24 -0500 | [diff] [blame] | 528 | The ``build/tmp/sysroots/`` directory can still be populated using the |
| 529 | ``bitbake build-sysroots`` command and can be used for compatibility in some |
| 530 | cases. However, in general it is not recommended to populate this directory. |
| 531 | Individual recipe-specific sysroots should be used. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 532 | |
| 533 | .. _structure-build-tmp-stamps: |
| 534 | |
| 535 | ``build/tmp/stamps/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 536 | ~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 537 | |
| 538 | This directory holds information that BitBake uses for accounting |
| 539 | purposes to track what tasks have run and when they have run. The |
| 540 | directory is sub-divided by architecture, package name, and version. |
Patrick Williams | 3965356 | 2024-03-01 08:54:02 -0600 | [diff] [blame] | 541 | Here is an example:: |
Andrew Geissler | 4c19ea1 | 2020-10-27 13:52:24 -0500 | [diff] [blame] | 542 | |
| 543 | stamps/all-poky-linux/distcc-config/1.0-r0.do_build-2fdd....2do |
| 544 | |
| 545 | Although the files in the directory are empty of data, BitBake uses the filenames |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 546 | and timestamps for tracking purposes. |
| 547 | |
| 548 | For information on how BitBake uses stamp files to determine if a task |
| 549 | should be rerun, see the |
Andrew Geissler | 09209ee | 2020-12-13 08:44:15 -0600 | [diff] [blame] | 550 | ":ref:`overview-manual/concepts:stamp files and the rerunning of tasks`" |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 551 | section in the Yocto Project Overview and Concepts Manual. |
| 552 | |
| 553 | .. _structure-build-tmp-log: |
| 554 | |
| 555 | ``build/tmp/log/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 556 | ~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 557 | |
| 558 | This directory contains general logs that are not otherwise placed using |
Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 559 | the package's :term:`WORKDIR`. Examples of logs are the output from the |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 560 | ``do_check_pkg`` or ``do_distro_check`` tasks. Running a build does not |
| 561 | necessarily mean this directory is created. |
| 562 | |
| 563 | .. _structure-build-tmp-work: |
| 564 | |
| 565 | ``build/tmp/work/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 566 | ~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 567 | |
| 568 | This directory contains architecture-specific work sub-directories for |
| 569 | packages built by BitBake. All tasks execute from the appropriate work |
| 570 | directory. For example, the source for a particular package is unpacked, |
| 571 | patched, configured and compiled all within its own work directory. |
| 572 | Within the work directory, organization is based on the package group |
| 573 | and version for which the source is being compiled as defined by the |
| 574 | :term:`WORKDIR`. |
| 575 | |
| 576 | It is worth considering the structure of a typical work directory. As an |
| 577 | example, consider ``linux-yocto-kernel-3.0`` on the machine ``qemux86`` |
| 578 | built within the Yocto Project. For this package, a work directory of |
| 579 | ``tmp/work/qemux86-poky-linux/linux-yocto/3.0+git1+<.....>``, referred |
Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 580 | to as the :term:`WORKDIR`, is created. Within this directory, the source is |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 581 | unpacked to ``linux-qemux86-standard-build`` and then patched by Quilt. |
Andrew Geissler | 517393d | 2023-01-13 08:55:19 -0600 | [diff] [blame] | 582 | (See the ":ref:`dev-manual/quilt:using quilt in your workflow`" section in |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 583 | the Yocto Project Development Tasks Manual for more information.) Within |
| 584 | the ``linux-qemux86-standard-build`` directory, standard Quilt |
| 585 | directories ``linux-3.0/patches`` and ``linux-3.0/.pc`` are created, and |
| 586 | standard Quilt commands can be used. |
| 587 | |
Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 588 | There are other directories generated within :term:`WORKDIR`. The most |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 589 | important directory is ``WORKDIR/temp/``, which has log files for each |
| 590 | task (``log.do_*.pid``) and contains the scripts BitBake runs for each |
| 591 | task (``run.do_*.pid``). The ``WORKDIR/image/`` directory is where "make |
| 592 | install" places its output that is then split into sub-packages within |
| 593 | ``WORKDIR/packages-split/``. |
| 594 | |
| 595 | .. _structure-build-tmp-work-tunearch-recipename-version: |
| 596 | |
| 597 | ``build/tmp/work/tunearch/recipename/version/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 598 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 599 | |
Andrew Geissler | 615f2f1 | 2022-07-15 14:00:58 -0500 | [diff] [blame] | 600 | The recipe work directory --- ``${WORKDIR}``. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 601 | |
| 602 | As described earlier in the |
Andrew Geissler | 4c19ea1 | 2020-10-27 13:52:24 -0500 | [diff] [blame] | 603 | ":ref:`structure-build-tmp-sysroots`" section, |
| 604 | beginning with the 2.3 release of the Yocto Project, the OpenEmbedded |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 605 | build system builds each recipe in its own work directory (i.e. |
| 606 | :term:`WORKDIR`). The path to the work directory is |
| 607 | constructed using the architecture of the given build (e.g. |
Andrew Geissler | 4c19ea1 | 2020-10-27 13:52:24 -0500 | [diff] [blame] | 608 | :term:`TUNE_PKGARCH`, :term:`MACHINE_ARCH`, or "allarch"), the recipe |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 609 | name, and the version of the recipe (i.e. |
| 610 | :term:`PE`\ ``:``\ :term:`PV`\ ``-``\ :term:`PR`). |
| 611 | |
William A. Kennington III | ac69b48 | 2021-06-02 12:28:27 -0700 | [diff] [blame] | 612 | Here are key subdirectories within each recipe work directory: |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 613 | |
| 614 | - ``${WORKDIR}/temp``: Contains the log files of each task executed for |
| 615 | this recipe, the "run" files for each executed task, which contain |
| 616 | the code run, and a ``log.task_order`` file, which lists the order in |
| 617 | which tasks were executed. |
| 618 | |
| 619 | - ``${WORKDIR}/image``: Contains the output of the |
| 620 | :ref:`ref-tasks-install` task, which corresponds to |
| 621 | the ``${``\ :term:`D`\ ``}`` variable in that task. |
| 622 | |
| 623 | - ``${WORKDIR}/pseudo``: Contains the pseudo database and log for any |
| 624 | tasks executed under pseudo for the recipe. |
| 625 | |
| 626 | - ``${WORKDIR}/sysroot-destdir``: Contains the output of the |
| 627 | :ref:`ref-tasks-populate_sysroot` task. |
| 628 | |
| 629 | - ``${WORKDIR}/package``: Contains the output of the |
| 630 | :ref:`ref-tasks-package` task before the output is |
| 631 | split into individual packages. |
| 632 | |
| 633 | - ``${WORKDIR}/packages-split``: Contains the output of the |
Patrick Williams | 2194f50 | 2022-10-16 14:26:09 -0500 | [diff] [blame] | 634 | :ref:`ref-tasks-package` task after the output has been split into individual |
William A. Kennington III | ac69b48 | 2021-06-02 12:28:27 -0700 | [diff] [blame] | 635 | packages. There are subdirectories for each individual package created by |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 636 | the recipe. |
| 637 | |
| 638 | - ``${WORKDIR}/recipe-sysroot``: A directory populated with the target |
| 639 | dependencies of the recipe. This directory looks like the target |
| 640 | filesystem and contains libraries that the recipe might need to link |
| 641 | against (e.g. the C library). |
| 642 | |
| 643 | - ``${WORKDIR}/recipe-sysroot-native``: A directory populated with the |
| 644 | native dependencies of the recipe. This directory contains the tools |
| 645 | the recipe needs to build (e.g. the compiler, Autoconf, libtool, and |
| 646 | so forth). |
| 647 | |
| 648 | - ``${WORKDIR}/build``: This subdirectory applies only to recipes that |
| 649 | support builds where the source is separate from the build artifacts. |
| 650 | The OpenEmbedded build system uses this directory as a separate build |
| 651 | directory (i.e. ``${``\ :term:`B`\ ``}``). |
| 652 | |
| 653 | .. _structure-build-work-shared: |
| 654 | |
| 655 | ``build/tmp/work-shared/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 656 | ~~~~~~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 657 | |
| 658 | For efficiency, the OpenEmbedded build system creates and uses this |
| 659 | directory to hold recipes that share a work directory with other |
| 660 | recipes. In practice, this is only used for ``gcc`` and its variants |
| 661 | (e.g. ``gcc-cross``, ``libgcc``, ``gcc-runtime``, and so forth). |
| 662 | |
| 663 | .. _structure-meta: |
| 664 | |
Andrew Geissler | 615f2f1 | 2022-07-15 14:00:58 -0500 | [diff] [blame] | 665 | The Metadata --- ``meta/`` |
| 666 | ========================== |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 667 | |
| 668 | As mentioned previously, :term:`Metadata` is the core of the |
| 669 | Yocto Project. Metadata has several important subdivisions: |
| 670 | |
| 671 | .. _structure-meta-classes: |
| 672 | |
Patrick Williams | 975a06f | 2022-10-21 14:42:47 -0500 | [diff] [blame] | 673 | ``meta/classes*/`` |
| 674 | ------------------ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 675 | |
Patrick Williams | 975a06f | 2022-10-21 14:42:47 -0500 | [diff] [blame] | 676 | These directories contain the ``*.bbclass`` files. Class files are used to |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 677 | abstract common code so it can be reused by multiple packages. Every |
Andrew Geissler | 7e0e3c0 | 2022-02-25 20:34:39 +0000 | [diff] [blame] | 678 | package inherits the :ref:`ref-classes-base` file. Examples of other important |
| 679 | classes are :ref:`ref-classes-autotools`, which in theory allows any |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 680 | Autotool-enabled package to work with the Yocto Project with minimal |
Andrew Geissler | 7e0e3c0 | 2022-02-25 20:34:39 +0000 | [diff] [blame] | 681 | effort. Another example is :ref:`ref-classes-kernel` that contains common code |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 682 | and functions for working with the Linux kernel. Functions like image |
| 683 | generation or packaging also have their specific class files such as |
Andrew Geissler | 7e0e3c0 | 2022-02-25 20:34:39 +0000 | [diff] [blame] | 684 | :ref:`ref-classes-image`, :ref:`ref-classes-rootfs*` and |
| 685 | :ref:`package*.bbclass <ref-classes-package>`. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 686 | |
| 687 | For reference information on classes, see the |
Andrew Geissler | 7e0e3c0 | 2022-02-25 20:34:39 +0000 | [diff] [blame] | 688 | ":doc:`/ref-manual/classes`" chapter. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 689 | |
| 690 | .. _structure-meta-conf: |
| 691 | |
| 692 | ``meta/conf/`` |
| 693 | -------------- |
| 694 | |
| 695 | This directory contains the core set of configuration files that start |
| 696 | from ``bitbake.conf`` and from which all other configuration files are |
| 697 | included. See the include statements at the end of the ``bitbake.conf`` |
| 698 | file and you will note that even ``local.conf`` is loaded from there. |
| 699 | While ``bitbake.conf`` sets up the defaults, you can often override |
| 700 | these by using the (``local.conf``) file, machine file or the |
| 701 | distribution configuration file. |
| 702 | |
| 703 | .. _structure-meta-conf-machine: |
| 704 | |
| 705 | ``meta/conf/machine/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 706 | ~~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 707 | |
| 708 | This directory contains all the machine configuration files. If you set |
| 709 | ``MACHINE = "qemux86"``, the OpenEmbedded build system looks for a |
| 710 | ``qemux86.conf`` file in this directory. The ``include`` directory |
| 711 | contains various data common to multiple machines. If you want to add |
| 712 | support for a new machine to the Yocto Project, look in this directory. |
| 713 | |
| 714 | .. _structure-meta-conf-distro: |
| 715 | |
| 716 | ``meta/conf/distro/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 717 | ~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 718 | |
| 719 | The contents of this directory controls any distribution-specific |
| 720 | configurations. For the Yocto Project, the ``defaultsetup.conf`` is the |
Andrew Geissler | 0903674 | 2021-06-25 14:25:14 -0500 | [diff] [blame] | 721 | main file here. This directory includes the versions and the :term:`SRCDATE` |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 722 | definitions for applications that are configured here. An example of an |
| 723 | alternative configuration might be ``poky-bleeding.conf``. Although this |
| 724 | file mainly inherits its configuration from Poky. |
| 725 | |
| 726 | .. _structure-meta-conf-machine-sdk: |
| 727 | |
| 728 | ``meta/conf/machine-sdk/`` |
Andrew Geissler | 87f5cff | 2022-09-30 13:13:31 -0500 | [diff] [blame] | 729 | ~~~~~~~~~~~~~~~~~~~~~~~~~~ |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 730 | |
| 731 | The OpenEmbedded build system searches this directory for configuration |
| 732 | files that correspond to the value of |
| 733 | :term:`SDKMACHINE`. By default, 32-bit and 64-bit x86 |
| 734 | files ship with the Yocto Project that support some SDK hosts. However, |
| 735 | it is possible to extend that support to other SDK hosts by adding |
| 736 | additional configuration files in this subdirectory within another |
| 737 | layer. |
| 738 | |
| 739 | .. _structure-meta-files: |
| 740 | |
| 741 | ``meta/files/`` |
| 742 | --------------- |
| 743 | |
| 744 | This directory contains common license files and several text files used |
| 745 | by the build system. The text files contain minimal device information |
| 746 | and lists of files and directories with known permissions. |
| 747 | |
| 748 | .. _structure-meta-lib: |
| 749 | |
| 750 | ``meta/lib/`` |
| 751 | ------------- |
| 752 | |
| 753 | This directory contains OpenEmbedded Python library code used during the |
Patrick Williams | 8e7b46e | 2023-05-01 14:19:06 -0500 | [diff] [blame] | 754 | build process. It is enabled via the ``addpylib`` directive in |
| 755 | ``meta/conf/local.conf``. For more information, see |
| 756 | :ref:`bitbake-user-manual/bitbake-user-manual-metadata:extending python library code`. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 757 | |
| 758 | .. _structure-meta-recipes-bsp: |
| 759 | |
| 760 | ``meta/recipes-bsp/`` |
| 761 | --------------------- |
| 762 | |
| 763 | This directory contains anything linking to specific hardware or |
| 764 | hardware configuration information such as "u-boot" and "grub". |
| 765 | |
| 766 | .. _structure-meta-recipes-connectivity: |
| 767 | |
| 768 | ``meta/recipes-connectivity/`` |
| 769 | ------------------------------ |
| 770 | |
| 771 | This directory contains libraries and applications related to |
| 772 | communication with other devices. |
| 773 | |
| 774 | .. _structure-meta-recipes-core: |
| 775 | |
| 776 | ``meta/recipes-core/`` |
| 777 | ---------------------- |
| 778 | |
| 779 | This directory contains what is needed to build a basic working Linux |
| 780 | image including commonly used dependencies. |
| 781 | |
| 782 | .. _structure-meta-recipes-devtools: |
| 783 | |
| 784 | ``meta/recipes-devtools/`` |
| 785 | -------------------------- |
| 786 | |
| 787 | This directory contains tools that are primarily used by the build |
| 788 | system. The tools, however, can also be used on targets. |
| 789 | |
| 790 | .. _structure-meta-recipes-extended: |
| 791 | |
| 792 | ``meta/recipes-extended/`` |
| 793 | -------------------------- |
| 794 | |
| 795 | This directory contains non-essential applications that add features |
| 796 | compared to the alternatives in core. You might need this directory for |
William A. Kennington III | ac69b48 | 2021-06-02 12:28:27 -0700 | [diff] [blame] | 797 | full tool functionality. |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 798 | |
| 799 | .. _structure-meta-recipes-gnome: |
| 800 | |
| 801 | ``meta/recipes-gnome/`` |
| 802 | ----------------------- |
| 803 | |
| 804 | This directory contains all things related to the GTK+ application |
| 805 | framework. |
| 806 | |
| 807 | .. _structure-meta-recipes-graphics: |
| 808 | |
| 809 | ``meta/recipes-graphics/`` |
| 810 | -------------------------- |
| 811 | |
| 812 | This directory contains X and other graphically related system |
| 813 | libraries. |
| 814 | |
| 815 | .. _structure-meta-recipes-kernel: |
| 816 | |
| 817 | ``meta/recipes-kernel/`` |
| 818 | ------------------------ |
| 819 | |
| 820 | This directory contains the kernel and generic applications and |
| 821 | libraries that have strong kernel dependencies. |
| 822 | |
Andrew Geissler | c9f7865 | 2020-09-18 14:11:35 -0500 | [diff] [blame] | 823 | .. _structure-meta-recipes-multimedia: |
| 824 | |
| 825 | ``meta/recipes-multimedia/`` |
| 826 | ---------------------------- |
| 827 | |
| 828 | This directory contains codecs and support utilities for audio, images |
| 829 | and video. |
| 830 | |
| 831 | .. _structure-meta-recipes-rt: |
| 832 | |
| 833 | ``meta/recipes-rt/`` |
| 834 | -------------------- |
| 835 | |
| 836 | This directory contains package and image recipes for using and testing |
| 837 | the ``PREEMPT_RT`` kernel. |
| 838 | |
| 839 | .. _structure-meta-recipes-sato: |
| 840 | |
| 841 | ``meta/recipes-sato/`` |
| 842 | ---------------------- |
| 843 | |
| 844 | This directory contains the Sato demo/reference UI/UX and its associated |
| 845 | applications and configuration data. |
| 846 | |
| 847 | .. _structure-meta-recipes-support: |
| 848 | |
| 849 | ``meta/recipes-support/`` |
| 850 | ------------------------- |
| 851 | |
| 852 | This directory contains recipes used by other recipes, but that are not |
| 853 | directly included in images (i.e. dependencies of other recipes). |
| 854 | |
| 855 | .. _structure-meta-site: |
| 856 | |
| 857 | ``meta/site/`` |
| 858 | -------------- |
| 859 | |
| 860 | This directory contains a list of cached results for various |
| 861 | architectures. Because certain "autoconf" test results cannot be |
| 862 | determined when cross-compiling due to the tests not able to run on a |
| 863 | live system, the information in this directory is passed to "autoconf" |
| 864 | for the various architectures. |
| 865 | |
| 866 | .. _structure-meta-recipes-txt: |
| 867 | |
| 868 | ``meta/recipes.txt`` |
| 869 | -------------------- |
| 870 | |
| 871 | This file is a description of the contents of ``recipes-*``. |