diff options
Diffstat (limited to 'documentation/poky-ref-manual')
-rw-r--r-- | documentation/poky-ref-manual/extendpoky.xml | 773 |
1 files changed, 389 insertions, 384 deletions
diff --git a/documentation/poky-ref-manual/extendpoky.xml b/documentation/poky-ref-manual/extendpoky.xml index 763670e17c..4fc30534ba 100644 --- a/documentation/poky-ref-manual/extendpoky.xml +++ b/documentation/poky-ref-manual/extendpoky.xml | |||
@@ -109,6 +109,7 @@ inherit autotools gettext | |||
109 | </para> | 109 | </para> |
110 | 110 | ||
111 | </section> | 111 | </section> |
112 | |||
112 | <section id='usingpoky-extend-addpkg-makefile'> | 113 | <section id='usingpoky-extend-addpkg-makefile'> |
113 | <title>Makefile-Based Package</title> | 114 | <title>Makefile-Based Package</title> |
114 | <para> | 115 | <para> |
@@ -160,6 +161,7 @@ do_install () { | |||
160 | </programlisting> | 161 | </programlisting> |
161 | 162 | ||
162 | </section> | 163 | </section> |
164 | |||
163 | <section id='usingpoky-extend-addpkg-files'> | 165 | <section id='usingpoky-extend-addpkg-files'> |
164 | <title>Controlling Package Content</title> | 166 | <title>Controlling Package Content</title> |
165 | <para> | 167 | <para> |
@@ -348,8 +350,7 @@ RRECOMMENDS_task-custom-tools = "\ | |||
348 | </section> | 350 | </section> |
349 | 351 | ||
350 | <section id='usingpoky-extend-customimage-imagefeatures'> | 352 | <section id='usingpoky-extend-customimage-imagefeatures'> |
351 | <title>Customising Images Using Custom <glossterm> | 353 | <title>Customising Images Using Custom IMAGE_FEATURES</title> |
352 | <link linkend='var-IMAGE_FEATURES'>IMAGE_FEATURES</link></glossterm></title> | ||
353 | <para> | 354 | <para> |
354 | Ultimately users might want to add extra image "features" as used by Poky with the | 355 | Ultimately users might want to add extra image "features" as used by Poky with the |
355 | <glossterm><link linkend='var-IMAGE_FEATURES'>IMAGE_FEATURES</link></glossterm> | 356 | <glossterm><link linkend='var-IMAGE_FEATURES'>IMAGE_FEATURES</link></glossterm> |
@@ -401,107 +402,108 @@ DISTRO_EXTRA_RDEPENDS += "strace" | |||
401 | dependencies - it only rebuilds the specified package. | 402 | dependencies - it only rebuilds the specified package. |
402 | </para> | 403 | </para> |
403 | <programlisting> | 404 | <programlisting> |
404 | bitbake -c clean task-boot task-base task-poky | 405 | $ bitbake -c clean task-boot task-base task-poky |
405 | bitbake poky-image-sato | 406 | $ bitbake poky-image-sato |
406 | </programlisting> | 407 | </programlisting> |
407 | </section> | 408 | </section> |
408 | 409 | ||
409 | </section> | 410 | </section> |
410 | 411 | ||
411 | <section id="platdev-newmachine"> | 412 | <section id="platdev-newmachine"> |
412 | <title>Porting Poky to a New Machine</title> | 413 | <title>Porting Poky to a New Machine</title> |
413 | <para> | ||
414 | Adding a new machine to Poky is a straightforward process. | ||
415 | This section provides information that gives you an idea of the changes you must make. | ||
416 | The information covers adding machines similar to those Poky already supports. | ||
417 | Although well within the capabilities of Poky, adding a totally new architecture might require | ||
418 | changes to <filename>gcc/glibc</filename> and to the site information. | ||
419 | Consequently, the information is beyond the scope of this manual. | ||
420 | </para> | ||
421 | |||
422 | <section id="platdev-newmachine-conffile"> | ||
423 | <title>Adding the Machine Configuration File</title> | ||
424 | <para> | ||
425 | To add a machine configuration you need to add a <filename>.conf</filename> file | ||
426 | with details of the device being added to <filename>conf/machine/</filename>. | ||
427 | The name of the file determines the name Poky uses to reference the new machine. | ||
428 | </para> | ||
429 | <para> | 414 | <para> |
430 | The most important variables to set in this file are <glossterm> | 415 | Adding a new machine to Poky is a straightforward process. |
431 | <link linkend='var-TARGET_ARCH'>TARGET_ARCH</link></glossterm> | 416 | This section provides information that gives you an idea of the changes you must make. |
432 | (e.g. "arm"), <glossterm><link linkend='var-PREFERRED_PROVIDER'> | 417 | The information covers adding machines similar to those Poky already supports. |
433 | PREFERRED_PROVIDER</link></glossterm>_virtual/kernel (see below) and | 418 | Although well within the capabilities of Poky, adding a totally new architecture might require |
434 | <glossterm><link linkend='var-MACHINE_FEATURES'>MACHINE_FEATURES | 419 | changes to <filename>gcc/glibc</filename> and to the site information. |
435 | </link></glossterm> (e.g. "kernel26 apm screen wifi"). | 420 | Consequently, the information is beyond the scope of this manual. |
436 | You might also need other variables like <glossterm><link linkend='var-SERIAL_CONSOLE'>SERIAL_CONSOLE | ||
437 | </link></glossterm> (e.g. "115200 ttyS0"), <glossterm> | ||
438 | <link linkend='var-KERNEL_IMAGETYPE'>KERNEL_IMAGETYPE</link> | ||
439 | </glossterm> (e.g. "zImage") and <glossterm><link linkend='var-IMAGE_FSTYPES'> | ||
440 | IMAGE_FSTYPES</link></glossterm> (e.g. "tar.gz jffs2"). | ||
441 | You can find full details on these variables in the reference section. | ||
442 | You can leverage many existing machine <filename>.conf</filename> files from | ||
443 | <filename>meta/conf/machine/</filename>. | ||
444 | </para> | 421 | </para> |
445 | </section> | ||
446 | 422 | ||
447 | <section id="platdev-newmachine-kernel"> | 423 | <section id="platdev-newmachine-conffile"> |
448 | <title>Adding a Kernel for the Machine</title> | 424 | <title>Adding the Machine Configuration File</title> |
449 | <para> | 425 | <para> |
450 | Poky needs to be able to build a kernel for the machine. | 426 | To add a machine configuration you need to add a <filename>.conf</filename> file |
451 | You need to either create a new kernel recipe for this machine, or extend an | 427 | with details of the device being added to <filename>conf/machine/</filename>. |
452 | existing recipe. | 428 | The name of the file determines the name Poky uses to reference the new machine. |
453 | You can find several kernel examples in the <filename>meta/recipes-kernel/linux</filename> | 429 | </para> |
454 | directory that can be used as references. | 430 | <para> |
455 | </para> | 431 | The most important variables to set in this file are <glossterm> |
456 | <para> | 432 | <link linkend='var-TARGET_ARCH'>TARGET_ARCH</link></glossterm> |
457 | If you are creating a new recipe, the "normal" recipe-writing rules apply for setting | 433 | (e.g. "arm"), <glossterm><link linkend='var-PREFERRED_PROVIDER'> |
458 | up a <glossterm><link linkend='var-SRC_URI'>SRC_URI</link></glossterm>. | 434 | PREFERRED_PROVIDER</link></glossterm>_virtual/kernel (see below) and |
459 | This means specifying any necessary patches and setting <glossterm> | 435 | <glossterm><link linkend='var-MACHINE_FEATURES'>MACHINE_FEATURES |
460 | <link linkend='var-S'>S</link></glossterm> to point at the source code. | 436 | </link></glossterm> (e.g. "kernel26 apm screen wifi"). |
461 | You need to create a "configure" task that configures the unpacked kernel with a defconfig. | 437 | You might also need other variables like <glossterm><link linkend='var-SERIAL_CONSOLE'>SERIAL_CONSOLE |
462 | You can do this by using a <filename>make defconfig</filename> command or | 438 | </link></glossterm> (e.g. "115200 ttyS0"), <glossterm> |
463 | more commonly by copying in a suitable defconfig and and then running | 439 | <link linkend='var-KERNEL_IMAGETYPE'>KERNEL_IMAGETYPE</link> |
464 | <filename>make oldconfig</filename>. | 440 | </glossterm> (e.g. "zImage") and <glossterm><link linkend='var-IMAGE_FSTYPES'> |
465 | By making use of "inherit kernel" and potentially some of the | 441 | IMAGE_FSTYPES</link></glossterm> (e.g. "tar.gz jffs2"). |
466 | <filename>linux-*.inc</filename> files, most other functionality is | 442 | You can find full details on these variables in the reference section. |
467 | centralized and the the defaults of the class normally work well. | 443 | You can leverage many existing machine <filename>.conf</filename> files from |
468 | </para> | 444 | <filename>meta/conf/machine/</filename>. |
469 | <para> | 445 | </para> |
470 | If you are extending an existing kernel, it is usually a matter of adding a | 446 | </section> |
471 | suitable <filename>defconfig</filename> file. | 447 | |
472 | The file needs to be added into a location similar to <filename>defconfig</filename> files | 448 | <section id="platdev-newmachine-kernel"> |
473 | used for other machines in a given kernel. | 449 | <title>Adding a Kernel for the Machine</title> |
474 | A possible way to do this is by listing the file in the | 450 | <para> |
475 | <glossterm><link linkend='var-SRC_URI'>SRC_URI</link></glossterm> | 451 | Poky needs to be able to build a kernel for the machine. |
476 | and adding the machine to the expression in | 452 | You need to either create a new kernel recipe for this machine, or extend an |
477 | <glossterm><link linkend='var-COMPATIBLE_MACHINE'>COMPATIBLE_MACHINE</link></glossterm>: | 453 | existing recipe. |
478 | </para> | 454 | You can find several kernel examples in the <filename>meta/recipes-kernel/linux</filename> |
479 | <programlisting> | 455 | directory that can be used as references. |
456 | </para> | ||
457 | <para> | ||
458 | If you are creating a new recipe, the "normal" recipe-writing rules apply for setting | ||
459 | up a <glossterm><link linkend='var-SRC_URI'>SRC_URI</link></glossterm>. | ||
460 | This means specifying any necessary patches and setting <glossterm> | ||
461 | <link linkend='var-S'>S</link></glossterm> to point at the source code. | ||
462 | You need to create a "configure" task that configures the unpacked kernel with a defconfig. | ||
463 | You can do this by using a <filename>make defconfig</filename> command or | ||
464 | more commonly by copying in a suitable defconfig and and then running | ||
465 | <filename>make oldconfig</filename>. | ||
466 | By making use of "inherit kernel" and potentially some of the | ||
467 | <filename>linux-*.inc</filename> files, most other functionality is | ||
468 | centralized and the the defaults of the class normally work well. | ||
469 | </para> | ||
470 | <para> | ||
471 | If you are extending an existing kernel, it is usually a matter of adding a | ||
472 | suitable <filename>defconfig</filename> file. | ||
473 | The file needs to be added into a location similar to <filename>defconfig</filename> files | ||
474 | used for other machines in a given kernel. | ||
475 | A possible way to do this is by listing the file in the | ||
476 | <glossterm><link linkend='var-SRC_URI'>SRC_URI</link></glossterm> | ||
477 | and adding the machine to the expression in | ||
478 | <glossterm><link linkend='var-COMPATIBLE_MACHINE'>COMPATIBLE_MACHINE</link></glossterm>: | ||
479 | </para> | ||
480 | <programlisting> | ||
480 | COMPATIBLE_MACHINE = '(qemux86|qemumips)' | 481 | COMPATIBLE_MACHINE = '(qemux86|qemumips)' |
481 | </programlisting> | 482 | </programlisting> |
482 | </section> | 483 | </section> |
483 | 484 | ||
484 | <section id="platdev-newmachine-formfactor"> | 485 | <section id="platdev-newmachine-formfactor"> |
485 | <title>Adding a Formfactor Configuration File</title> | 486 | <title>Adding a Formfactor Configuration File</title> |
486 | <para> | 487 | <para> |
487 | A formfactor configuration file provides information about the | 488 | A formfactor configuration file provides information about the |
488 | target hardware on which Poky is running, and that Poky cannot | 489 | target hardware on which Poky is running, and that Poky cannot |
489 | obtain from other sources such as the kernel. Some examples of | 490 | obtain from other sources such as the kernel. |
490 | information contained in a formfactor configuration file include | 491 | Some examples of information contained in a formfactor configuration file include |
491 | framebuffer orientation, whether or not the system has a keyboard, | 492 | framebuffer orientation, whether or not the system has a keyboard, |
492 | the positioning of the keyboard in relation to the screen, and | 493 | the positioning of the keyboard in relation to the screen, and |
493 | screen resolution. | 494 | screen resolution. |
494 | </para> | 495 | </para> |
495 | <para> | 496 | <para> |
496 | Sane defaults should be used in most cases, but if customisation is | 497 | Reasonable defaults are used in most cases, but if customization is |
497 | necessary you need to create a <filename>machconfig</filename> file | 498 | necessary you need to create a <filename>machconfig</filename> file |
498 | under <filename>meta/packages/formfactor/files/MACHINENAME/</filename> | 499 | under <filename>meta/packages/formfactor/files/MACHINENAME/</filename>, |
499 | where <literal>MACHINENAME</literal> is the name for which this infomation | 500 | where <literal>MACHINENAME</literal> is the name for which this infomation |
500 | applies. For information about the settings available and the defaults, please see | 501 | applies. |
501 | <filename>meta/packages/formfactor/files/config</filename>. Below is one | 502 | For information about the settings available and the defaults, see |
502 | example for qemuarm: | 503 | <filename>meta/packages/formfactor/files/config</filename>. |
503 | </para> | 504 | Following is an example for qemuarm: |
504 | <programlisting> | 505 | </para> |
506 | <programlisting> | ||
505 | HAVE_TOUCHSCREEN=1 | 507 | HAVE_TOUCHSCREEN=1 |
506 | HAVE_KEYBOARD=1 | 508 | HAVE_KEYBOARD=1 |
507 | 509 | ||
@@ -512,45 +514,44 @@ DISPLAY_ORIENTATION=0 | |||
512 | #DISPLAY_BPP=16 | 514 | #DISPLAY_BPP=16 |
513 | DISPLAY_DPI=150 | 515 | DISPLAY_DPI=150 |
514 | DISPLAY_SUBPIXEL_ORDER=vrgb | 516 | DISPLAY_SUBPIXEL_ORDER=vrgb |
515 | </programlisting> | 517 | </programlisting> |
518 | </section> | ||
516 | </section> | 519 | </section> |
517 | </section> | ||
518 | 520 | ||
519 | <section id='usingpoky-changes'> | 521 | <section id="usingpoky-changes"> |
520 | <title>Making and Maintaining Changes</title> | 522 | <title>Making and Maintaining Changes</title> |
521 | |||
522 | <para> | 523 | <para> |
523 | We recognise that people will want to extend/configure/optimise Poky for | 524 | Because Poky offers extreme configurability and fliexibility, we recognize that people will want |
524 | their specific uses, especially due to the extreme configurability and | 525 | to extend, configure or optimise Poky for their specific uses. |
525 | flexibility Poky offers. To ensure ease of keeping pace with future | 526 | To best keep pace with future Poky changes we recommend you make controlled changes to Poky. |
526 | changes in Poky we recommend making changes to Poky in a controlled way. | ||
527 | </para> | 527 | </para> |
528 | <para> | 528 | <para> |
529 | Poky supports the idea of <link | 529 | Poky supports the idea of <link linkend='usingpoky-changes-layers'>"layers"</link>. |
530 | linkend='usingpoky-changes-layers'>"layers"</link> which when used | 530 | If you use layers properly you can ease future upgrades and allow segregation |
531 | properly can massively ease future upgrades and allow segregation | 531 | between the Poky core and a given developer's changes. |
532 | between the Poky core and a given developer's changes. Some other advice on | 532 | The following section provides more advice on managing changes to Poky. |
533 | managing changes to Poky is also given in the following section. | ||
534 | </para> | 533 | </para> |
535 | 534 | ||
536 | <section id="usingpoky-changes-layers"> | 535 | <section id="usingpoky-changes-layers"> |
537 | <title>Bitbake Layers</title> | 536 | <title>Bitbake Layers</title> |
538 | |||
539 | <para> | 537 | <para> |
540 | Often, people want to extend Poky either through adding packages | 538 | Often, people want to extend Poky either by adding packages |
541 | or overriding files contained within Poky to add their own | 539 | or by overriding files contained within Poky to add their own |
542 | functionality. Bitbake has a powerful mechanism called | 540 | functionality. |
543 | layers which provides a way to handle this extension in a fully | 541 | Bitbake has a powerful mechanism called |
542 | "layers", which provides a way to handle this extension in a fully | ||
544 | supported and non-invasive fashion. | 543 | supported and non-invasive fashion. |
545 | </para> | 544 | </para> |
546 | |||
547 | <para> | 545 | <para> |
548 | The Poky tree includes several additional layers which demonstrate | 546 | The Poky tree includes several additional layers such as meta-emenlow and meta-extras |
549 | this functionality, such as meta-emenlow and meta-extras. | 547 | that demonstrate this functionality. |
550 | The meta-emenlow layer is an example layer enabled by default. The meta-extras | 548 | The meta-emenlow layer is an example layer that by default is enabled. |
551 | repostory is not enabled by default but enabling any layer is as easy as adding | 549 | However, the meta-extras repostory is not enabled by default. |
552 | the layers path to the BBLAYERS variable in your bblayers.conf. this is how | 550 | It is easy though to enable any layer. |
553 | meta-extras are enabled in Poky builds: | 551 | You simply add the layer's path to the |
552 | <glossterm><link linkend='var-BBLAYERS'>BBLAYERS</link></glossterm> variable in your | ||
553 | <filename>bblayers.conf</filename> file. | ||
554 | The following example shows how to enable meta-extras in the Poky build: | ||
554 | </para> | 555 | </para> |
555 | <para> | 556 | <para> |
556 | <literallayout class='monospaced'>LCONF_VERSION = "1" | 557 | <literallayout class='monospaced'>LCONF_VERSION = "1" |
@@ -565,15 +566,14 @@ BBLAYERS = " \ | |||
565 | </para> | 566 | </para> |
566 | 567 | ||
567 | <para> | 568 | <para> |
568 | Bitbake parses the conf/layer.conf of each of the layers in BBLAYERS | 569 | Bitbake parses each <filename>conf/layer.conf</filename> file for each layer in BBLAYERS |
569 | to add the recipes, classes and configuration contained within the layer to Poky. | 570 | and adds the recipes, classes and configuration contained within the layer to Poky. |
570 | To create your own layer, independent of the main Poky repository, | 571 | To create your own layer, independent of the main Poky repository, |
571 | you need only create a directory with a conf/layer.conf file and | 572 | simply create a directory with a <filename>conf/layer.conf</filename> file and |
572 | add the directory to your bblayers.conf. | 573 | add the directory to your <filename>bblayers.conf</filename> file. |
573 | </para> | 574 | </para> |
574 | |||
575 | <para> | 575 | <para> |
576 | The meta-emenlow/conf/layer.conf demonstrates the required syntax: | 576 | The <filename>meta-emenlow/conf/layer.conf</filename> file demonstrates the required syntax: |
577 | <literallayout class='monospaced'># We have a conf and classes directory, add to BBPATH | 577 | <literallayout class='monospaced'># We have a conf and classes directory, add to BBPATH |
578 | BBPATH := "${BBPATH}:${LAYERDIR}" | 578 | BBPATH := "${BBPATH}:${LAYERDIR}" |
579 | 579 | ||
@@ -586,66 +586,74 @@ BBFILE_PATTERN_emenlow := "^${LAYERDIR}/" | |||
586 | BBFILE_PRIORITY_emenlow = "6" | 586 | BBFILE_PRIORITY_emenlow = "6" |
587 | </literallayout> | 587 | </literallayout> |
588 | </para> | 588 | </para> |
589 | |||
590 | <para> | 589 | <para> |
591 | As can be seen, the layers recipes are added to | 590 | In the previous example, the recipes for the layers are added to |
592 | <glossterm> <link linkend='var-BBFILES'>BBFILES</link></glossterm>. The | 591 | <glossterm> <link linkend='var-BBFILES'>BBFILES</link></glossterm>. |
593 | BBFILE_COLLECTIONS variable is then appended to with the | 592 | The <glossterm><link linkend='var-BBFILE_COLLECTIONS'>BBFILE_COLLECTIONS</link></glossterm> |
594 | layer name. The BBFILE_PATTERN variable is immediately expanded | 593 | variable is then appended with the layer name. |
595 | with a regular expression used to match files from BBFILES into | 594 | The <glossterm><link linkend='var-BBFILE_PATTERN'>BBFILE_PATTERN</link></glossterm> variable |
595 | immediately expands with a regular expression used to match files from BBFILES into | ||
596 | a particular layer, in this case by using the base pathname. | 596 | a particular layer, in this case by using the base pathname. |
597 | The BBFILE_PRIORITY variable then assigns different | 597 | The <glossterm><link linkend='var-BBFILE_PRIORITY'>BBFILE_PRIORITY</link></glossterm> variable |
598 | priorities to the files in different layers. This is useful | 598 | then assigns different priorities to the files in different layers. |
599 | in situations where the same package might appear in multiple | 599 | This technique useful in situations where the same package might appear in multiple |
600 | layers and allows you to choose which layer should 'win'. | 600 | layers and allows you to choose what layer should take precedence. |
601 | Note the use of <glossterm><link linkend='var-LAYERDIR'> | 601 | </para> |
602 | LAYERDIR</link></glossterm> with the immediate expansion operator. | 602 | <para> |
603 | <glossterm><link linkend='var-LAYERDIR'>LAYERDIR</link></glossterm> | 603 | Note the use of the <glossterm><link linkend='var-LAYERDIR'>LAYERDIR</link></glossterm> |
604 | expands to the directory of the current layer and | 604 | variable with the immediate expansion operator. |
605 | requires use of the immediate expansion operator so that Bitbake | 605 | The LAYERDIR variable expands to the directory of the current layer and |
606 | does not lazily expand the variable when it's parsing a | 606 | requires the immediate expansion operator so that Bitbake does not wait to expand the variable |
607 | different directory. | 607 | when it's parsing a different directory. |
608 | </para> | 608 | </para> |
609 | 609 | <para> | |
610 | <para> | 610 | Bitbake can locate where other bbclass and configuration files are applied through |
611 | Additional bbclass and configuration files can be locationed by | 611 | the <glossterm><link linkend='var-BBPATH'>BBPATH</link></glossterm> |
612 | bitbake through the addition to the BBPATH | 612 | environment variable. |
613 | environment variable. In this case, the first file with the | 613 | For these cases, Bitake uses the first file with the matching name found in BBPATH. |
614 | matching name found in BBPATH is the one that is used, just | 614 | This is similar to the way the PATH variable is used for binaries. |
615 | like the PATH variable for binaries. It is therefore recommended | 615 | We recommend, therefore, that you use unique bbclass and configuration file names in your |
616 | that you use unique bbclass and configuration file names in your | ||
617 | custom layer. | 616 | custom layer. |
618 | </para> | 617 | </para> |
619 | |||
620 | <para> | 618 | <para> |
621 | The recommended approach for custom layers is to store them in a | 619 | We also recommend the following: |
622 | git repository of the format meta-prvt-XXXX and have this repository | 620 | <itemizedlist> |
623 | cloned alongside the other meta directories in the Poky tree. | 621 | <listitem><para>Store custom layers in a git repository that uses the |
624 | This way you can keep your Poky tree and it's configuration entirely | 622 | meta-prvt-XXXX format.</para></listitem> |
623 | <listitem><para>Clone the repository alongside other meta directories in the Poky | ||
624 | tree.</para></listitem> | ||
625 | </itemizedlist> | ||
626 | Following these recommendations keeps your Poky tree and its configuration entirely | ||
625 | inside POKYBASE. | 627 | inside POKYBASE. |
626 | </para> | 628 | </para> |
627 | </section> | 629 | </section> |
628 | 630 | ||
629 | <section id='usingpoky-changes-commits'> | 631 | <section id="usingpoky-changes-commits"> |
630 | <title>Committing Changes</title> | 632 | <title>Committing Changes</title> |
631 | |||
632 | <para> | 633 | <para> |
633 | Modifications to Poky are often managed under some kind of source | 634 | Modifications to Poky are often managed under some kind of source |
634 | revision control system. The policy for committing to such systems | 635 | revision control system. |
635 | is important as some simple policy can significantly improve | 636 | Because some simple practices can significantly improve usability, policy for committing changes |
636 | usability. The tips below are based on the policy followed for the | 637 | is important. |
637 | Poky core. | 638 | Following are suggestions for committing changes to the Poky core: |
638 | </para> | 639 | </para> |
639 | |||
640 | <para> | 640 | <para> |
641 | It helps to use a consistent style for commit messages when committing | 641 | It helps to use a consistent documentation style when committing changes. |
642 | changes. We've found a style where the first line of a commit message | 642 | We have found the following style works well. |
643 | summarises the change and starts with the name of any package affected | 643 | <itemizedlist> |
644 | work well. Not all changes are to specific packages so the prefix could | 644 | <listitem><para>The first line of the commit summarizes the change and begins with the |
645 | also be a machine name or class name instead. If a change needs a longer | 645 | name of the affected package or packages. |
646 | description this should follow the summary: | 646 | However, not all changes apply to specific packages. |
647 | Consequently, the prefix could also be a machine name or class name for | ||
648 | example.</para></listitem> | ||
649 | <listitem><para>The second part of the commit (if needed) is a longer more detailed | ||
650 | description of the changes. Placing a blank line between the first and second parts | ||
651 | helps with readability.</para></listitem> | ||
652 | </itemizedlist> | ||
653 | </para> | ||
654 | <para> | ||
655 | Following is an example commit: | ||
647 | </para> | 656 | </para> |
648 | |||
649 | <literallayout class='monospaced'> | 657 | <literallayout class='monospaced'> |
650 | bitbake/data.py: Add emit_func() and generate_dependencies() functions | 658 | bitbake/data.py: Add emit_func() and generate_dependencies() functions |
651 | 659 | ||
@@ -657,111 +665,121 @@ BBFILE_PRIORITY_emenlow = "6" | |||
657 | </literallayout> | 665 | </literallayout> |
658 | 666 | ||
659 | <para> | 667 | <para> |
660 | Any commit should be self contained in that it should leave the | 668 | All commits should be self-contained such that they leave the |
661 | metadata in a consistent state, buildable before and after the | 669 | metadata in a consistent state that builds both before and after the |
662 | commit. This helps ensure the autobuilder test results are valid | 670 | commit is made. |
663 | but is good practice regardless. | 671 | Besides being a good policy to follow, this helps ensure the autobuilder test results |
672 | are valid. | ||
664 | </para> | 673 | </para> |
665 | </section> | 674 | </section> |
666 | 675 | ||
667 | <section id='usingpoky-changes-prbump'> | 676 | <section id="usingpoky-changes-prbump"> |
668 | <title>Package Revision Incrementing</title> | 677 | <title>Package Revision Incrementing</title> |
669 | |||
670 | <para> | 678 | <para> |
671 | If a committed change will result in changing the package output | 679 | If a committed change results in changing the package output |
672 | then the value of the <glossterm><link linkend='var-PR'>PR</link> | 680 | then the value of the <glossterm><link linkend='var-PR'>PR</link> |
673 | </glossterm> variable needs to be increased (commonly referred to | 681 | </glossterm> variable needs to be increased ('bumped') as part of that commit. |
674 | as 'bumped') as part of that commit. Only integer values are used | 682 | This means that for new recipes you be sure to add the PR variable and set its initial value |
675 | and <glossterm><link linkend='var-PR'>PR</link></glossterm> = | 683 | equal to "r0". |
676 | "r0" should be added into new recipes as, while this is the | 684 | Not initially defining PR makes makes it easy to miss when you bump a package. |
677 | default value, not having the variable defined in a recipe makes | 685 | Note that you can only use integer values for the PR variable. |
678 | it easy to miss incrementing it when updating the recipe. | 686 | </para> |
679 | When upgrading the version of a package (<glossterm><link | 687 | <para> |
680 | linkend='var-PV'>PV</link></glossterm>), the <glossterm><link | 688 | When upgrading the version of a package the (<glossterm><link |
681 | linkend='var-PR'>PR</link></glossterm> variable should be reset to "r0". | 689 | linkend='var-PV'>PV</link></glossterm>) and PR variables should be reset to "r0". |
682 | </para> | 690 | </para> |
683 | |||
684 | <para> | 691 | <para> |
685 | The aim is that the package version will only ever increase. If | 692 | Usually a package version only increases. |
686 | for some reason <glossterm><link linkend='var-PV'>PV</link></glossterm> | 693 | However, if for some reason PV changes but does not increase, you can increase the |
687 | will change and but not increase, the <glossterm><link | 694 | <glossterm><link linkend='var-PE'>PE</link></glossterm> variable (Package Epoch). |
688 | linkend='var-PE'>PE</link></glossterm> (Package Epoch) can | 695 | The PE variable defaults to '0'. |
689 | be increased (it defaults to '0'). The version numbers aim to | 696 | </para> |
690 | follow the <ulink url='http://www.debian.org/doc/debian-policy/ch-controlfields.html'> | 697 | <para> |
691 | Debian Version Field Policy Guidelines</ulink> which define how | 698 | Version numbering strives to follow the |
692 | versions are compared and hence what "increasing" means. | 699 | <ulink url='http://www.debian.org/doc/debian-policy/ch-controlfields.html'> |
700 | Debian Version Field Policy Guidelines</ulink>. | ||
701 | These guidelines define how versions are compared and what "increasing" a version means. | ||
693 | </para> | 702 | </para> |
694 | |||
695 | <para> | 703 | <para> |
696 | There are two reasons for doing this, the first is to ensure that | 704 | There are two reasons for following these guidelines. |
697 | when a developer updates and rebuilds, they get all the changes to | 705 | First, to ensure that when a developer updates and rebuilds, they get all the changes to |
698 | the repository and don't have to remember to rebuild any sections. | 706 | the repository and don't have to remember to rebuild any sections. |
699 | The second is to ensure that target users are able to upgrade their | 707 | Second, to ensure that target users are able to upgrade their |
700 | devices via their package manager such as with the <command> | 708 | devices using package manager commands such as <filename> |
701 | opkg upgrade</command> commands (or similar for | 709 | opkg upgrade</filename> (or similar commands for dpkg/apt or rpm-based systems). |
702 | dpkg/apt or rpm based systems). The aim is to ensure Poky has | 710 | </para> |
703 | upgradable packages in all cases. | 711 | <para> |
712 | The goal is to ensure Poky has upgradable packages in all cases. | ||
704 | </para> | 713 | </para> |
705 | </section> | 714 | </section> |
706 | <section id='usingpoky-changes-collaborate'> | ||
707 | <title>Using Poky in a Team Environment</title> | ||
708 | 715 | ||
716 | <section id="usingpoky-changes-collaborate"> | ||
717 | <title>Using Poky in a Team Environment</title> | ||
709 | <para> | 718 | <para> |
710 | It may not be immediately clear how Poky can work in a team environment, | 719 | It may not be immediately clear how you can use Poky in a team environment, |
711 | or scale to a large team of developers. The specifics of any situation | 720 | or scale it for a large team of developers. |
712 | will determine the best solution and poky offers immense flexibility in | 721 | The specifics of any situation determine the best solution. |
713 | that aspect but there are some practises that experience has shown to work | 722 | Granted that Poky offers immense flexibility regarding this, practices do exist |
714 | well. | 723 | that experience has shown work well. |
715 | </para> | 724 | </para> |
716 | |||
717 | <para> | 725 | <para> |
718 | The core component of any development effort with Poky is often an | 726 | The core component of any development effort with Poky is often an |
719 | automated build testing framework and image generation process. This | 727 | automated build testing framework and an image generation process. |
720 | can be used to check that the metadata is buildable, highlight when | 728 | You can use these core components to check that the metadata is buildable, |
721 | commits break the builds and provide up to date images allowing people | 729 | highlight when commits break the builds, and provide up-to-date images that |
722 | to test the end result and use them as a base platform for further | 730 | allow people to test the end result and use it as a base platform for further |
723 | development. Experience shows that buildbot is a good fit for this role | 731 | development. |
724 | and that it works well to configure it to make two types of build - | 732 | Experience shows that buildbot is a good fit for this role. |
725 | incremental builds and 'from scratch'/full builds. The incremental builds | 733 | What works well is to configure buildbot to make two types of builds: |
726 | can be tied to a commit hook which triggers them each time a commit is | 734 | incremental and full (from scratch). |
727 | made to the metadata and are a useful acid test of whether a given commit | 735 | See <ulink url='http://autobuilder.pokylinux.org:8010'>poky autobuilder</ulink> |
728 | breaks the build in some serious way. They catch lots of simple errors | 736 | for an example implementation that uses buildbot. |
729 | and whilst they won't catch 100% of failures, the tests are fast so | 737 | </para> |
730 | developers can get feedback on their changes quickly. The full builds | 738 | <para> |
731 | are builds that build everything from the ground up and test everything. | 739 | You can tie incremental builds to a commit hook that triggers the build |
732 | They usually happen at preset times such as at night when the machine | 740 | each time a commit is made to the metadata. |
733 | load isn't high from the incremental builds. | 741 | This practice results in useful acid tests that determine whether a given commit |
734 | <ulink url='http://autobuilder.pokylinux.org:8010'>poky autobuilder</ulink> | 742 | breaks the build in some serious way. |
735 | is an example implementation with buildbot. | 743 | Associating a build to a commit can catch a lot of simple errors. |
736 | </para> | 744 | Furthermore, the tests are fast so developers can get quick feedback on changes. |
737 | 745 | </para> | |
738 | <para> | 746 | <para> |
739 | Most teams have pieces of software undergoing active development. It is of | 747 | Full builds build and test everything from the ground up. |
740 | significant benefit to put these under control of a source control system | 748 | They usually happen at preset times like during the night when the machine |
741 | compatible with Poky such as git or svn. The autobuilder can then be set to | 749 | load is low. |
742 | pull the latest revisions of these packages so the latest commits get tested | 750 | </para> |
743 | by the builds allowing any issues to be highlighted quickly. Poky easily | 751 | <para> |
744 | supports configurations where there is both a stable known good revision | 752 | Most teams have many pieces of software undergoing active development at any given time. |
745 | and a floating revision to test. Poky can also only take changes from specific | 753 | You can derive large benefits by putting these pieces under the control of a source |
746 | source control branches giving another way it can be used to track/test only | 754 | control system that is compatible with Poky (i.e. git or svn). |
747 | specified changes. | 755 | You can then set the autobuilder to pull the latest revisions of the packages |
748 | </para> | 756 | and test the latest commits by the builds. |
749 | <para> | 757 | This practice quickly highlights issues. |
750 | Perhaps the hardest part of setting this up is the policy that surrounds | 758 | Poky easily supports testing configurations that use both a stable known good revision |
751 | the different source control systems, be them software projects or the Poky | 759 | and a floating revision. |
752 | metadata itself. The circumstances will be different in each case but this is | 760 | Poky can also take just the changes from specific source control branches. |
753 | one of Poky's advantages - the system itself doesn't force any particular policy | 761 | This capability allows you to track and test specific changes. |
754 | unlike a lot of build systems, allowing the best policy to be chosen for the | 762 | </para> |
755 | circumstances. | 763 | <para> |
764 | Perhaps the hardest part of setting this up is defining the software project or | ||
765 | Poky metadata policies that surround the different source control systems. | ||
766 | Of course circumstances will be different in each case. | ||
767 | However, this situation reveals one of Poky's advantages - the system itself does not | ||
768 | force any particular policy on users, unlike a lot of build systems. | ||
769 | The system allows the best policy to be chosen for the given circumstances. | ||
756 | </para> | 770 | </para> |
757 | </section> | 771 | </section> |
758 | 772 | ||
759 | <section id='usingpoky-changes-updatingimages'> | 773 | <section id="usingpoky-changes-updatingimages"> |
760 | <title>Updating Existing Images</title> | 774 | <title>Updating Existing Images</title> |
761 | |||
762 | <para> | 775 | <para> |
763 | Often, rather than reflashing a new image you might wish to install updated | 776 | Often, rather than reflashing a new image you might wish to install updated |
764 | packages into an existing running system. This can be done by sharing the <filename class="directory">tmp/deploy/ipk/</filename> directory through a web server and then on the device, changing <filename>/etc/opkg/base-feeds.conf</filename> to point at this server, for example by adding: | 777 | packages into an existing running system. |
778 | You can do this by first sharing the | ||
779 | <filename class="directory">tmp/deploy/ipk/</filename> directory | ||
780 | through a web server and then by changing <filename>/etc/opkg/base-feeds.conf</filename> | ||
781 | to point at the shared server. | ||
782 | Following is an example: | ||
765 | </para> | 783 | </para> |
766 | <literallayout class='monospaced'> | 784 | <literallayout class='monospaced'> |
767 | src/gz all http://www.mysite.com/somedir/deploy/ipk/all | 785 | src/gz all http://www.mysite.com/somedir/deploy/ipk/all |
@@ -770,41 +788,33 @@ src/gz beagleboard http://www.mysite.com/somedir/deploy/ipk/beagleboard</literal | |||
770 | </section> | 788 | </section> |
771 | </section> | 789 | </section> |
772 | 790 | ||
773 | <section id='usingpoky-modifing-packages'> | 791 | <section id="usingpoky-modifing-packages"> |
774 | <title>Modifying Package Source Code</title> | 792 | <title>Modifying Package Source Code</title> |
775 | |||
776 | <para> | 793 | <para> |
777 | Poky is usually used to build software rather than modifying | 794 | Although Poky is usually used to build software, you can use it to modify software. |
778 | it. However, there are ways Poky can be used to modify software. | ||
779 | </para> | 795 | </para> |
780 | |||
781 | <para> | 796 | <para> |
782 | During building, the sources are available in <glossterm><link | 797 | During building, source is available in the |
783 | linkend='var-WORKDIR'>WORKDIR</link></glossterm> directory. | 798 | <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm> directory. |
784 | Where exactly this is depends on the type of package and the | 799 | The actual location depends on the type of package and the architecture of the target device. |
785 | architecture of target device. For a standard recipe not | 800 | For a standard recipe not related to |
786 | related to <glossterm><link | 801 | <glossterm><link linkend='var-MACHINE'>MACHINE</link></glossterm> the location is |
787 | linkend='var-MACHINE'>MACHINE</link></glossterm> it will be | ||
788 | <filename>tmp/work/PACKAGE_ARCH-poky-TARGET_OS/PN-PV-PR/</filename>. | 802 | <filename>tmp/work/PACKAGE_ARCH-poky-TARGET_OS/PN-PV-PR/</filename>. |
789 | Target device dependent packages use <glossterm><link | 803 | For target device-dependent packages you should use the MACHINE variable instead of |
790 | linkend='var-MACHINE'>MACHINE | 804 | <glossterm><link linkend='var-PACKAGE_ARCH'>PACKAGE_ARCH</link></glossterm> |
791 | </link></glossterm> | ||
792 | instead of <glossterm><link linkend='var-PACKAGE_ARCH'>PACKAGE_ARCH | ||
793 | </link></glossterm> | ||
794 | in the directory name. | 805 | in the directory name. |
795 | </para> | 806 | </para> |
796 | |||
797 | <tip> | 807 | <tip> |
798 | <para> | 808 | <para> |
799 | Check the package recipe sets the <glossterm><link | 809 | Be sure the package recipe sets the |
800 | linkend='var-S'>S</link></glossterm> variable to something | 810 | <glossterm><link linkend='var-S'>S</link></glossterm> variable to something |
801 | other than standard <filename>WORKDIR/PN-PV/</filename> value. | 811 | other than standard <filename>WORKDIR/PN-PV/</filename> value. |
802 | </para> | 812 | </para> |
803 | </tip> | 813 | </tip> |
804 | <para> | 814 | <para> |
805 | After building a package, a user can modify the package source code | 815 | After building a package, you can modify the package source code without problems. |
806 | without problem. The easiest way to test changes is by calling the | 816 | The easiest way to test your changes is by calling the "compile" task as shown in the |
807 | "compile" task: | 817 | following example: |
808 | </para> | 818 | </para> |
809 | 819 | ||
810 | <programlisting> | 820 | <programlisting> |
@@ -812,184 +822,179 @@ bitbake -c compile -f NAME_OF_PACKAGE | |||
812 | </programlisting> | 822 | </programlisting> |
813 | 823 | ||
814 | <para> | 824 | <para> |
815 | "-f" or "--force" is used to force re-execution of the specified task. | 825 | The "-f" or "--force" option forces re-execution of the specified task. |
816 | Other tasks may also be called this way. But note that all the modifications | 826 | You can call other tasks this way as well. |
817 | in <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm> | 827 | But note that all the modifications in |
818 | are gone once you executes "-c clean" for a package. | 828 | <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm> |
829 | are gone once you execute "-c clean" for a package. | ||
819 | </para> | 830 | </para> |
820 | 831 | ||
821 | <section id='usingpoky-modifying-packages-quilt'> | 832 | <section id="usingpoky-modifying-packages-quilt"> |
822 | <title>Modifying Package Source Code with quilt</title> | 833 | <title>Modifying Package Source Code with quilt</title> |
823 | |||
824 | <para> | 834 | <para> |
825 | By default Poky uses <ulink | 835 | By default Poky uses <ulink url='http://savannah.nongnu.org/projects/quilt'>quilt</ulink> |
826 | url='http://savannah.nongnu.org/projects/quilt'>quilt</ulink> | 836 | to manage patches in the <filename>do_patch</filename> task. |
827 | to manage patches in <function>do_patch</function> task. | 837 | This is a powerful tool that you can use to track all modifications to package sources. |
828 | It is a powerful tool which can be used to track all | ||
829 | modifications done to package sources. | ||
830 | </para> | 838 | </para> |
831 | |||
832 | <para> | 839 | <para> |
833 | Before modifying source code it is important to | 840 | Before modifying source code, it is important to notify quilt so it can track the changes |
834 | notify quilt so it will track changes into new patch | 841 | into the new patch file: |
835 | file: | 842 | |
836 | <programlisting> | 843 | <programlisting> |
837 | quilt new NAME-OF-PATCH.patch | 844 | quilt new NAME-OF-PATCH.patch |
838 | </programlisting> | 845 | </programlisting> |
839 | 846 | ||
840 | Then add all files which will be modified into that | 847 | After notifying quilt, add all modified files into that patch: |
841 | patch: | ||
842 | <programlisting> | 848 | <programlisting> |
843 | quilt add file1 file2 file3 | 849 | quilt add file1 file2 file3 |
844 | </programlisting> | 850 | </programlisting> |
845 | 851 | ||
846 | Now start editing. At the end quilt needs to be used | 852 | You can now start editing. |
847 | to generate final patch which will contain all | 853 | Once you are done editing, you need to use quilt to generate the final patch that |
848 | modifications: | 854 | will contain all your modifications. |
849 | <programlisting> | 855 | <programlisting> |
850 | quilt refresh | 856 | quilt refresh |
851 | </programlisting> | 857 | </programlisting> |
852 | 858 | ||
853 | The resulting patch file can be found in the | 859 | You can find the resulting patch file in the |
854 | <filename class="directory">patches/</filename> subdirectory of the source | 860 | <filename class="directory">patches/</filename> subdirectory of the source |
855 | (<glossterm><link linkend='var-S'>S</link></glossterm>) directory. For future builds it | 861 | (<glossterm><link linkend='var-S'>S</link></glossterm>) directory. |
856 | should be copied into | 862 | For future builds you should copy the patch into Poky metadata and add it into the |
857 | Poky metadata and added into <glossterm><link | 863 | <glossterm><link linkend='var-SRC_URI'>SRC_URI</link></glossterm> of a recipe. |
858 | linkend='var-SRC_URI'>SRC_URI</link></glossterm> of a recipe: | 864 | Here is an example: |
859 | <programlisting> | 865 | <programlisting> |
860 | SRC_URI += "file://NAME-OF-PATCH.patch" | 866 | SRC_URI += "file://NAME-OF-PATCH.patch" |
861 | </programlisting> | 867 | </programlisting> |
862 | 868 | Finally, don't forget to 'bump' the | |
863 | This also requires a bump of <glossterm><link | 869 | <glossterm><link linkend='var-PR'>PR</link></glossterm> value in the same recipe. |
864 | linkend='var-PR'>PR</link></glossterm> value in the same recipe as we changed resulting packages. | 870 | The resulting packages have changed. |
865 | </para> | 871 | </para> |
866 | |||
867 | </section> | 872 | </section> |
868 | 873 | ||
869 | </section> | 874 | </section> |
870 | <section id='usingpoky-configuring-LIC_FILES_CHKSUM'> | 875 | |
871 | <title>Track license change</title> | 876 | <section id="usingpoky-configuring-LIC_FILES_CHKSUM"> |
877 | <title>Track License Change</title> | ||
872 | <para> | 878 | <para> |
873 | The license of one upstream project may change in the future, and Poky provides | 879 | The license of an upstream project might change in the future. |
874 | one mechanism to track such license change - <glossterm> | 880 | To address this situation, Poky uses the |
875 | <link linkend='var-LIC_FILES_CHKSUM'>LIC_FILES_CHKSUM</link></glossterm> variable. | 881 | <glossterm><link linkend='var-LIC_FILES_CHKSUM'>LIC_FILES_CHKSUM</link></glossterm> variable |
882 | to track license changes. | ||
876 | </para> | 883 | </para> |
877 | 884 | ||
878 | <section id='usingpoky-specifying-LIC_FILES_CHKSUM'> | 885 | <section id="usingpoky-specifying-LIC_FILES_CHKSUM"> |
879 | <title>Specifying the LIC_FILES_CHKSUM variable </title> | 886 | <title>Specifying the LIC_FILES_CHKSUM Variable </title> |
880 | 887 | <para> | |
888 | The <glossterm><link linkend='var-LIC_FILES_CHKSUM'>LIC_FILES_CHKSUM</link></glossterm> | ||
889 | variable contains checksums of the license text in the recipe source code. | ||
890 | Poky uses this to track changes in the license text of the source code files. | ||
891 | Following is an example of LIC_FILES_CHKSUM: | ||
892 | </para> | ||
881 | <programlisting> | 893 | <programlisting> |
882 | LIC_FILES_CHKSUM = "file://COPYING; md5=xxxx \ | 894 | LIC_FILES_CHKSUM = "file://COPYING; md5=xxxx \ |
883 | file://licfile1.txt; beginline=5; endline=29;md5=yyyy \ | 895 | file://licfile1.txt; beginline=5; endline=29;md5=yyyy \ |
884 | file://licfile2.txt; endline=50;md5=zzzz \ | 896 | file://licfile2.txt; endline=50;md5=zzzz \ |
885 | ..." | 897 | ..." |
886 | </programlisting> | 898 | </programlisting> |
887 | |||
888 | <para> | 899 | <para> |
889 | <glossterm><link linkend='var-S'>S</link></glossterm> is the default directory | 900 | Poky uses the <glossterm><link linkend='var-S'>S</link></glossterm> variable as the |
890 | for searching files listed in <glossterm><link linkend='var-LIC_FILES_CHKSUM'> | 901 | default directory used when searching files listed in LIC_FILES_CHKSUM. |
891 | LIC_FILES_CHKSUM</link></glossterm>. Relative path could be used too: | 902 | The previous example employs the default directory. |
903 | </para> | ||
904 | <para> | ||
905 | You can also use relative paths as shown in the following example: | ||
892 | </para> | 906 | </para> |
893 | |||
894 | <programlisting> | 907 | <programlisting> |
895 | LIC_FILES_CHKSUM = "file://src/ls.c;startline=5;endline=16;\ | 908 | LIC_FILES_CHKSUM = "file://src/ls.c;startline=5;endline=16;\ |
896 | md5=bb14ed3c4cda583abc85401304b5cd4e" | 909 | md5=bb14ed3c4cda583abc85401304b5cd4e" |
897 | LIC_FILES_CHKSUM = "file://../license.html;md5=5c94767cedb5d6987c902ac850ded2c6" | 910 | LIC_FILES_CHKSUM = "file://../license.html;md5=5c94767cedb5d6987c902ac850ded2c6" |
898 | </programlisting> | 911 | </programlisting> |
899 | |||
900 | <para> | 912 | <para> |
901 | The first line locates a file in <glossterm><link linkend='var-S'> | 913 | In this example the first line locates a file in |
902 | S</link></glossterm>/src/ls.c, and the second line refers to a file in | 914 | <glossterm><link linkend='var-S'>S</link></glossterm><filename>/src/ls.c</filename>. |
903 | <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm>, which is the parent | 915 | The second line refers to a file in |
904 | of <glossterm><link linkend='var-S'>S</link></glossterm> | 916 | <glossterm><link linkend='var-WORKDIR'>WORKDIR</link></glossterm>, which is the parent |
917 | of <glossterm><link linkend='var-S'>S</link></glossterm>. | ||
905 | </para> | 918 | </para> |
906 | |||
907 | </section> | 919 | </section> |
908 | 920 | ||
909 | <section id='usingpoky-LIC_FILES_CHKSUM-explanation-of-syntax'> | 921 | <section id="usingpoky-LIC_FILES_CHKSUM-explanation-of-syntax"> |
910 | <title>Explanation of syntax</title> | 922 | <title>Explanation of Syntax</title> |
911 | |||
912 | <para> | 923 | <para> |
913 | This parameter lists all the important files containing the text | 924 | As mentioned in the previous section the LIC_FILES_CHKSUM variable lists all the |
914 | of licenses for the | 925 | important files that contain the license text for the source code. |
915 | source code. It is also possible to specify on which line the license text | 926 | Using this variable you can specify the line on which the license text starts and ends |
916 | starts and on which line it ends within that file using the "beginline" and | 927 | by supplyiing "beginline" and "endline" parameters. |
917 | "endline" parameters. If the "beginline" parameter is not specified then license | 928 | If you do not use the "beginline" parameter then it is assumed that the text begins on the |
918 | text begins from the 1st line is assumed. Similarly if "endline" parameter is | 929 | first line of the file. |
919 | not specified then the license text ends at the last line in the file is | 930 | Similarly, if you do not use the "endline" parameter it is assumed that the license text |
920 | assumed. So if a file contains only licensing information, then there is no need | 931 | ends as the last line of the file. |
921 | to specify "beginline" and "endline" parameters. | ||
922 | </para> | 932 | </para> |
923 | <para> | 933 | <para> |
924 | The "md5" parameter stores the md5 checksum of the license text. So if | 934 | The "md5" parameter stores the md5 checksum of the license text. |
925 | the license text changes in any way from a file, then its md5 sum will differ and will not | 935 | If the license text changes in any way as compared to this parameter |
926 | match with the previously stored md5 checksum. This mismatch will trigger build | 936 | then a mis-match occurs. |
927 | failure, notifying developer about the license text md5 mismatch, and allowing | 937 | This mismatch triggers a build failure and notifies the developer. |
928 | the developer to review the license text changes. Also note that if md5 checksum | 938 | Notification allows the developer to review and address the license text changes. |
929 | is not matched while building, the correct md5 checksum is printed in the build | 939 | Also note that if a mis-match occurs during the build, the correct md5 |
930 | log which can be easily copied to .bb file. | 940 | checksum is placed in the build log, which can be easily copied to a .bb file. |
931 | </para> | 941 | </para> |
932 | <para> | 942 | <para> |
933 | There is no limit on how many files can be specified on this parameter. But generally every | 943 | There is no limit to how many files you can specify using the LIC_FILES_CHKSUM variable. |
934 | project would need specifying of just one or two files for license tracking. | 944 | Generally, however, every project requires a few specifications for license tracking. |
935 | Many projects would have a "COPYING" file which will store all the | 945 | Many projects have a "COPYING" file that stores the license information for all the source |
936 | license information for all the source code files. If the "COPYING" file | 946 | code files. |
937 | is valid then tracking only that file would be enough. | 947 | This practice allow you to just track the "COPYING" file as long as it is kept up to date. |
938 | </para> | 948 | </para> |
939 | <tip> | 949 | <tip> |
940 | <para> | 950 | If you specify an empty or invalid "md5" parameter, bitback returns an md5 mis-match |
941 | 1. If you specify empty or invalid "md5" parameter; then while building | 951 | error and displays the correct "md5" parameter value during the build. The correct parameter |
942 | the package, bitbake will give md5 not matched error, and also show the correct | 952 | is also captured in the build log. |
943 | "md5" parameter value both on the screen and in the build log | 953 | </tip> |
944 | </para> | 954 | <tip> |
945 | <para> | 955 | If the whole file contains only license text, you do not need to use the "beginline" and |
946 | 2. If the whole file contains only license text, then there is no need to | 956 | "endline" parameters. |
947 | specify "beginline" and "endline" parameters. | ||
948 | </para> | ||
949 | </tip> | 957 | </tip> |
950 | </section> | 958 | </section> |
951 | </section> | 959 | </section> |
952 | <section id='usingpoky-configuring-DISTRO_PN_ALIAS'> | 960 | |
953 | <title>Handle package name alias</title> | 961 | <section id="usingpoky-configuring-DISTRO_PN_ALIAS"> |
962 | <title>Handling Package Name Alias</title> | ||
954 | <para> | 963 | <para> |
955 | Poky implements a distro_check task which automatically connects to major distributions | 964 | Sometimes a package name you are using might exist under an alias or as a similarly named |
956 | and checks whether they contains same package. Sometimes the same package has different | 965 | package in a different distribution. |
957 | names in different distributions, which results in a mismatch from distro_check task | 966 | Poky implements a distro_check task that automatically connects to major distributions |
958 | This can be solved by defining per distro recipe name alias - | 967 | and checks for these situations. |
959 | <glossterm><link linkend='var-DISTRO_PN_ALIAS'>DISTRO_PN_ALIAS</link></glossterm> | 968 | If the package exists under a different name in a different distribution you get a |
969 | distro_check mismatch. | ||
970 | You can resolve this problem by defining a per-distro recipe name alias using the | ||
971 | <glossterm><link linkend='var-DISTRO_PN_ALIAS'>DISTRO_PN_ALIAS</link></glossterm> variable. | ||
960 | </para> | 972 | </para> |
961 | 973 | ||
962 | <section id='usingpoky-specifying-DISTRO_PN_ALIAS'> | 974 | <section id="usingpoky-specifying-DISTRO_PN_ALIAS"> |
963 | <title>Specifying the DISTRO_PN_ALIAS variable </title> | 975 | <title>Specifying the DISTRO_PN_ALIAS Variable</title> |
964 | 976 | <para> | |
977 | Following is an example that shows how you specify the DISTRO_PN_ALIAS variable: | ||
965 | <programlisting> | 978 | <programlisting> |
966 | DISTRO_PN_ALIAS_pn-PACKAGENAME = "distro1=package_name_alias1 \ | 979 | DISTRO_PN_ALIAS_pn-PACKAGENAME = "distro1=package_name_alias1 \ |
967 | distro2=package_name_alias2 \ | 980 | distro2=package_name_alias2 \ |
968 | distro3=package_name_alias3 \ | 981 | distro3=package_name_alias3 \ |
969 | ..." | 982 | ..." |
970 | </programlisting> | 983 | </programlisting> |
984 | </para> | ||
971 | <para> | 985 | <para> |
972 | Use space as the delimiter if there're multiple distro aliases | 986 | If you have more than one distribution alias separate them with a space. |
987 | Note that Poky currently automatically checks the Fedora, OpenSuSE, Debian, Ubuntu, | ||
988 | and Mandriva distributions for source package recipes without having to specify them | ||
989 | using the DISTRO_PN_ALIAS variable. | ||
990 | For example, the following command generates a report that lists the Linux distributions | ||
991 | that include the sources for each of the Poky recipes. | ||
992 | <literallayout class='monospaced'> | ||
993 | $ bitbake world -f -c distro_check | ||
994 | </literallayout> | ||
995 | The results are stored in the <filename>build/tmp/log/distro_check-${DATETIME}.results</filename> | ||
996 | file. | ||
973 | </para> | 997 | </para> |
974 | <tip> | ||
975 | <para> | ||
976 | The current code can check if the src package for a recipe exists in the latest | ||
977 | releases of these distributions automatically. | ||
978 | </para> | ||
979 | <programlisting> | ||
980 | Fedora, OpenSuSE, Debian, Ubuntu, Mandriva | ||
981 | </programlisting> | ||
982 | <para> | ||
983 | For example, this command will generate a report, listing which linux distros include the | ||
984 | sources for each of the poky recipe. | ||
985 | </para> | ||
986 | <programlisting> | ||
987 | bitbake world -f -c distro_check | ||
988 | </programlisting> | ||
989 | <para> | ||
990 | The results will be stored in the build/tmp/log/distro_check-${DATETIME}.results file. | ||
991 | </para> | ||
992 | </tip> | ||
993 | </section> | 998 | </section> |
994 | </section> | 999 | </section> |
995 | </chapter> | 1000 | </chapter> |