diff options
author | Scott Rifenbark <scott.m.rifenbark@intel.com> | 2013-12-18 15:06:05 -0600 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2014-01-02 13:16:11 +0000 |
commit | 3b908ee6a8fb920b73ea1974ba62693fb575b7bd (patch) | |
tree | 748d6382a33b91efaa115a8fc94792de117cf206 | |
parent | b55ffe73568e6cf0f07b6212a75b78a5d5a011f1 (diff) | |
download | poky-3b908ee6a8fb920b73ea1974ba62693fb575b7bd.tar.gz |
dev-manual: Re-wrote the installation part of "Writing a Recipe"
(From yocto-docs rev: 7d99f9346a0747d2d1cb978ea10d1a681e70a98f)
Signed-off-by: Scott Rifenbark <scott.m.rifenbark@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | documentation/dev-manual/dev-manual-common-tasks.xml | 88 |
1 files changed, 77 insertions, 11 deletions
diff --git a/documentation/dev-manual/dev-manual-common-tasks.xml b/documentation/dev-manual/dev-manual-common-tasks.xml index 9fb2b1c550..2356b9fc36 100644 --- a/documentation/dev-manual/dev-manual-common-tasks.xml +++ b/documentation/dev-manual/dev-manual-common-tasks.xml | |||
@@ -1397,10 +1397,78 @@ the target, etc. | |||
1397 | <title>Installing</title> | 1397 | <title>Installing</title> |
1398 | 1398 | ||
1399 | <para> | 1399 | <para> |
1400 | install: for autotools/cmake recipes, if the recipe passes through do_install | 1400 | During installation, files your recipe builds are copied from |
1401 | successfully, nothing needs to be done (at this stage). If not, diagnose the | 1401 | locations where work is being done to locations on the target |
1402 | failure. For non-autotools recipes you need to define your own do_install | 1402 | device. |
1403 | (which may well just run "oe_runmake install"). | 1403 | The installation process moves the |
1404 | <filename>${</filename><ulink url='&YOCTO_DOCS_REF_URL;#var-S'><filename>S</filename></ulink><filename>}</filename>, | ||
1405 | <filename>${</filename><ulink url='&YOCTO_DOCS_REF_URL;#var-B'><filename>B</filename></ulink><filename>}</filename>, | ||
1406 | and | ||
1407 | <filename>${</filename><ulink url='&YOCTO_DOCS_REF_URL;#var-WORKDIR'><filename>WORKDIR</filename></ulink><filename>}</filename> | ||
1408 | to the | ||
1409 | <filename>${</filename><ulink url='&YOCTO_DOCS_REF_URL;#var-D'><filename>D</filename></ulink><filename>}</filename> | ||
1410 | to create the structure as it should appear on the target | ||
1411 | system. | ||
1412 | <note> | ||
1413 | During the installation process, some of the files might also | ||
1414 | be modified to suit the target layout as well. | ||
1415 | </note> | ||
1416 | </para> | ||
1417 | |||
1418 | <para> | ||
1419 | How your software is built affects what you must do to be | ||
1420 | sure your software is installed correctly. | ||
1421 | The following list describes what you must do for installation | ||
1422 | depending on how your recipe builds your software: | ||
1423 | <itemizedlist> | ||
1424 | <listitem><para><emphasis>Autotools and <filename>cmake</filename>:</emphasis> | ||
1425 | If the software your recipe is building uses Autotools | ||
1426 | or <filename>cmake</filename>, the OpenEmbedded build | ||
1427 | system understands how to install the software. | ||
1428 | Consequently, you do not have to have a | ||
1429 | <filename>do_install</filename> task as part of your | ||
1430 | recipe. | ||
1431 | You just need to make sure the install portion of the | ||
1432 | build completes with no issues.</para></listitem> | ||
1433 | <listitem><para><emphasis><filename>make install</filename>:</emphasis> | ||
1434 | You need to define a | ||
1435 | <filename>do_install</filename> function in your | ||
1436 | recipe. | ||
1437 | The function should call | ||
1438 | <filename>oe_runmake install</filename> and will likely | ||
1439 | need to pass in the destination directory as well. | ||
1440 | How you pass that path is dependent on how the | ||
1441 | <filename>Makefile</filename> being run is written | ||
1442 | (e.g. <filename>DESTDIR=${D}</filename>, | ||
1443 | <filename>PREFIX=${D}</filename>, | ||
1444 | <filename>INSTALLROOT=${D}</filename>, and so forth). | ||
1445 | </para></listitem> | ||
1446 | <listitem><para><emphasis><filename>install</filename>:</emphasis> | ||
1447 | You need to define a | ||
1448 | <filename>do_install</filename> function in your | ||
1449 | recipe. | ||
1450 | The function must first use | ||
1451 | <filename>install -d</filename> to create the | ||
1452 | directories. | ||
1453 | Once the directories exist, your function can use | ||
1454 | <filename>install</filename> to manually install the | ||
1455 | built software into the directories.</para> | ||
1456 | <para>You can find more information on | ||
1457 | <filename>install</filename> at | ||
1458 | <ulink url='http://www.gnu.org/software/coreutils/manual/html_node/install-invocation.html'></ulink>. | ||
1459 | </para></listitem> | ||
1460 | </itemizedlist> | ||
1461 | </para> | ||
1462 | |||
1463 | <para> | ||
1464 | For the scenarios that do not use Autotools or | ||
1465 | <filename>cmake</filename>, you need to track the installation | ||
1466 | and diagnose and fix any issues until everything installs | ||
1467 | correctly. | ||
1468 | You need to look in the default location of | ||
1469 | <filename>${D}</filename>, which is | ||
1470 | <filename>${WORKDIR}/image</filename>, to be sure your | ||
1471 | files have been installed correctly. | ||
1404 | </para> | 1472 | </para> |
1405 | </section> | 1473 | </section> |
1406 | 1474 | ||
@@ -1418,20 +1486,18 @@ section though. | |||
1418 | <para> | 1486 | <para> |
1419 | If you are adding services and the service initialization | 1487 | If you are adding services and the service initialization |
1420 | script or the service file itself is not installed, you must | 1488 | script or the service file itself is not installed, you must |
1421 | provide for that installation in your recipe. | 1489 | provide for that installation in your recipe using a |
1490 | <filename>do_install_append</filename> function. | ||
1422 | If your recipe already has a <filename>do_install</filename> | 1491 | If your recipe already has a <filename>do_install</filename> |
1423 | function, you will need to create a | 1492 | function, you will need to be sure to change it so that it |
1424 | <filename>do_install_append</filename> function to handle the | 1493 | handles the installation of your services. |
1425 | installation of your services. | ||
1426 | </para> | ||
1427 | |||
1428 | <para> | ||
1429 | When you create the installation for your services, you need | 1494 | When you create the installation for your services, you need |
1430 | to accomplish what is normally done by "make install". | 1495 | to accomplish what is normally done by "make install". |
1431 | In other words, make sure your installation puts the output | 1496 | In other words, make sure your installation puts the output |
1432 | in a layout that is similar to how they will be laid out on the | 1497 | in a layout that is similar to how they will be laid out on the |
1433 | target system. | 1498 | target system. |
1434 | </para> | 1499 | </para> |
1500 | |||
1435 | </section> | 1501 | </section> |
1436 | 1502 | ||
1437 | <section id='new-recipe-packaging'> | 1503 | <section id='new-recipe-packaging'> |