diff options
author | Scott Rifenbark <scott.m.rifenbark@intel.com> | 2014-02-18 14:50:13 -0600 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2014-03-09 18:59:03 -0700 |
commit | cd0c0673dcbd3e158bab8ad27a1b74b8629da146 (patch) | |
tree | 2253ebf88753c5f392a50e9504e07cfbd33819e7 /bitbake/doc/user-manual/user-manual-metadata.xml | |
parent | b82b3d2cc31fb5e36ca8f3329d5643e2aed05da9 (diff) | |
download | poky-cd0c0673dcbd3e158bab8ad27a1b74b8629da146.tar.gz |
bitbake: user-manual-metadata.xml: Title change, sections lifted.
Changed the title of the chapter to "Syntax and Operators". It
was called "Metadata".
Removed the bulk the "Checksums (Signatures)" section and the
placeholder for "Setscene". These are now in the "Execution"
chapter.
Created a more appropriate overview blurb to start the chapter.
(Bitbake rev: f955171d8468ed987f92146d39f52d9af4a03dbb)
Signed-off-by: Scott Rifenbark <scott.m.rifenbark@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/doc/user-manual/user-manual-metadata.xml')
-rw-r--r-- | bitbake/doc/user-manual/user-manual-metadata.xml | 208 |
1 files changed, 8 insertions, 200 deletions
diff --git a/bitbake/doc/user-manual/user-manual-metadata.xml b/bitbake/doc/user-manual/user-manual-metadata.xml index 8d37f6bee1..cabf25fb6f 100644 --- a/bitbake/doc/user-manual/user-manual-metadata.xml +++ b/bitbake/doc/user-manual/user-manual-metadata.xml | |||
@@ -2,40 +2,15 @@ | |||
2 | "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> | 2 | "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> |
3 | 3 | ||
4 | <chapter id="user-manual-metadata"> | 4 | <chapter id="user-manual-metadata"> |
5 | <title>Metadata</title> | 5 | <title>Syntax and Operators</title> |
6 | 6 | ||
7 | <section> | 7 | <para> |
8 | <title>Overview</title> | 8 | Bitbake files have their own syntax. |
9 | 9 | The syntax has similarities to several | |
10 | <para> | 10 | other languages but also has some unique features. |
11 | The BitBake task executor together with various types of configuration | 11 | This section describes the available syntax and operators |
12 | files form the OpenEmbedded Core. | 12 | as well as provides examples. |
13 | This section provides an overview of the task executor and the | 13 | </para> |
14 | configuration files by describing their use and interaction. | ||
15 | </para> | ||
16 | |||
17 | <para> | ||
18 | BitBake handles the parsing and execution of the data files. | ||
19 | The data itself is of various types: | ||
20 | <itemizedlist> | ||
21 | <listitem><para><emphasis>Recipes:</emphasis> | ||
22 | Details about particular pieces of software. | ||
23 | </para></listitem> | ||
24 | <listitem><para><emphasis>Class Data:</emphasis> | ||
25 | An abstraction of common build information | ||
26 | (e.g. how to build a Linux kernel). | ||
27 | </para></listitem> | ||
28 | <listitem><para><emphasis>Configuration Data:</emphasis> | ||
29 | Machine-specific settings, policy decisions, | ||
30 | and so forth. | ||
31 | Configuration data acts as the glue to bind everything | ||
32 | together.</para></listitem> | ||
33 | </itemizedlist> | ||
34 | The remainder of this chapter provides examples of BitBake metadata. | ||
35 | Any syntax not supported in any of the previously listed areas | ||
36 | is documented as such. | ||
37 | </para> | ||
38 | </section> | ||
39 | 14 | ||
40 | <section id='basic-syntax'> | 15 | <section id='basic-syntax'> |
41 | <title>Basic Syntax</title> | 16 | <title>Basic Syntax</title> |
@@ -1453,172 +1428,5 @@ | |||
1453 | </para></listitem> | 1428 | </para></listitem> |
1454 | </itemizedlist> | 1429 | </itemizedlist> |
1455 | </para> | 1430 | </para> |
1456 | |||
1457 | <section id='setscene'> | ||
1458 | <title>Setscene</title> | ||
1459 | |||
1460 | <para> | ||
1461 | This section needs to get the concept of the setscene across. | ||
1462 | The reader needs to know what it is and what it is used for during | ||
1463 | the build process. | ||
1464 | </para> | ||
1465 | </section> | ||
1466 | |||
1467 | <section id='checksums'> | ||
1468 | <title>Checksums (Signatures)</title> | ||
1469 | |||
1470 | <para> | ||
1471 | A checksum is a unique signature of a task's inputs. | ||
1472 | The setscene code uses a checksum to determine if a task needs | ||
1473 | to be run. | ||
1474 | Because it is a change in a task's inputs that triggers running | ||
1475 | the task, the process needs to detect all the inputs to a given task. | ||
1476 | For shell tasks, this turns out to be fairly easy because | ||
1477 | BitBake generates a "run" shell script for each task and | ||
1478 | it is possible to create a checksum that gives you a good idea of when | ||
1479 | the task's data changes. | ||
1480 | </para> | ||
1481 | |||
1482 | <para> | ||
1483 | To complicate the problem, some things should not be included in | ||
1484 | the checksum. | ||
1485 | First, there is the actual specific build path of a given task - | ||
1486 | the working directory. | ||
1487 | It does not matter if the working directory changes because it should not | ||
1488 | affect the output for target packages. | ||
1489 | The simplistic approach for excluding the working directory is to set | ||
1490 | it to some fixed value and create the checksum for the "run" script. | ||
1491 | </para> | ||
1492 | |||
1493 | <para> | ||
1494 | Another problem results from the "run" scripts containing functions that | ||
1495 | might or might not get called. | ||
1496 | The incremental build solution contains code that figures out dependencies | ||
1497 | between shell functions. | ||
1498 | This code is used to prune the "run" scripts down to the minimum set, | ||
1499 | thereby alleviating this problem and making the "run" scripts much more | ||
1500 | readable as a bonus. | ||
1501 | </para> | ||
1502 | |||
1503 | <para> | ||
1504 | So far we have solutions for shell scripts. | ||
1505 | What about Python tasks? | ||
1506 | The same approach applies even though these tasks are more difficult. | ||
1507 | The process needs to figure out what variables a Python function accesses | ||
1508 | and what functions it calls. | ||
1509 | Again, the incremental build solution contains code that first figures out | ||
1510 | the variable and function dependencies, and then creates a checksum for the data | ||
1511 | used as the input to the task. | ||
1512 | </para> | ||
1513 | |||
1514 | <para> | ||
1515 | Like the working directory case, situations exist where dependencies | ||
1516 | should be ignored. | ||
1517 | For these cases, you can instruct the build process to ignore a dependency | ||
1518 | by using a line like the following: | ||
1519 | <literallayout class='monospaced'> | ||
1520 | PACKAGE_ARCHS[vardepsexclude] = "MACHINE" | ||
1521 | </literallayout> | ||
1522 | This example ensures that the <filename>PACKAGE_ARCHS</filename> variable does not | ||
1523 | depend on the value of <filename>MACHINE</filename>, even if it does reference it. | ||
1524 | </para> | ||
1525 | |||
1526 | <para> | ||
1527 | Equally, there are cases where we need to add dependencies BitBake | ||
1528 | is not able to find. | ||
1529 | You can accomplish this by using a line like the following: | ||
1530 | <literallayout class='monospaced'> | ||
1531 | PACKAGE_ARCHS[vardeps] = "MACHINE" | ||
1532 | </literallayout> | ||
1533 | This example explicitly adds the <filename>MACHINE</filename> variable as a | ||
1534 | dependency for <filename>PACKAGE_ARCHS</filename>. | ||
1535 | </para> | ||
1536 | |||
1537 | <para> | ||
1538 | Consider a case with in-line Python, for example, where BitBake is not | ||
1539 | able to figure out dependencies. | ||
1540 | When running in debug mode (i.e. using <filename>-DDD</filename>), BitBake | ||
1541 | produces output when it discovers something for which it cannot figure out | ||
1542 | dependencies. | ||
1543 | </para> | ||
1544 | |||
1545 | <para> | ||
1546 | Thus far, this section has limited discussion to the direct inputs into a task. | ||
1547 | Information based on direct inputs is referred to as the "basehash" in the | ||
1548 | code. | ||
1549 | However, there is still the question of a task's indirect inputs - the | ||
1550 | things that were already built and present in the build directory. | ||
1551 | The checksum (or signature) for a particular task needs to add the hashes | ||
1552 | of all the tasks on which the particular task depends. | ||
1553 | Choosing which dependencies to add is a policy decision. | ||
1554 | However, the effect is to generate a master checksum that combines the basehash | ||
1555 | and the hashes of the task's dependencies. | ||
1556 | </para> | ||
1557 | |||
1558 | <para> | ||
1559 | At the code level, there are a variety of ways both the basehash and the | ||
1560 | dependent task hashes can be influenced. | ||
1561 | Within the BitBake configuration file, we can give BitBake some extra information | ||
1562 | to help it construct the basehash. | ||
1563 | The following statement effectively results in a list of global variable | ||
1564 | dependency excludes - variables never included in any checksum. | ||
1565 | This example uses variables from OpenEmbedded to help illustrate | ||
1566 | the concept: | ||
1567 | <literallayout class='monospaced'> | ||
1568 | BB_HASHBASE_WHITELIST ?= "TMPDIR FILE PATH PWD BB_TASKHASH BBPATH DL_DIR \ | ||
1569 | SSTATE_DIR THISDIR FILESEXTRAPATHS FILE_DIRNAME HOME LOGNAME SHELL TERM \ | ||
1570 | USER FILESPATH STAGING_DIR_HOST STAGING_DIR_TARGET COREBASE PRSERV_HOST \ | ||
1571 | PRSERV_DUMPDIR PRSERV_DUMPFILE PRSERV_LOCKDOWN PARALLEL_MAKE \ | ||
1572 | CCACHE_DIR EXTERNAL_TOOLCHAIN CCACHE CCACHE_DISABLE LICENSE_PATH SDKPKGSUFFIX" | ||
1573 | </literallayout> | ||
1574 | The previous example excludes the work directory, which is part of | ||
1575 | <filename>TMPDIR</filename>. | ||
1576 | </para> | ||
1577 | |||
1578 | <para> | ||
1579 | The rules for deciding which hashes of dependent tasks to include through | ||
1580 | dependency chains are more complex and are generally accomplished with a | ||
1581 | Python function. | ||
1582 | The code in <filename>meta/lib/oe/sstatesig.py</filename> shows two examples | ||
1583 | of this and also illustrates how you can insert your own policy into the system | ||
1584 | if so desired. | ||
1585 | This file defines the two basic signature generators OpenEmbedded Core | ||
1586 | uses: "OEBasic" and "OEBasicHash". | ||
1587 | By default, there is a dummy "noop" signature handler enabled in BitBake. | ||
1588 | This means that behavior is unchanged from previous versions. | ||
1589 | <filename>OE-Core</filename> uses the "OEBasicHash" signature handler by default | ||
1590 | through this setting in the <filename>bitbake.conf</filename> file: | ||
1591 | <literallayout class='monospaced'> | ||
1592 | BB_SIGNATURE_HANDLER ?= "OEBasicHash" | ||
1593 | </literallayout> | ||
1594 | The "OEBasicHash" <filename>BB_SIGNATURE_HANDLER</filename> is the same as the | ||
1595 | "OEBasic" version but adds the task hash to the stamp files. | ||
1596 | This results in any metadata change that changes the task hash, automatically | ||
1597 | causing the task to be run again. | ||
1598 | This removes the need to bump | ||
1599 | <link linkend='var-PR'><filename>PR</filename></link> | ||
1600 | values, and changes to metadata automatically ripple across the build. | ||
1601 | </para> | ||
1602 | |||
1603 | <para> | ||
1604 | It is also worth noting that the end result of these signature generators is to | ||
1605 | make some dependency and hash information available to the build. | ||
1606 | This information includes: | ||
1607 | <itemizedlist> | ||
1608 | <listitem><para><filename>BB_BASEHASH_task-<taskname></filename>: | ||
1609 | The base hashes for each task in the recipe. | ||
1610 | </para></listitem> | ||
1611 | <listitem><para><filename>BB_BASEHASH_<filename:taskname></filename>: | ||
1612 | The base hashes for each dependent task. | ||
1613 | </para></listitem> | ||
1614 | <listitem><para><filename>BBHASHDEPS_<filename:taskname></filename>: | ||
1615 | The task dependencies for each task. | ||
1616 | </para></listitem> | ||
1617 | <listitem><para><filename>BB_TASKHASH</filename>: | ||
1618 | The hash of the currently running task. | ||
1619 | </para></listitem> | ||
1620 | </itemizedlist> | ||
1621 | </para> | ||
1622 | </section> | ||
1623 | </section> | 1431 | </section> |
1624 | </chapter> | 1432 | </chapter> |