<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
"http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">

<chapter id='intro'>
<title>Introduction</title>

<section id='intro-welcome'>
    <title>Welcome to Poky!</title>

    <para>
        Poky is the build tool in Yocto Project.
        Yocto Project uses Poky to build images (kernel, system, and application software) for 
        targeted hardware.
    </para>

    <para>
        Before diving into Poky, it helps to have an understanding of the Yocto Project.
        Especially useful for newcomers is the information in the Yocto Project Quick Start, which 
        you can find on the <ulink url="http://www.yoctoproject.org">Yocto Project website</ulink>.
        Specifically, the guide is
        at <ulink url="http://www.yoctoproject.org/docs/yocto-quick-start/yocto-project-qs.html"/>.
    </para>
</section>

<section id='what-is-poky'>
    <title>What is Poky?</title>

    <para>
        Within the Yocto Project, Poky provides an open source, full-platform build tool based on 
        Linux, X11, Matchbox, GTK+, Pimlico, Clutter, 
        and other <ulink url='http://gnome.org/mobile'>GNOME Mobile</ulink> technologies.
        It provides a focused and stable subset of OpenEmbedded upon which you can easily and 
        reliably build and develop.
        Poky fully supports a wide range of x86, ARM, MIPS and PowerPC hardware and device virtualization.
    </para>

    <para>
        Poky is primarily a platform builder that generates filesystem images
        based on open source software such as the Kdrive X server, the Matchbox
        window manager, the GTK+ toolkit and the D-Bus message bus system. While images
        for many kinds of devices can be generated, the standard example
        machines target QEMU full-system emulation (x86, ARM, MIPS and PowerPC) and
        real reference boards for each of these architectures.
        Poky's ability to boot inside a QEMU
        emulator makes it particularly suitable as a test platform for developing embedded software.
    </para>

    <para>
        An important component integrated within Poky is Sato, a GNOME Mobile-based
        user interface environment.
        It is designed to work well with screens that use very high DPI and have restricted
        sizes, such as those often found on smartphones and PDAs. 
        Because Sato is coded for speed and efficiency, it works smoothly on hand-held and
        other embedded hardware. 
        It sits nicely on top of any device that uses the GNOME Mobile stack and it results in
        a well-defined user experience.
    </para>

    <screenshot>
    <mediaobject>
        <imageobject>
            <imagedata fileref="screenshots/ss-sato.png" format="PNG" align='center' scalefit='1' width="100%" contentdepth="100%"/>
        </imageobject>
        <caption>
            <para>The Sato Desktop - A screenshot from a machine running a Poky built image</para>
        </caption>
     </mediaobject>
     </screenshot>

    <para>
        Poky has a growing open source community and is also backed up by commercial organizations 
        including <ulink url="http://www.intel.com/">Intel Corporation</ulink>.
    </para>
</section>

<section id='intro-manualoverview'>
    <title>Documentation Overview</title>
    <para>
        The sections in this reference manual describe different aspects of Poky. 
        The <link linkend='usingpoky'>'Using Poky'</link> section provides an overview of the components 
        that make up Poky followed by information about using Poky and debugging images created in Yocto Project. 
        The <link linkend='extendpoky'>'Extending Poky'</link> and 
        <link linkend='bsp'>'Board Support Packages'</link> sections provide information 
        about how to extend and customize Poky along with advice on how to manage these changes. 
        The <link linkend='platdev'>'Platform Development with Poky'</link> section provides information about
        interaction between Poky and target hardware for common platform development tasks such as software
        development, debugging and profiling. 
        The rest of the manual consists of several reference sections, each providing details on a specific
        area of Poky functionality.
    </para>

    <para>
        This manual applies to Poky Release 4.0 (laverne).
    </para>
</section>


<section id='intro-requirements'>
    <title>System Requirements</title>
    <para>
        Although we recommend Debian-based distributions 
        (Ubuntu 10.04 or newer) as the host system for Poky, nothing in Poky is
        distribution-specific.  Consequently, other distributions should work as long 
        as the appropriate prerequisites are installed.  For example, we know of Poky being used 
        successfully on Redhat, SUSE, Gentoo and Slackware host systems.
        For information on what you need to develop images using Yocto Project and Poky, 
        you should see the Yocto Project Quick Start on the <ulink url="http://www.yoctoproject.org">
        Yocto Project website</ulink>.
        The direct link to the quick start is 
        <ulink url='http://yoctoproject.org/docs/yocto-quick-start/yocto-project-qs.html'/>.
    </para>
</section>

<section id='intro-getit'>
    <title>Obtaining Poky</title>

    <section id='intro-getit-releases'>
        <title>Releases</title>

        <para>Periodically, we make releases of Poky available
            at <ulink url='http://pokylinux.org/releases/'/>.
            These releases are more stable and more rigorously tested than the nightly development images.
        </para>
    </section>

    <section id='intro-getit-nightly'>
        <title>Nightly Builds</title>

        <para>
            We make nightly builds of Poky for testing purposes and to make the
            latest developments available. The output from these builds is available
            at <ulink url='http://autobuilder.pokylinux.org/'/>.
            The numbers used in the builds increase for each subsequent build and can be used to 
            reference a specific build.
        </para>

        <para>
            Automated builds are available for "standard" Poky and for Poky SDKs and toolchains.
            Additionally, testing versions such as poky-bleeding can be made available as 
            'experimental' builds.
            The toolchains can
            be used either as external standalone toolchains or can be combined with Poky as a
            prebuilt toolchain to reduce build time. Using the external toolchains is simply a
            case of untarring the tarball into the root of your system (it only creates files in
            <filename>/opt/poky</filename>) and then enabling the option 
            in <filename>local.conf</filename>.
        </para>
    </section>

    <section id='intro-getit-dev'>
        <title>Development Checkouts</title>

        <para>
            Poky is available from our git repository located at
            git://git.pokylinux.org/poky.git; a web interface to the repository
            can be accessed at <ulink url='http://git.pokylinux.org/'/>.
        </para>

        <para>
           The 'master' is where the deveopment work takes place and you should use this if you're
           interested in working with the latest cutting-edge developments. It is possible for the trunk
           to suffer temporary periods of instability while new features are developed.
           If these periods of instability are undesireable, we recommend using one of the release branches.
        </para>
    </section>
</section>
</chapter>
<!--
vim: expandtab tw=80 ts=4
-->