diff options
-rw-r--r-- | documentation/dev-manual/dev-manual-bsp-appendix.xml | 713 | ||||
-rw-r--r-- | documentation/dev-manual/dev-manual.xml | 2 |
2 files changed, 0 insertions, 715 deletions
diff --git a/documentation/dev-manual/dev-manual-bsp-appendix.xml b/documentation/dev-manual/dev-manual-bsp-appendix.xml deleted file mode 100644 index a4de731dfa..0000000000 --- a/documentation/dev-manual/dev-manual-bsp-appendix.xml +++ /dev/null | |||
@@ -1,713 +0,0 @@ | |||
1 | <!DOCTYPE appendix PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" | ||
2 | "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd" | ||
3 | [<!ENTITY % poky SYSTEM "../poky.ent"> %poky; ] > | ||
4 | |||
5 | <appendix id='dev-manual-bsp-appendix'> | ||
6 | |||
7 | <title>BSP Development Example</title> | ||
8 | |||
9 | <para> | ||
10 | This appendix provides a complete BSP development example. | ||
11 | The example assumes the following: | ||
12 | <itemizedlist> | ||
13 | <listitem><para>No previous preparation or use of the Yocto Project.</para></listitem> | ||
14 | <listitem><para>Use of the Fish River Island 2 Board Support Package (BSP) as a "base" BSP from | ||
15 | which to work. | ||
16 | The example begins with the Fish River Island 2 BSP as the starting point | ||
17 | but ends by building a new 'atom-pc' BSP, which was based on the Fish River Island 2 BSP. | ||
18 | </para></listitem> | ||
19 | <listitem><para>Shell commands assume <filename>bash</filename></para></listitem> | ||
20 | <listitem><para>Example was developed on an Intel-based Core i7 platform running | ||
21 | Ubuntu 10.04 LTS released in April of 2010.</para></listitem> | ||
22 | </itemizedlist> | ||
23 | </para> | ||
24 | |||
25 | <section id='getting-local-yocto-project-files-and-bsp-files'> | ||
26 | <title>Getting Local Source Files and BSP Files</title> | ||
27 | |||
28 | <para> | ||
29 | You need to have the <link linkend='source-directory'>Source Directory</link> | ||
30 | available on your host system. | ||
31 | You can set up this directory through tarball extraction or by cloning the | ||
32 | <filename>poky</filename> Git repository. | ||
33 | The following paragraphs describe both methods. | ||
34 | For additional information, see the bulleted item | ||
35 | "<link linkend='local-yp-release'>Yocto Project Release</link>". | ||
36 | </para> | ||
37 | |||
38 | <para> | ||
39 | As mentioned, one way to set up the Source Directory is to use Git to clone the | ||
40 | <filename>poky</filename> repository. | ||
41 | These commands create a local copy of the Git repository. | ||
42 | By default, the top-level directory of the repository is named <filename>poky</filename>: | ||
43 | <literallayout class='monospaced'> | ||
44 | $ git clone git://git.yoctoproject.org/poky | ||
45 | $ cd poky | ||
46 | </literallayout> | ||
47 | Alternatively, you can start with the downloaded Poky "&DISTRO_NAME;" tarball. | ||
48 | These commands unpack the tarball into a Source Directory structure. | ||
49 | By default, the top-level directory of the Source Directory is named | ||
50 | <filename>&YOCTO_POKY;</filename>: | ||
51 | <literallayout class='monospaced'> | ||
52 | $ tar xfj &YOCTO_POKY_TARBALL; | ||
53 | $ cd &YOCTO_POKY; | ||
54 | </literallayout> | ||
55 | <note><para>If you're using the tarball method, you can ignore all the following steps that | ||
56 | ask you to carry out Git operations. | ||
57 | You already have the results of those operations | ||
58 | in the form of the &DISTRO_NAME; release tarballs. | ||
59 | Consequently, there is nothing left to do other than extract those tarballs into the | ||
60 | proper locations.</para> | ||
61 | |||
62 | <para>Once you expand the released tarball, you have a snapshot of the Git repository | ||
63 | that represents a specific release. | ||
64 | Fundamentally, this is different than having a local copy of the Poky Git repository. | ||
65 | Given the tarball method, changes you make are building on top of a release. | ||
66 | With the Git repository method you have the ability to track development | ||
67 | and keep changes in revision control. | ||
68 | See the | ||
69 | "<link linkend='repositories-tags-and-branches'>Repositories, Tags, and Branches</link>" section | ||
70 | for more discussion around these differences.</para></note> | ||
71 | </para> | ||
72 | |||
73 | <para> | ||
74 | With the local <filename>poky</filename> Git repository set up, | ||
75 | you have all the development branches available to you from which you can work. | ||
76 | Next, you need to be sure that your local repository reflects the exact | ||
77 | release in which you are interested. | ||
78 | From inside the repository you can see the development branches that represent | ||
79 | areas of development that have diverged from the main (master) branch | ||
80 | at some point, such as a branch to track a maintenance release's development. | ||
81 | You can also see the tag names used to mark snapshots of stable releases or | ||
82 | points in the repository. | ||
83 | Use the following commands to list out the branches and the tags in the repository, | ||
84 | respectively. | ||
85 | <literallayout class='monospaced'> | ||
86 | $ git branch -a | ||
87 | $ git tag -l | ||
88 | </literallayout> | ||
89 | For this example, we are going to use the Yocto Project &DISTRO; Release, which is code | ||
90 | named "&DISTRO_NAME;". | ||
91 | To make sure we have a local area (branch in Git terms) on our machine that | ||
92 | reflects the &DISTRO; release, we can use the following commands: | ||
93 | <literallayout class='monospaced'> | ||
94 | $ cd ~/poky | ||
95 | $ git fetch --tags | ||
96 | $ git checkout -b &DISTRO_NAME;-&POKYVERSION; origin/&DISTRO_NAME; | ||
97 | Switched to a new branch '&DISTRO_NAME;-&POKYVERSION;' | ||
98 | </literallayout> | ||
99 | The <filename>git fetch --tags</filename> is somewhat redundant since you just set | ||
100 | up the repository and should have all the tags. | ||
101 | The <filename>fetch</filename> command makes sure all the tags are available in your | ||
102 | local repository. | ||
103 | The Git <filename>checkout</filename> command with the <filename>-b</filename> option | ||
104 | creates a local branch for you named <filename>&DISTRO_NAME;-&POKYVERSION;</filename>. | ||
105 | Your local branch begins in the same state as the Yocto Project &DISTRO; released tarball | ||
106 | marked with the <filename>&DISTRO_NAME;-&POKYVERSION;</filename> tag in the source repositories. | ||
107 | </para> | ||
108 | </section> | ||
109 | |||
110 | <section id='choosing-a-base-bsp-app'> | ||
111 | <title>Choosing a Base BSP</title> | ||
112 | |||
113 | <para> | ||
114 | For this example, the base BSP is the <trademark class='registered'>Intel</trademark> | ||
115 | <trademark class='trade'>Atom</trademark> Processor E660 with Intel Platform | ||
116 | Controller Hub EG20T Development Kit, which is otherwise referred to as "Fish River Island 2." | ||
117 | The BSP layer is <filename>meta-fri2</filename>. | ||
118 | The base BSP is simply the BSP | ||
119 | we will be using as a starting point, so don't worry if you don't actually have Fish River Island 2 | ||
120 | hardware. | ||
121 | The remainder of the example transforms the base BSP into a BSP that should be | ||
122 | able to boot on generic atom-pc (netbook) hardware. | ||
123 | </para> | ||
124 | |||
125 | <para> | ||
126 | For information on how to choose a base BSP, see | ||
127 | "<link linkend='developing-a-board-support-package-bsp'>Developing a Board Support Package (BSP)</link>". | ||
128 | </para> | ||
129 | </section> | ||
130 | |||
131 | <section id='getting-your-base-bsp-app'> | ||
132 | <title>Getting Your Base BSP</title> | ||
133 | |||
134 | <para> | ||
135 | You need to have the base BSP layer on your development system. | ||
136 | Similar to the local <link linkend='source-directory'>Source Directory</link>, | ||
137 | you can get the BSP | ||
138 | layer in a couple of different ways: | ||
139 | download the BSP tarball and extract it, or set up a local Git repository that | ||
140 | has the BSP layers. | ||
141 | You should use the same method that you used to set up the Source Directory earlier. | ||
142 | See "<link linkend='getting-setup'>Getting Setup</link>" for information on how to get | ||
143 | the BSP files. | ||
144 | </para> | ||
145 | |||
146 | <para> | ||
147 | This example assumes the BSP layer will be located within a directory named | ||
148 | <filename>meta-intel</filename> contained within the <filename>poky</filename> | ||
149 | parent directory. | ||
150 | The following steps will automatically create the | ||
151 | <filename>meta-intel</filename> directory and the contained | ||
152 | <filename>meta-fri2</filename> starting point in both the Git and the tarball cases. | ||
153 | </para> | ||
154 | |||
155 | <para> | ||
156 | If you're using the Git method, you could do the following to create | ||
157 | the starting layout after you have made sure you are in the <filename>poky</filename> | ||
158 | directory created in the previous steps: | ||
159 | <literallayout class='monospaced'> | ||
160 | $ git clone git://git.yoctoproject.org/meta-intel.git | ||
161 | $ cd meta-intel | ||
162 | </literallayout> | ||
163 | Alternatively, you can start with the downloaded Fish River Island 2 tarball. | ||
164 | You can download the &DISTRO_NAME; version of the BSP tarball from the | ||
165 | <ulink url='&YOCTO_HOME_URL;/download'>Downloads</ulink> page of the | ||
166 | Yocto Project website. | ||
167 | Here is the specific link for the tarball needed for this example: | ||
168 | <ulink url='&YOCTO_MACHINES_DL_URL;/fri2-noemgd/fri2-noemgd-&DISTRO_NAME;-&POKYVERSION;.tar.bz2'></ulink>. | ||
169 | Again, be sure that you are already in the <filename>poky</filename> directory | ||
170 | as described previously before installing the tarball: | ||
171 | <literallayout class='monospaced'> | ||
172 | $ tar xfj fri2-noemgd-&DISTRO_NAME;-&POKYVERSION;.tar.bz2 | ||
173 | $ cd meta-intel | ||
174 | </literallayout> | ||
175 | </para> | ||
176 | |||
177 | <para> | ||
178 | The <filename>meta-intel</filename> directory contains all the metadata | ||
179 | that supports BSP creation. | ||
180 | If you're using the Git method, the following | ||
181 | step will switch to the &DISTRO_NAME; metadata. | ||
182 | If you're using the tarball method, you already have the correct metadata and can | ||
183 | skip to the next step. | ||
184 | Because <filename>meta-intel</filename> is its own Git repository, you will want | ||
185 | to be sure you are in the appropriate branch for your work. | ||
186 | For this example we are going to use the <filename>&DISTRO_NAME;</filename> | ||
187 | branch. | ||
188 | <literallayout class='monospaced'> | ||
189 | $ git checkout -b &DISTRO_NAME;-&POKYVERSION; origin/&DISTRO_NAME; | ||
190 | Branch &DISTRO_NAME;-&POKYVERSION; set up to track remote branch &DISTRO_NAME; from origin. | ||
191 | Switched to a new branch '&DISTRO_NAME;-&POKYVERSION;' | ||
192 | </literallayout> | ||
193 | </para> | ||
194 | </section> | ||
195 | |||
196 | <section id='making-a-copy-of-the-base bsp-to-create-your-new-bsp-layer-app'> | ||
197 | <title>Making a Copy of the Base BSP to Create Your New BSP Layer</title> | ||
198 | |||
199 | <para> | ||
200 | Now that you have set up the Source Directory and included the base BSP files, you need to | ||
201 | create a new layer for your BSP. | ||
202 | To create your BSP layer, you simply copy the <filename>meta-fri2</filename> | ||
203 | layer to a new layer. | ||
204 | </para> | ||
205 | |||
206 | <para> | ||
207 | For this example, the new layer will be named <filename>meta-mymachine</filename>. | ||
208 | The name should follow the BSP layer naming convention, which is | ||
209 | <filename>meta-<name></filename>. | ||
210 | The following assumes your working directory is <filename>meta-intel</filename> | ||
211 | inside your Source Directory. | ||
212 | To start your new layer, just copy the new layer alongside the existing | ||
213 | BSP layers in the <filename>meta-intel</filename> directory: | ||
214 | <literallayout class='monospaced'> | ||
215 | $ cp -a meta-fri2/ meta-mymachine | ||
216 | </literallayout> | ||
217 | </para> | ||
218 | </section> | ||
219 | |||
220 | <section id='making-changes-to-your-bsp-app'> | ||
221 | <title>Making Changes to Your BSP</title> | ||
222 | |||
223 | <para> | ||
224 | Right now you have two identical BSP layers with different names: | ||
225 | <filename>meta-fri2</filename> and <filename>meta-mymachine</filename>. | ||
226 | You need to change your configurations so that they work for your new BSP and | ||
227 | your particular hardware. | ||
228 | The following sections look at each of these areas of the BSP. | ||
229 | </para> | ||
230 | |||
231 | <section id='changing-the-bsp-configuration'> | ||
232 | <title>Changing the BSP Configuration</title> | ||
233 | |||
234 | <para> | ||
235 | We will look first at the configurations, which are all done in the layer’s | ||
236 | <filename>conf</filename> directory. | ||
237 | </para> | ||
238 | |||
239 | <para> | ||
240 | First, since in this example the new BSP will not support EMGD, we will get rid of the | ||
241 | <filename>fri2.conf</filename> file and then rename the | ||
242 | <filename>fri2-noemgd.conf</filename> file to <filename>mymachine.conf</filename>. | ||
243 | Much of what we do in the configuration directory is designed to help the OpenEmbedded | ||
244 | build system work with the new layer and to be able to find and use the right software. | ||
245 | The following two commands result in a single machine configuration file named | ||
246 | <filename>mymachine.conf</filename>. | ||
247 | <literallayout class='monospaced'> | ||
248 | $ rm meta-mymachine/conf/machine/fri2.conf | ||
249 | $ mv meta-mymachine/conf/machine/fri2-noemgd.conf \ | ||
250 | meta-mymachine/conf/machine/mymachine.conf | ||
251 | </literallayout> | ||
252 | </para> | ||
253 | |||
254 | <para> | ||
255 | Next, we need to make changes to the <filename>mymachine.conf</filename> itself. | ||
256 | The only changes we want to make for this example are to the comment lines. | ||
257 | Changing comments, of course, is never strictly necessary, but it's always good form to make | ||
258 | them reflect reality as much as possible. | ||
259 | |||
260 | Here, simply substitute the Fish River Island 2 name with an appropriate name for the BSP | ||
261 | (<filename>mymachine</filename> in this case) and change the description to | ||
262 | something that describes your hardware. | ||
263 | </para> | ||
264 | |||
265 | <para> | ||
266 | Note that inside the <filename>mymachine.conf</filename> is the | ||
267 | <filename>PREFERRED_VERSION_linux-yocto</filename> statement. | ||
268 | This statement identifies the kernel that the BSP is going to use. | ||
269 | In this case, the BSP is using <filename>linux-yocto</filename>, which is the | ||
270 | current Yocto Project kernel based on the Linux 3.4 release. | ||
271 | </para> | ||
272 | |||
273 | <para> | ||
274 | The next configuration file in the new BSP layer we need to edit is | ||
275 | <filename>meta-mymachine/conf/layer.conf</filename>. | ||
276 | This file identifies build information needed for the new layer. | ||
277 | You can see the | ||
278 | "<ulink url='&YOCTO_DOCS_BSP_URL;#bsp-filelayout-layer'>Layer Configuration File</ulink>" section | ||
279 | in The Board Support Packages (BSP) Development Guide for more information on this configuration file. | ||
280 | Basically, we are changing the existing statements to work with our BSP. | ||
281 | </para> | ||
282 | |||
283 | <para> | ||
284 | The file contains these statements that reference the Fish River Island 2 BSP: | ||
285 | <literallayout class='monospaced'> | ||
286 | BBFILE_COLLECTIONS += "fri2" | ||
287 | BBFILE_PATTERN_fri2 := "^${LAYERDIR}/" | ||
288 | BBFILE_PRIORITY_fri2 = "6" | ||
289 | |||
290 | LAYERDEPENDS_fri2 = "intel" | ||
291 | </literallayout> | ||
292 | </para> | ||
293 | |||
294 | <para> | ||
295 | Simply substitute the machine string name <filename>fri2</filename> | ||
296 | with the new machine name <filename>mymachine</filename> to get the following: | ||
297 | <literallayout class='monospaced'> | ||
298 | BBFILE_COLLECTIONS += "mymachine" | ||
299 | BBFILE_PATTERN_mymachine := "^${LAYERDIR}/" | ||
300 | BBFILE_PRIORITY_mymachine = "6" | ||
301 | |||
302 | LAYERDEPENDS_mymachine = "intel" | ||
303 | </literallayout> | ||
304 | </para> | ||
305 | </section> | ||
306 | |||
307 | <section id='changing-the-recipes-in-your-bsp'> | ||
308 | <title>Changing the Recipes in Your BSP</title> | ||
309 | |||
310 | <para> | ||
311 | Now we will take a look at the recipes in your new layer. | ||
312 | The standard BSP structure has areas for BSP, graphics, core, and kernel recipes. | ||
313 | When you create a BSP, you use these areas for appropriate recipes and append files. | ||
314 | Recipes take the form of <filename>.bb</filename> files, while append files take | ||
315 | the form of <filename>.bbappend</filename> files. | ||
316 | If you want to leverage the existing recipes the OpenEmbedded build system uses | ||
317 | but change those recipes, you can use <filename>.bbappend</filename> files. | ||
318 | All new recipes and append files for your layer must go in the layer’s | ||
319 | <filename>recipes-bsp</filename>, <filename>recipes-kernel</filename>, | ||
320 | <filename>recipes-core</filename>, and | ||
321 | <filename>recipes-graphics</filename> directories. | ||
322 | </para> | ||
323 | |||
324 | <section id='changing-recipes-bsp'> | ||
325 | <title>Changing <filename>recipes-bsp</filename></title> | ||
326 | |||
327 | <para> | ||
328 | First, let's look at <filename>recipes-bsp</filename>. | ||
329 | For this example we are not adding any new BSP recipes. | ||
330 | And, we only need to remove the formfactor we do not want and change the name of | ||
331 | the remaining one that doesn't support EMGD. | ||
332 | These commands take care of the <filename>recipes-bsp</filename> recipes: | ||
333 | <literallayout class='monospaced'> | ||
334 | $ rm -rf meta-mymachine/recipes-bsp/formfactor/formfactor/fri2 | ||
335 | $ mv meta-mymachine/recipes-bsp/formfactor/formfactor/fri2-noemgd/ \ | ||
336 | meta-mymachine/recipes-bsp/formfactor/formfactor/mymachine | ||
337 | </literallayout> | ||
338 | </para> | ||
339 | </section> | ||
340 | |||
341 | <section id='changing-recipes-graphics'> | ||
342 | <title>Changing <filename>recipes-graphics</filename></title> | ||
343 | |||
344 | <para> | ||
345 | Now let's look at <filename>recipes-graphics</filename>. | ||
346 | For this example we want to remove anything that supports EMGD and | ||
347 | be sure to rename remaining directories appropriately. | ||
348 | The following commands clean up the <filename>recipes-graphics</filename> directory: | ||
349 | <literallayout class='monospaced'> | ||
350 | $ rm -rf meta-mymachine/recipes-graphics/xorg-xserver/xserver-xf86-config/fri2 | ||
351 | $ mv meta-mymachine/recipes-graphics/xorg-xserver/xserver-xf86-config/fri2-noemgd \ | ||
352 | meta-mymachine/recipes-graphics/xorg-xserver/xserver-xf86-config/mymachine | ||
353 | </literallayout> | ||
354 | </para> | ||
355 | |||
356 | <para> | ||
357 | At this point the <filename>recipes-graphics</filename> directory just has files that | ||
358 | support Video Electronics Standards Association (VESA) graphics modes and not EMGD. | ||
359 | </para> | ||
360 | </section> | ||
361 | |||
362 | <section id='changing-recipes-kernel'> | ||
363 | <title>Changing <filename>recipes-kernel</filename></title> | ||
364 | |||
365 | <para> | ||
366 | Finally, let's look at <filename>recipes-kernel</filename> changes. | ||
367 | Recall that the BSP uses the <filename>linux-yocto</filename> kernel as determined | ||
368 | earlier in the <filename>mymachine.conf</filename>. | ||
369 | The recipe for that kernel is not located in the | ||
370 | BSP layer but rather in the Source Directory at | ||
371 | <filename>meta/recipes-kernel/linux</filename> and is | ||
372 | named <filename>linux-yocto_3.4.bb</filename>. | ||
373 | The <filename>SRCREV_machine</filename> and <filename>SRCREV_meta</filename> | ||
374 | statements point to the exact commits used by the Yocto Project development team | ||
375 | in their source repositories that identify the right kernel for our hardware. | ||
376 | In other words, the <filename>SRCREV</filename> values are simply Git commit | ||
377 | IDs that identify which commit on each | ||
378 | of the kernel branches (machine and meta) will be checked out and used to build | ||
379 | the kernel. | ||
380 | </para> | ||
381 | |||
382 | <para> | ||
383 | However, in the <filename>meta-mymachine</filename> layer in | ||
384 | <filename>recipes-kernel/linux</filename> resides a <filename>.bbappend</filename> | ||
385 | file named <filename>linux-yocto_3.4.bbappend</filename> that | ||
386 | appends the information to the recipe of the same name | ||
387 | that is found in <filename>meta/recipes-kernel/linux</filename>. | ||
388 | Thus, the <filename>SRCREV</filename> statements in our | ||
389 | <filename>mymachine</filename> append file override | ||
390 | the more general statements found in the more general recipe. | ||
391 | </para> | ||
392 | |||
393 | <para> | ||
394 | The <filename>SRCREV</filename> statements in the | ||
395 | <filename>mymachine</filename> append file currently identify | ||
396 | the kernel that supports the Fish River Island 2 BSP with and without EMGD support. | ||
397 | Here are the statements: | ||
398 | <note>The commit ID strings used in this manual might not match the actual commit | ||
399 | ID strings found in the <filename>linux-yocto_3.4.bbappend</filename> file. | ||
400 | For the example, this difference does not matter.</note> | ||
401 | <literallayout class='monospaced'> | ||
402 | SRCREV_machine_pn-linux-yocto_fri2 ?= \ | ||
403 | "59c3ff750831338d05ab67d5efd7fc101c451aff" | ||
404 | #SRCREV_meta_pn-linux-yocto_fri2 ?= \ | ||
405 | "c5bddf8ea379406ffec550528e17b777a0eba24b" | ||
406 | |||
407 | SRCREV_machine_pn-linux-yocto_fri2-noemgd ?= \ | ||
408 | "59c3ff750831338d05ab67d5efd7fc101c451aff" | ||
409 | #SRCREV_meta_pn-linux-yocto_fir2-noemgd ?= \ | ||
410 | "c5bddf8ea379406ffec550528e17b777a0eba24b" | ||
411 | </literallayout> | ||
412 | <note>The <filename>SRCREV_meta_pn-linux-yocto_fir2-noemgd</filename> | ||
413 | statements in the <filename>mymachine</filename> append file, | ||
414 | which originated from the Fish River Island 2 BSP, are | ||
415 | commented out. | ||
416 | The reason they are not used is because the commit IDs are identical to | ||
417 | those in the general <filename>linux-yocto_3.4.bbappend</filename> recipe, | ||
418 | which is found in <filename>meta/recipes-kernel/linux</filename>. | ||
419 | </note> | ||
420 | </para> | ||
421 | |||
422 | <para> | ||
423 | You will notice that there are two pairs of <filename>SRCREV</filename> statements. | ||
424 | The top pair identifies the kernel that supports | ||
425 | EMGD, which we don’t care about in this example. | ||
426 | The bottom pair identifies the kernel that we will use: | ||
427 | <filename>linux-yocto</filename>. | ||
428 | At this point though, the unique commit strings all are still associated with | ||
429 | Fish River Island 2 and not <filename>meta-mymachine</filename>. | ||
430 | </para> | ||
431 | |||
432 | <para> | ||
433 | To fix this situation in <filename>linux-yocto_3.4.bbappend</filename> | ||
434 | for <filename>mymachine</filename>, | ||
435 | we delete the two <filename>SRCREV</filename> statements that support | ||
436 | EMGD (the top pair). | ||
437 | We also change the remaining pair to specify <filename>mymachine</filename> | ||
438 | and insert the commit identifiers to identify the kernel in which we | ||
439 | are interested, which will be based on the <filename>atom-pc-standard</filename> | ||
440 | kernel. | ||
441 | In this case, because we're working with the &DISTRO_NAME; branch of everything, we | ||
442 | need to use the <filename>SRCREV</filename> values for the atom-pc branch | ||
443 | that are associated with the &DISTRO_NAME; release. | ||
444 | </para> | ||
445 | |||
446 | <para> | ||
447 | To find the machine value, we need to find the <filename>SRCREV</filename> | ||
448 | value that &DISTRO_NAME; uses for the atom-pc branch, which we find in the | ||
449 | <filename>poky/meta-yocto-bsp/recipes-kernel/linux/linux-yocto_3.4.bbappend</filename> | ||
450 | file. | ||
451 | The machine <filename>SRCREV</filename> we want is in the | ||
452 | <filename>SRCREV_machine_atom-pc</filename> variable. | ||
453 | </para> | ||
454 | |||
455 | <para> | ||
456 | The meta <filename>SRCREV</filename> isn't specified in this file, so if you | ||
457 | needed it, you would find it in the base kernel recipe in the | ||
458 | <filename>poky/meta/recipes-kernel/linux/linux-yocto_3.4.bb</filename>. | ||
459 | Recall that for this example the commit ID's for the <filename>SRCREV</filename> | ||
460 | meta statements are identical and do not have to be used in the | ||
461 | <filename>mymachine</filename> append file. | ||
462 | </para> | ||
463 | |||
464 | <para> | ||
465 | Here are the final <filename>SRCREV</filename> statements for the | ||
466 | <filename>mymachine</filename> append file: | ||
467 | <literallayout class='monospaced'> | ||
468 | SRCREV_machine_pn-linux-yocto_mymachine ?= \ | ||
469 | "0985844fa6235422c67ef269952fa4e765f252f9" | ||
470 | #SRCREV_meta_pn-linux-yocto_mymachine ?= \ | ||
471 | "c5bddf8ea379406ffec550528e17b777a0eba24b" | ||
472 | </literallayout> | ||
473 | </para> | ||
474 | |||
475 | <para> | ||
476 | In this example, we're using the <filename>SRCREV</filename> values we | ||
477 | found already captured in the &DISTRO_NAME; release because we're creating a BSP based on | ||
478 | &DISTRO_NAME;. | ||
479 | If, instead, we had based our BSP on the master branches, we would want to use | ||
480 | the most recent <filename>SRCREV</filename> values taken directly from the kernel's | ||
481 | repository. | ||
482 | We will not be doing that for this example. | ||
483 | However, if you do base a future BSP on master and | ||
484 | if you are familiar with Git repositories, you probably won’t have trouble locating the | ||
485 | exact commit strings in the Yocto Project source repositories you need to change | ||
486 | the <filename>SRCREV</filename> statements. | ||
487 | You can find all the <filename>machine</filename> and <filename>meta</filename> | ||
488 | branch points (commits) for the <filename>linux-yocto-3.4</filename> kernel at | ||
489 | <ulink url='&YOCTO_GIT_URL;/cgit/cgit.cgi/linux-yocto-3.4'></ulink>. | ||
490 | </para> | ||
491 | |||
492 | <para> | ||
493 | If you need a little more assistance after going to the link then do the following: | ||
494 | <orderedlist> | ||
495 | <listitem><para>Expand the list of branches by clicking <filename>[…]</filename></para></listitem> | ||
496 | <listitem><para>Click on the <filename>standard/default/common-pc/atom-pc</filename> | ||
497 | branch</para></listitem> | ||
498 | <listitem><para>Click on the commit column header to view the top commit</para></listitem> | ||
499 | <listitem><para>Copy the commit string for use in the | ||
500 | <filename>linux-yocto_3.4.bbappend</filename> file</para></listitem> | ||
501 | </orderedlist> | ||
502 | </para> | ||
503 | |||
504 | <para> | ||
505 | For the <filename>SRCREV</filename> statement that points to the <filename>meta</filename> | ||
506 | branch use the same procedure except expand the <filename>meta</filename> | ||
507 | branch in step 2 above. | ||
508 | </para> | ||
509 | |||
510 | <para> | ||
511 | Also in the <filename>linux-yocto_3.4.bbappend</filename> file are | ||
512 | <ulink url='&YOCTO_DOCS_REF_URL;#var-COMPATIBLE_MACHINE'><filename>COMPATIBLE_MACHINE</filename></ulink>, | ||
513 | <ulink url='&YOCTO_DOCS_REF_URL;#var-KMACHINE'><filename>KMACHINE</filename></ulink>, | ||
514 | and | ||
515 | <ulink url='&YOCTO_DOCS_REF_URL;#var-KBRANCH'><filename>KBRANCH</filename></ulink> statements. | ||
516 | Two sets of these exist: one set supports EMGD and one set does not. | ||
517 | Because we are not interested in supporting EMGD those three can be deleted. | ||
518 | The remaining three must be changed so that <filename>mymachine</filename> replaces | ||
519 | <filename>fri2-noemgd</filename> and <filename>fri2</filename>. | ||
520 | </para> | ||
521 | |||
522 | <para> | ||
523 | Because we are using the <filename>atom-pc</filename> branch for this new BSP, we can also find | ||
524 | the exact branch we need for the <filename>KMACHINE</filename> | ||
525 | and <filename>KBRANCH</filename> variables in our new BSP from the value | ||
526 | we find in the | ||
527 | <filename>poky/meta-yocto-bsp/recipes-kernel/linux/linux-yocto_3.4.bbappend</filename> | ||
528 | file we looked at in a previous step. | ||
529 | In this case, the values we want are in the <filename>KMACHINE_atom-pc</filename> variable | ||
530 | and the <filename>KBRANCH_atom-pc</filename> variables in that file. | ||
531 | Here is the final <filename>linux-yocto_3.4.bbappend</filename> file after all | ||
532 | the edits: | ||
533 | <literallayout class='monospaced'> | ||
534 | FILESEXTRAPATHS_prepend := "${THISDIR}/${PN}:" | ||
535 | |||
536 | COMPATIBLE_MACHINE_mymachine = "mymachine" | ||
537 | KMACHINE_mymachine = "atom-pc" | ||
538 | KBRANCH_mymachine = "standard/default/common-pc/atom-pc" | ||
539 | |||
540 | SRCREV_machine_pn-linux-yocto_mymachine ?= \ | ||
541 | "f29531a41df15d74be5ad47d958e4117ca9e489e" | ||
542 | SRCREV_meta_pn-linux-yocto_mymachine ?= \ | ||
543 | "b14a08f5c7b469a5077c10942f4e1aec171faa9d" | ||
544 | </literallayout> | ||
545 | </para> | ||
546 | </section> | ||
547 | </section> | ||
548 | |||
549 | <section id='bsp-recipe-change-summary'> | ||
550 | <title>BSP Recipe Change Summary</title> | ||
551 | |||
552 | <para> | ||
553 | In summary, the edits to the layer’s recipe files result in removal of any files and | ||
554 | statements that do not support your targeted hardware in addition to the inclusion | ||
555 | of any new recipes you might need. | ||
556 | In this example, it was simply a matter of ridding the new layer | ||
557 | <filename>meta-mymachine</filename> of any code that supported the EMGD features | ||
558 | and making sure we were identifying the kernel that supports our example, which | ||
559 | is the <filename>atom-pc-standard</filename> kernel. | ||
560 | We did not introduce any new recipes to the layer. | ||
561 | </para> | ||
562 | |||
563 | <para> | ||
564 | Finally, it is also important to update the layer’s <filename>README</filename> | ||
565 | file so that the information in it reflects your BSP. | ||
566 | </para> | ||
567 | </section> | ||
568 | </section> | ||
569 | |||
570 | <section id='preparing-for-the-build-app'> | ||
571 | <title>Preparing for the Build</title> | ||
572 | |||
573 | <para> | ||
574 | To get ready to build your image that uses the new layer you need to do the following: | ||
575 | <orderedlist> | ||
576 | <listitem><para>Get the environment ready for the build by sourcing the environment | ||
577 | script. | ||
578 | The environment script is in the top-level of the Source Directory. | ||
579 | The script has the string | ||
580 | <filename>init-build-env</filename> in the file’s name. | ||
581 | For this example, the following command gets the build environment ready: | ||
582 | <literallayout class='monospaced'> | ||
583 | $ source oe-init-build-env yocto-build | ||
584 | </literallayout> | ||
585 | When you source the script, a build directory is created in the current | ||
586 | working directory. | ||
587 | In our example we were in the <filename>poky</filename> directory. | ||
588 | Thus, entering the previous command created the <filename>yocto-build</filename> directory. | ||
589 | If you do not provide a name for the build directory it defaults to | ||
590 | <filename>build</filename>. | ||
591 | The <filename>yocto-build</filename> directory contains a | ||
592 | <filename>conf</filename> directory that has | ||
593 | two configuration files you will need to check: <filename>bblayers.conf</filename> | ||
594 | and <filename>local.conf</filename>.</para></listitem> | ||
595 | <listitem><para>Check and edit the resulting <filename>local.conf</filename> file. | ||
596 | This file minimally identifies the machine for which to build the image by | ||
597 | configuring the <filename>MACHINE</filename> variable. | ||
598 | For this example you must set the variable to mymachine as follows: | ||
599 | <literallayout class='monospaced'> | ||
600 | MACHINE ??= “mymachine” | ||
601 | </literallayout> | ||
602 | You should also be sure any other variables in which you are interested are set. | ||
603 | Some variables to consider are <filename>BB_NUMBER_THREADS</filename> | ||
604 | and <filename>PARALLEL_MAKE</filename>, both of which can greatly reduce your build time | ||
605 | if your development system supports multiple cores. | ||
606 | For development systems that support multiple cores, a good rule of thumb is to set | ||
607 | both the <filename>BB_NUMBER_THREADS</filename> and <filename>PARALLEL_MAKE</filename> | ||
608 | variables to twice the number of cores your system supports.</para></listitem> | ||
609 | <listitem><para>Update the <filename>bblayers.conf</filename> file so that it includes | ||
610 | both the path to your new BSP layer and the path to the | ||
611 | <filename>meta-intel</filename> layer. | ||
612 | In this example, you need to include both these paths as part of the | ||
613 | <filename>BBLAYERS</filename> variable: | ||
614 | <literallayout class='monospaced'> | ||
615 | $HOME/poky/meta-intel | ||
616 | $HOME/poky/meta-intel/meta-mymachine | ||
617 | </literallayout></para></listitem> | ||
618 | </orderedlist> | ||
619 | </para> | ||
620 | |||
621 | <para> | ||
622 | The | ||
623 | <ulink url='&YOCTO_DOCS_REF_URL;#ref-variables-glos'>Variables Glossary</ulink> chapter in the | ||
624 | Yocto Project Reference Manual has more information on configuration variables. | ||
625 | </para> | ||
626 | </section> | ||
627 | |||
628 | <section id='building-the-image-app'> | ||
629 | <title>Building and Booting the Image</title> | ||
630 | |||
631 | <para> | ||
632 | To build the image for our <filename>meta-mymachine</filename> BSP enter the following command | ||
633 | from the same shell from which you ran the setup script. | ||
634 | You should run the <filename>bitbake</filename> command without any intervening shell commands. | ||
635 | For example, moving your working directory around could cause problems. | ||
636 | Here is the command for this example: | ||
637 | <literallayout class='monospaced'> | ||
638 | $ bitbake -k core-image-sato | ||
639 | </literallayout> | ||
640 | </para> | ||
641 | |||
642 | <para> | ||
643 | This command specifies an image that has Sato support and that can be run from a USB device or | ||
644 | from a CD without having to first install anything. | ||
645 | The build process takes significant time and includes thousands of tasks, which are reported | ||
646 | at the console. | ||
647 | If the build results in any type of error you should check for misspellings in the | ||
648 | files you changed or problems with your host development environment such as missing packages. | ||
649 | </para> | ||
650 | |||
651 | <para> | ||
652 | Finally, once you have an image, you can try booting it from a device | ||
653 | (e.g. a USB device). | ||
654 | To prepare a bootable USB device, insert a USB flash drive into your build system and | ||
655 | copy the <filename>.hddimg</filename> file, located in the | ||
656 | <filename>poky/build/tmp/deploy/images</filename> | ||
657 | directory after a successful build to the flash drive. | ||
658 | Assuming the USB flash drive takes device <filename>/dev/sdf</filename>, | ||
659 | use <filename>dd</filename> to copy the live image to it. | ||
660 | For example: | ||
661 | <literallayout class='monospaced'> | ||
662 | # dd if=core-image-sato-mymachine-20111101223904.hddimg of=/dev/sdf | ||
663 | # sync | ||
664 | # eject /dev/sdf | ||
665 | </literallayout> | ||
666 | You should now have a bootable USB flash device. | ||
667 | </para> | ||
668 | |||
669 | <para> | ||
670 | Insert the device | ||
671 | into a bootable USB socket on the target, and power it on. | ||
672 | The system should boot to the Sato graphical desktop. | ||
673 | <footnote><para>Because | ||
674 | this new image is not in any way tailored to the system you're | ||
675 | booting it on, which is assumed to be some sort of atom-pc (netbook) system for this | ||
676 | example, it might not be completely functional though it should at least boot to a text | ||
677 | prompt. | ||
678 | Specifically, it might fail to boot into graphics without some tweaking. | ||
679 | If this ends up being the case, a possible next step would be to replace the | ||
680 | <filename>mymachine.conf</filename> | ||
681 | contents with the contents of <filename>atom-pc.conf</filename> and replace | ||
682 | <filename>xorg.conf</filename> with <filename>atom-pc xorg.conf</filename> | ||
683 | in <filename>meta-yocto</filename> and see if it fares any better. | ||
684 | In any case, following the previous steps will give you a buildable image that | ||
685 | will probably boot on most systems. | ||
686 | Getting things working like you want | ||
687 | them to for your hardware will normally require some amount of experimentation with | ||
688 | configuration settings.</para></footnote> | ||
689 | </para> | ||
690 | |||
691 | <para> | ||
692 | For reference, the sato image produced by the previous steps for &DISTRO_NAME; | ||
693 | should look like the following in terms of size. | ||
694 | If your sato image is much different from this, | ||
695 | you probably made a mistake in one of the above steps: | ||
696 | <literallayout class='monospaced'> | ||
697 | 260538368 2012-04-27 01:44 core-image-sato-mymachine-20120427025051.hddimg | ||
698 | </literallayout> | ||
699 | <note>The previous instructions are also present in the README that was copied | ||
700 | from meta-fri2, which should also be updated to reflect the specifics of your | ||
701 | new BSP. | ||
702 | That file and the <filename>README.hardware</filename> file in the top-level | ||
703 | <filename>poky</filename> directory | ||
704 | also provides some suggestions for things to try if booting fails and produces | ||
705 | strange error messages.</note> | ||
706 | </para> | ||
707 | </section> | ||
708 | </appendix> | ||
709 | |||
710 | |||
711 | <!-- | ||
712 | vim: expandtab tw=80 ts=4 | ||
713 | --> | ||
diff --git a/documentation/dev-manual/dev-manual.xml b/documentation/dev-manual/dev-manual.xml index 0cbd85fc3b..a5856e0995 100644 --- a/documentation/dev-manual/dev-manual.xml +++ b/documentation/dev-manual/dev-manual.xml | |||
@@ -80,8 +80,6 @@ | |||
80 | 80 | ||
81 | <xi:include href="dev-manual-model.xml"/> | 81 | <xi:include href="dev-manual-model.xml"/> |
82 | 82 | ||
83 | <xi:include href="dev-manual-bsp-appendix.xml"/> | ||
84 | |||
85 | <xi:include href="dev-manual-kernel-appendix.xml"/> | 83 | <xi:include href="dev-manual-kernel-appendix.xml"/> |
86 | 84 | ||
87 | </book> | 85 | </book> |