summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorScott Rifenbark <scott.m.rifenbark@intel.com>2013-03-19 14:41:41 -0700
committerRichard Purdie <richard.purdie@linuxfoundation.org>2013-03-22 17:08:42 +0000
commit70583639c462fb4d303cf392927498daacc904f7 (patch)
tree146f1dd3c422413f26360658c1b50b916dccf484
parentac15c28151a89b2dc60b037e8e99214349952c8b (diff)
downloadpoky-70583639c462fb4d303cf392927498daacc904f7.tar.gz
dev-manual: second pass of poky-tiny section.
(From yocto-docs rev: 44be6fdc992809846fcaade8986c1a1323c14f0c) 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.xml243
1 files changed, 209 insertions, 34 deletions
diff --git a/documentation/dev-manual/dev-manual-common-tasks.xml b/documentation/dev-manual/dev-manual-common-tasks.xml
index 39da63436f..a6aa8fafbe 100644
--- a/documentation/dev-manual/dev-manual-common-tasks.xml
+++ b/documentation/dev-manual/dev-manual-common-tasks.xml
@@ -2086,7 +2086,7 @@
2086 You can include nearly any variable from the 2086 You can include nearly any variable from the
2087 <filename>local.conf</filename> file. 2087 <filename>local.conf</filename> file.
2088 The variables you use are not limited to the list in the 2088 The variables you use are not limited to the list in the
2089 previous bulletted item.</para></listitem> 2089 previous bulleted item.</para></listitem>
2090 <listitem><para><emphasis>Point to Your Distribution Configuration File:</emphasis> 2090 <listitem><para><emphasis>Point to Your Distribution Configuration File:</emphasis>
2091 In your <filename>local.conf</filename> file in the 2091 In your <filename>local.conf</filename> file in the
2092 <link linkend='build-directory'>Build Directory</link>, 2092 <link linkend='build-directory'>Build Directory</link>,
@@ -2130,22 +2130,14 @@
2130 <section id='building-a-tiny-system'> 2130 <section id='building-a-tiny-system'>
2131 <title>Building a Tiny System</title> 2131 <title>Building a Tiny System</title>
2132 2132
2133 <literallayout class='monospaced'>
2134 * Introduction that tells what, why, and benefits
2135 * Overview of the process
2136 * Cutting back on the kernel size
2137 * Cutting back on the filesystem (libc and busybox)
2138 </literallayout>
2139
2140 <para> 2133 <para>
2141 Very small distributions have some significant advantages such 2134 Very small distributions have some significant advantages such
2142 requiring less on-die memory (cheaper), better performance through 2135 as requiring less on-die memory (cheaper), better performance
2143 efficient cache usage, lower power requirements due to less 2136 through efficient cache usage, lower power requirements due to less
2144 memory, faster boot times, and reduced development overhead. 2137 memory, faster boot times, and reduced development overhead.
2145 Some real-world examples where a very small distribution gives 2138 Some real-world examples where a very small distribution gives
2146 you distinct advantages are digital cameras, medical devices, 2139 you distinct advantages are digital cameras, medical devices,
2147 small headless systems, and partitioned flash. 2140 small headless systems, and partitioned flash.
2148 You can use the Yocto Project to create very small distribution.
2149 </para> 2141 </para>
2150 2142
2151 <para> 2143 <para>
@@ -2167,11 +2159,13 @@
2167 <itemizedlist> 2159 <itemizedlist>
2168 <listitem><para>Determine your goals and guiding 2160 <listitem><para>Determine your goals and guiding
2169 principles.</para></listitem> 2161 principles.</para></listitem>
2170 <listitem><para>Know what you are starting with. 2162 <listitem><para>Understand what gives your image size.
2171 </para></listitem> 2163 </para></listitem>
2172 <listitem><para>Trim the root filesystem. 2164 <listitem><para>Reduce the size of the root filesystem.
2173 </para></listitem> 2165 </para></listitem>
2174 <listitem><para>Trim the kernel</para></listitem> 2166 <listitem><para>Reduce the size of the kernel.
2167 </para></listitem>
2168 <listitem><para>Iterate on the process.</para></listitem>
2175 </itemizedlist> 2169 </itemizedlist>
2176 </para> 2170 </para>
2177 </section> 2171 </section>
@@ -2190,15 +2184,15 @@
2190 a root filesystem that is 3 Mbytes or less). 2184 a root filesystem that is 3 Mbytes or less).
2191 </para></listitem> 2185 </para></listitem>
2192 <listitem><para>Find the areas that are currently 2186 <listitem><para>Find the areas that are currently
2193 taking 90% of the space and concentrate on that 2187 taking 90% of the space and concentrate on reducing
2194 for trimming. 2188 those areas.
2195 </para></listitem> 2189 </para></listitem>
2196 <listitem><para>Do not create any difficult "hacks" 2190 <listitem><para>Do not create any difficult "hacks"
2197 to achieve your goals.</para></listitem> 2191 to achieve your goals.</para></listitem>
2198 <listitem><para>Leverage of the device-specific 2192 <listitem><para>Leverage off the device-specific
2199 options.</para></listitem> 2193 options.</para></listitem>
2200 <listitem><para>Do your work in a separate layer 2194 <listitem><para>Work in a separate layer so that you
2201 to keep changes isolated. 2195 keep changes isolated.
2202 For information on how to create layers, see 2196 For information on how to create layers, see
2203 the "<link linkend='understanding-and-creating-layers'>Understanding and Creating Layers</link>" section. 2197 the "<link linkend='understanding-and-creating-layers'>Understanding and Creating Layers</link>" section.
2204 </para></listitem> 2198 </para></listitem>
@@ -2206,8 +2200,8 @@
2206 </para> 2200 </para>
2207 </section> 2201 </section>
2208 2202
2209 <section id='know-what-you-are-starting-with'> 2203 <section id='understand-what-gives-your-image-size'>
2210 <title>Know What You Are Starting With</title> 2204 <title>Understand What Gives Your Image Size</title>
2211 2205
2212 <para> 2206 <para>
2213 You will need to have an image from which you can 2207 You will need to have an image from which you can
@@ -2218,27 +2212,30 @@
2218 that works with two shipped Board Support Packages (BSPs): 2212 that works with two shipped Board Support Packages (BSPs):
2219 Fish River Island 2 and QEMU. 2213 Fish River Island 2 and QEMU.
2220 You can use this distribution as a starting point and trim 2214 You can use this distribution as a starting point and trim
2221 down from there. 2215 the size down from there.
2222 If you need to build out the <filename>poky-tiny</filename> 2216 If you need to build out the <filename>poky-tiny</filename>
2223 distribution, see the 2217 distribution, see the
2224 "<link linkend='creating-your-own-distribution'>Creating Your Own Distribution</link>" 2218 "<link linkend='creating-your-own-distribution'>Creating Your Own Distribution</link>"
2225 section. 2219 section for information.
2226 </para> 2220 </para>
2227 2221
2228 <para> 2222 <para>
2229 Understanding some memory concepts will help you reduce the 2223 Understanding some memory concepts will help you reduce the
2230 system size. 2224 system size.
2231 Memory consists of static, dynamic, and temporary memory. 2225 Memory consists of static, dynamic, and temporary memory.
2232 Static memory is the TEXT, DATA, and BSS sections. 2226 Static memory is the TEXT (the code), DATA (initialized data
2227 in the code), and BSS (uninitialized data) sections.
2233 Dynamic memory contains memory that is allocate at runtime, 2228 Dynamic memory contains memory that is allocate at runtime,
2234 stacks, hashtables, and so forth. 2229 stacks, hash tables, and so forth.
2235 Temporary memory is decompression and 2230 Temporary memory is decompressed from the expanded kernel
2236 <filename>__init__</filename> 2231 after boot.
2232 Temporary memory also includes the <filename>__init__</filename>
2233 functions.
2237 </para> 2234 </para>
2238 2235
2239 <para> 2236 <para>
2240 To help you see where you currently are with kernel and root 2237 To help you see where you currently are with kernel and root
2241 filesystem sizes, you can use some tools found in the 2238 filesystem sizes, you can use two tools found in the
2242 <link linkend='source-directory'>Source Directory</link> in 2239 <link linkend='source-directory'>Source Directory</link> in
2243 the <filename>scripts</filename> directory: 2240 the <filename>scripts</filename> directory:
2244 <itemizedlist> 2241 <itemizedlist>
@@ -2247,17 +2244,29 @@
2247 <listitem><para><filename>dirsize.py</filename>: Reports 2244 <listitem><para><filename>dirsize.py</filename>: Reports
2248 the size of the root filesystem.</para></listitem> 2245 the size of the root filesystem.</para></listitem>
2249 </itemizedlist> 2246 </itemizedlist>
2250 This next tool and command helps you organized configuration 2247 This next tool and command helps you organize configuration
2251 fragments and view file dependencies in a human-readable form: 2248 fragments and view file dependencies in a human-readable form:
2252 <itemizedlist> 2249 <itemizedlist>
2253 <listitem><para><filename>merge_config.sh</filename>: 2250 <listitem><para><filename>merge_config.sh</filename>:
2254 Merges individual configuration fragments. 2251 Helps you manage configuration files and fragments
2255 For more information on configuration fragments, see 2252 within the kernel.
2256 the 2253 With this tool you can merge individual configuration
2254 fragments together.
2255 The tool allows you to make overrides and warns you
2256 of any missing configuration options.
2257 The tool is ideal for allowing you to iterate on
2258 configurations, create minimal configurations, and
2259 create a configuration files for different machines
2260 without having to duplicate your process.</para>
2261 <para>The <filename>merge_config.sh</filename> script is
2262 part of the Linux Yocto kernel Git repository in the
2263 <filename>scripts/kconfig</filename> directory.</para>
2264 <para>For more information on configuration fragments,
2265 see the
2257 "<ulink url='&YOCTO_DOCS_KERNEL_DEV_URL;#generating-configuration-files'>Generating Configuration Files</ulink>" 2266 "<ulink url='&YOCTO_DOCS_KERNEL_DEV_URL;#generating-configuration-files'>Generating Configuration Files</ulink>"
2258 section of the Yocto Project Linux Kernel Development 2267 section of the Yocto Project Linux Kernel Development
2259 Manual and the "<link linkend='creating-config-fragments'>Creating Configuration Fragments</link>" 2268 Manual and the "<link linkend='creating-config-fragments'>Creating Configuration Fragments</link>"
2260 section in this manual.</para></listitem> 2269 section, which is in this manual.</para></listitem>
2261 <listitem><para><filename>bitbake -u depexp -g core-image-*</filename>: 2270 <listitem><para><filename>bitbake -u depexp -g core-image-*</filename>:
2262 Using the BitBake command with these options brings up 2271 Using the BitBake command with these options brings up
2263 a Dependency Explorer from which you can view file 2272 a Dependency Explorer from which you can view file
@@ -2272,6 +2281,172 @@
2272 <section id='trim-the-root-filesystem'> 2281 <section id='trim-the-root-filesystem'>
2273 <title>Trim the Root Filesystem</title> 2282 <title>Trim the Root Filesystem</title>
2274 2283
2284 <para>
2285 Root filesystem is made up of packages for booting, libraries,
2286 and applications.
2287 To change things you can configure how the packaging happens,
2288 which changes the way you build them.
2289 You can also tweak the filesystem itself or select a different
2290 file system.
2291 </para>
2292
2293 <para>
2294 First, check out what is hogging your file system running the
2295 <filename>dirsize.sh</filename> script from your root directory:
2296 <literallayout class='monospaced'>
2297 $ cd &lt;root-directory-of-image&gt;
2298 $ dirsize.py 100000 > dirsize-100k.log
2299 $ cat dirsize-100k.log
2300 </literallayout>
2301 You can apply a filter to the script to ignore files under
2302 a certain size.
2303 This example filters out anything below 100 Kbytes.
2304 When you examine your log file, you can focus on areas of the
2305 root filesystem that take up large amounts of memory.
2306 </para>
2307
2308 <para>
2309 You need to be sure that what you eliminate does not cripple
2310 the functionality you need.
2311 One way to see how packages relate to each other is by using
2312 the Dependency Explorer UI with the BitBake command:
2313 <literallayout class='monospaced'>
2314 $ cd &lt;image-directory&gt;
2315 $ bitbake -u depexp -g &lt;image&gt;
2316 </literallayout>
2317 Use the interface to select potential packages you wish to
2318 eliminate and see their dependency relationships.
2319 </para>
2320
2321 <para>
2322 When deciding how to reduce the size, get rid of packages that
2323 result in minimal impact on the feature set.
2324 For example, you might not need a VGA display.
2325 Or, you might be able to get by with <filename>devtmpfs</filename>
2326 and <filename>mdev</filename>.
2327 </para>
2328
2329 <para>
2330 Use the <filename>local.conf</filename> file to make changes.
2331 For example, to eliminate <filename>udev</filename> and
2332 <filename>glib</filename>, set the following in the
2333 local configuration file:
2334 <literallayout class='monospaced'>
2335 VIRTUAL-RUNTIME_dev_manager = ""
2336 </literallayout>
2337 </para>
2338
2339 <para>
2340 Some other examples of where you can look to eliminate size
2341 from the root filesystem are using <filename>ext2</filename>
2342 rather than <filename>ext3</filename>, which requires a
2343 1 Mbyte journal.
2344 If you are okay with running read-only you don't need this
2345 journal.
2346 </para>
2347
2348 <note>
2349 After each round of elimination, you need to rebuild your
2350 system and then use the tools to see the effects of your
2351 reductions.
2352 </note>
2353
2354
2355 </section>
2356
2357 <section id='trim-the-kernel'>
2358 <title>Trim the Kernel</title>
2359
2360 <para>
2361 Kernel is built by including policies for hardware-independent
2362 aspects.
2363 What subsystems do you enable?
2364 What architecture are you building for?
2365 Which drivers do you build by default.
2366 <note>You can modify the kernel source if you want to help
2367 with boot time.
2368 </note>
2369 </para>
2370
2371 <para>
2372 Run the <filename>ksize.py</filename> script from the top-level
2373 Linux build directory to get an idea of what is making up
2374 the kernel:
2375 <literallayout class='monospaced'>
2376 $ cd &lt;top-level-linux-build-directory&gt;
2377 $ ksize.py > ksize.log
2378 $ cat ksize.log
2379 </literallayout>
2380 When you examine the log, you will see how much space is
2381 taken up with the built-in <filename>.o</filename> files for
2382 drivers, networking, core kernel files, filesystem, sound,
2383 and so forth.
2384 Look to reduce the areas that are large and taking up around
2385 the "90% rule".
2386 </para>
2387
2388 <para>
2389 To examine, or drill down, into any particular area, use the
2390 <filename>-d</filename> option with the script:
2391 <literallayout class='monospaced'>
2392 $ ksize.py -d > ksize.log
2393 </literallayout>
2394 Using this option breaks out the individual file information
2395 for each area of the kernel (e.g. drivers, networking, and
2396 so forth).
2397 </para>
2398
2399 <para>
2400 Use your log file to see what you can eliminate from the kernel
2401 based on features you can let go.
2402 For example, if you are not going to need sound, you do not
2403 need any drivers that support sound.
2404 </para>
2405
2406 <para>
2407 After figuring out what to eliminate, you need to reconfigure
2408 kernel to reflect those changes during the next build.
2409 You could run <filename>menuconfig</filename> and make all your
2410 changes at once.
2411 However, that makes it difficult to see the effects of your
2412 individual eliminations and also makes it difficult to replicate
2413 the changes for perhaps another target device.
2414 A better method is to start with no configurations using
2415 <filename>allnoconfig</filename>, create configuration
2416 fragments for individual changes, and then manage the
2417 fragments into a single configuration file using
2418 <filename>merge_config.sh</filename>.
2419 The tool makes it easy for you to iterate using the
2420 configuration change/build cycle.
2421 </para>
2422
2423 <para>
2424 Each time you make configuration changes, you need to rebuild
2425 the kernel and check to see what impact your changes had on
2426 the overall size.
2427 </para>
2428 </section>
2429
2430 <section id='iterate-on-the-process'>
2431 <title>Iterate on the Process</title>
2432
2433 <para>
2434 If you have not reached your goals on system size, you need
2435 to iterate on the process.
2436 The process is the same.
2437 Use the tools and see just what is taking up 90% of the root
2438 filesystem and the kernel.
2439 Decide what you can eliminate without limiting your device
2440 beyond what you need.
2441 </para>
2442
2443 <para>
2444 Depending on your system, a good place to look might be
2445 Busybox, which provides a stripped down
2446 version of Unix tools in a single, executable file.
2447 You might be able to drop virtual terminal services or perhaps
2448 ipv6.
2449 </para>
2275 </section> 2450 </section>
2276 </section> 2451 </section>
2277 2452
@@ -3005,7 +3180,7 @@
3005 </literallayout> 3180 </literallayout>
3006 Once the binary is built, you can find it here: 3181 Once the binary is built, you can find it here:
3007 <literallayout class='monospaced'> 3182 <literallayout class='monospaced'>
3008 tmp/sysroots/&lt;host-arch&gt;/usr/bin/&lt;target-abi&gt;-gdb 3183 tmp/sysroots/&lt;host-arch&gt;/usr/bin/&lt;target-platform&gt;/&lt;target-abi&gt;-gdb
3009 </literallayout> 3184 </literallayout>
3010 </para> 3185 </para>
3011 </section> 3186 </section>