diff options
author | Scott Rifenbark <scott.m.rifenbark@intel.com> | 2011-09-02 11:54:20 -0700 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-09-02 23:38:52 +0100 |
commit | 99cb233e0c8058c9a406e18fedae70b0f60e3864 (patch) | |
tree | 46d8754ec8d2d0c96a963c314d68819ec1387d3b | |
parent | ce0456d95d9859477429a1208433245ae8724fd7 (diff) | |
download | poky-99cb233e0c8058c9a406e18fedae70b0f60e3864.tar.gz |
YOCTO #1088: documentation - Added text to partially address package bug
This bug was filed by Gary Thomas and was requesting more information
on the "hows" and "whys" of setting up your own package repositories.
At this point, I have added information to help the user understand
build performance issues when choosing between the RPM and IPKG packaging
systems. Likely, there is more that needs to be added to fully address
this bug.
For now, I added explanations in the packaging class and glossary areas
of the YP reference manual, a new paragraph in the YP QS just prior to
firing off a build, and a new bit of information in the configuring
PMS in the ADT Manual.
(From yocto-docs rev: d0025f862cb85ca741787b4737dca286e3ebfb45)
Signed-off-by: Scott Rifenbark <scott.m.rifenbark@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | documentation/adt-manual/adt-package.xml | 7 | ||||
-rw-r--r-- | documentation/poky-ref-manual/ref-classes.xml | 50 | ||||
-rw-r--r-- | documentation/poky-ref-manual/ref-variables.xml | 14 | ||||
-rw-r--r-- | documentation/yocto-project-qs/yocto-project-qs.xml | 16 |
4 files changed, 81 insertions, 6 deletions
diff --git a/documentation/adt-manual/adt-package.xml b/documentation/adt-manual/adt-package.xml index f7b236f8d5..c035c2d011 100644 --- a/documentation/adt-manual/adt-package.xml +++ b/documentation/adt-manual/adt-package.xml | |||
@@ -52,6 +52,13 @@ | |||
52 | See the configuration file for details. | 52 | See the configuration file for details. |
53 | </para> | 53 | </para> |
54 | 54 | ||
55 | <note> | ||
56 | For build performance information related to the PMS, see | ||
57 | <ulink url='http://www.yoctoproject.org/docs/1.1/poky-ref-manual/poky-ref-manual.html#ref-classes-package'>Packaging - <filename>package*.bbclass</filename></ulink> | ||
58 | in <ulink url='http://www.yoctoproject.org/docs/1.1/poky-ref-manual/poky-ref-manual.html'> | ||
59 | The Yocto Project Reference Manual</ulink>. | ||
60 | </note> | ||
61 | |||
55 | <para> | 62 | <para> |
56 | As an example, consider a scenario where you are using OPKG and you want to add | 63 | As an example, consider a scenario where you are using OPKG and you want to add |
57 | the <filename>libglade</filename> package to the target sysroot. | 64 | the <filename>libglade</filename> package to the target sysroot. |
diff --git a/documentation/poky-ref-manual/ref-classes.xml b/documentation/poky-ref-manual/ref-classes.xml index cf396800df..93e9ea8d43 100644 --- a/documentation/poky-ref-manual/ref-classes.xml +++ b/documentation/poky-ref-manual/ref-classes.xml | |||
@@ -265,17 +265,59 @@ | |||
265 | The packaging classes add support for generating packages from a build's | 265 | The packaging classes add support for generating packages from a build's |
266 | output. | 266 | output. |
267 | The core generic functionality is in <filename>package.bbclass</filename>. | 267 | The core generic functionality is in <filename>package.bbclass</filename>. |
268 | The code specific | 268 | The code specific to particular package types is contained in various sub-classes such as |
269 | to particular package types is contained in various sub-classes such as | ||
270 | <filename>package_deb.bbclass</filename>, <filename>package_ipk.bbclass</filename>, | 269 | <filename>package_deb.bbclass</filename>, <filename>package_ipk.bbclass</filename>, |
271 | and <filename>package_rpm.bbclass</filename>. | 270 | and <filename>package_rpm.bbclass</filename>. |
272 | Most users will want one or more of these classes. | 271 | Most users will want one or more of these classes. |
272 | </para> | ||
273 | |||
274 | <para> | ||
273 | You can control the list of resulting package formats by using the | 275 | You can control the list of resulting package formats by using the |
274 | <filename><link linkend='var-PACKAGE_CLASSES'>PACKAGE_CLASSES</link></filename> | 276 | <filename><link linkend='var-PACKAGE_CLASSES'>PACKAGE_CLASSES</link></filename> |
275 | variable. | 277 | variable defined in the <filename>local.conf</filename> configuration file |
276 | The first class listed in this variable is be used for image generation. | 278 | found in the Yocto Project file's <filename>conf</filename> directory. |
279 | When defining the variable, you can specify one or more package types. | ||
277 | Since images are generated from packages, a packaging class is | 280 | Since images are generated from packages, a packaging class is |
278 | needed to enable image generation. | 281 | needed to enable image generation. |
282 | The first class listed in this variable is used for image generation. | ||
283 | </para> | ||
284 | |||
285 | <para> | ||
286 | The package class you choose can affect build-time performance and has space | ||
287 | ramifications. | ||
288 | In general, building a package with RPM takes about thirty percent more time as | ||
289 | compared to using IPK to build the same or similar package. | ||
290 | This comparison takes into account a complete build of the package with all | ||
291 | dependencies previously built. | ||
292 | The reason for this discrepancy is because the RPM package manager creates and | ||
293 | processes more metadata than the IPK package manager. | ||
294 | Consequently, you might consider setting <filename>PACKAGE_CLASSES</filename> | ||
295 | to "package_ipk" if you are building smaller systems. | ||
296 | </para> | ||
297 | |||
298 | <para> | ||
299 | Keep in mind, however, that RPM starts to provide more abilities than IPK due to | ||
300 | the fact that it processes more metadata. | ||
301 | For example, this information includes individual file types, file checksum generation | ||
302 | and evaluation on install, sparse file support, conflict detection and resolution | ||
303 | for multilib systems, ACID style upgrade, and repackaging abilities for rollbacks. | ||
304 | </para> | ||
305 | |||
306 | <para> | ||
307 | Another consideration for packages built using the RPM package manager is space. | ||
308 | For smaller systems, the extra space used for the Berkley Database and the amount | ||
309 | of metadata can affect your ability to do on-device upgrades. | ||
310 | </para> | ||
311 | |||
312 | <para> | ||
313 | You can find additional information on the effects of the package class at these | ||
314 | two Yocto Project mailing list links: | ||
315 | <itemizedlist> | ||
316 | <listitem><para><ulink url='https://lists.yoctoproject.org/pipermail/poky/2011-May/006362.html'> | ||
317 | https://lists.yoctoproject.org/pipermail/poky/2011-May/006362.html</ulink></para></listitem> | ||
318 | <listitem><para><ulink url='https://lists.yoctoproject.org/pipermail/poky/2011-May/006363.html'> | ||
319 | https://lists.yoctoproject.org/pipermail/poky/2011-May/006363.html</ulink></para></listitem> | ||
320 | </itemizedlist> | ||
279 | </para> | 321 | </para> |
280 | </section> | 322 | </section> |
281 | 323 | ||
diff --git a/documentation/poky-ref-manual/ref-variables.xml b/documentation/poky-ref-manual/ref-variables.xml index 7f51fc9885..0bde65915c 100644 --- a/documentation/poky-ref-manual/ref-variables.xml +++ b/documentation/poky-ref-manual/ref-variables.xml | |||
@@ -679,7 +679,19 @@ | |||
679 | 679 | ||
680 | <glossentry id='var-PACKAGE_CLASSES'><glossterm>PACKAGE_CLASSES</glossterm> | 680 | <glossentry id='var-PACKAGE_CLASSES'><glossterm>PACKAGE_CLASSES</glossterm> |
681 | <glossdef> | 681 | <glossdef> |
682 | <para>Specifies the list of resulting package formats.</para> | 682 | <para>This variable, which is set in the <filename>local.conf</filename> configuration |
683 | file found in the Yocto Project file's <filename>conf</filename> directory, | ||
684 | specifies the package manager to use when packaging data. | ||
685 | You can provide one or more arguments for the variable with the first | ||
686 | argument being the package manager used to create images: | ||
687 | <literallayout class='monospaced'> | ||
688 | PACKAGE_CLASSES ?= "package_rpm package_deb package_ipk" | ||
689 | </literallayout> | ||
690 | For information on build performance effects as a result of the | ||
691 | package manager use, see | ||
692 | <link linkend='ref-classes-package'>Packaging - <filename>package*.bbclass</filename></link> | ||
693 | in this manual. | ||
694 | </para> | ||
683 | </glossdef> | 695 | </glossdef> |
684 | </glossentry> | 696 | </glossentry> |
685 | 697 | ||
diff --git a/documentation/yocto-project-qs/yocto-project-qs.xml b/documentation/yocto-project-qs/yocto-project-qs.xml index 62280b619f..c95e1a02ab 100644 --- a/documentation/yocto-project-qs/yocto-project-qs.xml +++ b/documentation/yocto-project-qs/yocto-project-qs.xml | |||
@@ -330,7 +330,8 @@ | |||
330 | <filename>conf/local.conf</filename> file.</para></listitem> | 330 | <filename>conf/local.conf</filename> file.</para></listitem> |
331 | </itemizedlist> | 331 | </itemizedlist> |
332 | <para> | 332 | <para> |
333 | Take some time to examine your <filename>conf/local.conf</filename> file. | 333 | Take some time to examine your <filename>conf/local.conf</filename> file found in the |
334 | Yocto Project file's <filename>conf</filename>. | ||
334 | The defaults should work fine. | 335 | The defaults should work fine. |
335 | However, if you have a multi-core CPU you might want to set the variable | 336 | However, if you have a multi-core CPU you might want to set the variable |
336 | BB_NUMBER_THREADS equal to twice the number of processor cores your system has. | 337 | BB_NUMBER_THREADS equal to twice the number of processor cores your system has. |
@@ -338,6 +339,19 @@ | |||
338 | Setting these variables can significantly shorten your build time. | 339 | Setting these variables can significantly shorten your build time. |
339 | By default, these variables are commented out. | 340 | By default, these variables are commented out. |
340 | </para> | 341 | </para> |
342 | |||
343 | <para> | ||
344 | Another consideration before you build is the package manager used when creating | ||
345 | the image. | ||
346 | By default, the Yocto Project build system uses the RPM package manager. | ||
347 | You can control this configuration by using the | ||
348 | <filename><ulink url='http://www.yoctoproject.org/docs/1.1/poky-ref-manual/poky-ref-manual.html#var-PACKAGE_CLASSES'>PACKAGE_CLASSES</ulink></filename> variable. | ||
349 | For additional package manager selection information, see | ||
350 | <ulink url='http://www.yoctoproject.org/docs/1.1/poky-ref-manual/poky-ref-manual.html#ref-classes-package'>Packaging - <filename>package*.bbclass</filename></ulink> in | ||
351 | <ulink url='http://www.yoctoproject.org/docs/1.1/poky-ref-manual/poky-ref-manual.html'> | ||
352 | The Yocto Project Reference Manual</ulink>. | ||
353 | </para> | ||
354 | |||
341 | <para> | 355 | <para> |
342 | Continue with the following command to build an OS image for the target, which is | 356 | Continue with the following command to build an OS image for the target, which is |
343 | <filename>core-image-sato</filename> in this example. | 357 | <filename>core-image-sato</filename> in this example. |