summaryrefslogtreecommitdiffstats
path: root/documentation/adt-manual/adt-prepare.xml
blob: 686e3e98ea2431e0262bb1f1cb7d8ca6c265a0f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
"http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">

<chapter id='adt-prepare'>

<title>Preparing to Use the Application Development Toolkit (ADT)</title>

<para>
    In order to use the ADT you must install it, source a script to set up the 
    environment, and be sure the kernel and filesystem image specific to the target architecture 
    exists. 
</para>

<para> 
    This section describes how to be sure you meet these requirements.
    Througout this section two important terms are used:
    <itemizedlist>
        <listitem><para><emphasis>Yocto Project Source Tree:</emphasis>
        This term refers to the directory structure created as a result of downloading 
        and unpacking a Yocto Project release tarball.
        The Yocto Project source tree contains Bitbake, Documentation, Meta-data and 
        other files. 
        The name of the top-level directory of the Yocto Project source tree  
        is derived from the Yocto Project release tarball.
        For example, downloading and unpacking <filename>poky-bernard-5.0.1.tar.bz2</filename>
        results in a Yocto Project source tree whose Yocto Project source directory is named 
        <filename>poky-bernard-5.0.1</filename>.</para></listitem>
        <listitem><para><emphasis>Yocto Project Build Tree:</emphasis>
        This term refers to the area where you run your builds.  
        The area is created when you source the Yocto Project setup environment script
        that is found in the Yocto Project source directory 
        (e.g. <filename>poky-init-build-env</filename>).
        You can create the Yocto Project build tree anywhere you want on your 
        development system.
        Here is an example that creates the tree in <filename>mybuilds</filename> 
        and names the Yocto Project build directory <filename>YP-5.0.1</filename>:
        <literallayout class='monospaced'> 
     $ source poky-bernard-5.0.1/poky-init-build-env $HOME/mybuilds/YP-5.0.1
        </literallayout>
        If you don't specifically name the build directory then Bitbake creates it 
        in the current directory and uses the name <filename>build</filename>.
        Also, if you supply an existing directory then Bitbake uses that 
        directory as the Yocto Project build directory and populates the build tree
        beneath it.</para></listitem>
    </itemizedlist>
</para>

<section id='installing-the-adt'>
    <title>Installing the ADT</title>

    <para>
        The following list describes how you can install the ADT, which includes the cross-toolchain.
        Regardless of the installation you choose, however, you must source the cross-toolchain
        environment setup script before you use the toolchain.
        See the <xref linkend='setting-up-the-environment'>“Setting Up the Environment”</xref> 
        section for more information.
        <itemizedlist>
            <listitem><para><emphasis>Use the ADT Installer Script:</emphasis>
            This method is the recommended way to install the ADT because it
            automates much of the process for you.
            For example, you can configure the installation to install the QEMU emulator
            and the user-space NFS, specify which root filesystem profiles to download, 
            and define the target sysroot location.
            </para></listitem>
            <listitem><para><emphasis>Use an Existing Toolchain Tarball:</emphasis>
            Using this method you select and download an architecture-specific
            toolchain tarball and then hand-install the toolchain.
            If you use this method you just get the cross-toolchain and QEMU - you do not 
            get any of the other mentioned benefits had you run the ADT Installer script.</para></listitem>
            <listitem><para><emphasis>Use the Toolchain from Within a Yocto Project Build Tree:</emphasis>
            If you already have a Yocto Project build tree you can install the cross-toolchain 
            using that tree.
            However, like the previous method mentioned, you only get the cross-toolchain and QEMU - you 
            do not get any of the other benefits without taking separate steps.</para></listitem>
        </itemizedlist>
    </para>

    <section id='using-the-adt-installer'>
        <title>Using the ADT Installer</title>

        <para>
            To run the ADT Installer you need to first get the ADT Installer tarball and then run the ADT
            Installer Script.
        </para>

        <section id='getting-the-adt-installer-tarball'>
            <title>Getting the ADT Installer Tarball</title>

            <para>
                The ADT Installer is contained in the ADT Installer tarball.
                You can download the tarball into any directory from  
                <ulink url='http://autobuilder.yoctoproject.org/downloads/yocto-1.0/adt-installer/'></ulink>.
                Or, you can use Bitbake to generate the tarball inside the existing Yocto Project build tree.
            </para>

            <para>
                If you use Bitbake to generate the ADT Installer tarball, you must 
                source the Yocto Project environment setup script located in the Yocto Project
                source directory before running the Bitbake command that creates the tarball.
            </para>

            <para>
                The following example commands download the Yocto Project release tarball, create the Yocto 
                Project source tree, set up the environment while also creating the Yocto Project build tree, 
                and finally run the Bitbake command that results in the tarball 
                <filename>~/yocto-project/build/tmp/deploy/sdk/adt_installer.tar.bz2</filename>:
                <literallayout class='monospaced'>
     $ cd ~
     $ mkdir yocto-project
     $ cd yocto-project
     $ wget http://www.yoctoproject.org/downloads/poky/poky-bernard-5.0.1.tar.bz2
     $ tar xjf poky-bernard-5.0.1.tar.bz2
     $ source poky-bernard-5.0.1/poky-init-build-env poky-5.0.1-build
     $ bitbake adt-installer
                </literallayout>
            </para>

        </section>

        <section id='configuring-and-running-the-adt-installer-script'>
            <title>Configuring and Running the ADT Installer Script</title>

            <para>
                Before running the ADT Installer script you need to unpack the tarball.
                You can unpack the tarball in any directory you wish.
                Unpacking it creates the directory <filename>adt-installer</filename>, 
                which contains the ADT Installer script and its configuration file.
            </para>

            <para>
                Before you run the script, however, you should examine the ADT Installer configuration 
                file (<filename>adt_installer</filename>) and be sure you are going to get what you want.  
                Your configurations determine which kernel and filesystem image are downloaded.
            </para>

            <para>  
                The following list describes the configurations you can define for the ADT Installer.  
                For configuration values and restrictions see the comments in  
                the <filename>adt-installer.conf</filename> file:

                <itemizedlist>
                    <listitem><para><filename>YOCTOADT_IPKG_REPO</filename> – This area 
                    includes the IPKG-based packages and the root filesystem upon which 
                    the installation is based.  
                    If you want to set up your own IPKG repository pointed to by 
                    <filename>YOCTOADT_IPKG_REPO</filename>, you need to be sure that the 
                    directory structure follows the same layout as the reference directory 
                    set up at <ulink url='http://adtrepo.yoctoproject.org'></ulink>.  
                    Also, your repository needs to be accessible through HTTP.
                    </para></listitem>
                    <listitem><para><filename>YOCTOADT-TARGETS</filename> – The machine 
                    target architectures for which you want to set up cross-development 
                    environments.
                    </para></listitem>
                    <listitem><para><filename>YOCTOADT_QEMU</filename> – Indicates whether 
                    or not to install the emulator QEMU.
                    </para></listitem>
                    <listitem><para><filename>YOCTOADT_NFS_UTIL</filename> – Indicates whether 
                    or not to install user-mode NFS.  
                    If you plan to use the Yocto Eclipse IDE plug-in against QEMU, 
                    you should install NFS.
                    <note>
                    To boot QEMU images using our userspace NFS server, you need 
                    to be running portmap or rpcbind. 
                    If you are running rpcbind, you will also need to add the -i 
                    option when rpcbind starts up. 
                    Please make sure you understand the security implications of doing this. 
                    Your firewall settings may also have to be modified to allow 
                    NFS booting to work.
                    </note>
                    </para></listitem>
                    <listitem><para><filename>YOCTOADT_ROOTFS_&lt;arch&gt;</filename> - The root 
                    filesystem images you want to download.
                    </para></listitem>
                    <listitem><para><filename>YOCTOADT_TARGET_SYSROOT_IMAGE_&lt;arch&gt;</filename> - The 
                    root filesystem used to extract and create the target sysroot.
                    </para></listitem>
                    <listitem><para><filename>YOCTOADT_TARGET_SYSROOT_LOC_&lt;arch&gt;</filename> - The 
                    location of the target sysroot that will be set up on the development machine.
                    </para></listitem>
                </itemizedlist>
            </para>

            <para>
                After you have configured the <filename>adt_installer.conf</filename> file, 
                run the installer using the following command:
                <literallayout class='monospaced'>
     $ adt_installer
                </literallayout>
            </para>

            <note>
                The ADT Installer requires the <filename>libtool</filename> package to complete.  
                If you install the recommended packages as described in the 
                <ulink url='http://www.yoctoproject.org/docs/yocto-project-qs/yocto-project-qs.html'>
                Yocto Project Quick Start</ulink> then you will have libtool installed.
            </note>

            <para>
                Once the installer begins to run you are asked whether you want to run in 
                interactive or silent mode.  
                If you want to closely monitor the installation then choose “I” for interactive 
                mode rather than “S” for silent mode.  
                Follow the prompts from the script to complete the installation.
            </para>

            <para>
                Once the installation completes, the ADT, which includes the cross-toolchain, is installed.
                You will notice environment setup files for the cross-toolchain in 
                <filename>/opt/poky/$SDKVERSION</filename>,
                and image tarballs in the <filename>adt-installer</filename>
                directory according to your installer configurations, and the target sysroot located
                according to the <filename>YOCTOADT_TARGET_SYSROOT_LOC_&lt;arch&gt;</filename> variable
                also in your configuration file.
            </para>
          
        </section>
    </section>

    <section id='using-an-existing-toolchain-tarball'>
        <title>Using a Cross-Toolchain Tarball</title>
        <para>
            If you want to simply install the cross-toolchain by hand you can do so by using an existing 
            cross-toolchain tarball.  
            If you install the cross-toolchain by hand you will have to set up the sysroot separately.
        </para>

        <para>
            Follow these steps:
            <orderedlist>
                <listitem><para>Go to  
                <ulink url='http://autobuilder.yoctoproject.org/downloads/yocto-1.0/toolchain'></ulink> 
                and find the folder that matches your host development system 
                (i.e. 'i686' for 32-bit machines or 'x86_64' for 64-bit machines).</para>
                </listitem>
                <listitem><para>Go into that folder and download the toolchain tarball whose name 
                includes the appropriate target architecture.
                For example, if your host development system is an Intel-based 64-bit system and 
                you are going to use your cross-toolchain for an arm target go into the 
                <filename>x86_64</filename> folder and download the following tarball:
                <literallayout class='monospaced'>
     yocto-eglibc-x86_64-arm-toolchain-gmae-1.0.tar.bz2
                </literallayout>
                <note>
                Alternatively you can build the toolchain tarball if you have a Yocto Project build tree.
                Use the <filename>bitbake meta-toolchain</filename> command after you have 
                sourced the <filename>poky-build-init script</filename> located in the Yocto Project 
                source directory.  
                When the <filename>bitbake</filename> command completes the toolchain tarball will 
                be in <filename>tmp/deploy/sdk</filename> in the Yocto Project build tree.
                </note></para></listitem>
                <listitem><para>Make sure you are in the root directory and then expand 
                the tarball.  
                The tarball expands into <filename>/opt/poky/$SDKVERSION</filename>.
                Once the tarball in unpacked the cross-toolchain is installed.
                You will notice environment setup files for the cross-toolchain in the directory.
                </para></listitem>
            </orderedlist>
        </para>
    </section>

    <section id='using-the-toolchain-from-within-the-build-tree'>
        <title>Using Bitbake and the Yocto Project Build Tree</title>
        <para>
            A final way of installing just the cross-toolchain is to use Bitbake within an existing 
            Yocto Project build tree.
            Follow these steps:
            <orderedlist>
                <listitem><para>Source the environment setup script located in the Yocto Project
                source directory.
                The script has the string <filename>init-build-env</filename>
                as part of the name.</para></listitem> 
                <listitem><para>At this point you should be sure that the 
                <filename>MACHINE</filename> variable 
                in the <filename>local.conf</filename> file is set for the target architecture.
                You can find the <filename>local.conf</filename> file in the Yocto Project source
                directory.
                Comments within the <filename>local.conf</filename> file list the values you 
                can use for the <filename>MACHINE</filename> variable.  
                <note>You can populate the build tree with the cross-toolchains for more 
                than a single architecture.  
                You just need to edit the <filename>MACHINE</filename> variable in the 
                <filename>local.conf</filename> file and re-run the BitBake command.</note></para></listitem>
                <listitem><para>Run <filename>bitbake meta-ide-support</filename> to complete the 
                cross-toolchain installation.
                <note>If you change your working directory after you source the environment 
                setup script and before you run the Bitbake command the command will not work. 
                Be sure to run the Bitbake command immediately after checking or editing the 
                <filename>local.conf</filename> but without changing your working directory.</note>
                Once Bitbake finishes, the cross-toolchain is installed.
                You will notice environment setup files for the cross-toolchain in the 
                Yocto Project build tree in the <filename>tmp</filename> directory.
                Setup script filenames contain the strings <filename>environment-setup</filename>.
                </para></listitem>
            </orderedlist>
        </para>
    </section>
</section>

<section id='setting-up-the-environment'>
    <title>Setting Up the Environment</title>
    <para>
        Before you can use the cross-toolchain you need to set up the toolchain environment by 
        sourcing the environment setup script.  
        If you used the ADT Installer or used an existing ADT tarball to install the ADT,
        then you can find this script in the <filename>/opt/poky/$SDKVERSION</filename>
        directory.  
        If you used Bitbake and the Yocto Project Build Tree to install the cross-toolchain
        then you can find the environment setup scripts in in the Yocto Project build tree 
        in the <filename>tmp</filename> directory.
    </para>

    <para> 
        Be sure to run the environment setup script that matches the architecture for 
        which you are developing.  
        Environment setup scripts begin with the string “environment-setup” and include as 
        part of their name the architecture.  
        For example, the environment setup script for a 64-bit IA-based architecture would 
        be the following: 
        <literallayout class='monospaced'>
     /opt/poky/1.0/environment-setup-x86_64-poky-linux
        </literallayout>
    </para>
</section>

<section id='kernels-and-filesystem-images'>
    <title>Kernels and Filesystem Images</title>
    <para>
        You will need to have a kernel and filesystem image to boot using your 
        hardware or the QEMU emulator.  
        That means you either have to build them or know where to get them.  
        You can find lots of details on how to get or build images and kernels for your 
        architecture in the "Yocto Project Quick Start" found at 
        <ulink url='http://www.yoctoproject.org/docs/yocto-quick-start/yocto-project-qs.html'></ulink>.
        <note> 
            Yocto Project provides basic kernels and filesystem images for several 
            architectures (x86, x86-64, mips, powerpc, and arm) that you can use 
            unaltered in the QEMU emulator.  
            These kernels and filesystem images reside in the Yocto Project release 
            area - <ulink url='http://autobuilder.yoctoproject.org/downloads/yocto-1.0/machines/'></ulink>
            and are ideal for experimentation within Yocto Project.
        </note>
    </para>
</section>

</chapter>
<!--
vim: expandtab tw=80 ts=4
-->