diff options
Diffstat (limited to 'documentation')
-rw-r--r-- | documentation/poky-ref-manual/ref-structure.xml | 362 |
1 files changed, 194 insertions, 168 deletions
diff --git a/documentation/poky-ref-manual/ref-structure.xml b/documentation/poky-ref-manual/ref-structure.xml index 296ea54eb3..74687c50a5 100644 --- a/documentation/poky-ref-manual/ref-structure.xml +++ b/documentation/poky-ref-manual/ref-structure.xml | |||
@@ -6,9 +6,9 @@ | |||
6 | <title>Reference: Directory Structure</title> | 6 | <title>Reference: Directory Structure</title> |
7 | 7 | ||
8 | <para> | 8 | <para> |
9 | Poky consists of several components and understanding what these are | 9 | Poky consists of several components. |
10 | and where they're located is one of the keys to using it. This section walks | 10 | Understanding them and knowing where they are located is key to using Poky well. |
11 | through the Poky directory structure giving information about the various | 11 | This appendix describes the Poky directory structure and gives information about the various |
12 | files and directories. | 12 | files and directories. |
13 | </para> | 13 | </para> |
14 | 14 | ||
@@ -19,17 +19,20 @@ | |||
19 | <title><filename class="directory">bitbake/</filename></title> | 19 | <title><filename class="directory">bitbake/</filename></title> |
20 | 20 | ||
21 | <para> | 21 | <para> |
22 | A copy of BitBake is included within Poky for ease of use, and should | 22 | Poky includes a copy of BitBake for ease of use. |
23 | usually match the current BitBake stable release from the BitBake project. | 23 | The copy usually matches the current stable BitBake release from the BitBake project. |
24 | Bitbake, a metadata interpreter, reads the Poky metadata and runs the tasks | 24 | BitBake, a metadata interpreter, reads the Poky metadata and runs the tasks |
25 | defined in the Poky metadata. Failures are usually from the metadata, not | 25 | defined by that data. |
26 | BitBake itself, so most users don't need to worry about BitBake. The | 26 | Failures are usually from the metadata and not |
27 | <filename class="directory">bitbake/bin/</filename> directory is placed | 27 | from BitBake itself. |
28 | into the PATH environment variable by the <link | 28 | Consequently, most users do not need to worry about BitBake. |
29 | linkend="structure-core-script">poky-init-build-env</link> script. | 29 | The <filename class="directory">bitbake/bin/</filename> directory is placed |
30 | into the PATH environment variable by the | ||
31 | <link linkend="structure-core-script">poky-init-build-env</link> script. | ||
30 | </para> | 32 | </para> |
33 | |||
31 | <para> | 34 | <para> |
32 | For more information on BitBake please see the BitBake project site at | 35 | For more information on BitBake, see the BitBake project site at |
33 | <ulink url="http://bitbake.berlios.de/"/> | 36 | <ulink url="http://bitbake.berlios.de/"/> |
34 | and the BitBake on-line manual at <ulink url="http://bitbake.berlios.de/manual/"/>. | 37 | and the BitBake on-line manual at <ulink url="http://bitbake.berlios.de/manual/"/>. |
35 | </para> | 38 | </para> |
@@ -41,9 +44,11 @@ | |||
41 | <para> | 44 | <para> |
42 | This directory contains user configuration files and the output | 45 | This directory contains user configuration files and the output |
43 | generated by Poky in its standard configuration where the source tree is | 46 | generated by Poky in its standard configuration where the source tree is |
44 | combined with the output. It is also possible to place output and configuration | 47 | combined with the output. |
45 | files in a directory separate from the Poky source, see the section <link | 48 | It is also possible to place output and configuration |
46 | linkend='structure-core-script'>seperate output directory</link>. | 49 | files in a directory separate from the Poky source. |
50 | For information on separating output from the Poky source, see <link | ||
51 | linkend='structure-core-script'>poky-init-build-env</link>. | ||
47 | </para> | 52 | </para> |
48 | </section> | 53 | </section> |
49 | 54 | ||
@@ -51,8 +56,8 @@ | |||
51 | <title><filename class="directory">meta/</filename></title> | 56 | <title><filename class="directory">meta/</filename></title> |
52 | 57 | ||
53 | <para> | 58 | <para> |
54 | This directory contains the core metadata, a key part of Poky. Within this | 59 | This directory contains the core metadata, which is a key part of Poky. |
55 | directory there are definitions of the machines, the Poky distribution | 60 | This directory contains the machine definitions, the Poky distribution, |
56 | and the packages that make up a given system. | 61 | and the packages that make up a given system. |
57 | </para> | 62 | </para> |
58 | </section> | 63 | </section> |
@@ -61,9 +66,9 @@ | |||
61 | <title><filename class="directory">meta-extras/</filename></title> | 66 | <title><filename class="directory">meta-extras/</filename></title> |
62 | 67 | ||
63 | <para> | 68 | <para> |
64 | This directory is similar to <filename class="directory">meta/</filename>, | 69 | This directory is similar to <filename class="directory">meta/</filename>. |
65 | and contains some extra metadata not included in standard Poky. These are | 70 | The directory contains extra metadata not included in standard Poky. |
66 | disabled by default, and are not supported as part of Poky. | 71 | This metadata is disabled by default and is not supported as part of Poky. |
67 | </para> | 72 | </para> |
68 | </section> | 73 | </section> |
69 | 74 | ||
@@ -71,8 +76,8 @@ | |||
71 | <title><filename class="directory">meta-***/</filename></title> | 76 | <title><filename class="directory">meta-***/</filename></title> |
72 | 77 | ||
73 | <para> | 78 | <para> |
74 | These directories are optional layers to be added to core metadata, which | 79 | These directories are optional layers that are added to core metadata. |
75 | are enabled by adding them to conf/bblayers.conf. | 80 | The layers are enabled by adding them to the <filename>conf/bblayers.conf</filename> file. |
76 | </para> | 81 | </para> |
77 | </section> | 82 | </section> |
78 | 83 | ||
@@ -80,10 +85,10 @@ | |||
80 | <title><filename class="directory">scripts/</filename></title> | 85 | <title><filename class="directory">scripts/</filename></title> |
81 | 86 | ||
82 | <para> | 87 | <para> |
83 | This directory contains various integration scripts which implement | 88 | This directory contains various integration scripts that implement |
84 | extra functionality in the Poky environment, such as the QEMU | 89 | extra functionality in the Poky environment (e.g. QEMU scripts). |
85 | scripts. This directory is appended to the PATH environment variable by the | 90 | The <link linkend="structure-core-script">poky-init-build-env</link> script appends this |
86 | <link linkend="structure-core-script">poky-init-build-env</link> script. | 91 | directory to the PATH environment variable. |
87 | </para> | 92 | </para> |
88 | </section> | 93 | </section> |
89 | 94 | ||
@@ -91,40 +96,42 @@ | |||
91 | <title><filename class="directory">sources/</filename></title> | 96 | <title><filename class="directory">sources/</filename></title> |
92 | 97 | ||
93 | <para> | 98 | <para> |
94 | While not part of a checkout, Poky will create this directory as | 99 | This directory receives downloads as specified by the |
95 | part of any build. Any downloads are placed in this directory (as | 100 | <glossterm><link linkend='var-DL_DIR'>DL_DIR</link></glossterm> variable. |
96 | specified by the <glossterm><link linkend='var-DL_DIR'>DL_DIR</link> | 101 | Even though the directory is not part of a checkout, Poky creates it during a build. |
97 | </glossterm> variable). This directory can be shared between Poky | 102 | You can use this directory to share downloading files between Poky builds. |
98 | builds to save downloading files multiple times. SCM checkouts are | 103 | This practice can save you from downloading files multiple times. |
99 | also stored here as e.g. <filename class="directory">sources/svn/ | 104 | <note><para> |
100 | </filename>, <filename class="directory">sources/cvs/</filename> or | 105 | You can override the location for this directory by setting |
101 | <filename class="directory">sources/git/</filename> and the | 106 | the DL_DIR variable in <filename>local.conf</filename>. |
102 | sources directory may contain archives of checkouts for various | 107 | </para></note> |
103 | revisions or dates. | ||
104 | </para> | 108 | </para> |
105 | 109 | ||
106 | <para> | 110 | <para> |
107 | It's worth noting that BitBake creates <filename class="extension">.md5 | 111 | This directory also contains SCM checkouts (e.g. <filename class="directory">sources/svn/ |
108 | </filename> stamp files for downloads. It uses these to mark downloads as | 112 | </filename>, <filename class="directory">sources/cvs/</filename> or |
109 | complete as well as for checksum and access accounting purposes. If you add | 113 | <filename class="directory">sources/git/</filename>). |
110 | a file manually to the directory, you need to touch the corresponding | 114 | The <filename class="directory">sources</filename> directory can contain archives of |
111 | <filename class="extension">.md5</filename> file too. | 115 | checkouts for various revisions or dates. |
112 | </para> | 116 | </para> |
113 | 117 | ||
114 | <para> | 118 | <para> |
115 | This location can be overridden by setting <glossterm><link | 119 | It's worth noting that BitBake creates <filename class="extension">.md5 |
116 | linkend='var-DL_DIR'>DL_DIR</link></glossterm> in <filename>local.conf | 120 | </filename> stamp files for downloads. |
117 | </filename>. This directory can be shared between builds and even between | 121 | BitBake uses these files to mark downloads as |
118 | machines via NFS, so downloads are only made once, speeding up builds. | 122 | complete as well as for checksum and access accounting purposes. |
123 | If you manually add a file to the directory, you need to touch the corresponding | ||
124 | <filename class="extension">.md5</filename> file as well. | ||
119 | </para> | 125 | </para> |
120 | |||
121 | </section> | 126 | </section> |
122 | 127 | ||
123 | <section id='handbook'> | 128 | <section id='handbook'> |
124 | <title><filename class="directory">documentation</filename></title> | 129 | <title><filename class="directory">documentation</filename></title> |
125 | 130 | ||
126 | <para> | 131 | <para> |
127 | This is the location for documentaiton about poky including this handbook. | 132 | This directory holds the source for the documentation. Each manual is contained in |
133 | a sub-folder. For example, the files for this manual reside in | ||
134 | <filename class="directory">poky-ref-manual</filename>. | ||
128 | </para> | 135 | </para> |
129 | </section> | 136 | </section> |
130 | 137 | ||
@@ -132,46 +139,50 @@ | |||
132 | <title><filename>poky-init-build-env</filename></title> | 139 | <title><filename>poky-init-build-env</filename></title> |
133 | 140 | ||
134 | <para> | 141 | <para> |
135 | This script is used to setup the Poky build environment. Sourcing this file in | 142 | This script sets up the Poky build environment. |
143 | Sourcing this file in | ||
136 | a shell makes changes to PATH and sets other core BitBake variables based on the | 144 | a shell makes changes to PATH and sets other core BitBake variables based on the |
137 | current working directory. You need to use this before running Poky commands. | 145 | current working directory. |
138 | Internally it uses scripts within the <filename class="directory">scripts/ | 146 | You need to run this script before running Poky commands. |
139 | </filename> directory to do the bulk of the work. This script supports | 147 | The script uses other scripts within the <filename class="directory">scripts/ |
140 | specifying any directory as the build output: | 148 | </filename> directory to do the bulk of the work. |
149 | You can use this script to specify any directory for the build's output by doing the following: | ||
141 | </para> | 150 | </para> |
142 | 151 | ||
143 | <programlisting> | 152 | <literallayout class='monospaced'> |
144 | source POKY_SRC/poky-init-build-env [BUILDDIR] | 153 | $ source POKY_SRC/poky-init-build-env [BUILDDIR] |
145 | </programlisting> | 154 | </literallayout> |
146 | 155 | ||
147 | <para> | 156 | <para> |
148 | The above command can be typed from any directory, as long as POKY_SRC points to | 157 | You can enter the above command from any directory, as long as POKY_SRC points to |
149 | the desired Poky source tree. The optional BUILDDIR could be any directory you'd | 158 | the desired Poky source tree. |
150 | like Poky to generate the build output into. | 159 | The optional BUILDDIR can be any directory into which you would |
160 | like Poky to generate the build output. | ||
151 | </para> | 161 | </para> |
152 | </section> | 162 | </section> |
153 | </section> | 163 | </section> |
154 | 164 | ||
155 | <section id='structure-build'> | 165 | <section id='structure-build'> |
156 | <title><filename class="directory">build/</filename> - The Build Directory</title> | 166 | <title>The Build Directory - <filename class="directory">build/</filename></title> |
157 | 167 | ||
158 | <section id='structure-build-conf-local.conf'> | 168 | <section id='structure-build-conf-local.conf'> |
159 | <title><filename>build/conf/local.conf</filename></title> | 169 | <title><filename>build/conf/local.conf</filename></title> |
160 | 170 | ||
161 | <para> | 171 | <para> |
162 | This file contains all the local user configuration of Poky. If there | 172 | This file contains all the local user configuration of Poky. |
163 | is no <filename>local.conf</filename> present, it is created from | 173 | If there is no <filename>local.conf</filename> present, it is created from |
164 | <filename>local.conf.sample</filename>. The <filename>local.conf</filename> | 174 | <filename>local.conf.sample</filename>. |
165 | file contains documentation on the various configuration options. Any | 175 | The <filename>local.conf</filename> file contains documentation on the various configuration options. |
166 | variable set here overrides any variable set elsewhere within Poky unless | 176 | Any variable set here overrides any variable set elsewhere within Poky unless |
167 | that variable is hardcoded within Poky (e.g. by using '=' instead of '?='). | 177 | that variable is hard-coded within Poky (e.g. by using '=' instead of '?='). |
168 | Some variables are hardcoded for various reasons but these variables are | 178 | Some variables are hard-coded for various reasons but these variables are |
169 | relatively rare. | 179 | relatively rare. |
170 | </para> | 180 | </para> |
171 | 181 | ||
172 | <para> | 182 | <para> |
173 | Edit this file to set the <glossterm><link linkend='var-MACHINE'>MACHINE</link></glossterm> for which you want to build, which package types you | 183 | Edit this file to set the <glossterm><link linkend='var-MACHINE'>MACHINE</link></glossterm> |
174 | wish to use (PACKAGE_CLASSES) or where downloaded files should go | 184 | for which you want to build, which package types you |
185 | wish to use (PACKAGE_CLASSES) or where you want to downloaded files | ||
175 | (<glossterm><link linkend='var-DL_DIR'>DL_DIR</link></glossterm>). | 186 | (<glossterm><link linkend='var-DL_DIR'>DL_DIR</link></glossterm>). |
176 | </para> | 187 | </para> |
177 | </section> | 188 | </section> |
@@ -180,9 +191,10 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
180 | <title><filename>build/conf/bblayers.conf</filename></title> | 191 | <title><filename>build/conf/bblayers.conf</filename></title> |
181 | 192 | ||
182 | <para> | 193 | <para> |
183 | This file defines layers walked by bitbake. If there's no <filename> | 194 | This file defines layers, which is a directory tree, traversed (or walked) by BitBake. |
184 | bblayers.conf</filename> present, it is created from <filename>bblayers.conf.sample | 195 | If <filename>bblayers.conf</filename> |
185 | </filename> when the environment setup script is sourced. | 196 | is not present, it is created from <filename>bblayers.conf.sample</filename> when the environment |
197 | setup script is sourced. | ||
186 | </para> | 198 | </para> |
187 | </section> | 199 | </section> |
188 | 200 | ||
@@ -190,10 +202,12 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
190 | <title><filename class="directory">build/tmp/</filename></title> | 202 | <title><filename class="directory">build/tmp/</filename></title> |
191 | 203 | ||
192 | <para> | 204 | <para> |
193 | This is created by BitBake if it doesn't exist and is where all the Poky output | 205 | This directory receives all the Poky output. |
194 | is placed. To clean Poky and start a build from scratch (other than downloads), | 206 | BitBake creates this directory if it does not exist. |
195 | you can wipe this directory. The <filename class="directory">tmp/ | 207 | To clean Poky and start a build from scratch (other than downloads), |
196 | </filename> directory has some important sub-components detailed below. | 208 | you can remove everything in this directory or get rid of the directory completely. |
209 | The <filename class="directory">tmp/</filename> directory has some important | ||
210 | sub-components detailed below. | ||
197 | </para> | 211 | </para> |
198 | </section> | 212 | </section> |
199 | 213 | ||
@@ -201,24 +215,24 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
201 | <title><filename class="directory">build/tmp/cache/</filename></title> | 215 | <title><filename class="directory">build/tmp/cache/</filename></title> |
202 | 216 | ||
203 | <para> | 217 | <para> |
204 | When BitBake parses the metadata it creates a cache file of the result which can | 218 | When BitBake parses the metadata it creates a cache file of the result that can |
205 | be used when subsequently running commands. These are stored here on | 219 | be used when subsequently running commands. |
206 | a per machine basis. | 220 | These results are stored here on a per-machine basis. |
207 | </para> | 221 | </para> |
208 | </section> | 222 | </section> |
209 | 223 | ||
210 | <section id='structure-build-tmp-deploy'> | 224 | <section id='structure-build-tmp-deploy'> |
211 | <title><filename class="directory">build/tmp/deploy/</filename></title> | 225 | <title><filename class="directory">build/tmp/deploy/</filename></title> |
212 | 226 | ||
213 | <para>Any 'end result' output from Poky is placed under here.</para> | 227 | <para>This directory contains any 'end result' output from Poky.</para> |
214 | </section> | 228 | </section> |
215 | 229 | ||
216 | <section id='structure-build-tmp-deploy-deb'> | 230 | <section id='structure-build-tmp-deploy-deb'> |
217 | <title><filename class="directory">build/tmp/deploy/deb/</filename></title> | 231 | <title><filename class="directory">build/tmp/deploy/deb/</filename></title> |
218 | 232 | ||
219 | <para> | 233 | <para> |
220 | Any .deb packages emitted by Poky are placed here, sorted into feeds for | 234 | This directory receives any .deb packages produced by Poky. |
221 | different architecture types. | 235 | The packages are sorted into feeds for different architecture types. |
222 | </para> | 236 | </para> |
223 | </section> | 237 | </section> |
224 | 238 | ||
@@ -226,8 +240,8 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
226 | <title><filename class="directory">build/tmp/deploy/rpm/</filename></title> | 240 | <title><filename class="directory">build/tmp/deploy/rpm/</filename></title> |
227 | 241 | ||
228 | <para> | 242 | <para> |
229 | Any .rpm packages emitted by Poky are placed here, sorted into feeds for | 243 | This directory receives any .rpm packages produced by Poky. |
230 | different architecture types. | 244 | The packages re sorted into feeds for different architecture types. |
231 | </para> | 245 | </para> |
232 | </section> | 246 | </section> |
233 | 247 | ||
@@ -235,24 +249,25 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
235 | <title><filename class="directory">build/tmp/deploy/images/</filename></title> | 249 | <title><filename class="directory">build/tmp/deploy/images/</filename></title> |
236 | 250 | ||
237 | <para> | 251 | <para> |
238 | Complete filesystem images are placed here. If you want to flash the resulting | 252 | This directory receives complete filesystem images. |
239 | image from a build onto a device, look here for them. | 253 | If you want to flash the resulting image from a build onto a device, look here for the image. |
240 | </para> | 254 | </para> |
241 | </section> | 255 | </section> |
242 | 256 | ||
243 | <section id='structure-build-tmp-deploy-ipk'> | 257 | <section id='structure-build-tmp-deploy-ipk'> |
244 | <title><filename class="directory">build/tmp/deploy/ipk/</filename></title> | 258 | <title><filename class="directory">build/tmp/deploy/ipk/</filename></title> |
245 | 259 | ||
246 | <para>Any resulting .ipk packages emitted by Poky are placed here.</para> | 260 | <para>This directory receives .ipk packages produced by Poky.</para> |
247 | </section> | 261 | </section> |
248 | 262 | ||
249 | <section id='structure-build-tmp-sysroots'> | 263 | <section id='structure-build-tmp-sysroots'> |
250 | <title><filename class="directory">build/tmp/sysroots/</filename></title> | 264 | <title><filename class="directory">build/tmp/sysroots/</filename></title> |
251 | 265 | ||
252 | <para> | 266 | <para> |
253 | Any package needing to share output with other packages does so within sysroots. | 267 | This directory contains shared header files and libraries as well as other shared |
254 | This means it contains any shared header files and any shared libraries amongst | 268 | data. |
255 | other data. It is subdivided by architecture so multiple builds can run within | 269 | Packages that need to share output with other packages do so within this directory. |
270 | The directory is subdivided by architecture so multiple builds can run within | ||
256 | the one build directory. | 271 | the one build directory. |
257 | </para> | 272 | </para> |
258 | </section> | 273 | </section> |
@@ -261,9 +276,11 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
261 | <title><filename class="directory">build/tmp/stamps/</filename></title> | 276 | <title><filename class="directory">build/tmp/stamps/</filename></title> |
262 | 277 | ||
263 | <para> | 278 | <para> |
264 | This is used by BitBake for accounting purposes to keep track of which tasks | 279 | This directory holds information that that BitBake uses for accounting purposes |
265 | have been run and when. It is also subdivided by architecture. The files are | 280 | to track what tasks have run and when they have run. |
266 | empty and the important information is the filenames and timestamps. | 281 | The directory is sub-divided by architecture. |
282 | The files in the directory are empty of data. | ||
283 | However, BitBake uses the filenames and timestamps for tracking purposes. | ||
267 | </para> | 284 | </para> |
268 | </section> | 285 | </section> |
269 | 286 | ||
@@ -271,9 +288,9 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
271 | <title><filename class="directory">build/tmp/log/</filename></title> | 288 | <title><filename class="directory">build/tmp/log/</filename></title> |
272 | 289 | ||
273 | <para> | 290 | <para> |
274 | This contains some general logs if not placing in a package's | 291 | This directory contains general logs that are not otherwise placed using the |
275 | <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm>, such as | 292 | package's <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm>. |
276 | the log output from check_pkg or distro_check tasks. | 293 | Examples of logs are the output from the "check_pkg" or "distro_check" tasks. |
277 | </para> | 294 | </para> |
278 | </section> | 295 | </section> |
279 | 296 | ||
@@ -281,9 +298,8 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
281 | <title><filename class="directory">build/tmp/pkgdata/</filename></title> | 298 | <title><filename class="directory">build/tmp/pkgdata/</filename></title> |
282 | 299 | ||
283 | <para> | 300 | <para> |
284 | This is an intermediate place for saving packaging data, which will be used | 301 | This directory contains intermediate packaging data that is used later in the packaging process. |
285 | in later packaging process. For detail please refer to <link linkend='ref-classes-package'> | 302 | For more information, see <link linkend='ref-classes-package'>package.bbclass</link>. |
286 | package.bbclass</link>. | ||
287 | </para> | 303 | </para> |
288 | </section> | 304 | </section> |
289 | 305 | ||
@@ -291,9 +307,9 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
291 | <title><filename class="directory">build/tmp/pstagelogs/</filename></title> | 307 | <title><filename class="directory">build/tmp/pstagelogs/</filename></title> |
292 | 308 | ||
293 | <para> | 309 | <para> |
294 | This directory contains manifest for task based prebuilt. Each manifest is basically | 310 | This directory contains manifest for task-based pre-built. |
295 | a file list for installed files from a given task, which would be useful for later | 311 | Each manifest is basically a file list for installed files from a given task. |
296 | packaging or cleanup process. | 312 | Manifests are useful for later packaging or cleanup processes. |
297 | </para> | 313 | </para> |
298 | </section> | 314 | </section> |
299 | 315 | ||
@@ -301,62 +317,63 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
301 | <title><filename class="directory">build/tmp/work/</filename></title> | 317 | <title><filename class="directory">build/tmp/work/</filename></title> |
302 | 318 | ||
303 | <para> | 319 | <para> |
304 | This directory contains various subdirectories for each architecture, and each package built by BitBake has its own work directory under the appropriate architecture subdirectory. All tasks are executed from this work directory. As an example, the source for a particular package will be unpacked, patched, configured and compiled all within its own work directory. | 320 | This directory contains architecture-specific work sub-directories for packages built by BitBake. |
321 | All tasks execute from a work directory. | ||
322 | For example, the source for a particular package is unpacked, patched, configured and compiled all | ||
323 | within its own work directory. | ||
305 | </para> | 324 | </para> |
306 | 325 | ||
307 | <para> | 326 | <para> |
308 | It is worth considering the structure of a typical work directory. An | 327 | It is worth considering the structure of a typical work directory. |
309 | example is the linux-rp kernel, version 2.6.20 r7 on the machine spitz | 328 | As an example consider the linux-rp kernel, version 2.6.20 r7 on the machine spitz |
310 | built within Poky. For this package a work directory of <filename | 329 | built within Poky. |
311 | class="directory">tmp/work/spitz-poky-linux-gnueabi/linux-rp-2.6.20-r7/ | 330 | For this package a work directory of |
312 | </filename>, referred to as <glossterm><link linkend='var-WORKDIR'>WORKDIR | 331 | <filename class="directory">tmp/work/spitz-poky-linux-gnueabi/linux-rp-2.6.20-r7/</filename>, |
313 | </link></glossterm>, is created. Within this directory, the source is | 332 | referred to as <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm>, is created. |
314 | unpacked to linux-2.6.20 and then patched by quilt (see <link | 333 | Within this directory, the source is unpacked to linux-2.6.20 and then patched by quilt |
315 | linkend="usingpoky-modifying-packages-quilt">Section 3.5.1</link>). | 334 | (see <link linkend="usingpoky-modifying-packages-quilt">Section 3.5.1</link>). |
316 | Within the <filename class="directory">linux-2.6.20</filename> directory, | 335 | Within the <filename class="directory">linux-2.6.20</filename> directory, |
317 | standard Quilt directories <filename class="directory">linux-2.6.20/patches</filename> | 336 | standard quilt directories <filename class="directory">linux-2.6.20/patches</filename> |
318 | and <filename class="directory">linux-2.6.20/.pc</filename> are created, | 337 | and <filename class="directory">linux-2.6.20/.pc</filename> are created, |
319 | and standard quilt commands can be used. | 338 | and standard quilt commands can be used. |
320 | </para> | 339 | </para> |
321 | 340 | ||
322 | <para> | 341 | <para> |
323 | There are other directories generated within <glossterm><link | 342 | There are other directories generated within WORKDIR. |
324 | linkend='var-WORKDIR'>WORKDIR</link></glossterm>. The most important | 343 | The most important directory is WORKDIR |
325 | is <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm><filename class="directory">/temp/</filename> which has log files for each | 344 | <filename class="directory">/temp/</filename>, which has log files for each |
326 | task (<filename>log.do_*.pid</filename>) and the scripts BitBake runs for | 345 | task (<filename>log.do_*.pid</filename>) and contains the scripts BitBake runs for |
327 | each task (<filename>run.do_*.pid</filename>). The <glossterm><link | 346 | each task (<filename>run.do_*.pid</filename>). |
328 | linkend='var-WORKDIR'>WORKDIR</link></glossterm><filename | 347 | The WORKDIR<filename class="directory">/image/</filename> directory is where "make |
329 | class="directory">/image/</filename> directory is where <command>make | 348 | install" places its output that is then split into sub-packages |
330 | install</command> places its output which is then split into subpackages | 349 | within WORKDIR<filename class="directory">/packages-split/</filename>. |
331 | within <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm> | ||
332 | <filename class="directory">/packages-split/</filename>. | ||
333 | </para> | 350 | </para> |
334 | </section> | 351 | </section> |
335 | </section> | 352 | </section> |
336 | 353 | ||
337 | <section id='structure-meta'> | 354 | <section id='structure-meta'> |
338 | <title><filename class="directory">meta/</filename> - The Metadata</title> | 355 | <title>The Metadata - <filename class="directory">meta/</filename></title> |
339 | 356 | ||
340 | <para> | 357 | <para> |
341 | As mentioned previously, this is the core of Poky. It has several | 358 | As mentioned previously, metadata is the core of Poky. |
342 | important subdivisions: | 359 | Metadata has several important subdivisions: |
343 | </para> | 360 | </para> |
344 | 361 | ||
345 | <section id='structure-meta-classes'> | 362 | <section id='structure-meta-classes'> |
346 | <title><filename class="directory">meta/classes/</filename></title> | 363 | <title><filename class="directory">meta/classes/</filename></title> |
347 | 364 | ||
348 | <para> | 365 | <para> |
349 | Contains the <filename class="extension">*.bbclass</filename> files. Class | 366 | This directory contains the <filename class="extension">*.bbclass</filename> files. |
350 | files are used to abstract common code allowing it to be reused by multiple | 367 | Class files are used to abstract common code so it can be reused by multiple |
351 | packages. The <filename>base.bbclass</filename> file is inherited by every | 368 | packages. |
352 | package. Examples of other important classes are | 369 | Every package inherits the <filename>base.bbclass</filename> file. |
353 | <filename>autotools.bbclass</filename> that in theory allows any | 370 | Examples of other important classes are <filename>autotools.bbclass</filename>, which |
354 | Autotool-enabled package to work with Poky with minimal effort, or | 371 | in theory allows any Autotool-enabled package to work with Poky with minimal effort. |
355 | <filename>kernel.bbclass</filename> that contains common code and functions | 372 | Another example is <filename>kernel.bbclass</filename> that contains common code and functions |
356 | for working with the linux kernel. Functions like image generation or | 373 | for working with the Linux kernel. |
357 | packaging also have their specific class files (<filename>image.bbclass | 374 | Functions like image generation or packaging also have their specific class files |
358 | </filename>, <filename>rootfs_*.bbclass</filename> and | 375 | such as <filename>image.bbclass</filename>, <filename>rootfs_*.bbclass</filename> and |
359 | <filename>package*.bbclass</filename>). | 376 | <filename>package*.bbclass</filename>. |
360 | </para> | 377 | </para> |
361 | </section> | 378 | </section> |
362 | 379 | ||
@@ -364,13 +381,14 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
364 | <title><filename class="directory">meta/conf/</filename></title> | 381 | <title><filename class="directory">meta/conf/</filename></title> |
365 | 382 | ||
366 | <para> | 383 | <para> |
367 | This is the core set of configuration files which start from | 384 | This directory contains the core set of configuration files that start from |
368 | <filename>bitbake.conf</filename> and from which all other configuration | 385 | <filename>bitbake.conf</filename> and from which all other configuration |
369 | files are included (see the includes at the end of the file, even | 386 | files are included. |
370 | <filename>local.conf</filename> is loaded from there!). While | 387 | See the includes at the end of the file and you will note that even |
371 | <filename>bitbake.conf</filename> sets up the defaults, these can often be | 388 | <filename>local.conf</filename> is loaded from there! |
372 | overridden by user (<filename>local.conf</filename>), machine or | 389 | While <filename>bitbake.conf</filename> sets up the defaults, you can often override |
373 | distribution configuration files. | 390 | these by using the (<filename>local.conf</filename>) file, machine file or |
391 | the distribution configuration file. | ||
374 | </para> | 392 | </para> |
375 | </section> | 393 | </section> |
376 | 394 | ||
@@ -378,10 +396,11 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
378 | <title><filename class="directory">meta/conf/machine/</filename></title> | 396 | <title><filename class="directory">meta/conf/machine/</filename></title> |
379 | 397 | ||
380 | <para> | 398 | <para> |
381 | Contains all the machine configuration files. If you set MACHINE="spitz", the | 399 | This directory contains all the machine configuration files. |
382 | end result is Poky looking for a <filename>spitz.conf</filename> file in this directory. The includes | 400 | If you set MACHINE="spitz", Poky looks for a <filename>spitz.conf</filename> file in this |
383 | directory contains various data common to multiple machines. If you want to add | 401 | directory. |
384 | support for a new machine to Poky, this is the directory to look in. | 402 | The includes directory contains various data common to multiple machines. |
403 | If you want to add support for a new machine to Poky, look in this directory. | ||
385 | </para> | 404 | </para> |
386 | </section> | 405 | </section> |
387 | 406 | ||
@@ -389,12 +408,12 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
389 | <title><filename class="directory">meta/conf/distro/</filename></title> | 408 | <title><filename class="directory">meta/conf/distro/</filename></title> |
390 | 409 | ||
391 | <para> | 410 | <para> |
392 | Any distribution specific configuration is controlled from here. OpenEmbedded | 411 | Any distribution-specific configuration is controlled from this directory. |
393 | supports multiple distributions of which Poky is one. Poky only contains the | 412 | Poky only contains the Poky distribution so <filename>poky.conf</filename> |
394 | Poky distribution so poky.conf is the main file here. This includes the | 413 | is the main file here. |
395 | versions and SRCDATES for applications which are configured here. An example of | 414 | This directory includes the versions and SRCDATES for applications that are configured here. |
396 | an alternative configuration is poky-bleeding.conf although this mainly inherits | 415 | An example of an alternative configuration is <filename>poky-bleeding.conf</filename> |
397 | its configuration from Poky itself. | 416 | although this file mainly inherits its configuration from Poky itself. |
398 | </para> | 417 | </para> |
399 | </section> | 418 | </section> |
400 | 419 | ||
@@ -402,8 +421,8 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
402 | <title><filename class="directory">meta/recipes-bsp/</filename></title> | 421 | <title><filename class="directory">meta/recipes-bsp/</filename></title> |
403 | 422 | ||
404 | <para> | 423 | <para> |
405 | Anything linking to specific hardware or hardware configuration information | 424 | This directory contains anything linking to specific hardware or hardware configuration information |
406 | are placed here, such as uboot, grub, etc. | 425 | such as "uboot" and "grub". |
407 | </para> | 426 | </para> |
408 | </section> | 427 | </section> |
409 | 428 | ||
@@ -411,7 +430,7 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
411 | <title><filename class="directory">meta/recipes-connectivity/</filename></title> | 430 | <title><filename class="directory">meta/recipes-connectivity/</filename></title> |
412 | 431 | ||
413 | <para> | 432 | <para> |
414 | Libraries and applications related to communication with other devices | 433 | This directory contains libraries and applications related to communication with other devices. |
415 | </para> | 434 | </para> |
416 | </section> | 435 | </section> |
417 | 436 | ||
@@ -419,7 +438,8 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
419 | <title><filename class="directory">meta/recipes-core/</filename></title> | 438 | <title><filename class="directory">meta/recipes-core/</filename></title> |
420 | 439 | ||
421 | <para> | 440 | <para> |
422 | What's needed to build a basic working Linux image including commonly used dependencies | 441 | This directory contains what is needed to build a basic working Linux image |
442 | including commonly used dependencies. | ||
423 | </para> | 443 | </para> |
424 | </section> | 444 | </section> |
425 | 445 | ||
@@ -427,7 +447,8 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
427 | <title><filename class="directory">meta/recipes-devtools/</filename></title> | 447 | <title><filename class="directory">meta/recipes-devtools/</filename></title> |
428 | 448 | ||
429 | <para> | 449 | <para> |
430 | Tools primarily used by the build system (but can also be used on targets) | 450 | This directory contains tools that are primarily used by the build system. |
451 | The tools, however, can also be used on targets. | ||
431 | </para> | 452 | </para> |
432 | </section> | 453 | </section> |
433 | 454 | ||
@@ -435,8 +456,10 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
435 | <title><filename class="directory">meta/recipes-extended/</filename></title> | 456 | <title><filename class="directory">meta/recipes-extended/</filename></title> |
436 | 457 | ||
437 | <para> | 458 | <para> |
438 | Applications which whilst not essential add features compared to the alternatives in | 459 | This directory contains non-essential applications that add features compared to the |
439 | core. May be needed for full tool functionality or LSB compliance. | 460 | alternatives in core. |
461 | You might need this directory for full tool functionality or for Linux Standard Base (LSB) | ||
462 | compliance. | ||
440 | </para> | 463 | </para> |
441 | </section> | 464 | </section> |
442 | 465 | ||
@@ -444,7 +467,7 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
444 | <title><filename class="directory">meta/recipes-gnome/</filename></title> | 467 | <title><filename class="directory">meta/recipes-gnome/</filename></title> |
445 | 468 | ||
446 | <para> | 469 | <para> |
447 | All things related to the GTK+ application framework | 470 | This directory contains all things related to the GTK+ application framework. |
448 | </para> | 471 | </para> |
449 | </section> | 472 | </section> |
450 | 473 | ||
@@ -452,7 +475,7 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
452 | <title><filename class="directory">meta/recipes-graphics/</filename></title> | 475 | <title><filename class="directory">meta/recipes-graphics/</filename></title> |
453 | 476 | ||
454 | <para> | 477 | <para> |
455 | X and other graphically related system libraries | 478 | This directory contains X and other graphically related system libraries |
456 | </para> | 479 | </para> |
457 | </section> | 480 | </section> |
458 | 481 | ||
@@ -460,7 +483,8 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
460 | <title><filename class="directory">meta/recipes-kernel/</filename></title> | 483 | <title><filename class="directory">meta/recipes-kernel/</filename></title> |
461 | 484 | ||
462 | <para> | 485 | <para> |
463 | The kernel and generic applications/libraries with strong kernel dependencies | 486 | This directory contains the kernel and generic applications and libraries that |
487 | have strong kernel dependencies. | ||
464 | </para> | 488 | </para> |
465 | </section> | 489 | </section> |
466 | 490 | ||
@@ -468,7 +492,7 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
468 | <title><filename class="directory">meta/recipes-multimedia/</filename></title> | 492 | <title><filename class="directory">meta/recipes-multimedia/</filename></title> |
469 | 493 | ||
470 | <para> | 494 | <para> |
471 | Codecs and support utilties for audio, images and video | 495 | This directory contains codecs and support utilities for audio, images and video. |
472 | </para> | 496 | </para> |
473 | </section> | 497 | </section> |
474 | 498 | ||
@@ -476,7 +500,7 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
476 | <title><filename class="directory">meta/recipes-qt/</filename></title> | 500 | <title><filename class="directory">meta/recipes-qt/</filename></title> |
477 | 501 | ||
478 | <para> | 502 | <para> |
479 | All things related to the QT application framework | 503 | This directory contains all things related to the QT application framework. |
480 | </para> | 504 | </para> |
481 | </section> | 505 | </section> |
482 | 506 | ||
@@ -484,7 +508,8 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
484 | <title><filename class="directory">meta/recipes-sato/</filename></title> | 508 | <title><filename class="directory">meta/recipes-sato/</filename></title> |
485 | 509 | ||
486 | <para> | 510 | <para> |
487 | The Sato demo/reference UI/UX, its associated apps and configuration | 511 | This directory contains the Sato demo/reference UI/UX and its associated applications |
512 | and configuration data. | ||
488 | </para> | 513 | </para> |
489 | </section> | 514 | </section> |
490 | 515 | ||
@@ -492,9 +517,10 @@ source POKY_SRC/poky-init-build-env [BUILDDIR] | |||
492 | <title><filename class="directory">meta/site/</filename></title> | 517 | <title><filename class="directory">meta/site/</filename></title> |
493 | 518 | ||
494 | <para> | 519 | <para> |
495 | Certain autoconf test results cannot be determined when cross compiling since it | 520 | This directory contains a list of cached results for various architectures. |
496 | can't run tests on a live system. This directory therefore contains a list of | 521 | Because certain "autoconf" test results cannot be determined when cross-compiling due to |
497 | cached results for various architectures which is passed to autoconf. | 522 | the tests not able to run on a live system, the information in this directory is |
523 | passed to "autoconf" for the various architectures. | ||
498 | </para> | 524 | </para> |
499 | </section> | 525 | </section> |
500 | </section> | 526 | </section> |