The cirros image was rebuilt against the 3.13.0-83 kernel, drivers e1000e, igbvf...
[packages/trusty/cirros-testvm.git] / cirros-testvm / src-cirros / buildroot-2015.05 / docs / manual / manual.html
1 <?xml version="1.0" encoding="UTF-8"?>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /><title>The Buildroot user manual</title><link rel="stylesheet" type="text/css" href="docbook-xsl.css" /><meta name="generator" content="DocBook XSL Stylesheets V1.78.1" /></head><body><div xml:lang="en" class="book" lang="en"><div class="titlepage"><div><div><h1 class="title"><a id="idm139994505750784"></a>The Buildroot user manual</h1></div></div><hr /></div><div class="toc"><p><strong>Table of Contents</strong></p><dl class="toc"><dt><span class="preface"><a href="#idm139994504916048"></a></span></dt><dt><span class="part"><a href="#_getting_started">I. Getting started</a></span></dt><dd><dl><dt><span class="chapter"><a href="#_about_buildroot">1. About Buildroot</a></span></dt><dt><span class="chapter"><a href="#requirement">2. System requirements</a></span></dt><dd><dl><dt><span class="section"><a href="#requirement-mandatory">2.1. Mandatory packages</a></span></dt><dt><span class="section"><a href="#requirement-optional">2.2. Optional packages</a></span></dt></dl></dd><dt><span class="chapter"><a href="#getting-buildroot">3. Getting Buildroot</a></span></dt><dt><span class="chapter"><a href="#_buildroot_quick_start">4. Buildroot quick start</a></span></dt><dt><span class="chapter"><a href="#community-resources">5. Community resources</a></span></dt></dl></dd><dt><span class="part"><a href="#_user_guide">II. User guide</a></span></dt><dd><dl><dt><span class="chapter"><a href="#configure">6. Buildroot configuration</a></span></dt><dd><dl><dt><span class="section"><a href="#_cross_compilation_toolchain">6.1. Cross-compilation toolchain</a></span></dt><dt><span class="section"><a href="#_dev_management">6.2. /dev management</a></span></dt><dt><span class="section"><a href="#_init_system">6.3. init system</a></span></dt></dl></dd><dt><span class="chapter"><a href="#_configuration_of_other_components">7. Configuration of other components</a></span></dt><dt><span class="chapter"><a href="#_general_buildroot_usage">8. General Buildroot usage</a></span></dt><dd><dl><dt><span class="section"><a href="#make-tips">8.1. <span class="emphasis"><em>make</em></span> tips</a></span></dt><dt><span class="section"><a href="#full-rebuild">8.2. Understanding when a full rebuild is necessary</a></span></dt><dt><span class="section"><a href="#rebuild-pkg">8.3. Understanding how to rebuild packages</a></span></dt><dt><span class="section"><a href="#_offline_builds">8.4. Offline builds</a></span></dt><dt><span class="section"><a href="#_building_out_of_tree">8.5. Building out-of-tree</a></span></dt><dt><span class="section"><a href="#env-vars">8.6. Environment variables</a></span></dt><dt><span class="section"><a href="#_dealing_efficiently_with_filesystem_images">8.7. Dealing efficiently with filesystem images</a></span></dt><dt><span class="section"><a href="#_graphing_the_dependencies_between_packages">8.8. Graphing the dependencies between packages</a></span></dt><dt><span class="section"><a href="#_graphing_the_build_duration">8.9. Graphing the build duration</a></span></dt><dt><span class="section"><a href="#_integration_with_eclipse">8.10. Integration with Eclipse</a></span></dt><dt><span class="section"><a href="#_advanced_usage">8.11. Advanced usage</a></span></dt></dl></dd><dt><span class="chapter"><a href="#customize">9. Project-specific customization</a></span></dt><dd><dl><dt><span class="section"><a href="#customize-dir-structure">9.1. Recommended directory structure</a></span></dt><dt><span class="section"><a href="#outside-br-custom">9.2. Keeping customizations outside of Buildroot</a></span></dt><dt><span class="section"><a href="#customize-store-buildroot-config">9.3. Storing the Buildroot configuration</a></span></dt><dt><span class="section"><a href="#customize-store-package-config">9.4. Storing the configuration of other components</a></span></dt><dt><span class="section"><a href="#rootfs-custom">9.5. Customizing the generated target filesystem</a></span></dt><dt><span class="section"><a href="#customize-users">9.6. Adding custom user accounts</a></span></dt><dt><span class="section"><a href="#_customization_emphasis_after_emphasis_the_images_have_been_created">9.7. Customization <span class="emphasis"><em>after</em></span> the images have been created</a></span></dt><dt><span class="section"><a href="#customize-patches">9.8. Adding project-specific patches</a></span></dt><dt><span class="section"><a href="#customize-packages">9.9. Adding project-specific packages</a></span></dt><dt><span class="section"><a href="#_quick_guide_to_storing_your_project_specific_customizations">9.10. Quick guide to storing your project-specific customizations</a></span></dt></dl></dd><dt><span class="chapter"><a href="#_frequently_asked_questions_amp_troubleshooting">10. Frequently Asked Questions &amp; Troubleshooting</a></span></dt><dd><dl><dt><span class="section"><a href="#faq-boot-hang-after-starting">10.1. The boot hangs after <span class="emphasis"><em>Starting network…</em></span></a></span></dt><dt><span class="section"><a href="#faq-no-compiler-on-target">10.2. Why is there no compiler on the target?</a></span></dt><dt><span class="section"><a href="#faq-no-dev-files-on-target">10.3. Why are there no development files on the target?</a></span></dt><dt><span class="section"><a href="#faq-no-doc-on-target">10.4. Why is there no documentation on the target?</a></span></dt><dt><span class="section"><a href="#faq-why-not-visible-package">10.5. Why are some packages not visible in the Buildroot config menu?</a></span></dt><dt><span class="section"><a href="#faq-why-not-use-target-as-chroot">10.6. Why not use the target directory as a chroot directory?</a></span></dt><dt><span class="section"><a href="#faq-no-binary-packages">10.7. Why doesn’t Buildroot generate binary packages (.deb, .ipkg…)?</a></span></dt><dt><span class="section"><a href="#faq-speeding-up-build">10.8. How to speed-up the build process?</a></span></dt></dl></dd><dt><span class="chapter"><a href="#_known_issues">11. Known issues</a></span></dt><dt><span class="chapter"><a href="#legal-info">12. Legal notice and licensing</a></span></dt><dd><dl><dt><span class="section"><a href="#_complying_with_open_source_licenses">12.1. Complying with open source licenses</a></span></dt><dt><span class="section"><a href="#legal-info-list-licenses">12.2. License abbreviations</a></span></dt><dt><span class="section"><a href="#_complying_with_the_buildroot_license">12.3. Complying with the Buildroot license</a></span></dt></dl></dd><dt><span class="chapter"><a href="#_beyond_buildroot">13. Beyond Buildroot</a></span></dt><dd><dl><dt><span class="section"><a href="#_boot_the_generated_images">13.1. Boot the generated images</a></span></dt><dt><span class="section"><a href="#_chroot">13.2. Chroot</a></span></dt></dl></dd></dl></dd><dt><span class="part"><a href="#_developer_guide">III. Developer guide</a></span></dt><dd><dl><dt><span class="chapter"><a href="#_how_buildroot_works">14. How Buildroot works</a></span></dt><dt><span class="chapter"><a href="#_coding_style">15. Coding style</a></span></dt><dd><dl><dt><span class="section"><a href="#writing-rules-config-in">15.1. <code class="literal">Config.in</code> file</a></span></dt><dt><span class="section"><a href="#writing-rules-mk">15.2. The <code class="literal">.mk</code> file</a></span></dt><dt><span class="section"><a href="#_the_documentation">15.3. The documentation</a></span></dt></dl></dd><dt><span class="chapter"><a href="#adding-board-support">16. Adding support for a particular board</a></span></dt><dt><span class="chapter"><a href="#adding-packages">17. Adding new packages to Buildroot</a></span></dt><dd><dl><dt><span class="section"><a href="#_package_directory">17.1. Package directory</a></span></dt><dt><span class="section"><a href="#_config_files">17.2. Config files</a></span></dt><dt><span class="section"><a href="#_the_literal_mk_literal_file">17.3. The <code class="literal">.mk</code> file</a></span></dt><dt><span class="section"><a href="#adding-packages-hash">17.4. The <code class="literal">.hash</code> file</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_packages_with_specific_build_systems">17.5. Infrastructure for packages with specific build systems</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_autotools_based_packages">17.6. Infrastructure for autotools-based packages</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_cmake_based_packages">17.7. Infrastructure for CMake-based packages</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_python_packages">17.8. Infrastructure for Python packages</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_luarocks_based_packages">17.9. Infrastructure for LuaRocks-based packages</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_perl_cpan_packages">17.10. Infrastructure for Perl/CPAN packages</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_virtual_packages">17.11. Infrastructure for virtual packages</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_packages_using_kconfig_for_configuration_files">17.12. Infrastructure for packages using kconfig for configuration files</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_rebar_based_packages">17.13. Infrastructure for rebar-based packages</a></span></dt><dt><span class="section"><a href="#_infrastructure_for_asciidoc_documents">17.14. Infrastructure for asciidoc documents</a></span></dt><dt><span class="section"><a href="#hooks">17.15. Hooks available in the various build steps</a></span></dt><dt><span class="section"><a href="#_gettext_integration_and_interaction_with_packages">17.16. Gettext integration and interaction with packages</a></span></dt><dt><span class="section"><a href="#_tips_and_tricks">17.17. Tips and tricks</a></span></dt><dt><span class="section"><a href="#_conclusion">17.18. Conclusion</a></span></dt></dl></dd><dt><span class="chapter"><a href="#patch-policy">18. Patching a package</a></span></dt><dd><dl><dt><span class="section"><a href="#_providing_patches">18.1. Providing patches</a></span></dt><dt><span class="section"><a href="#patch-apply-order">18.2. How patches are applied</a></span></dt><dt><span class="section"><a href="#_format_and_licensing_of_the_package_patches">18.3. Format and licensing of the package patches</a></span></dt><dt><span class="section"><a href="#_integrating_patches_found_on_the_web">18.4. Integrating patches found on the Web</a></span></dt></dl></dd><dt><span class="chapter"><a href="#download-infra">19. Download infrastructure</a></span></dt><dt><span class="chapter"><a href="#debugging-buildroot">20. Debugging Buildroot</a></span></dt><dt><span class="chapter"><a href="#_contributing_to_buildroot">21. Contributing to Buildroot</a></span></dt><dd><dl><dt><span class="section"><a href="#_reproducing_analyzing_and_fixing_bugs">21.1. Reproducing, analyzing and fixing bugs</a></span></dt><dt><span class="section"><a href="#_analyzing_and_fixing_autobuild_failures">21.2. Analyzing and fixing autobuild failures</a></span></dt><dt><span class="section"><a href="#_reviewing_and_testing_patches">21.3. Reviewing and testing patches</a></span></dt><dt><span class="section"><a href="#_work_on_items_from_the_todo_list">21.4. Work on items from the TODO list</a></span></dt><dt><span class="section"><a href="#submitting-patches">21.5. Submitting patches</a></span></dt><dt><span class="section"><a href="#reporting-bugs">21.6. Reporting issues/bugs or getting help</a></span></dt></dl></dd></dl></dd><dt><span class="part"><a href="#_appendix">IV. Appendix</a></span></dt><dd><dl><dt><span class="chapter"><a href="#makedev-syntax">22. Makedev syntax documentation</a></span></dt><dt><span class="chapter"><a href="#makeuser-syntax">23. Makeusers syntax documentation</a></span></dt><dt><span class="chapter"><a href="#package-list">24. List of target packages available in Buildroot</a></span></dt><dt><span class="chapter"><a href="#virtual-package-list">25. List of virtual packages</a></span></dt><dt><span class="chapter"><a href="#host-package-list">26. List of host utilities available in Buildroot</a></span></dt><dt><span class="chapter"><a href="#deprecated-list">27. Deprecated features</a></span></dt></dl></dd></dl></div><div class="list-of-examples"><p><strong>List of Examples</strong></p><dl><dt>17.1. <a href="#idm139994498807568">Config script: <span class="emphasis"><em>divine</em></span> package</a></dt><dt>17.2. <a href="#idm139994498804640">Config script: <span class="emphasis"><em>imagemagick</em></span> package:</a></dt></dl></div><div class="preface"><div class="titlepage"><div><div><h1 class="title"><a id="idm139994504916048"></a></h1></div></div></div><p>Buildroot 2015.05 manual generated on 2015-05-31
3 21:28:39 UTC from git revision 6d73615</p><p>The Buildroot manual is written by the Buildroot developers.
4 It is licensed under the GNU General Public License, version 2. Refer to the
5 <a class="ulink" href="http://git.buildroot.org/buildroot/tree/COPYING" target="_top">COPYING</a> file in the Buildroot
6 sources for the full text of this license.</p><p>Copyright © 2004-2014 The Buildroot developers</p><div class="informalfigure"><div class="mediaobject"><img src="logo.png" alt="logo.png" /></div></div></div><div class="part"><div class="titlepage"><div><div><h1 class="title"><a id="_getting_started"></a>Part I. Getting started</h1></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_about_buildroot"></a>Chapter 1. About Buildroot</h2></div></div></div><p>Buildroot is a tool that simplifies and automates the process of
7 building a complete Linux system for an embedded system, using
8 cross-compilation.</p><p>In order to achieve this, Buildroot is able to generate a
9 cross-compilation toolchain, a root filesystem, a Linux kernel image
10 and a bootloader for your target. Buildroot can be used for any
11 combination of these options, independently (you can for example use
12 an existing cross-compilation toolchain, and build only your root
13 filesystem with Buildroot).</p><p>Buildroot is useful mainly for people working with embedded systems.
14 Embedded systems often use processors that are not the regular x86
15 processors everyone is used to having in his PC. They can be PowerPC
16 processors, MIPS processors, ARM processors, etc.</p><p>Buildroot supports numerous processors and their variants; it also
17 comes with default configurations for several boards available
18 off-the-shelf. Besides this, a number of third-party projects are based on,
19 or develop their BSP <a href="#ftn.idm139994500951776" class="footnote" id="idm139994500951776"><sup class="footnote">[1]</sup></a> or
20 SDK <a href="#ftn.idm139994504459696" class="footnote" id="idm139994504459696"><sup class="footnote">[2]</sup></a> on top of Buildroot.</p><div class="footnotes"><br /><hr style="width:100; text-align:left;margin-left: 0" /><div id="ftn.idm139994500951776" class="footnote"><p><a href="#idm139994500951776" class="simpara"><sup class="simpara">[1] </sup></a>BSP: Board Support Package</p></div><div id="ftn.idm139994504459696" class="footnote"><p><a href="#idm139994504459696" class="simpara"><sup class="simpara">[2] </sup></a>SDK: Software Development Kit</p></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="requirement"></a>Chapter 2. System requirements</h2></div></div></div><p>Buildroot is designed to run on Linux systems.</p><p>While Buildroot itself will build most host packages it needs for the
21 compilation, certain standard Linux utilities are expected to be
22 already installed on the host system. Below you will find an overview of
23 the mandatory and optional packages (note that package names may vary
24 between distributions).</p><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="requirement-mandatory"></a>2.1. Mandatory packages</h2></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p class="simpara">
25 Build tools:
26 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
27 <code class="literal">which</code>
28 </li><li class="listitem">
29 <code class="literal">sed</code>
30 </li><li class="listitem">
31 <code class="literal">make</code> (version 3.81 or any later)
32 </li><li class="listitem">
33 <code class="literal">binutils</code>
34 </li><li class="listitem">
35 <code class="literal">build-essential</code> (only for Debian based systems)
36 </li><li class="listitem">
37 <code class="literal">gcc</code> (version 2.95 or any later)
38 </li><li class="listitem">
39 <code class="literal">g++</code> (version 2.95 or any later)
40 </li><li class="listitem">
41 <code class="literal">bash</code>
42 </li><li class="listitem">
43 <code class="literal">patch</code>
44 </li><li class="listitem">
45 <code class="literal">gzip</code>
46 </li><li class="listitem">
47 <code class="literal">bzip2</code>
48 </li><li class="listitem">
49 <code class="literal">perl</code> (version 5.8.7 or any later)
50 </li><li class="listitem">
51 <code class="literal">tar</code>
52 </li><li class="listitem">
53 <code class="literal">cpio</code>
54 </li><li class="listitem">
55 <code class="literal">python</code> (version 2.6 or 2.7)
56 </li><li class="listitem">
57 <code class="literal">unzip</code>
58 </li><li class="listitem">
59 <code class="literal">rsync</code>
60 </li></ul></div></li><li class="listitem"><p class="simpara">
61 Source fetching tools:
62 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
63 <code class="literal">wget</code>
64 </li></ul></div></li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="requirement-optional"></a>2.2. Optional packages</h2></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p class="simpara">
65 Configuration interface dependencies:
66 </p><p class="simpara">For these libraries, you need to install both runtime and development
67 data, which in many distributions are packaged separately. The
68 development packages typically have a <span class="emphasis"><em>-dev</em></span> or <span class="emphasis"><em>-devel</em></span> suffix.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
69 <code class="literal">ncurses5</code> to use the <span class="emphasis"><em>menuconfig</em></span> interface
70 </li><li class="listitem">
71 <code class="literal">qt4</code> to use the <span class="emphasis"><em>xconfig</em></span> interface
72 </li><li class="listitem">
73 <code class="literal">glib2</code>, <code class="literal">gtk2</code> and <code class="literal">glade2</code> to use the <span class="emphasis"><em>gconfig</em></span> interface
74 </li></ul></div></li><li class="listitem"><p class="simpara">
75 Source fetching tools:
76 </p><p class="simpara">In the official tree, most of the package sources are retrieved using
77 <code class="literal">wget</code> from <span class="emphasis"><em>ftp</em></span>, <span class="emphasis"><em>http</em></span> or <span class="emphasis"><em>https</em></span> locations. A few packages are only
78 available through a version control system. Moreover, Buildroot is
79 capable of downloading sources via other tools, like <code class="literal">rsync</code> or <code class="literal">scp</code>
80 (refer to <a class="xref" href="#download-infra" title="Chapter 19. Download infrastructure">Chapter 19, <em>Download infrastructure</em></a> for more details). If you enable
81 packages using any of these methods, you will need to install the
82 corresponding tool on the host system:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
83 <code class="literal">bazaar</code>
84 </li><li class="listitem">
85 <code class="literal">cvs</code>
86 </li><li class="listitem">
87 <code class="literal">git</code>
88 </li><li class="listitem">
89 <code class="literal">mercurial</code>
90 </li><li class="listitem">
91 <code class="literal">rsync</code>
92 </li><li class="listitem">
93 <code class="literal">scp</code>
94 </li><li class="listitem">
95 <code class="literal">subversion</code>
96 </li></ul></div></li><li class="listitem"><p class="simpara">
97 Java-related packages, if the Java Classpath needs to be built for
98   the target system:
99 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
100 The <code class="literal">javac</code> compiler
101 </li><li class="listitem">
102 The <code class="literal">jar</code> tool
103 </li></ul></div></li><li class="listitem"><p class="simpara">
104 Documentation generation tools:
105 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
106 <code class="literal">asciidoc</code>, version 8.6.3 or higher
107 </li><li class="listitem">
108 <code class="literal">w3m</code>
109 </li><li class="listitem">
110 <code class="literal">python</code> with the <code class="literal">argparse</code> module (automatically present in 2.7+ and 3.2+)
111 </li><li class="listitem">
112 <code class="literal">dblatex</code> (required for the pdf manual only)
113 </li></ul></div></li><li class="listitem"><p class="simpara">
114 Graph generation tools:
115 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
116 <code class="literal">graphviz</code> to use <span class="emphasis"><em>graph-depends</em></span> and <span class="emphasis"><em>&lt;pkg&gt;-graph-depends</em></span>
117 </li><li class="listitem">
118 <code class="literal">python-matplotlib</code> to use <span class="emphasis"><em>graph-build</em></span>
119 </li></ul></div></li></ul></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="getting-buildroot"></a>Chapter 3. Getting Buildroot</h2></div></div></div><p>Buildroot releases are made every 3 months, in February, May, August and
120 November. Release numbers are in the format YYYY.MM, so for example
121 2013.02, 2014.08.</p><p>Release tarballs are available at <a class="ulink" href="http://buildroot.org/downloads/" target="_top">http://buildroot.org/downloads/</a>.</p><p>If you want to follow development, you can use the daily snapshots or
122 make a clone of the Git repository. Refer to the
123 <a class="ulink" href="http://buildroot.org/download" target="_top">Download page</a> of the Buildroot website
124 for more details.</p></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_buildroot_quick_start"></a>Chapter 4. Buildroot quick start</h2></div></div></div><p><span class="strong"><strong>Important</strong></span>: you can and should <span class="strong"><strong>build everything as a normal user</strong></span>. There
125 is no need to be root to configure and use Buildroot. By running all
126 commands as a regular user, you protect your system against packages
127 behaving badly during compilation and installation.</p><p>The first step when using Buildroot is to create a configuration.
128 Buildroot has a nice configuration tool similar to the one you can
129 find in the <a class="ulink" href="http://www.kernel.org/" target="_top">Linux kernel</a> or in
130 <a class="ulink" href="http://www.busybox.net/" target="_top">BusyBox</a>.</p><p>From the buildroot directory, run</p><pre class="screen"> $ make menuconfig</pre><p>for the original curses-based configurator, or</p><pre class="screen"> $ make nconfig</pre><p>for the new curses-based configurator, or</p><pre class="screen"> $ make xconfig</pre><p>for the Qt-based configurator, or</p><pre class="screen"> $ make gconfig</pre><p>for the GTK-based configurator.</p><p>All of these "make" commands will need to build a configuration
131 utility (including the interface), so you may need to install
132 "development" packages for relevant libraries used by the
133 configuration utilities. Refer to <a class="xref" href="#requirement" title="Chapter 2. System requirements">Chapter 2, <em>System requirements</em></a> for more details,
134 specifically the <a class="link" href="#requirement-optional" title="2.2. Optional packages">optional requirements</a>
135 <a class="xref" href="#requirement-optional" title="2.2. Optional packages">Section 2.2, “Optional packages”</a>
136 to get the dependencies of your favorite interface.</p><p>For each menu entry in the configuration tool, you can find associated
137 help that describes the purpose of the entry. Refer to <a class="xref" href="#configure" title="Chapter 6. Buildroot configuration">Chapter 6, <em>Buildroot configuration</em></a>
138 for details on some specific configuration aspects.</p><p>Once everything is configured, the configuration tool generates a
139 <code class="literal">.config</code> file that contains the entire configuration. This file will be
140 read by the top-level Makefile.</p><p>To start the build process, simply run:</p><pre class="screen"> $ make</pre><p>You <span class="strong"><strong>should never</strong></span> use <code class="literal">make -jN</code> with Buildroot: top-level parallel
141 make is currently not supported. Instead, use the <code class="literal">BR2_JLEVEL</code> option
142 to tell Buildroot to run the compilation of each individual package
143 with <code class="literal">make -jN</code>.</p><p>The <code class="literal">make</code> command will generally perform the following steps:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
144 download source files (as required);
145 </li><li class="listitem">
146 configure, build and install the cross-compilation toolchain, or
147   simply import an external toolchain;
148 </li><li class="listitem">
149 configure, build and install selected target packages;
150 </li><li class="listitem">
151 build a kernel image, if selected;
152 </li><li class="listitem">
153 build a bootloader image, if selected;
154 </li><li class="listitem">
155 create a root filesystem in selected formats.
156 </li></ul></div><p>Buildroot output is stored in a single directory, <code class="literal">output/</code>.
157 This directory contains several subdirectories:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
158 <code class="literal">images/</code> where all the images (kernel image, bootloader and root
159   filesystem images) are stored. These are the files you need to put
160   on your target system.
161 </li><li class="listitem">
162 <code class="literal">build/</code> where all the components are built (this includes tools
163   needed by Buildroot on the host and packages compiled for the
164   target). This directory contains one subdirectory for each of these
165   components.
166 </li><li class="listitem">
167 <code class="literal">staging/</code> which contains a hierarchy similar to a root filesystem
168   hierarchy. This directory contains the headers and libraries of the
169   cross-compilation toolchain and all the userspace packages selected
170   for the target. However, this directory is <span class="emphasis"><em>not</em></span> intended to be
171   the root filesystem for the target: it contains a lot of development
172   files, unstripped binaries and libraries that make it far too big
173   for an embedded system. These development files are used to compile
174   libraries and applications for the target that depend on other
175   libraries.
176 </li><li class="listitem">
177 <code class="literal">target/</code> which contains <span class="emphasis"><em>almost</em></span> the complete root filesystem for
178   the target: everything needed is present except the device files in
179   <code class="literal">/dev/</code> (Buildroot can’t create them because Buildroot doesn’t run
180   as root and doesn’t want to run as root). Also, it doesn’t have the correct
181   permissions (e.g. setuid for the busybox binary). Therefore, this directory
182   <span class="strong"><strong>should not be used on your target</strong></span>. Instead, you should use one of
183   the images built in the <code class="literal">images/</code> directory. If you need an
184   extracted image of the root filesystem for booting over NFS, then
185   use the tarball image generated in <code class="literal">images/</code> and extract it as
186   root. Compared to <code class="literal">staging/</code>, <code class="literal">target/</code> contains only the files and
187   libraries needed to run the selected target applications: the
188   development files (headers, etc.) are not present, the binaries are
189   stripped.
190 </li><li class="listitem">
191 <code class="literal">host/</code> contains the installation of tools compiled for the host
192   that are needed for the proper execution of Buildroot, including the
193   cross-compilation toolchain.
194 </li></ul></div><p>These commands, <code class="literal">make menuconfig|nconfig|gconfig|xconfig</code> and <code class="literal">make</code>, are the
195 basic ones that allow to easily and quickly generate images fitting
196 your needs, with all the features and applications you enabled.</p><p>More details about the "make" command usage are given in
197 <a class="xref" href="#make-tips" title="8.1. make tips">Section 8.1, “<span class="emphasis"><em>make</em></span> tips”</a>.</p></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="community-resources"></a>Chapter 5. Community resources</h2></div></div></div><p>Like any open source project, Buildroot has different ways to share
198 information in its community and outside.</p><p>Each of those ways may interest you if you are looking for some help,
199 want to understand Buildroot or contribute to the project.</p><div class="variablelist"><dl class="variablelist"><dt><span class="term">
200 Mailing List
201 </span></dt><dd><p class="simpara">Buildroot has a mailing list for discussion and development. It is the
202 main method of interaction for Buildroot users and developers.</p><p class="simpara">Only subscribers to the Buildroot mailing list are allowed to post to
203 this list. You can subscribe via the
204 <a class="ulink" href="http://lists.busybox.net/mailman/listinfo/buildroot" target="_top">mailing list info
205 page</a>.</p><p class="simpara">Mails that are sent to the mailing list are also available in the
206 <a class="ulink" href="http://lists.busybox.net/pipermail/buildroot" target="_top">mailing list archives</a> and
207 via <a class="ulink" href="http://gmane.org" target="_top">Gmane</a>, at
208 <a class="ulink" href="http://dir.gmane.org/gmane.comp.lib.uclibc.buildroot" target="_top"><code class="literal">gmane.comp.lib.uclibc.buildroot</code></a>.
209 Please search the mailing list archives before asking questions, since
210 there is a good chance someone else has asked the same question before.</p></dd><dt><span class="term">
211 IRC
212 </span></dt><dd><p class="simpara">The Buildroot IRC channel <a class="ulink" href="irc://freenode.net/#buildroot" target="_top">#buildroot</a> is
213 hosted on <a class="ulink" href="http://webchat.freenode.net" target="_top">Freenode</a>. It is a useful place to
214 ask quick questions or discuss on certain topics.</p><p class="simpara">When asking for help on IRC, share relevant logs or pieces of code
215 using a code sharing website, such as <a class="ulink" href="http://code.bulix.org" target="_top">http://code.bulix.org</a>.</p><p class="simpara">Note that for certain questions, posting to the mailing list may be
216 better as it will reach more people, both developers and users.</p></dd><dt><span class="term">
217 Bug tracker
218 </span></dt><dd>Bugs in Buildroot can be reported via the mailing list or alternatively
219 via the <a class="ulink" href="https://bugs.busybox.net/buglist.cgi?product=buildroot" target="_top">Buildroot
220 bugtracker</a>. Please refer to <a class="xref" href="#reporting-bugs" title="21.6. Reporting issues/bugs or getting help">Section 21.6, “Reporting issues/bugs or getting help”</a> before creating a bug
221 report.</dd><dt><span class="term">
222 Wiki
223 </span></dt><dd><a class="ulink" href="http://elinux.org/Buildroot" target="_top">The Buildroot wiki page</a> is hosted on
224 the <a class="ulink" href="http://elinux.org" target="_top">eLinux</a> wiki. It contains some useful links, an
225 overview of past and upcoming events, and a TODO list.</dd><dt><span class="term">
226 Patchwork
227 </span></dt><dd><p class="simpara">Patchwork is a web-based patch tracking system designed to facilitate
228 the contribution and management of contributions to an open-source
229 project. Patches that have been sent to a mailing list are 'caught' by
230 the system, and appear on a web page. Any comments posted that
231 reference the patch are appended to the patch page too. For more
232 information on Patchwork see
233 <a class="ulink" href="http://jk.ozlabs.org/projects/patchwork/" target="_top">http://jk.ozlabs.org/projects/patchwork/</a>.</p><p class="simpara">Buildroot’s Patchwork website is mainly for use by Buildroot’s
234 maintainer to ensure patches aren’t missed. It is also used by Buildroot
235 patch reviewers (see also <a class="xref" href="#apply-patches-patchwork" title="21.3.1. Applying Patches from Patchwork">Section 21.3.1, “Applying Patches from Patchwork”</a>).
236 However, since the website exposes patches and their corresponding
237 review comments in a clean and concise web interface, it can be useful
238 for all Buildroot developers.</p><p class="simpara">The Buildroot patch management interface is available at
239 <a class="ulink" href="http://patchwork.buildroot.org" target="_top">http://patchwork.buildroot.org</a>.</p></dd></dl></div></div></div><div class="part"><div class="titlepage"><div><div><h1 class="title"><a id="_user_guide"></a>Part II. User guide</h1></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="configure"></a>Chapter 6. Buildroot configuration</h2></div></div></div><p>All the configuration options in <code class="literal">make *config</code> have a help text
240 providing details about the option.</p><p>The <code class="literal">make *config</code> commands also offer a search tool. Read the help
241 message in the different frontend menus to know how to use it:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
242 in <span class="emphasis"><em>menuconfig</em></span>, the search tool is called by pressing <code class="literal">/</code>;
243 </li><li class="listitem">
244 in <span class="emphasis"><em>xconfig</em></span>, the search tool is called by pressing <code class="literal">Ctrl</code> + <code class="literal">f</code>.
245 </li></ul></div><p>The result of the search shows the help message of the matching items.
246 In <span class="emphasis"><em>menuconfig</em></span>, numbers in the left column provide a shortcut to the
247 corresponding entry. Just type this number to directly jump to the
248 entry, or to the containing menu in case the entry is not selectable due
249 to a missing dependency.</p><p>Although the menu structure and the help text of the entries should be
250 sufficiently self-explanatory, a number of topics require additional
251 explanation that cannot easily be covered in the help text and are
252 therefore covered in the following sections.</p><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_cross_compilation_toolchain"></a>6.1. Cross-compilation toolchain</h2></div></div></div><p>A compilation toolchain is the set of tools that allows you to compile
253 code for your system. It consists of a compiler (in our case, <code class="literal">gcc</code>),
254 binary utils like assembler and linker (in our case, <code class="literal">binutils</code>) and a
255 C standard library (for example
256 <a class="ulink" href="http://www.gnu.org/software/libc/libc.html" target="_top">GNU Libc</a>,
257 <a class="ulink" href="http://www.uclibc.org/" target="_top">uClibc</a>).</p><p>The system installed on your development station certainly already has
258 a compilation toolchain that you can use to compile an application
259 that runs on your system. If you’re using a PC, your compilation
260 toolchain runs on an x86 processor and generates code for an x86
261 processor. Under most Linux systems, the compilation toolchain uses
262 the GNU libc (glibc) as the C standard library. This compilation
263 toolchain is called the "host compilation toolchain". The machine on
264 which it is running, and on which you’re working, is called the "host
265 system" <a href="#ftn.idm139994500107152" class="footnote" id="idm139994500107152"><sup class="footnote">[3]</sup></a>.</p><p>The compilation toolchain is provided by your distribution, and
266 Buildroot has nothing to do with it (other than using it to build a
267 cross-compilation toolchain and other tools that are run on the
268 development host).</p><p>As said above, the compilation toolchain that comes with your system
269 runs on and generates code for the processor in your host system. As
270 your embedded system has a different processor, you need a
271 cross-compilation toolchain - a compilation toolchain that runs on
272 your <span class="emphasis"><em>host system</em></span> but generates code for your <span class="emphasis"><em>target system</em></span> (and
273 target processor). For example, if your host system uses x86 and your
274 target system uses ARM, the regular compilation toolchain on your host
275 runs on x86 and generates code for x86, while the cross-compilation
276 toolchain runs on x86 and generates code for ARM.</p><p>Buildroot provides two solutions for the cross-compilation toolchain:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
277 The <span class="strong"><strong>internal toolchain backend</strong></span>, called <code class="literal">Buildroot toolchain</code> in
278    the configuration interface.
279 </li><li class="listitem">
280 The <span class="strong"><strong>external toolchain backend</strong></span>, called <code class="literal">External toolchain</code> in
281    the configuration interface.
282 </li></ul></div><p>The choice between these two solutions is done using the <code class="literal">Toolchain
283 Type</code> option in the <code class="literal">Toolchain</code> menu. Once one solution has been
284 chosen, a number of configuration options appear, they are detailed in
285 the following sections.</p><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="internal-toolchain-backend"></a>6.1.1. Internal toolchain backend</h3></div></div></div><p>The <span class="emphasis"><em>internal toolchain backend</em></span> is the backend where Buildroot builds
286 by itself a cross-compilation toolchain, before building the userspace
287 applications and libraries for your target embedded system.</p><p>This backend supports several C libraries:
288 <a class="ulink" href="http://www.uclibc.org" target="_top">uClibc</a>, the
289 <a class="ulink" href="http://www.gnu.org/software/libc/libc.html" target="_top">glibc</a> and
290 <a class="ulink" href="http://www.eglibc.org" target="_top">eglibc</a>.</p><p>Once you have selected this backend, a number of options appear. The
291 most important ones allow to:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
292 Change the version of the Linux kernel headers used to build the
293    toolchain. This item deserves a few explanations. In the process of
294    building a cross-compilation toolchain, the C library is being
295    built. This library provides the interface between userspace
296    applications and the Linux kernel. In order to know how to "talk"
297    to the Linux kernel, the C library needs to have access to the
298    <span class="emphasis"><em>Linux kernel headers</em></span> (i.e. the <code class="literal">.h</code> files from the kernel), which
299    define the interface between userspace and the kernel (system
300    calls, data structures, etc.). Since this interface is backward
301    compatible, the version of the Linux kernel headers used to build
302    your toolchain do not need to match <span class="emphasis"><em>exactly</em></span> the version of the
303    Linux kernel you intend to run on your embedded system. They only
304    need to have a version equal or older to the version of the Linux
305    kernel you intend to run. If you use kernel headers that are more
306    recent than the Linux kernel you run on your embedded system, then
307    the C library might be using interfaces that are not provided by
308    your Linux kernel.
309 </li><li class="listitem">
310 Change the version of the GCC compiler, binutils and the C library.
311 </li><li class="listitem">
312 Select a number of toolchain options (uClibc only): whether the
313    toolchain should have RPC support (used mainly for NFS),
314    wide-char support, locale support (for internationalization),
315    C++ support or thread support. Depending on which options you choose,
316    the number of userspace applications and libraries visible in
317    Buildroot menus will change: many applications and libraries require
318    certain toolchain options to be enabled. Most packages show a comment
319    when a certain toolchain option is required to be able to enable
320    those packages. If needed, you can further refine the uClibc
321    configuration by running <code class="literal">make uclibc-menuconfig</code>. Note however that
322    all packages in Buildroot are tested against the default uClibc
323    configuration bundled in Buildroot: if you deviate from this
324    configuration by removing features from uClibc, some packages may no
325    longer build.
326 </li></ul></div><p>It is worth noting that whenever one of those options is modified,
327 then the entire toolchain and system must be rebuilt. See
328 <a class="xref" href="#full-rebuild" title="8.2. Understanding when a full rebuild is necessary">Section 8.2, “Understanding when a full rebuild is necessary”</a>.</p><p>Advantages of this backend:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
329 Well integrated with Buildroot
330 </li><li class="listitem">
331 Fast, only builds what’s necessary
332 </li></ul></div><p>Drawbacks of this backend:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
333 Rebuilding the toolchain is needed when doing <code class="literal">make clean</code>, which
334   takes time. If you’re trying to reduce your build time, consider
335   using the <span class="emphasis"><em>External toolchain backend</em></span>.
336 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="external-toolchain-backend"></a>6.1.2. External toolchain backend</h3></div></div></div><p>The <span class="emphasis"><em>external toolchain backend</em></span> allows to use existing pre-built
337 cross-compilation toolchains. Buildroot knows about a number of
338 well-known cross-compilation toolchains (from
339 <a class="ulink" href="http://www.linaro.org" target="_top">Linaro</a> for ARM,
340 <a class="ulink" href="http://www.mentor.com/embedded-software/sourcery-tools/sourcery-codebench/editions/lite-edition/" target="_top">Sourcery
341 CodeBench</a> for ARM, x86, x86-64, PowerPC, MIPS and SuperH,
342 <a class="ulink" href="https://blackfin.uclinux.org/gf/project/toolchain" target="_top">Blackfin toolchains
343 from Analog Devices</a>, etc.) and is capable of downloading them
344 automatically, or it can be pointed to a custom toolchain, either
345 available for download or installed locally.</p><p>Then, you have three solutions to use an external toolchain:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
346 Use a predefined external toolchain profile, and let Buildroot
347   download, extract and install the toolchain. Buildroot already knows
348   about a few CodeSourcery, Linaro, Blackfin and Xilinx toolchains.
349   Just select the toolchain profile in <code class="literal">Toolchain</code> from the
350   available ones. This is definitely the easiest solution.
351 </li><li class="listitem">
352 Use a predefined external toolchain profile, but instead of having
353   Buildroot download and extract the toolchain, you can tell Buildroot
354   where your toolchain is already installed on your system. Just
355   select the toolchain profile in <code class="literal">Toolchain</code> through the available
356   ones, unselect <code class="literal">Download toolchain automatically</code>, and fill the
357   <code class="literal">Toolchain path</code> text entry with the path to your cross-compiling
358   toolchain.
359 </li><li class="listitem">
360 Use a completely custom external toolchain. This is particularly
361   useful for toolchains generated using crosstool-NG or with Buildroot
362   itself. To do this, select the <code class="literal">Custom toolchain</code> solution in the
363   <code class="literal">Toolchain</code> list. You need to fill the <code class="literal">Toolchain path</code>, <code class="literal">Toolchain
364   prefix</code> and <code class="literal">External toolchain C library</code> options. Then, you have
365   to tell Buildroot what your external toolchain supports. If your
366   external toolchain uses the <span class="emphasis"><em>glibc</em></span> library, you only have to tell
367   whether your toolchain supports C++ or not and whether it has
368   built-in RPC support. If your external toolchain uses the <span class="emphasis"><em>uClibc</em></span>
369   library, then you have to tell Buildroot if it supports RPC,
370   wide-char, locale, program invocation, threads and C++.
371   At the beginning of the execution, Buildroot will tell you if
372   the selected options do not match the toolchain configuration.
373 </li></ul></div><p>Our external toolchain support has been tested with toolchains from
374 CodeSourcery and Linaro, toolchains generated by
375 <a class="ulink" href="http://crosstool-ng.org" target="_top">crosstool-NG</a>, and toolchains generated by
376 Buildroot itself. In general, all toolchains that support the
377 <span class="emphasis"><em>sysroot</em></span> feature should work. If not, do not hesitate to contact the
378 developers.</p><p>We do not support toolchains or SDK generated by OpenEmbedded or
379 Yocto, because these toolchains are not pure toolchains (i.e. just the
380 compiler, binutils, the C and C++ libraries). Instead these toolchains
381 come with a very large set of pre-compiled libraries and
382 programs. Therefore, Buildroot cannot import the <span class="emphasis"><em>sysroot</em></span> of the
383 toolchain, as it would contain hundreds of megabytes of pre-compiled
384 libraries that are normally built by Buildroot.</p><p>We also do not support using the distribution toolchain (i.e. the
385 gcc/binutils/C library installed by your distribution) as the
386 toolchain to build software for the target. This is because your
387 distribution toolchain is not a "pure" toolchain (i.e. only with the
388 C/C++ library), so we cannot import it properly into the Buildroot
389 build environment. So even if you are building a system for a x86 or
390 x86_64 target, you have to generate a cross-compilation toolchain with
391 Buildroot or crosstool-NG.</p><p>If you want to generate a custom toolchain for your project, that can
392 be used as an external toolchain in Buildroot, our recommendation is
393 definitely to build it with <a class="ulink" href="http://crosstool-ng.org" target="_top">crosstool-NG</a>. We
394 recommend to build the toolchain separately from Buildroot, and then
395 <span class="emphasis"><em>import</em></span> it in Buildroot using the external toolchain backend.</p><p>Advantages of this backend:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
396 Allows to use well-known and well-tested cross-compilation
397   toolchains.
398 </li><li class="listitem">
399 Avoids the build time of the cross-compilation toolchain, which is
400   often very significant in the overall build time of an embedded
401   Linux system.
402 </li><li class="listitem">
403 Not limited to uClibc: glibc and eglibc toolchains are supported.
404 </li></ul></div><p>Drawbacks of this backend:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
405 If your pre-built external toolchain has a bug, may be hard to get a
406   fix from the toolchain vendor, unless you build your external
407   toolchain by yourself using Crosstool-NG.
408 </li></ul></div><div class="section"><div class="titlepage"><div><div><h4 class="title"><a id="_external_toolchain_wrapper"></a>External toolchain wrapper</h4></div></div></div><p>When using an external toolchain, Buildroot generates a wrapper program,
409 that transparently passes the appropriate options (according to the
410 configuration) to the external toolchain programs. In case you need to
411 debug this wrapper to check exactly what arguments are passed, you can
412 set the environment variable <code class="literal">BR2_DEBUG_WRAPPER</code> to either one of:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
413 <code class="literal">0</code>, empty or not set: no debug
414 </li><li class="listitem">
415 <code class="literal">1</code>: trace all arguments on a single line
416 </li><li class="listitem">
417 <code class="literal">2</code>: trace one argument per line
418 </li></ul></div></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_dev_management"></a>6.2. /dev management</h2></div></div></div><p>On a Linux system, the <code class="literal">/dev</code> directory contains special files, called
419 <span class="emphasis"><em>device files</em></span>, that allow userspace applications to access the
420 hardware devices managed by the Linux kernel. Without these <span class="emphasis"><em>device
421 files</em></span>, your userspace applications would not be able to use the
422 hardware devices, even if they are properly recognized by the Linux
423 kernel.</p><p>Under <code class="literal">System configuration</code>, <code class="literal">/dev management</code>, Buildroot offers four
424 different solutions to handle the <code class="literal">/dev</code> directory :</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
425 The first solution is <span class="strong"><strong>Static using device table</strong></span>. This is the old
426    classical way of handling device files in Linux. With this method,
427    the device files are persistently stored in the root filesystem
428    (i.e. they persist across reboots), and there is nothing that will
429    automatically create and remove those device files when hardware
430    devices are added or removed from the system. Buildroot therefore
431    creates a standard set of device files using a <span class="emphasis"><em>device table</em></span>, the
432    default one being stored in <code class="literal">system/device_table_dev.txt</code> in the
433    Buildroot source code. This file is processed when Buildroot
434    generates the final root filesystem image, and the <span class="emphasis"><em>device files</em></span>
435    are therefore not visible in the <code class="literal">output/target</code> directory. The
436    <code class="literal">BR2_ROOTFS_STATIC_DEVICE_TABLE</code> option allows to change the
437    default device table used by Buildroot, or to add an additional
438    device table, so that additional <span class="emphasis"><em>device files</em></span> are created by
439    Buildroot during the build. So, if you use this method, and a
440    <span class="emphasis"><em>device file</em></span> is missing in your system, you can for example create
441    a <code class="literal">board/&lt;yourcompany&gt;/&lt;yourproject&gt;/device_table_dev.txt</code> file
442    that contains the description of your additional <span class="emphasis"><em>device files</em></span>,
443    and then you can set <code class="literal">BR2_ROOTFS_STATIC_DEVICE_TABLE</code> to
444    <code class="literal">system/device_table_dev.txt
445    board/&lt;yourcompany&gt;/&lt;yourproject&gt;/device_table_dev.txt</code>. For more
446    details about the format of the device table file, see
447    <a class="xref" href="#makedev-syntax" title="Chapter 22. Makedev syntax documentation">Chapter 22, <em>Makedev syntax documentation</em></a>.
448 </li><li class="listitem">
449 The second solution is <span class="strong"><strong>Dynamic using devtmpfs only</strong></span>. <span class="emphasis"><em>devtmpfs</em></span> is
450    a virtual filesystem inside the Linux kernel that has been
451    introduced in kernel 2.6.32 (if you use an older kernel, it is not
452    possible to use this option). When mounted in <code class="literal">/dev</code>, this virtual
453    filesystem will automatically make <span class="emphasis"><em>device files</em></span> appear and
454    disappear as hardware devices are added and removed from the
455    system. This filesystem is not persistent across reboots: it is
456    filled dynamically by the kernel. Using <span class="emphasis"><em>devtmpfs</em></span> requires the
457    following kernel configuration options to be enabled:
458    <code class="literal">CONFIG_DEVTMPFS</code> and <code class="literal">CONFIG_DEVTMPFS_MOUNT</code>. When Buildroot is in
459    charge of building the Linux kernel for your embedded device, it
460    makes sure that those two options are enabled. However, if you
461    build your Linux kernel outside of Buildroot, then it is your
462    responsibility to enable those two options (if you fail to do so,
463    your Buildroot system will not boot).
464 </li><li class="listitem">
465 The third solution is <span class="strong"><strong>Dynamic using mdev</strong></span>. This method also relies
466    on the <span class="emphasis"><em>devtmpfs</em></span> virtual filesystem detailed above (so the
467    requirement to have <code class="literal">CONFIG_DEVTMPFS</code> and <code class="literal">CONFIG_DEVTMPFS_MOUNT</code>
468    enabled in the kernel configuration still apply), but adds the
469    <code class="literal">mdev</code> userspace utility on top of it. <code class="literal">mdev</code> is a program part of
470    BusyBox that the kernel will call every time a device is added or
471    removed. Thanks to the <code class="literal">/etc/mdev.conf</code> configuration file, <code class="literal">mdev</code>
472    can be configured to for example, set specific permissions or
473    ownership on a device file, call a script or application whenever a
474    device appears or disappear, etc. Basically, it allows <span class="emphasis"><em>userspace</em></span>
475    to react on device addition and removal events. <code class="literal">mdev</code> can for
476    example be used to automatically load kernel modules when devices
477    appear on the system. <code class="literal">mdev</code> is also important if you have devices
478    that require a firmware, as it will be responsible for pushing the
479    firmware contents to the kernel. <code class="literal">mdev</code> is a lightweight
480    implementation (with fewer features) of <code class="literal">udev</code>. For more details
481    about <code class="literal">mdev</code> and the syntax of its configuration file, see
482    <a class="ulink" href="http://git.busybox.net/busybox/tree/docs/mdev.txt" target="_top">http://git.busybox.net/busybox/tree/docs/mdev.txt</a>.
483 </li><li class="listitem">
484 The fourth solution is <span class="strong"><strong>Dynamic using eudev</strong></span>. This method also
485    relies on the <span class="emphasis"><em>devtmpfs</em></span> virtual filesystem detailed above, but
486    adds the <code class="literal">eudev</code> userspace daemon on top of it. <code class="literal">eudev</code> is a daemon
487    that runs in the background, and gets called by the kernel when a
488    device gets added or removed from the system. It is a more
489    heavyweight solution than <code class="literal">mdev</code>, but provides higher flexibility.
490    <code class="literal">eudev</code> is a standalone version of <code class="literal">udev</code>, the original userspace
491    daemon used in most desktop Linux distributions, which is now part
492    of Systemd. For more details, see <a class="ulink" href="http://en.wikipedia.org/wiki/Udev" target="_top">http://en.wikipedia.org/wiki/Udev</a>.
493 </li></ul></div><p>The Buildroot developers recommendation is to start with the <span class="strong"><strong>Dynamic
494 using devtmpfs only</strong></span> solution, until you have the need for userspace
495 to be notified when devices are added/removed, or if firmwares are
496 needed, in which case <span class="strong"><strong>Dynamic using mdev</strong></span> is usually a good solution.</p><p>Note that if <code class="literal">systemd</code> is chosen as init system, /dev management will
497 be performed by the <code class="literal">udev</code> program provided by <code class="literal">systemd</code>.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_init_system"></a>6.3. init system</h2></div></div></div><p>The <span class="emphasis"><em>init</em></span> program is the first userspace program started by the
498 kernel (it carries the PID number 1), and is responsible for starting
499 the userspace services and programs (for example: web server,
500 graphical applications, other network servers, etc.).</p><p>Buildroot allows to use three different types of init systems, which
501 can be chosen from <code class="literal">System configuration</code>, <code class="literal">Init system</code>:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
502 The first solution is <span class="strong"><strong>BusyBox</strong></span>. Amongst many programs, BusyBox has
503    an implementation of a basic <code class="literal">init</code> program, which is sufficient
504    for most embedded systems. Enabling the <code class="literal">BR2_INIT_BUSYBOX</code> will
505    ensure BusyBox will build and install its <code class="literal">init</code> program. This is
506    the default solution in Buildroot. The BusyBox <code class="literal">init</code> program will
507    read the <code class="literal">/etc/inittab</code> file at boot to know what to do. The syntax
508    of this file can be found in
509    <a class="ulink" href="http://git.busybox.net/busybox/tree/examples/inittab" target="_top">http://git.busybox.net/busybox/tree/examples/inittab</a> (note that
510    BusyBox <code class="literal">inittab</code> syntax is special: do not use a random <code class="literal">inittab</code>
511    documentation from the Internet to learn about BusyBox
512    <code class="literal">inittab</code>). The default <code class="literal">inittab</code> in Buildroot is stored in
513    <code class="literal">system/skeleton/etc/inittab</code>. Apart from mounting a few important
514    filesystems, the main job the default inittab does is to start the
515    <code class="literal">/etc/init.d/rcS</code> shell script, and start a <code class="literal">getty</code> program (which
516    provides a login prompt).
517 </li><li class="listitem">
518 The second solution is <span class="strong"><strong>systemV</strong></span>. This solution uses the old
519    traditional <span class="emphasis"><em>sysvinit</em></span> program, packed in Buildroot in
520    <code class="literal">package/sysvinit</code>. This was the solution used in most desktop
521    Linux distributions, until they switched to more recent
522    alternatives such as Upstart or Systemd. <code class="literal">sysvinit</code> also works with
523    an <code class="literal">inittab</code> file (which has a slightly different syntax than the
524    one from BusyBox). The default <code class="literal">inittab</code> installed with this init
525    solution is located in <code class="literal">package/sysvinit/inittab</code>.
526 </li><li class="listitem">
527 The third solution is <span class="strong"><strong>systemd</strong></span>. <code class="literal">systemd</code> is the new generation
528    init system for Linux. It does far more than traditional <span class="emphasis"><em>init</em></span>
529    programs: aggressive parallelization capabilities, uses socket and
530    D-Bus activation for starting services, offers on-demand starting
531    of daemons, keeps track of processes using Linux control groups,
532    supports snapshotting and restoring of the system state,
533    etc. <code class="literal">systemd</code> will be useful on relatively complex embedded
534    systems, for example the ones requiring D-Bus and services
535    communicating between each other. It is worth noting that <code class="literal">systemd</code>
536    brings a fairly big number of large dependencies: <code class="literal">dbus</code>, <code class="literal">udev</code>
537    and more. For more details about <code class="literal">systemd</code>, see
538    <a class="ulink" href="http://www.freedesktop.org/wiki/Software/systemd" target="_top">http://www.freedesktop.org/wiki/Software/systemd</a>.
539 </li></ul></div><p>The solution recommended by Buildroot developers is to use the
540 <span class="strong"><strong>BusyBox init</strong></span> as it is sufficient for most embedded
541 systems. <span class="strong"><strong>systemd</strong></span> can be used for more complex situations.</p></div><div class="footnotes"><br /><hr style="width:100; text-align:left;margin-left: 0" /><div id="ftn.idm139994500107152" class="footnote"><p><a href="#idm139994500107152" class="simpara"><sup class="simpara">[3] </sup></a>This terminology differs from what is used by GNU
542 configure, where the host is the machine on which the application will
543 run (which is usually the same as target)</p></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_configuration_of_other_components"></a>Chapter 7. Configuration of other components</h2></div></div></div><p>Before attempting to modify any of the components below, make sure you
544 have already configured Buildroot itself, and have enabled the
545 corresponding package.</p><div class="variablelist"><dl class="variablelist"><dt><span class="term">
546 BusyBox
547 </span></dt><dd><p class="simpara">If you already have a BusyBox configuration file, you can directly
548 specify this file in the Buildroot configuration, using
549 <code class="literal">BR2_PACKAGE_BUSYBOX_CONFIG</code>. Otherwise, Buildroot will start from a
550 default BusyBox configuration file.</p><p class="simpara">To make subsequent changes to the configuration, use <code class="literal">make
551 busybox-menuconfig</code> to open the BusyBox configuration editor.</p><p class="simpara">It is also possible to specify a BusyBox configuration file through an
552 environment variable, although this is not recommended. Refer to
553 <a class="xref" href="#env-vars" title="8.6. Environment variables">Section 8.6, “Environment variables”</a> for more details.</p></dd><dt><span class="term">
554 uClibc
555 </span></dt><dd>Configuration of uClibc is done in the same way as for BusyBox. The
556 configuration variable to specify an existing configuration file is
557 <code class="literal">BR2_UCLIBC_CONFIG</code>. The command to make subsequent changes is <code class="literal">make
558 uclibc-menuconfig</code>.</dd><dt><span class="term">
559 Linux kernel
560 </span></dt><dd><p class="simpara">If you already have a kernel configuration file, you can directly
561 specify this file in the Buildroot configuration, using
562 <code class="literal">BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG</code>.</p><p class="simpara">If you do not yet have a kernel configuration file, you can either start
563 by specifying a defconfig in the Buildroot configuration, using
564 <code class="literal">BR2_LINUX_KERNEL_USE_DEFCONFIG</code>, or start by creating an empty file and
565 specifying it as custom configuration file, using
566 <code class="literal">BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG</code>.</p><p class="simpara">To make subsequent changes to the configuration, use <code class="literal">make
567 linux-menuconfig</code> to open the Linux configuration editor.</p></dd><dt><span class="term">
568 Barebox
569 </span></dt><dd>Configuration of Barebox is done in the same way as for the Linux
570 kernel. The corresponding configuration variables are
571 <code class="literal">BR2_TARGET_BAREBOX_USE_CUSTOM_CONFIG</code> and
572 <code class="literal">BR2_TARGET_BAREBOX_USE_DEFCONFIG</code>. To open the configuration editor,
573 use <code class="literal">make barebox-menuconfig</code>.</dd></dl></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_general_buildroot_usage"></a>Chapter 8. General Buildroot usage</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="make-tips"></a>8.1. <span class="emphasis"><em>make</em></span> tips</h2></div></div></div><p>This is a collection of tips that help you make the most of Buildroot.</p><p><strong>Display all commands executed by make: </strong>
574 </p><pre class="screen"> $ make V=1 &lt;target&gt;</pre><p>
575 </p><p><strong>Display the list of boards with a defconfig: </strong>
576 </p><pre class="screen"> $ make list-defconfigs</pre><p>
577 </p><p><strong>Display all available targets: </strong>
578 </p><pre class="screen"> $ make help</pre><p>
579 </p><p>Not all targets are always available,
580 some settings in the <code class="literal">.config</code> file may hide some targets:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
581 <code class="literal">busybox-menuconfig</code> only works when <code class="literal">busybox</code> is enabled;
582 </li><li class="listitem">
583 <code class="literal">linux-menuconfig</code> and <code class="literal">linux-savedefconfig</code> only work when
584   <code class="literal">linux</code> is enabled;
585 </li><li class="listitem">
586 <code class="literal">uclibc-menuconfig</code> is only available when the uClibc C library is
587   selected in the internal toolchain backend;
588 </li><li class="listitem">
589 <code class="literal">barebox-menuconfig</code> and <code class="literal">barebox-savedefconfig</code> only work when the
590   <code class="literal">barebox</code> bootloader is enabled.
591 </li></ul></div><p><strong>Cleaning: </strong>Explicit cleaning is required when any of the architecture or toolchain
592 configuration options are changed.</p><p>To delete all build products (including build directories, host, staging
593 and target trees, the images and the toolchain):</p><pre class="screen"> $ make clean</pre><p><strong>Generating the manual: </strong>The present manual sources are located in the <span class="emphasis"><em>docs/manual</em></span> directory.
594 To generate the manual:</p><pre class="screen"> $ make manual-clean
595  $ make manual</pre><p>The manual outputs will be generated in <span class="emphasis"><em>output/docs/manual</em></span>.</p><div class="itemizedlist"><p class="title"><strong>Notes</strong></p><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
596 A few tools are required to build the documentation (see:
597   <a class="xref" href="#requirement-optional" title="2.2. Optional packages">Section 2.2, “Optional packages”</a>).
598 </li></ul></div><p><strong>Resetting Buildroot for a new target: </strong>To delete all build products as well as the configuration:</p><pre class="screen"> $ make distclean</pre><p><strong>Notes. </strong>If <code class="literal">ccache</code> is enabled, running <code class="literal">make clean</code> or <code class="literal">distclean</code> does
599 not empty the compiler cache used by Buildroot. To delete it, refer
600 to <a class="xref" href="#ccache" title="8.11.3. Using ccache in Buildroot">Section 8.11.3, “Using <code class="literal">ccache</code> in Buildroot”</a>.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="full-rebuild"></a>8.2. Understanding when a full rebuild is necessary</h2></div></div></div><p>Buildroot does not attempt to detect what parts of the system should
601 be rebuilt when the system configuration is changed through <code class="literal">make
602 menuconfig</code>, <code class="literal">make xconfig</code> or one of the other configuration
603 tools. In some cases, Buildroot should rebuild the entire system, in
604 some cases, only a specific subset of packages. But detecting this in
605 a completely reliable manner is very difficult, and therefore the
606 Buildroot developers have decided to simply not attempt to do this.</p><p>Instead, it is the responsibility of the user to know when a full
607 rebuild is necessary. As a hint, here are a few rules of thumb that
608 can help you understand how to work with Buildroot:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
609 When the target architecture configuration is changed, a complete
610    rebuild is needed. Changing the architecture variant, the binary
611    format or the floating point strategy for example has an impact on
612    the entire system.
613 </li><li class="listitem">
614 When the toolchain configuration is changed, a complete rebuild
615    generally is needed. Changing the toolchain configuration often
616    involves changing the compiler version, the type of C library or
617    its configuration, or some other fundamental configuration item,
618    and these changes have an impact on the entire system.
619 </li><li class="listitem">
620 When an additional package is added to the configuration, a full
621    rebuild is not necessarily needed. Buildroot will detect that this
622    package has never been built, and will build it. However, if this
623    package is a library that can optionally be used by packages that
624    have already been built, Buildroot will not automatically rebuild
625    those. Either you know which packages should be rebuilt, and you
626    can rebuild them manually, or you should do a full rebuild. For
627    example, let’s suppose you have built a system with the <code class="literal">ctorrent</code>
628    package, but without <code class="literal">openssl</code>. Your system works, but you realize
629    you would like to have SSL support in <code class="literal">ctorrent</code>, so you enable the
630    <code class="literal">openssl</code> package in Buildroot configuration and restart the
631    build. Buildroot will detect that <code class="literal">openssl</code> should be built and
632    will be build it, but it will not detect that <code class="literal">ctorrent</code> should be
633    rebuilt to benefit from <code class="literal">openssl</code> to add OpenSSL support. You will
634    either have to do a full rebuild, or rebuild <code class="literal">ctorrent</code> itself.
635 </li><li class="listitem">
636 When a package is removed from the configuration, Buildroot does
637    not do anything special. It does not remove the files installed by
638    this package from the target root filesystem or from the toolchain
639    <span class="emphasis"><em>sysroot</em></span>. A full rebuild is needed to get rid of this
640    package. However, generally you don’t necessarily need this package
641    to be removed right now: you can wait for the next lunch break to
642    restart the build from scratch.
643 </li><li class="listitem">
644 When the sub-options of a package are changed, the package is not
645    automatically rebuilt. After making such changes, rebuilding only
646    this package is often sufficient, unless enabling the package
647    sub-option adds some features to the package that are useful for
648    another package which has already been built. Again, Buildroot does
649    not track when a package should be rebuilt: once a package has been
650    built, it is never rebuilt unless explicitly told to do so.
651 </li><li class="listitem">
652 When a change to the root filesystem skeleton is made, a full
653    rebuild is needed. However, when changes to the root filesystem
654    overlay, a post-build script or a post-image script are made,
655    there is no need for a full rebuild: a simple <code class="literal">make</code> invocation
656    will take the changes into account.
657 </li></ul></div><p>Generally speaking, when you’re facing a build error and you’re unsure
658 of the potential consequences of the configuration changes you’ve
659 made, do a full rebuild. If you get the same build error, then you are
660 sure that the error is not related to partial rebuilds of packages,
661 and if this error occurs with packages from the official Buildroot, do
662 not hesitate to report the problem! As your experience with Buildroot
663 progresses, you will progressively learn when a full rebuild is really
664 necessary, and you will save more and more time.</p><p>For reference, a full rebuild is achieved by running:</p><pre class="screen">$ make clean all</pre></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="rebuild-pkg"></a>8.3. Understanding how to rebuild packages</h2></div></div></div><p>One of the most common questions asked by Buildroot users is how to
665 rebuild a given package or how to remove a package without rebuilding
666 everything from scratch.</p><p>Removing a package is unsupported by Buildroot without
667 rebuilding from scratch. This is because Buildroot doesn’t keep track
668 of which package installs what files in the <code class="literal">output/staging</code> and
669 <code class="literal">output/target</code> directories, or which package would be compiled differently
670 depending on the availability of another package.</p><p>The easiest way to rebuild a single package from scratch is to remove
671 its build directory in <code class="literal">output/build</code>. Buildroot will then re-extract,
672 re-configure, re-compile and re-install this package from scratch. You
673 can ask buildroot to do this with the <code class="literal">make &lt;package&gt;-dirclean</code> command.</p><p>On the other hand, if you only want to restart the build process of a
674 package from its compilation step, you can run <code class="literal">make
675 &lt;package&gt;-rebuild</code>, followed by <code class="literal">make</code> or <code class="literal">make &lt;package&gt;</code>. It will
676 restart the compilation and installation of the package, but not from
677 scratch: it basically re-executes <code class="literal">make</code> and <code class="literal">make install</code>
678 inside the package, so it will only rebuild files that changed.</p><p>If you want to restart the build process of a package from its
679 configuration step, you can run <code class="literal">make &lt;package&gt;-reconfigure</code>, followed
680 by <code class="literal">make</code> or <code class="literal">make &lt;package&gt;</code>. It will restart the configuration,
681 compilation and installation of the package.</p><p>Internally, Buildroot creates so-called <span class="emphasis"><em>stamp files</em></span> to keep track of
682 which build steps have been completed for each package. They are
683 stored in the package build directory,
684 <code class="literal">output/build/&lt;package&gt;-&lt;version&gt;/</code> and are named
685 <code class="literal">.stamp_&lt;step-name&gt;</code>. The commands detailed above simply manipulate
686 these stamp files to force Buildroot to restart a specific set of
687 steps of a package build process.</p><p>Further details about package special make targets are explained in
688 <a class="xref" href="#pkg-build-steps" title="8.11.5. Package-specific make targets">Section 8.11.5, “Package-specific <span class="emphasis"><em>make</em></span> targets”</a>.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_offline_builds"></a>8.4. Offline builds</h2></div></div></div><p>If you intend to do an offline build and just want to download
689 all sources that you previously selected in the configurator
690 (<span class="emphasis"><em>menuconfig</em></span>, <span class="emphasis"><em>nconfig</em></span>, <span class="emphasis"><em>xconfig</em></span> or <span class="emphasis"><em>gconfig</em></span>), then issue:</p><pre class="screen"> $ make source</pre><p>You can now disconnect or copy the content of your <code class="literal">dl</code>
691 directory to the build-host.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_building_out_of_tree"></a>8.5. Building out-of-tree</h2></div></div></div><p>As default, everything built by Buildroot is stored in the directory
692 <code class="literal">output</code> in the Buildroot tree.</p><p>Buildroot also supports building out of tree with a syntax similar to
693 the Linux kernel. To use it, add <code class="literal">O=&lt;directory&gt;</code> to the make command
694 line:</p><pre class="screen"> $ make O=/tmp/build</pre><p>Or:</p><pre class="screen"> $ cd /tmp/build; make O=$PWD -C path/to/buildroot</pre><p>All the output files will be located under <code class="literal">/tmp/build</code>. If the <code class="literal">O</code>
695 path does not exist, Buildroot will create it.</p><p><span class="strong"><strong>Note:</strong></span> the <code class="literal">O</code> path can be either an absolute or a relative path, but if it’s
696 passed as a relative path, it is important to note that it is interpreted
697 relative to the main Buildroot source directory, <span class="strong"><strong>not</strong></span> the current working
698 directory.</p><p>When using out-of-tree builds, the Buildroot <code class="literal">.config</code> and temporary
699 files are also stored in the output directory. This means that you can
700 safely run multiple builds in parallel using the same source tree as
701 long as they use unique output directories.</p><p>For ease of use, Buildroot generates a Makefile wrapper in the output
702 directory - so after the first run, you no longer need to pass <code class="literal">O=&lt;…&gt;</code>
703 and <code class="literal">-C &lt;…&gt;</code>, simply run (in the output directory):</p><pre class="screen"> $ make &lt;target&gt;</pre></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="env-vars"></a>8.6. Environment variables</h2></div></div></div><p>Buildroot also honors some environment variables, when they are passed
704 to <code class="literal">make</code> or set in the environment:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
705 <code class="literal">HOSTCXX</code>, the host C++ compiler to use
706 </li><li class="listitem">
707 <code class="literal">HOSTCC</code>, the host C compiler to use
708 </li><li class="listitem">
709 <code class="literal">UCLIBC_CONFIG_FILE=&lt;path/to/.config&gt;</code>, path to
710   the uClibc configuration file, used to compile uClibc, if an
711   internal toolchain is being built.
712  
713   Note that the uClibc configuration file can also be set from the
714   configuration interface, so through the Buildroot <code class="literal">.config</code> file; this
715   is the recommended way of setting it.
716  
717 </li><li class="listitem">
718 <code class="literal">BUSYBOX_CONFIG_FILE=&lt;path/to/.config&gt;</code>, path to
719   the BusyBox configuration file.
720  
721   Note that the BusyBox configuration file can also be set from the
722   configuration interface, so through the Buildroot <code class="literal">.config</code> file; this
723   is the recommended way of setting it.
724  
725 </li><li class="listitem">
726 <code class="literal">BR2_DL_DIR</code> to override the directory in which
727   Buildroot stores/retrieves downloaded files
728  
729   Note that the Buildroot download directory can also be set from the
730   configuration interface, so through the Buildroot <code class="literal">.config</code> file; this
731   is the recommended way of setting it.
732 </li><li class="listitem">
733 <code class="literal">BR2_GRAPH_ALT</code>, if set and non-empty, to use an alternate color-scheme in
734   build-time graphs
735 </li><li class="listitem">
736 <code class="literal">BR2_GRAPH_OUT</code> to set the filetype of generated graphs, either <code class="literal">pdf</code> (the
737   default), or <code class="literal">png</code>.
738 </li><li class="listitem">
739 <code class="literal">BR2_GRAPH_DEPS_OPTS</code> to pass extra options to the dependency graph; see
740   <a class="xref" href="#graph-depends">Section 8.8, “Graphing the dependencies between packages”</a> for the accepted options
741 </li><li class="listitem">
742 <code class="literal">BR2_GRAPH_DOT_OPTS</code> is passed verbatim as options to the <code class="literal">dot</code> utility to
743   draw the dependency graph.
744 </li></ul></div><p>An example that uses config files located in the toplevel directory and
745 in your $HOME:</p><pre class="screen"> $ make UCLIBC_CONFIG_FILE=uClibc.config BUSYBOX_CONFIG_FILE=$HOME/bb.config</pre><p>If you want to use a compiler other than the default <code class="literal">gcc</code>
746 or <code class="literal">g</code>++ for building helper-binaries on your host, then do</p><pre class="screen"> $ make HOSTCXX=g++-4.3-HEAD HOSTCC=gcc-4.3-HEAD</pre></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_dealing_efficiently_with_filesystem_images"></a>8.7. Dealing efficiently with filesystem images</h2></div></div></div><p>Filesystem images can get pretty big, depending on the filesystem you choose,
747 the number of packages, whether you provisioned free space… Yet, some
748 locations in the filesystems images may just be <span class="emphasis"><em>empty</em></span> (e.g. a long run of
749 <span class="emphasis"><em>zeroes</em></span>); such a file is called a <span class="emphasis"><em>sparse</em></span> file.</p><p>Most tools can handle sparse files efficiently, and will only store or write
750 those parts of a sparse file that are not empty.</p><p>For example:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p class="simpara">
751 <code class="literal">tar</code> accepts the <code class="literal">-S</code> option to tell it to only store non-zero blocks
752   of sparse files:
753 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
754 <code class="literal">tar cf archive.tar -S [files…]</code> will efficiently store sparse files
755    in a tarball
756 </li><li class="listitem">
757 <code class="literal">tar xf archive.tar -S</code> will efficiently store sparse files extracted
758    from a tarball
759 </li></ul></div></li><li class="listitem"><p class="simpara">
760 <code class="literal">cp</code> accepts the <code class="literal">--sparse=WHEN</code> option (<code class="literal">WHEN</code> is one of <code class="literal">auto</code>,
761   <code class="literal">never</code> or <code class="literal">always</code>):
762 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
763 <code class="literal">cp --sparse=always source.file dest.file</code> will make <code class="literal">dest.file</code> a
764    sparse file if <code class="literal">source.file</code> has long runs of zeroes
765 </li></ul></div></li></ul></div><p>Other tools may have similar options. Please consult their respective man
766 pages.</p><p>You can use sparse files if you need to store the filesystem images (e.g.
767 to transfer from one machine to another), or if you need to send them (e.g.
768 to the Q&amp;A team).</p><p>Note however that flashing a filesystem image to a device while using the
769 sparse mode of <code class="literal">dd</code> may result in a broken filesystem (e.g. the block bitmap
770 of an ext2 filesystem may be corrupted; or, if you have sparse files in
771 your filesystem, those parts may not be all-zeroes when read back). You
772 should only use sparse files when handling files on the build machine, not
773 when transferring them to an actual device that will be used on the target.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_graphing_the_dependencies_between_packages"></a>8.8. Graphing the dependencies between packages</h2></div></div></div><p><a id="graph-depends"></a>One of Buildroot’s jobs is to know the dependencies between packages,
774 and make sure they are built in the right order. These dependencies
775 can sometimes be quite complicated, and for a given system, it is
776 often not easy to understand why such or such package was brought into
777 the build by Buildroot.</p><p>In order to help understanding the dependencies, and therefore better
778 understand what is the role of the different components in your
779 embedded Linux system, Buildroot is capable of generating dependency
780 graphs.</p><p>To generate a dependency graph of the full system you have compiled,
781 simply run:</p><pre class="screen">make graph-depends</pre><p>You will find the generated graph in
782 <code class="literal">output/graphs/graph-depends.pdf</code>.</p><p>If your system is quite large, the dependency graph may be too complex
783 and difficult to read. It is therefore possible to generate the
784 dependency graph just for a given package:</p><pre class="screen">make &lt;pkg&gt;-graph-depends</pre><p>You will find the generated graph in
785 <code class="literal">output/graph/&lt;pkg&gt;-graph-depends.pdf</code>.</p><p>Note that the dependency graphs are generated using the <code class="literal">dot</code> tool
786 from the <span class="emphasis"><em>Graphviz</em></span> project, which you must have installed on your
787 system to use this feature. In most distributions, it is available as
788 the <code class="literal">graphviz</code> package.</p><p>By default, the dependency graphs are generated in the PDF
789 format. However, by passing the <code class="literal">BR2_GRAPH_OUT</code> environment variable, you
790 can switch to other output formats, such as PNG, PostScript or
791 SVG. All formats supported by the <code class="literal">-T</code> option of the <code class="literal">dot</code> tool are
792 supported.</p><pre class="screen">BR2_GRAPH_OUT=svg make graph-depends</pre><p>The <code class="literal">graph-depends</code> behaviour can be controlled by setting options in the
793 <code class="literal">BR2_GRAPH_DEPS_OPTS</code> environment variable. The accepted options are:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
794 <code class="literal">--depth N</code>, <code class="literal">-d N</code>, to limit the dependency depth to <code class="literal">N</code> levels. The
795   default, <code class="literal">0</code>, means no limit.
796 </li><li class="listitem">
797 <code class="literal">--stop-on PKG</code>, <code class="literal">-s PKG</code>, to stop the graph on the package <code class="literal">PKG</code>.
798   <code class="literal">PKG</code> can be an actual package name, a glob, or the keyword <span class="emphasis"><em>virtual</em></span>
799   (to stop on virtual packages). The package is still present on the
800   graph, but its dependencies are not.
801 </li><li class="listitem">
802 <code class="literal">--exclude PKG</code>, <code class="literal">-x PKG</code>, like <code class="literal">--stop-on</code>, but also omits <code class="literal">PKG</code> from
803   the graph.
804 </li><li class="listitem">
805 <code class="literal">--transitive</code>, <code class="literal">--no-transitive</code>, to draw (or not) the transitive
806   dependencies. The default is to not draw transitive dependencies.
807 </li><li class="listitem">
808 <code class="literal">--colours R,T,H</code>, the comma-separated list of colours to draw the
809   root package (<code class="literal">R</code>), the target packages (<code class="literal">T</code>) and the host packages
810   (<code class="literal">H</code>). Defaults to: <code class="literal">lightblue,grey,gainsboro</code>
811 </li></ul></div><pre class="screen">BR2_GRAPH_DEPS_OPTS='-d 3 --no-transitive --colours=red,green,blue' make graph-depends</pre></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_graphing_the_build_duration"></a>8.9. Graphing the build duration</h2></div></div></div><p><a id="graph-duration"></a>When the build of a system takes a long time, it is sometimes useful
812 to be able to understand which packages are the longest to build, to
813 see if anything can be done to speed up the build. In order to help
814 such build time analysis, Buildroot collects the build time of each
815 step of each package, and allows to generate graphs from this data.</p><p>To generate the build time graph after a build, run:</p><pre class="screen">make graph-build</pre><p>This will generate a set of files in <code class="literal">output/graphs</code> :</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
816 <code class="literal">build.hist-build.pdf</code>, a histogram of the build time for each
817   package, ordered in the build order.
818 </li><li class="listitem">
819 <code class="literal">build.hist-duration.pdf</code>, a histogram of the build time for each
820   package, ordered by duration (longest first)
821 </li><li class="listitem">
822 <code class="literal">build.hist-name.pdf</code>, a histogram of the build time for each
823   package, order by package name.
824 </li><li class="listitem">
825 <code class="literal">build.pie-packages.pdf</code>, a pie chart of the build time per package
826 </li><li class="listitem">
827 <code class="literal">build.pie-steps.pdf</code>, a pie chart of the global time spent in each
828   step of the packages build process.
829 </li></ul></div><p>This <code class="literal">graph-build</code> target requires the Python Matplotlib and Numpy
830 libraries to be installed (<code class="literal">python-matplotlib</code> and <code class="literal">python-numpy</code> on
831 most distributions), and also the <code class="literal">argparse</code> module if you’re using a
832 Python version older than 2.7 (<code class="literal">python-argparse</code> on most
833 distributions).</p><p>By default, the output format for the graph is PDF, but a different
834 format can be selected using the <code class="literal">BR2_GRAPH_OUT</code> environment variable. The
835 only other format supported is PNG:</p><pre class="screen">BR2_GRAPH_OUT=png make graph-build</pre></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_integration_with_eclipse"></a>8.10. Integration with Eclipse</h2></div></div></div><p>While a part of the embedded Linux developers like classical text
836 editors like Vim or Emacs, and command-line based interfaces, a number
837 of other embedded Linux developers like richer graphical interfaces to
838 do their development work. Eclipse being one of the most popular
839 Integrated Development Environment, Buildroot integrates with Eclipse
840 in order to ease the development work of Eclipse users.</p><p>Our integration with Eclipse simplifies the compilation, remote
841 execution and remote debugging of applications and libraries that are
842 built on top of a Buildroot system. It does not integrate the
843 Buildroot configuration and build processes themselves with
844 Eclipse. Therefore, the typical usage model of our Eclipse integration
845 would be:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
846 Configure your Buildroot system with <code class="literal">make menuconfig</code>, <code class="literal">make
847   xconfig</code> or any other configuration interface provided with
848   Buildroot.
849 </li><li class="listitem">
850 Build your Buildroot system by running <code class="literal">make</code>.
851 </li><li class="listitem">
852 Start Eclipse to develop, execute and debug your own custom
853   applications and libraries, that will rely on the libraries built
854   and installed by Buildroot.
855 </li></ul></div><p>The Buildroot Eclipse integration installation process and usage is
856 described in detail at
857 <a class="ulink" href="https://github.com/mbats/eclipse-buildroot-bundle/wiki" target="_top">https://github.com/mbats/eclipse-buildroot-bundle/wiki</a>.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_advanced_usage"></a>8.11. Advanced usage</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_using_the_generated_toolchain_outside_buildroot"></a>8.11.1. Using the generated toolchain outside Buildroot</h3></div></div></div><p>You may want to compile, for your target, your own programs or other
858 software that are not packaged in Buildroot. In order to do this you
859 can use the toolchain that was generated by Buildroot.</p><p>The toolchain generated by Buildroot is located by default in
860 <code class="literal">output/host/</code>. The simplest way to use it is to add
861 <code class="literal">output/host/usr/bin/</code> to your PATH environment variable and then to
862 use <code class="literal">ARCH-linux-gcc</code>, <code class="literal">ARCH-linux-objdump</code>, <code class="literal">ARCH-linux-ld</code>, etc.</p><p>It is possible to relocate the toolchain - but then <code class="literal">--sysroot</code> must
863 be passed every time the compiler is called to tell where the
864 libraries and header files are.</p><p>It is also possible to generate the Buildroot toolchain in a directory
865 other than <code class="literal">output/host</code> by using the <code class="literal">Build options → Host dir</code>
866 option. This could be useful if the toolchain must be shared with
867 other users.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_using_literal_gdb_literal_in_buildroot"></a>8.11.2. Using <code class="literal">gdb</code> in Buildroot</h3></div></div></div><p>Buildroot allows to do cross-debugging, where the debugger runs on the
868 build machine and communicates with <code class="literal">gdbserver</code> on the target to
869 control the execution of the program.</p><p>To achieve this:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
870 If you are using an <span class="emphasis"><em>internal toolchain</em></span> (built by Buildroot), you
871   must enable <code class="literal">BR2_PACKAGE_HOST_GDB</code>, <code class="literal">BR2_PACKAGE_GDB</code> and
872   <code class="literal">BR2_PACKAGE_GDB_SERVER</code>. This ensures that both the cross gdb and
873   gdbserver get built, and that gdbserver gets installed to your target.
874 </li><li class="listitem">
875 If you are using an <span class="emphasis"><em>external toolchain</em></span>, you should enable
876   <code class="literal">BR2_TOOLCHAIN_EXTERNAL_GDB_SERVER_COPY</code>, which will copy the
877   gdbserver included with the external toolchain to the target. If your
878   external toolchain does not have a cross gdb or gdbserver, it is also
879   possible to let Buildroot build them, by enabling the same options as
880   for the <span class="emphasis"><em>internal toolchain backend</em></span>.
881 </li></ul></div><p>Now, to start debugging a program called <code class="literal">foo</code>, you should run on the
882 target:</p><pre class="screen">gdbserver :2345 foo</pre><p>This will cause <code class="literal">gdbserver</code> to listen on TCP port 2345 for a connection
883 from the cross gdb.</p><p>Then, on the host, you should start the cross gdb using the following
884 command line:</p><pre class="screen">&lt;buildroot&gt;/output/host/usr/bin/&lt;tuple&gt;-gdb -x &lt;buildroot&gt;/output/staging/usr/share/buildroot/gdbinit foo</pre><p>Of course, <code class="literal">foo</code> must be available in the current directory, built
885 with debugging symbols. Typically you start this command from the
886 directory where <code class="literal">foo</code> is built (and not from <code class="literal">output/target/</code> as the
887 binaries in that directory are stripped).</p><p>The <code class="literal">&lt;buildroot&gt;/output/staging/usr/share/buildroot/gdbinit</code> file will tell the
888 cross gdb where to find the libraries of the target.</p><p>Finally, to connect to the target from the cross gdb:</p><pre class="screen">(gdb) target remote &lt;target ip address&gt;:2345</pre></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="ccache"></a>8.11.3. Using <code class="literal">ccache</code> in Buildroot</h3></div></div></div><p><a class="ulink" href="http://ccache.samba.org" target="_top">ccache</a> is a compiler cache. It stores the
889 object files resulting from each compilation process, and is able to
890 skip future compilation of the same source file (with same compiler
891 and same arguments) by using the pre-existing object files. When doing
892 almost identical builds from scratch a number of times, it can nicely
893 speed up the build process.</p><p><code class="literal">ccache</code> support is integrated in Buildroot. You just have to enable
894 <code class="literal">Enable compiler cache</code> in <code class="literal">Build options</code>. This will automatically
895 build <code class="literal">ccache</code> and use it for every host and target compilation.</p><p>The cache is located in <code class="literal">$HOME/.buildroot-ccache</code>. It is stored
896 outside of Buildroot output directory so that it can be shared by
897 separate Buildroot builds. If you want to get rid of the cache, simply
898 remove this directory.</p><p>You can get statistics on the cache (its size, number of hits,
899 misses, etc.) by running <code class="literal">make ccache-stats</code>.</p><p>The make target <code class="literal">ccache-options</code> and the <code class="literal">CCACHE_OPTIONS</code> variable
900 provide more generic access to the ccache. For example</p><pre class="screen"># set cache limit size
901 make CCACHE_OPTIONS="--max-size=5G" ccache-options
902
903 # zero statistics counters
904 make CCACHE_OPTIONS="--zero-stats" ccache-options</pre></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_location_of_downloaded_packages"></a>8.11.4. Location of downloaded packages</h3></div></div></div><p>The various tarballs that are downloaded by Buildroot are all stored
905 in <code class="literal">BR2_DL_DIR</code>, which by default is the <code class="literal">dl</code> directory. If you want
906 to keep a complete version of Buildroot which is known to be working
907 with the associated tarballs, you can make a copy of this directory.
908 This will allow you to regenerate the toolchain and the target
909 filesystem with exactly the same versions.</p><p>If you maintain several Buildroot trees, it might be better to have a
910 shared download location. This can be achieved by pointing the
911 <code class="literal">BR2_DL_DIR</code> environment variable to a directory. If this is
912 set, then the value of <code class="literal">BR2_DL_DIR</code> in the Buildroot configuration is
913 overridden. The following line should be added to <code class="literal">&lt;~/.bashrc&gt;</code>.</p><pre class="screen"> $ export BR2_DL_DIR &lt;shared download location&gt;</pre><p>The download location can also be set in the <code class="literal">.config</code> file, with the
914 <code class="literal">BR2_DL_DIR</code> option. Unlike most options in the .config file, this value
915 is overridden by the <code class="literal">BR2_DL_DIR</code> environment variable.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="pkg-build-steps"></a>8.11.5. Package-specific <span class="emphasis"><em>make</em></span> targets</h3></div></div></div><p>Running <code class="literal">make &lt;package&gt;</code> builds and installs that particular package
916 and its dependencies.</p><p>For packages relying on the Buildroot infrastructure, there are
917 numerous special make targets that can be called independently like
918 this:</p><pre class="screen">make &lt;package&gt;-&lt;target&gt;</pre><p>The package build targets are (in the order they are executed):</p><div class="informaltable"><table cellpadding="4px" style="border-collapse: collapse;border-top: 3px solid #527bbd; border-bottom: 3px solid #527bbd; border-left: 3px solid #527bbd; border-right: 3px solid #527bbd; " width="90%"><colgroup><col class="col_1" /><col class="col_2" /></colgroup><thead><tr><th style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"> command/target    </th><th style="border-bottom: 1px solid #527bbd; " align="left" valign="top"> Description</th></tr></thead><tbody><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">source</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Fetch the source (download the tarball, clone
919 the source repository, etc)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">depends</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Build and install all dependencies required to
920 build the package</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">extract</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Put the source in the package build directory
921 (extract the tarball, copy the source, etc)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">patch</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Apply the patches, if any</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">configure</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Run the configure commands, if any</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">build</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Run the compilation commands</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">install-staging</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><span class="strong"><strong>target package:</strong></span> Run the installation of the package in the
922 staging directory, if necessary</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">install-target</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><span class="strong"><strong>target package:</strong></span> Run the installation of the package in the
923 target directory, if necessary</p></td></tr><tr><td style="border-right: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">install</code></p></td><td style="" align="left" valign="top"><p><span class="strong"><strong>target package:</strong></span> Run the 2 previous installation commands</p>
924 <p><span class="strong"><strong>host package:</strong></span> Run the installation of the package in the host
925 directory</p></td></tr></tbody></table></div><p>Additionally, there are some other useful make targets:</p><div class="informaltable"><table cellpadding="4px" style="border-collapse: collapse;border-top: 3px solid #527bbd; border-bottom: 3px solid #527bbd; border-left: 3px solid #527bbd; border-right: 3px solid #527bbd; " width="90%"><colgroup><col class="col_1" /><col class="col_2" /></colgroup><thead><tr><th style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"> command/target    </th><th style="border-bottom: 1px solid #527bbd; " align="left" valign="top"> Description</th></tr></thead><tbody><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">show-depends</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Displays the dependencies required to build the
926 package</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">graph-depends</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Generate a dependency graph of the package, in the
927 context of the current Buildroot configuration. See
928 <a class="link" href="#graph-depends">this section</a>
929 <a class="xref" href="#graph-depends">Section 8.8, “Graphing the dependencies between packages”</a> for more details about dependency
930 graphs.</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">dirclean</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Remove the whole package build directory</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">reinstall</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Re-run the install commands</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">rebuild</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Re-run the compilation commands - this only makes
931 sense when using the <code class="literal">OVERRIDE_SRCDIR</code> feature or when you modified a file
932 directly in the build directory</p></td></tr><tr><td style="border-right: 1px solid #527bbd; " align="center" valign="top"><p><code class="literal">reconfigure</code></p></td><td style="" align="left" valign="top"><p>Re-run the configure commands, then rebuild - this only
933 makes sense when using the <code class="literal">OVERRIDE_SRCDIR</code> feature or when you modified a
934 file directly in the build directory</p></td></tr></tbody></table></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_using_buildroot_during_development"></a>8.11.6. Using Buildroot during development</h3></div></div></div><p>The normal operation of Buildroot is to download a tarball, extract
935 it, configure, compile and install the software component found inside
936 this tarball. The source code is extracted in
937 <code class="literal">output/build/&lt;package&gt;-&lt;version&gt;</code>, which is a temporary directory:
938 whenever <code class="literal">make clean</code> is used, this directory is entirely removed, and
939 re-recreated at the next <code class="literal">make</code> invocation. Even when a Git or
940 Subversion repository is used as the input for the package source
941 code, Buildroot creates a tarball out of it, and then behaves as it
942 normally does with tarballs.</p><p>This behavior is well-suited when Buildroot is used mainly as an
943 integration tool, to build and integrate all the components of an
944 embedded Linux system. However, if one uses Buildroot during the
945 development of certain components of the system, this behavior is not
946 very convenient: one would instead like to make a small change to the
947 source code of one package, and be able to quickly rebuild the system
948 with Buildroot.</p><p>Making changes directly in <code class="literal">output/build/&lt;package&gt;-&lt;version&gt;</code> is not
949 an appropriate solution, because this directory is removed on <code class="literal">make
950 clean</code>.</p><p>Therefore, Buildroot provides a specific mechanism for this use case:
951 the <code class="literal">&lt;pkg&gt;_OVERRIDE_SRCDIR</code> mechanism. Buildroot reads an <span class="emphasis"><em>override</em></span>
952 file, which allows the user to tell Buildroot the location of the
953 source for certain packages. By default this <span class="emphasis"><em>override</em></span> file is named
954 <code class="literal">local.mk</code> and located in the top directory of the Buildroot source
955 tree, but a different location can be specified through the
956 <code class="literal">BR2_PACKAGE_OVERRIDE_FILE</code> configuration option.</p><p>In this <span class="emphasis"><em>override</em></span> file, Buildroot expects to find lines of the form:</p><pre class="screen">&lt;pkg1&gt;_OVERRIDE_SRCDIR = /path/to/pkg1/sources
957 &lt;pkg2&gt;_OVERRIDE_SRCDIR = /path/to/pkg2/sources</pre><p>For example:</p><pre class="screen">LINUX_OVERRIDE_SRCDIR = /home/bob/linux/
958 BUSYBOX_OVERRIDE_SRCDIR = /home/bob/busybox/</pre><p>When Buildroot finds that for a given package, an
959 <code class="literal">&lt;pkg&gt;_OVERRIDE_SRCDIR</code> has been defined, it will no longer attempt to
960 download, extract and patch the package. Instead, it will directly use
961 the source code available in in the specified directory and <code class="literal">make
962 clean</code> will not touch this directory. This allows to point Buildroot
963 to your own directories, that can be managed by Git, Subversion, or
964 any other version control system. To achieve this, Buildroot will use
965 <span class="emphasis"><em>rsync</em></span> to copy the source code of the component from the specified
966 <code class="literal">&lt;pkg&gt;_OVERRIDE_SRCDIR</code> to <code class="literal">output/build/&lt;package&gt;-custom/</code>.</p><p>This mechanism is best used in conjunction with the <code class="literal">make
967 &lt;pkg&gt;-rebuild</code> and <code class="literal">make &lt;pkg&gt;-reconfigure</code> targets. A <code class="literal">make
968 &lt;pkg&gt;-rebuild all</code> sequence will <span class="emphasis"><em>rsync</em></span> the source code from
969 <code class="literal">&lt;pkg&gt;_OVERRIDE_SRCDIR</code> to <code class="literal">output/build/&lt;package&gt;-custom</code> (thanks to
970 <span class="emphasis"><em>rsync</em></span>, only the modified files are copied), and restart the build
971 process of just this package.</p><p>In the example of the <code class="literal">linux</code> package above, the developer can then
972 make a source code change in <code class="literal">/home/bob/linux</code> and then run:</p><pre class="screen">make linux-rebuild all</pre><p>and in a matter of seconds gets the updated Linux kernel image in
973 <code class="literal">output/images</code>. Similarly, a change can be made to the BusyBox source
974 code in <code class="literal">/home/bob/busybox</code>, and after:</p><pre class="screen">make busybox-rebuild all</pre><p>the root filesystem image in <code class="literal">output/images</code> contains the updated
975 BusyBox.</p></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="customize"></a>Chapter 9. Project-specific customization</h2></div></div></div><p>Typical actions you may need to perform for a given project are:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
976 configuring Buildroot (including build options and toolchain,
977   bootloader, kernel, package and filesystem image type selection)
978 </li><li class="listitem">
979 configuring other components, like the Linux kernel and BusyBox
980 </li><li class="listitem"><p class="simpara">
981 customizing the generated target filesystem
982 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
983 adding or overwriting files on the target filesystem (using
984      <code class="literal">BR2_ROOTFS_OVERLAY</code>)
985 </li><li class="listitem">
986 modifying or deleting files on the target filesystem (using
987      <code class="literal">BR2_ROOTFS_POST_BUILD_SCRIPT</code>)
988 </li><li class="listitem">
989 running arbitrary commands prior to generating the filesystem image
990      (using <code class="literal">BR2_ROOTFS_POST_BUILD_SCRIPT</code>)
991 </li><li class="listitem">
992 setting file permissions and ownership (using
993      <code class="literal">BR2_ROOTFS_DEVICE_TABLE</code>)
994 </li><li class="listitem">
995 adding custom devices nodes (using
996      <code class="literal">BR2_ROOTFS_STATIC_DEVICE_TABLE</code>)
997 </li></ul></div></li><li class="listitem">
998 adding custom user accounts (using <code class="literal">BR2_ROOTFS_USERS_TABLES</code>)
999 </li><li class="listitem">
1000 running arbitrary commands after generating the filesystem image
1001   (using <code class="literal">BR2_ROOTFS_POST_IMAGE_SCRIPT</code>)
1002 </li><li class="listitem">
1003 adding project-specific patches to some packages (using
1004   <code class="literal">BR2_GLOBAL_PATCH_DIR</code>)
1005 </li><li class="listitem">
1006 adding project-specific packages
1007 </li></ul></div><p>An important note regarding such <span class="emphasis"><em>project-specific</em></span> customizations:
1008 please carefully consider which changes are indeed project-specific and
1009 which changes are also useful to developers outside your project. The
1010 Buildroot community highly recommends and encourages the upstreaming of
1011 improvements, packages and board support to the official Buildroot
1012 project. Of course, it is sometimes not possible or desirable to
1013 upstream because the changes are highly specific or proprietary.</p><p>This chapter describes how to make such project-specific customizations
1014 in Buildroot and how to store them in a way that you can build the same
1015 image in a reproducible way, even after running <span class="emphasis"><em>make clean</em></span>. By
1016 following the recommended strategy, you can even use the same Buildroot
1017 tree to build multiple distinct projects!</p><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="customize-dir-structure"></a>9.1. Recommended directory structure</h2></div></div></div><p>When customizing Buildroot for your project, you will be creating one or
1018 more project-specific files that need to be stored somewhere. While most
1019 of these files could be placed in <span class="emphasis"><em>any</em></span> location as their path is to be
1020 specified in the Buildroot configuration, the Buildroot developers
1021 recommend a specific directory structure which is described in this
1022 section.</p><p>Orthogonal to this directory structure, you can choose <span class="emphasis"><em>where</em></span> you place
1023 this structure itself: either inside the Buildroot tree, or outside of
1024 it using <code class="literal">BR2_EXTERNAL</code>. Both options are valid, the choice is up to you.</p><pre class="screen">+-- board/
1025 |   +-- &lt;company&gt;/
1026 |       +-- &lt;boardname&gt;/
1027 |           +-- linux.config
1028 |           +-- busybox.config
1029 |           +-- &lt;other configuration files&gt;
1030 |           +-- post_build.sh
1031 |           +-- post_image.sh
1032 |           +-- rootfs_overlay/
1033 |           |   +-- etc/
1034 |           |   +-- &lt;some file&gt;
1035 |           +-- patches/
1036 |               +-- foo/
1037 |               |   +-- &lt;some patch&gt;
1038 |               +-- libbar/
1039 |                   +-- &lt;some other patches&gt;
1040 |
1041 +-- configs/
1042 |   +-- &lt;boardname&gt;_defconfig
1043 |
1044 +-- package/
1045 |   +-- &lt;company&gt;/
1046 |       +-- Config.in (if not using BR2_EXTERNAL)
1047 |       +-- &lt;company&gt;.mk (if not using BR2_EXTERNAL)
1048 |       +-- package1/
1049 |       |    +-- Config.in
1050 |       |    +-- package1.mk
1051 |       +-- package2/
1052 |           +-- Config.in
1053 |           +-- package2.mk
1054 |
1055 +-- Config.in (if using BR2_EXTERNAL)
1056 +-- external.mk (if using BR2_EXTERNAL)</pre><p>Details on the files shown above are given further in this chapter.</p><p>Note: if you choose to place this structure outside of the Buildroot
1057 tree using <code class="literal">BR2_EXTERNAL</code>, the &lt;company&gt; and possibly &lt;boardname&gt;
1058 components may be superfluous and can be left out.</p><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_implementing_layered_customizations"></a>9.1.1. Implementing layered customizations</h3></div></div></div><p>It is quite common for a user to have several related projects that partly
1059 need the same customizations. Instead of duplicating these
1060 customizations for each project, it is recommended to use a layered
1061 customization approach, as explained in this section.</p><p>Almost all of the customization methods available in Buildroot, like
1062 post-build scripts and root filesystem overlays, accept a
1063 space-separated list of items. The specified items are always treated in
1064 order, from left to right. By creating more than one such item, one for
1065 the common customizations and another one for the really
1066 project-specific customizations, you can avoid unnecessary duplication.
1067 Each layer is typically embodied by a separate directory inside
1068 <code class="literal">board/&lt;company&gt;/</code>. Depending on your projects, you could even introduce
1069 more than two layers.</p><p>An example directory structure for where a user has two customization
1070 layers <span class="emphasis"><em>common</em></span> and <span class="emphasis"><em>fooboard</em></span> is:</p><pre class="screen">+-- board/
1071     +-- &lt;company&gt;/
1072         +-- common/
1073         |   +-- post_build.sh
1074         |   +-- rootfs_overlay/
1075         |   |   +-- ...
1076         |   +-- patches/
1077         |       +-- ...
1078         |
1079         +-- fooboard/
1080             +-- linux.config
1081             +-- busybox.config
1082             +-- &lt;other configuration files&gt;
1083             +-- post_build.sh
1084             +-- rootfs_overlay/
1085             |   +-- ...
1086             +-- patches/
1087                 +-- ...</pre><p>For example, if the user has the <code class="literal">BR2_GLOBAL_PATCH_DIR</code> configuration
1088 option set as:</p><pre class="screen">BR2_GLOBAL_PATCH_DIR="board/&lt;company&gt;/common/patches board/&lt;company&gt;/fooboard/patches"</pre><p>then first the patches from the <span class="emphasis"><em>common</em></span> layer would be applied,
1089 followed by the patches from the <span class="emphasis"><em>fooboard</em></span> layer.</p></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="outside-br-custom"></a>9.2. Keeping customizations outside of Buildroot</h2></div></div></div><p>As already briefly mentioned in <a class="xref" href="#customize-dir-structure" title="9.1. Recommended directory structure">Section 9.1, “Recommended directory structure”</a>, you can
1090 place project-specific customizations in two locations:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1091 directly within the Buildroot tree, typically maintaining them using
1092    branches in a version control system so that upgrading to a newer
1093    Buildroot release is easy.
1094 </li><li class="listitem">
1095 outside of the Buildroot tree, using the <code class="literal">BR2_EXTERNAL</code> mechanism.
1096    This mechanism allows to keep package recipes, board support and
1097    configuration files outside of the Buildroot tree, while still
1098    having them nicely integrated in the build logic. This section
1099    explains how to use <code class="literal">BR2_EXTERNAL</code>.
1100 </li></ul></div><p><code class="literal">BR2_EXTERNAL</code> is an environment variable that can be used to point to
1101 a directory that contains Buildroot customizations. It can be passed
1102 to any Buildroot <code class="literal">make</code> invocation. It is automatically saved in the
1103 hidden <code class="literal">.br-external</code> file in the output directory. Thanks to this,
1104 there is no need to pass <code class="literal">BR2_EXTERNAL</code> at every <code class="literal">make</code> invocation. It
1105 can however be changed at any time by passing a new value, and can be
1106 removed by passing an empty value.</p><p><strong>Note. </strong>The <code class="literal">BR2_EXTERNAL</code> path can be either an absolute or a relative path,
1107 but if it’s passed as a relative path, it is important to note that it
1108 is interpreted relative to the main Buildroot source directory, <span class="strong"><strong>not</strong></span>
1109 to the Buildroot output directory.</p><p>Some examples:</p><pre class="screen">buildroot/ $ make BR2_EXTERNAL=/path/to/foobar menuconfig</pre><p>From now on, external definitions from the <code class="literal">/path/to/foobar</code>
1110 directory will be used:</p><pre class="screen">buildroot/ $ make
1111 buildroot/ $ make legal-info</pre><p>We can switch to another external definitions directory at any time:</p><pre class="screen">buildroot/ $ make BR2_EXTERNAL=/where/we/have/barfoo xconfig</pre><p>Or disable the usage of external definitions:</p><pre class="screen">buildroot/ $ make BR2_EXTERNAL= xconfig</pre><p><code class="literal">BR2_EXTERNAL</code> allows three different things:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1112 One can store all the board-specific configuration files there,
1113    such as the kernel configuration, the root filesystem overlay, or
1114    any other configuration file for which Buildroot allows to set its
1115    location. The <code class="literal">BR2_EXTERNAL</code> value is available within the
1116    Buildroot configuration using <code class="literal">$(BR2_EXTERNAL)</code>. As an example, one
1117    could set the <code class="literal">BR2_ROOTFS_OVERLAY</code> Buildroot option to
1118    <code class="literal">$(BR2_EXTERNAL)/board/&lt;boardname&gt;/overlay/</code> (to specify a root
1119    filesystem overlay), or the <code class="literal">BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE</code>
1120    Buildroot option to
1121    <code class="literal">$(BR2_EXTERNAL)/board/&lt;boardname&gt;/kernel.config</code> (to specify the
1122    location of the kernel configuration file).
1123 </li><li class="listitem"><p class="simpara">
1124 One can store package recipes (i.e. <code class="literal">Config.in</code> and
1125    <code class="literal">&lt;packagename&gt;.mk</code>), or even custom configuration options and make
1126    logic. Buildroot automatically includes <code class="literal">$(BR2_EXTERNAL)/Config.in</code> to
1127    make it appear in the top-level configuration menu, and includes
1128    <code class="literal">$(BR2_EXTERNAL)/external.mk</code> with the rest of the makefile logic.
1129 </p><p><strong>Note. </strong>Providing <code class="literal">Config.in</code> and <code class="literal">external.mk</code> is mandatory, but they can be
1130    empty.</p><p class="simpara">The main usage of this is to store package recipes. The recommended
1131    way to do this is to write a <code class="literal">$(BR2_EXTERNAL)/Config.in</code> file that
1132    looks like:</p><pre class="screen">source "$BR2_EXTERNAL/package/package1/Config.in"
1133 source "$BR2_EXTERNAL/package/package2/Config.in"</pre><p class="simpara">Then, have a <code class="literal">$(BR2_EXTERNAL)/external.mk</code> file that looks like:</p><pre class="screen">include $(sort $(wildcard $(BR2_EXTERNAL)/package/*/*.mk))</pre><p class="simpara">And then in <code class="literal">$(BR2_EXTERNAL)/package/package1</code> and
1134    <code class="literal">$(BR2_EXTERNAL)/package/package2</code> create normal Buildroot
1135    package recipes, as explained in <a class="xref" href="#adding-packages" title="Chapter 17. Adding new packages to Buildroot">Chapter 17, <em>Adding new packages to Buildroot</em></a>.
1136    If you prefer, you can also group the packages in subdirectories
1137    called &lt;boardname&gt; and adapt the above paths accordingly.</p></li><li class="listitem">
1138 One can store Buildroot defconfigs in the <code class="literal">configs</code> subdirectory of
1139    <code class="literal">$(BR2_EXTERNAL)</code>. Buildroot will automatically show them in the
1140    output of <code class="literal">make list-defconfigs</code> and allow them to be loaded with the
1141    normal <code class="literal">make &lt;name&gt;_defconfig</code> command. They will be visible under the
1142    <code class="literal">User-provided configs</code>' label in the <span class="emphasis"><em>make list-defconfigs</em></span> output.
1143 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="customize-store-buildroot-config"></a>9.3. Storing the Buildroot configuration</h2></div></div></div><p>The Buildroot configuration can be stored using the command
1144  <code class="literal">make savedefconfig</code>.</p><p>This strips the Buildroot configuration down by removing configuration
1145 options that are at their default value. The result is stored in a file
1146 called <code class="literal">defconfig</code>. If you want to save it in another place, change the
1147 <code class="literal">BR2_DEFCONFIG</code> option in the Buildroot configuration itself, or call
1148 make with <code class="literal">make savedefconfig BR2_DEFCONFIG=&lt;path-to-defconfig&gt;</code>.</p><p>The recommended place to store this defconfig is
1149 <code class="literal">configs/&lt;boardname&gt;_defconfig</code>. If you follow this recommendation, the
1150 configuration will be listed in <code class="literal">make help</code> and can be set again by
1151 running <code class="literal">make &lt;boardname&gt;_defconfig</code>.</p><p>Alternatively, you can copy the file to any other place and rebuild with
1152 <code class="literal">make defconfig BR2_DEFCONFIG=&lt;path-to-defconfig-file&gt;</code>.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="customize-store-package-config"></a>9.4. Storing the configuration of other components</h2></div></div></div><p>The configuration files for BusyBox, the Linux kernel, Barebox and
1153 uClibc should be stored as well if changed. For each of these
1154 components, a Buildroot configuration option exists to point to an input
1155 configuration file, e.g. <code class="literal">BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE</code>. To store
1156 their configuration, set these configuration options to a path where you
1157 want to save the configuration files, and then use the helper targets
1158 described below to actually store the configuration.</p><p>As explained in <a class="xref" href="#customize-dir-structure" title="9.1. Recommended directory structure">Section 9.1, “Recommended directory structure”</a>, the recommended path to
1159 store these configuration files is
1160 <code class="literal">board/&lt;company&gt;/&lt;boardname&gt;/foo.config</code>.</p><p>Make sure that you create a configuration file <span class="emphasis"><em>before</em></span> changing
1161 the <code class="literal">BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE</code> etc. options. Otherwise,
1162 Buildroot will try to access this config file, which doesn’t exist
1163 yet, and will fail. You can create the configuration file by running
1164 <code class="literal">make linux-menuconfig</code> etc.</p><p>Buildroot provides a few helper targets to make the saving of
1165 configuration files easier.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1166 <code class="literal">make linux-update-defconfig</code> saves the linux configuration to the
1167   path specified by <code class="literal">BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE</code>. It
1168   simplifies the config file by removing default values. However,
1169   this only works with kernels starting from 2.6.33. For earlier
1170   kernels, use <code class="literal">make linux-update-config</code>.
1171 </li><li class="listitem">
1172 <code class="literal">make busybox-update-config</code> saves the busybox configuration to the
1173   path specified by <code class="literal">BR2_PACKAGE_BUSYBOX_CONFIG</code>.
1174 </li><li class="listitem">
1175 <code class="literal">make uclibc-update-config</code> saves the uClibc configuration to the
1176   path specified by <code class="literal">BR2_UCLIBC_CONFIG</code>.
1177 </li><li class="listitem">
1178 <code class="literal">make barebox-update-defconfig</code> saves the barebox configuration to the
1179   path specified by <code class="literal">BR2_TARGET_BAREBOX_CUSTOM_CONFIG_FILE</code>.
1180 </li><li class="listitem">
1181 For at91bootstrap3, no helper exists so you have to copy the config
1182   file manually to <code class="literal">BR2_TARGET_AT91BOOTSTRAP3_CUSTOM_CONFIG_FILE</code>.
1183 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="rootfs-custom"></a>9.5. Customizing the generated target filesystem</h2></div></div></div><p>Besides changing the configuration through <code class="literal">make *config</code>,
1184 there are a few other ways to customize the resulting target filesystem.</p><p>The two recommended methods, which can co-exist, are root filesystem
1185 overlay(s) and post build script(s).</p><div class="variablelist"><dl class="variablelist"><dt><span class="term">
1186 Root filesystem overlays (<code class="literal">BR2_ROOTFS_OVERLAY</code>)
1187 </span></dt><dd><p class="simpara">A filesystem overlay is a tree of files that is copied directly
1188   over the target filesystem after it has been built. To enable this
1189   feature, set config option <code class="literal">BR2_ROOTFS_OVERLAY</code> (in the <code class="literal">System
1190   configuration</code> menu) to the root of the overlay. You can even specify
1191   multiple overlays, space-separated. If you specify a relative path,
1192   it will be relative to the root of the Buildroot tree. Hidden
1193   directories of version control systems, like <code class="literal">.git</code>, <code class="literal">.svn</code>, <code class="literal">.hg</code>,
1194   etc., files called <code class="literal">.empty</code> and files ending in <code class="literal">~</code> are excluded from
1195   the copy.</p><p class="simpara">As shown in <a class="xref" href="#customize-dir-structure" title="9.1. Recommended directory structure">Section 9.1, “Recommended directory structure”</a>, the recommended path for
1196   this overlay is <code class="literal">board/&lt;company&gt;/&lt;boardname&gt;/rootfs-overlay</code>.</p></dd><dt><span class="term">
1197 Post-build scripts (<code class="literal">BR2_ROOTFS_POST_BUILD_SCRIPT</code>)
1198 </span></dt><dd><p class="simpara">Post-build scripts are shell scripts called <span class="emphasis"><em>after</em></span> Buildroot builds
1199   all the selected software, but <span class="emphasis"><em>before</em></span> the rootfs images are
1200   assembled. To enable this feature, specify a space-separated list of
1201   post-build scripts in config option <code class="literal">BR2_ROOTFS_POST_BUILD_SCRIPT</code> (in
1202   the <code class="literal">System configuration</code> menu). If you specify a relative path, it
1203   will be relative to the root of the Buildroot tree.</p><p class="simpara">Using post-build scripts, you can remove or modify any file in your
1204   target filesystem. You should, however, use this feature with care.
1205   Whenever you find that a certain package generates wrong or unneeded
1206   files, you should fix that package rather than work around it with some
1207   post-build cleanup scripts.</p><p class="simpara">As shown in <a class="xref" href="#customize-dir-structure" title="9.1. Recommended directory structure">Section 9.1, “Recommended directory structure”</a>, the recommended path for
1208   this script is <code class="literal">board/&lt;company&gt;/&lt;boardname&gt;/post_build.sh</code>.</p><p class="simpara">The post-build scripts are run with the main Buildroot tree as current
1209   working directory. The path to the target filesystem is passed as the
1210   first argument to each script. If the config option
1211   <code class="literal">BR2_ROOTFS_POST_SCRIPT_ARGS</code> is not empty, these arguments will be
1212   passed to the script too. All the scripts will be passed the exact
1213   same set of arguments, it is not possible to pass different sets of
1214   arguments to each script.</p><p class="simpara">In addition, you may also use these environment variables:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1215 <code class="literal">BR2_CONFIG</code>: the path to the Buildroot .config file
1216 </li><li class="listitem">
1217 <code class="literal">HOST_DIR</code>, <code class="literal">STAGING_DIR</code>, <code class="literal">TARGET_DIR</code>: see
1218     <a class="xref" href="#generic-package-reference" title="17.5.2. generic-package reference">Section 17.5.2, “<code class="literal">generic-package</code> reference”</a>
1219 </li><li class="listitem">
1220 <code class="literal">BUILD_DIR</code>: the directory where packages are extracted and built
1221 </li><li class="listitem">
1222 <code class="literal">BINARIES_DIR</code>: the place where all binary files (aka images) are
1223     stored
1224 </li><li class="listitem">
1225 <code class="literal">BASE_DIR</code>: the base output directory
1226 </li></ul></div></dd></dl></div><p>Below two more methods of customizing the target filesystem are
1227 described, but they are not recommended.</p><div class="variablelist"><dl class="variablelist"><dt><span class="term">
1228 Direct modification of the target filesystem
1229 </span></dt><dd><p class="simpara">For temporary modifications, you can modify the target filesystem
1230   directly and rebuild the image. The target filesystem is available
1231   under <code class="literal">output/target/</code>. After making your changes, run <code class="literal">make</code> to
1232   rebuild the target filesystem image.</p><p class="simpara">This method allows you to do anything to the target filesystem, but if
1233   you need to clean your Buildroot tree using <code class="literal">make clean</code>, these
1234   changes will be lost. Such cleaning is necessary in several cases,
1235   refer to <a class="xref" href="#full-rebuild" title="8.2. Understanding when a full rebuild is necessary">Section 8.2, “Understanding when a full rebuild is necessary”</a> for details. This solution is therefore
1236   only useful for quick tests: <span class="emphasis"><em>changes do not survive the <code class="literal">make clean</code>
1237   command</em></span>. Once you have validated your changes, you should make sure
1238   that they will persist after a <code class="literal">make clean</code>, using a root filesystem
1239   overlay or a post-build script.</p></dd><dt><span class="term">
1240 Custom target skeleton (<code class="literal">BR2_ROOTFS_SKELETON_CUSTOM</code>)
1241 </span></dt><dd><p class="simpara">The root filesystem image is created from a target skeleton, on top of
1242   which all packages install their files. The skeleton is copied to the
1243   target directory <code class="literal">output/target</code> before any package is built and
1244   installed. The default target skeleton provides the standard Unix
1245   filesystem layout and some basic init scripts and configuration files.</p><p class="simpara">If the default skeleton (available under <code class="literal">system/skeleton</code>) does not
1246   match your needs, you would typically use a root filesystem overlay or
1247   post-build script to adapt it. However, if the default skeleton is
1248   entirely different than what you need, using a custom skeleton may be
1249   more suitable.</p><p class="simpara">To enable this feature, enable config option
1250   <code class="literal">BR2_ROOTFS_SKELETON_CUSTOM</code> and set <code class="literal">BR2_ROOTFS_SKELETON_CUSTOM_PATH</code>
1251   to the path of your custom skeleton. Both options are available in the
1252   <code class="literal">System configuration</code> menu. If you specify a relative path, it will
1253   be relative to the root of the Buildroot tree.</p><p class="simpara">This method is not recommended because it duplicates the entire
1254   skeleton, which prevents taking advantage of the fixes or improvements
1255   brought to the default skeleton in later Buildroot releases.</p></dd></dl></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="customize-device-permission"></a>9.5.1. Setting file permissions and ownership and adding custom devices nodes</h3></div></div></div><p>Sometimes it is needed to set specific permissions or ownership on files
1256 or device nodes. For example, certain files may need to be owned by
1257 root. Since the post-build scripts are not run as root, you cannot do
1258 such changes from there unless you use an explicit fakeroot from the
1259 post-build script.</p><p>Instead, Buildroot provides support for so-called <span class="emphasis"><em>permission tables</em></span>.
1260 To use this feature, set config option <code class="literal">BR2_ROOTFS_DEVICE_TABLE</code> to a
1261 space-separated list of permission tables, regular text files following
1262 the <a class="link" href="#makedev-syntax" title="Chapter 22. Makedev syntax documentation">makedev syntax</a>
1263 <a class="xref" href="#makedev-syntax" title="Chapter 22. Makedev syntax documentation">Chapter 22, <em>Makedev syntax documentation</em></a>.</p><p>If you are using a static device table (i.e. not using <code class="literal">devtmpfs</code>,
1264 <code class="literal">mdev</code>, or <code class="literal">(e)udev</code>) then you can add device nodes using the same
1265 syntax, in so-called <span class="emphasis"><em>device tables</em></span>. To use this feature, set config
1266 option <code class="literal">BR2_ROOTFS_STATIC_DEVICE_TABLE</code> to a space-separated list of
1267 device tables.</p><p>As shown in <a class="xref" href="#customize-dir-structure" title="9.1. Recommended directory structure">Section 9.1, “Recommended directory structure”</a>, the recommended location for
1268 such files is <code class="literal">board/&lt;company&gt;/&lt;boardname&gt;/</code>.</p><p>It should be noted that if the specific permissions or device nodes are
1269 related to a specific application, you should set variables
1270 <code class="literal">FOO_PERMISSIONS</code> and <code class="literal">FOO_DEVICES</code> in the package’s <code class="literal">.mk</code> file instead
1271 (see <a class="xref" href="#generic-package-reference" title="17.5.2. generic-package reference">Section 17.5.2, “<code class="literal">generic-package</code> reference”</a>).</p></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="customize-users"></a>9.6. Adding custom user accounts</h2></div></div></div><p>Sometimes it is needed to add specific users in the target system.
1272 To cover this requirement, Buildroot provides support for so-called
1273 <span class="emphasis"><em>users tables</em></span>. To use this feature, set config option
1274 <code class="literal">BR2_ROOTFS_USERS_TABLES</code> to a space-separated list of users tables,
1275 regular text files following the <a class="link" href="#makeuser-syntax" title="Chapter 23. Makeusers syntax documentation">makeusers syntax</a>
1276 <a class="xref" href="#makeuser-syntax" title="Chapter 23. Makeusers syntax documentation">Chapter 23, <em>Makeusers syntax documentation</em></a>.</p><p>As shown in <a class="xref" href="#customize-dir-structure" title="9.1. Recommended directory structure">Section 9.1, “Recommended directory structure”</a>, the recommended location for
1277 such files is <code class="literal">board/&lt;company&gt;/&lt;boardname&gt;/</code>.</p><p>It should be noted that if the custom users are related to a specific
1278 application, you should set variable <code class="literal">FOO_USERS</code> in the package’s <code class="literal">.mk</code>
1279 file instead (see <a class="xref" href="#generic-package-reference" title="17.5.2. generic-package reference">Section 17.5.2, “<code class="literal">generic-package</code> reference”</a>).</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_customization_emphasis_after_emphasis_the_images_have_been_created"></a>9.7. Customization <span class="emphasis"><em>after</em></span> the images have been created</h2></div></div></div><p>While post-build scripts (<a class="xref" href="#rootfs-custom" title="9.5. Customizing the generated target filesystem">Section 9.5, “Customizing the generated target filesystem”</a>) are run <span class="emphasis"><em>before</em></span>
1280 building the filesystem image, kernel and bootloader, <span class="strong"><strong>post-image
1281 scripts</strong></span> can be used to perform some specific actions <span class="emphasis"><em>after</em></span> all images
1282 have been created.</p><p>Post-image scripts can for example be used to automatically extract your
1283 root filesystem tarball in a location exported by your NFS server, or
1284 to create a special firmware image that bundles your root filesystem and
1285 kernel image, or any other custom action required for your project.</p><p>To enable this feature, specify a space-separated list of post-image
1286 scripts in config option <code class="literal">BR2_ROOTFS_POST_IMAGE_SCRIPT</code> (in the <code class="literal">System
1287 configuration</code> menu). If you specify a relative path, it will be
1288 relative to the root of the Buildroot tree.</p><p>Just like post-build scripts, post-image scripts are run with the main
1289 Buildroot tree as current working directory. The path to the <code class="literal">images</code>
1290 output directory is passed as the first argument to each script. If the
1291 config option <code class="literal">BR2_ROOTFS_POST_SCRIPT_ARGS</code> is not empty, these
1292 arguments will be passed to the script too. All the scripts will be
1293 passed the exact same set of arguments, it is not possible to pass
1294 different sets of arguments to each script.</p><p>Again just like for the post-build scripts, the scripts have access to
1295 the environment variables <code class="literal">BR2_CONFIG</code>, <code class="literal">HOST_DIR</code>, <code class="literal">STAGING_DIR</code>,
1296 <code class="literal">TARGET_DIR</code>, <code class="literal">BUILD_DIR</code>, <code class="literal">BINARIES_DIR</code> and <code class="literal">BASE_DIR</code>.</p><p>The post-image scripts will be executed as the user that executes
1297 Buildroot, which should normally <span class="emphasis"><em>not</em></span> be the root user. Therefore, any
1298 action requiring root permissions in one of these scripts will require
1299 special handling (usage of fakeroot or sudo), which is left to the
1300 script developer.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="customize-patches"></a>9.8. Adding project-specific patches</h2></div></div></div><p>It is sometimes useful to apply <span class="emphasis"><em>extra</em></span> patches to packages - on top of
1301 those provided in Buildroot. This might be used to support custom
1302 features in a project, for example, or when working on a new
1303 architecture.</p><p>The <code class="literal">BR2_GLOBAL_PATCH_DIR</code> configuration option can be used to specify
1304 a space separated list of one or more directories containing package
1305 patches.</p><p>For a specific version <code class="literal">&lt;packageversion&gt;</code> of a specific package
1306 <code class="literal">&lt;packagename&gt;</code>, patches are applied from <code class="literal">BR2_GLOBAL_PATCH_DIR</code> as
1307 follows:</p><div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem"><p class="simpara">
1308 For every directory - <code class="literal">&lt;global-patch-dir&gt;</code> - that exists in
1309   <code class="literal">BR2_GLOBAL_PATCH_DIR</code>, a <code class="literal">&lt;package-patch-dir&gt;</code> will be determined as
1310   follows:
1311 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1312 <code class="literal">&lt;global-patch-dir&gt;/&lt;packagename&gt;/&lt;packageversion&gt;/</code> if the
1313   directory exists.
1314 </li><li class="listitem">
1315 Otherwise, <code class="literal">&lt;global-patch-dir&gt;/&lt;packagename&gt;</code> if the directory
1316   exists.
1317 </li></ul></div></li><li class="listitem"><p class="simpara">
1318 Patches will then be applied from a <code class="literal">&lt;package-patch-dir&gt;</code> as
1319   follows:
1320 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1321 If a <code class="literal">series</code> file exists in the package directory, then patches are
1322   applied according to the <code class="literal">series</code> file;
1323 </li><li class="listitem">
1324 Otherwise, patch files matching <code class="literal">*.patch</code> are applied in
1325   alphabetical order.  So, to ensure they are applied in the right
1326   order, it is highly recommended to name the patch files like this:
1327   <code class="literal">&lt;number&gt;-&lt;description&gt;.patch</code>, where <code class="literal">&lt;number&gt;</code> refers to the
1328   <span class="emphasis"><em>apply order</em></span>.
1329 </li></ul></div></li></ol></div><p>For information about how patches are applied for a package, see
1330 <a class="xref" href="#patch-apply-order" title="18.2. How patches are applied">Section 18.2, “How patches are applied”</a></p><p>The <code class="literal">BR2_GLOBAL_PATCH_DIR</code> option is the preferred method for
1331 specifying a custom patch directory for packages. It can be used to
1332 specify a patch directory for any package in buildroot. It should also
1333 be used in place of the custom patch directory options that are
1334 available for packages such as U-Boot and Barebox. By doing this, it
1335 will allow a user to manage their patches from one top-level
1336 directory.</p><p>The exception to <code class="literal">BR2_GLOBAL_PATCH_DIR</code> being the preferred method for
1337 specifying custom patches is <code class="literal">BR2_LINUX_KERNEL_PATCH</code>.
1338 <code class="literal">BR2_LINUX_KERNEL_PATCH</code> should be used to specify kernel patches that
1339 are available at an URL. <span class="strong"><strong>Note:</strong></span> <code class="literal">BR2_LINUX_KERNEL_PATCH</code> specifies kernel
1340 patches that are applied after patches available in <code class="literal">BR2_GLOBAL_PATCH_DIR</code>,
1341 as it is done from a post-patch hook of the Linux package.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="customize-packages"></a>9.9. Adding project-specific packages</h2></div></div></div><p>In general, any new package should be added directly in the <code class="literal">package</code>
1342 directory and submitted to the Buildroot upstream project. How to add
1343 packages to Buildroot in general is explained in full detail in
1344 <a class="xref" href="#adding-packages" title="Chapter 17. Adding new packages to Buildroot">Chapter 17, <em>Adding new packages to Buildroot</em></a> and will not be repeated here. However, your
1345 project may need some proprietary packages that cannot be upstreamed.
1346 This section will explain how you can keep such project-specific
1347 packages in a project-specific directory.</p><p>As shown in <a class="xref" href="#customize-dir-structure" title="9.1. Recommended directory structure">Section 9.1, “Recommended directory structure”</a>, the recommended location for
1348 project-specific packages is <code class="literal">package/&lt;company&gt;/</code>. If you are using the
1349 <code class="literal">BR2_EXTERNAL</code> feature (see <a class="xref" href="#outside-br-custom" title="9.2. Keeping customizations outside of Buildroot">Section 9.2, “Keeping customizations outside of Buildroot”</a>) the recommended
1350 location is <code class="literal">$(BR2_EXTERNAL)/package/</code>.</p><p>However, Buildroot will not be aware of the packages in this location,
1351 unless we perform some additional steps. As explained in
1352 <a class="xref" href="#adding-packages" title="Chapter 17. Adding new packages to Buildroot">Chapter 17, <em>Adding new packages to Buildroot</em></a>, a package in Buildroot basically consists of two
1353 files: a <code class="literal">.mk</code> file (describing how to build the package) and a
1354 <code class="literal">Config.in</code> file (describing the configuration options for this
1355 package).</p><p>Buildroot will automatically include the <code class="literal">.mk</code> files in first-level
1356 subdirectories of the <code class="literal">package</code> directory (using the pattern
1357 <code class="literal">package/*/*.mk</code>). If we want Buildroot to include <code class="literal">.mk</code> files from
1358 deeper subdirectories (like <code class="literal">package/&lt;company&gt;/package1/</code>) then we
1359 simply have to add a <code class="literal">.mk</code> file in a first-level subdirectory that
1360 includes these additional <code class="literal">.mk</code> files. Therefore, create a file
1361 <code class="literal">package/&lt;company&gt;/&lt;company&gt;.mk</code> with following contents (assuming you
1362 have only one extra directory level below <code class="literal">package/&lt;company&gt;/</code>):</p><pre class="screen">include $(sort $(wildcard package/&lt;company&gt;/*/*.mk))</pre><p>If you are using <code class="literal">BR2_EXTERNAL</code>, create a file
1363 <code class="literal">$(BR2_EXTERNAL)/external.mk</code> with following contents (again assuming only
1364 one extra level):</p><pre class="screen">include $(sort $(wildcard $(BR2_EXTERNAL)/package/*/*.mk))</pre><p>For the <code class="literal">Config.in</code> files, create a file <code class="literal">package/&lt;company&gt;/Config.in</code>
1365 that includes the <code class="literal">Config.in</code> files of all your packages. An exhaustive
1366 list has to be provided since wildcards are not supported in the source command of kconfig.
1367 For example:</p><pre class="screen">source "package/&lt;company&gt;/package1/Config.in"
1368 source "package/&lt;company&gt;/package2/Config.in"</pre><p>Include this new file <code class="literal">package/&lt;company&gt;/Config.in</code> from
1369 <code class="literal">package/Config.in</code>, preferably in a company-specific menu to make
1370 merges with future Buildroot versions easier.</p><p>If you are using <code class="literal">BR2_EXTERNAL</code>, create a file
1371 <code class="literal">$(BR2_EXTERNAL)/Config.in</code> with similar contents:</p><pre class="screen">source "$BR2_EXTERNAL/package/package1/Config.in"
1372 source "$BR2_EXTERNAL/package/package2/Config.in"</pre><p>You do not have to add an include for this <code class="literal">$(BR2_EXTERNAL)/Config.in</code>
1373 file as it is included automatically.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_quick_guide_to_storing_your_project_specific_customizations"></a>9.10. Quick guide to storing your project-specific customizations</h2></div></div></div><p>Earlier in this chapter, the different methods for making
1374 project-specific customizations have been described. This section will
1375 now summarize all this by providing step-by-step instructions to storing your
1376 project-specific customizations. Clearly, the steps that are not relevant to
1377 your project can be skipped.</p><div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem">
1378 <code class="literal">make menuconfig</code> to configure toolchain, packages and kernel.
1379 </li><li class="listitem">
1380 <code class="literal">make linux-menuconfig</code> to update the kernel config, similar for
1381    other configuration like busybox, uclibc, …
1382 </li><li class="listitem">
1383 <code class="literal">mkdir -p board/&lt;manufacturer&gt;/&lt;boardname&gt;</code>
1384 </li><li class="listitem"><p class="simpara">
1385 Set the following options to <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;/&lt;package&gt;.config</code>
1386    (as far as they are relevant):
1387 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1388 <code class="literal">BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE</code>
1389 </li><li class="listitem">
1390 <code class="literal">BR2_PACKAGE_BUSYBOX_CONFIG</code>
1391 </li><li class="listitem">
1392 <code class="literal">BR2_UCLIBC_CONFIG</code>
1393 </li><li class="listitem">
1394 <code class="literal">BR2_TARGET_AT91BOOTSTRAP3_CUSTOM_CONFIG_FILE</code>
1395 </li><li class="listitem">
1396 <code class="literal">BR2_TARGET_BAREBOX_CUSTOM_CONFIG_FILE</code>
1397 </li></ul></div></li><li class="listitem"><p class="simpara">
1398 Write the configuration files:
1399 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1400 <code class="literal">make linux-update-defconfig</code>
1401 </li><li class="listitem">
1402 <code class="literal">make busybox-update-config</code>
1403 </li><li class="listitem">
1404 <code class="literal">make uclibc-update-config</code>
1405 </li><li class="listitem">
1406 <code class="literal">cp &lt;output&gt;/build/at91bootstrap3-*/.config
1407      board/&lt;manufacturer&gt;/&lt;boardname&gt;/at91bootstrap3.config</code>
1408 </li><li class="listitem">
1409 <code class="literal">make barebox-update-defconfig</code>
1410 </li></ul></div></li><li class="listitem">
1411 Create <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;/rootfs-overlay/</code> and fill it
1412    with additional files you need on your rootfs, e.g.
1413    <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;/rootfs-overlay/etc/inittab</code>.
1414    Set <code class="literal">BR2_ROOTFS_OVERLAY</code>
1415    to <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;/rootfs-overlay</code>.
1416 </li><li class="listitem">
1417 Create a post-build script
1418    <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;/post_build.sh</code>. Set
1419    <code class="literal">BR2_ROOTFS_POST_BUILD_SCRIPT</code> to
1420    <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;/post_build.sh</code>
1421 </li><li class="listitem">
1422 If additional setuid permissions have to be set or device nodes have
1423    to be created, create <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;/device_table.txt</code>
1424    and add that path to <code class="literal">BR2_ROOTFS_DEVICE_TABLE</code>.
1425 </li><li class="listitem">
1426 If additional user accounts have to be created, create
1427    <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;/users_table.txt</code> and add that path
1428    to <code class="literal">BR2_ROOTFS_USERS_TABLES</code>.
1429 </li><li class="listitem">
1430 To add custom patches to certain packages, set <code class="literal">BR2_GLOBAL_PATCH_DIR</code>
1431    to <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;/patches/</code> and add your patches
1432    for each package in a subdirectory named after the package. Each
1433    patch should be called <code class="literal">&lt;packagename&gt;-&lt;num&gt;-&lt;description&gt;.patch</code>.
1434 </li><li class="listitem">
1435 Specifically for the Linux kernel, there also exists the option
1436    <code class="literal">BR2_LINUX_KERNEL_PATCH</code> with as main advantage that it can also
1437    download patches from a URL. If you do not need this,
1438    <code class="literal">BR2_GLOBAL_PATCH_DIR</code> is preferred. U-Boot, Barebox, at91bootstrap
1439    and at91bootstrap3 also have separate options, but these do not
1440    provide any advantage over <code class="literal">BR2_GLOBAL_PATCH_DIR</code> and will likely be
1441    removed in the future.
1442 </li><li class="listitem">
1443 If you need to add project-specific packages, create
1444    <code class="literal">package/&lt;manufacturer&gt;/</code> and place your packages in that
1445    directory. Create an overall <code class="literal">&lt;manufacturer&gt;.mk</code> file that
1446    includes the <code class="literal">.mk</code> files of all your packages. Create an overall
1447    <code class="literal">Config.in</code> file that sources the <code class="literal">Config.in</code> files of all your
1448    packages. Include this <code class="literal">Config.in</code> file from Buildroot’s
1449    <code class="literal">package/Config.in</code> file.
1450 </li><li class="listitem">
1451 <code class="literal">make savedefconfig</code> to save the buildroot configuration.
1452 </li><li class="listitem">
1453 <code class="literal">cp defconfig configs/&lt;boardname&gt;_defconfig</code>
1454 </li></ol></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_frequently_asked_questions_amp_troubleshooting"></a>Chapter 10. Frequently Asked Questions &amp; Troubleshooting</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="faq-boot-hang-after-starting"></a>10.1. The boot hangs after <span class="emphasis"><em>Starting network…</em></span></h2></div></div></div><p>If the boot process seems to hang after the following messages
1455 (messages not necessarily exactly similar, depending on the list of
1456 packages selected):</p><pre class="screen">Freeing init memory: 3972K
1457 Initializing random number generator... done.
1458 Starting network...
1459 Starting dropbear sshd: generating rsa key... generating dsa key... OK</pre><p>then it means that your system is running, but didn’t start a shell on
1460 the serial console. In order to have the system start a shell on your
1461 serial console, you have to go into the Buildroot configuration, in
1462 <code class="literal">System configuration</code>, modify <code class="literal">Run a getty (login prompt) after boot</code>
1463 and set the appropriate port and baud rate in the <code class="literal">getty options</code>
1464 submenu. This will automatically tune the <code class="literal">/etc/inittab</code> file of the
1465 generated system so that a shell starts on the correct serial port.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="faq-no-compiler-on-target"></a>10.2. Why is there no compiler on the target?</h2></div></div></div><p>It has been decided that support for the <span class="emphasis"><em>native compiler on the
1466 target</em></span> would be stopped from the Buildroot-2012.11 release because:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1467 this feature was neither maintained nor tested, and often broken;
1468 </li><li class="listitem">
1469 this feature was only available for Buildroot toolchains;
1470 </li><li class="listitem">
1471 Buildroot mostly targets <span class="emphasis"><em>small</em></span> or <span class="emphasis"><em>very small</em></span> target hardware
1472   with limited resource onboard (CPU, ram, mass-storage), for which
1473   compiling on the target does not make much sense;
1474 </li><li class="listitem">
1475 Buildroot aims at easing the cross-compilation, making native
1476   compilation on the target unnecessary.
1477 </li></ul></div><p>If you need a compiler on your target anyway, then Buildroot is not
1478 suitable for your purpose. In such case, you need a <span class="emphasis"><em>real
1479 distribution</em></span> and you should opt for something like:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1480 <a class="ulink" href="http://www.openembedded.org" target="_top">openembedded</a>
1481 </li><li class="listitem">
1482 <a class="ulink" href="https://www.yoctoproject.org" target="_top">yocto</a>
1483 </li><li class="listitem">
1484 <a class="ulink" href="http://www.emdebian.org" target="_top">emdebian</a>
1485 </li><li class="listitem">
1486 <a class="ulink" href="https://fedoraproject.org/wiki/Architectures" target="_top">Fedora</a>
1487 </li><li class="listitem">
1488 <a class="ulink" href="http://en.opensuse.org/Portal:ARM" target="_top">openSUSE ARM</a>
1489 </li><li class="listitem">
1490 <a class="ulink" href="http://archlinuxarm.org" target="_top">Arch Linux ARM</a>
1491 </li><li class="listitem">
1492
1493 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="faq-no-dev-files-on-target"></a>10.3. Why are there no development files on the target?</h2></div></div></div><p>Since there is no compiler available on the target (see
1494 <a class="xref" href="#faq-no-compiler-on-target" title="10.2. Why is there no compiler on the target?">Section 10.2, “Why is there no compiler on the target?”</a>), it does not make sense to waste
1495 space with headers or static libraries.</p><p>Therefore, those files are always removed from the target since the
1496 Buildroot-2012.11 release.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="faq-no-doc-on-target"></a>10.4. Why is there no documentation on the target?</h2></div></div></div><p>Because Buildroot mostly targets <span class="emphasis"><em>small</em></span> or <span class="emphasis"><em>very small</em></span> target
1497 hardware with limited resource onboard (CPU, ram, mass-storage), it
1498 does not make sense to waste space with the documentation data.</p><p>If you need documentation data on your target anyway, then Buildroot
1499 is not suitable for your purpose, and you should look for a <span class="emphasis"><em>real
1500 distribution</em></span> (see: <a class="xref" href="#faq-no-compiler-on-target" title="10.2. Why is there no compiler on the target?">Section 10.2, “Why is there no compiler on the target?”</a>).</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="faq-why-not-visible-package"></a>10.5. Why are some packages not visible in the Buildroot config menu?</h2></div></div></div><p>If a package exists in the Buildroot tree and does not appear in the
1501 config menu, this most likely means that some of the package’s
1502 dependencies are not met.</p><p>To know more about the dependencies of a package, search for the
1503 package symbol in the config menu (see <a class="xref" href="#make-tips" title="8.1. make tips">Section 8.1, “<span class="emphasis"><em>make</em></span> tips”</a>).</p><p>Then, you may have to recursively enable several options (which
1504 correspond to the unmet dependencies) to finally be able to select
1505 the package.</p><p>If the package is not visible due to some unmet toolchain options,
1506 then you should certainly run a full rebuild (see <a class="xref" href="#make-tips" title="8.1. make tips">Section 8.1, “<span class="emphasis"><em>make</em></span> tips”</a> for
1507 more explanations).</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="faq-why-not-use-target-as-chroot"></a>10.6. Why not use the target directory as a chroot directory?</h2></div></div></div><p>There are plenty of reasons to <span class="strong"><strong>not</strong></span> use the target directory a chroot
1508 one, among these:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1509 file ownerships, modes and permissions are not correctly set in the
1510   target directory;
1511 </li><li class="listitem">
1512 device nodes are not created in the target directory.
1513 </li></ul></div><p>For these reasons, commands run through chroot, using the target
1514 directory as the new root, will most likely fail.</p><p>If you want to run the target filesystem inside a chroot, or as an NFS
1515 root, then use the tarball image generated in <code class="literal">images/</code> and extract it
1516 as root.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="faq-no-binary-packages"></a>10.7. Why doesn’t Buildroot generate binary packages (.deb, .ipkg…)?</h2></div></div></div><p>One feature that is often discussed on the Buildroot list is the
1517 general topic of "package management". To summarize, the idea
1518 would be to add some tracking of which Buildroot package installs
1519 what files, with the goals of:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1520 being able to remove files installed by a package when this package
1521    gets unselected from the menuconfig;
1522 </li><li class="listitem">
1523 being able to generate binary packages (ipk or other format) that
1524    can be installed on the target without re-generating a new root
1525    filesystem image.
1526 </li></ul></div><p>In general, most people think it is easy to do: just track which package
1527 installed what and remove it when the package is unselected. However, it
1528 is much more complicated than that:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1529 It is not only about the <code class="literal">target/</code> directory, but also the sysroot in
1530    <code class="literal">host/usr/&lt;tuple&gt;/sysroot</code> and the <code class="literal">host/</code> directory itself. All files
1531    installed in those directories by various packages must be tracked.
1532 </li><li class="listitem">
1533 When a package is unselected from the configuration, it is not
1534    sufficient to remove just the files it installed. One must also
1535    remove all its reverse dependencies (i.e. packages relying on it)
1536    and rebuild all those packages. For example, package A depends
1537    optionally on the OpenSSL library. Both are selected, and Buildroot
1538    is built. Package A is built with crypto support using OpenSSL.
1539    Later on, OpenSSL gets unselected from the configuration, but
1540    package A remains (since OpenSSL is an optional dependency, this
1541    is possible.) If only OpenSSL files are removed, then the files
1542    installed by package A are broken: they use a library that is no
1543    longer present on the target. Although this is technically doable,
1544    it adds a lot of complexity to Buildroot, which goes against the
1545    simplicity we try to stick to.
1546 </li><li class="listitem">
1547 In addition to the previous problem, there is the case where the
1548    optional dependency is not even known to Buildroot. For example,
1549    package A in version 1.0 never used OpenSSL, but in version 2.0 it
1550    automatically uses OpenSSL if available. If the Buildroot .mk file
1551    hasn’t been updated to take this into account, then package A will
1552    not be part of the reverse dependencies of OpenSSL and will not be
1553    removed and rebuilt when OpenSSL is removed. For sure, the .mk file
1554    of package A should be fixed to mention this optional dependency,
1555    but in the mean time, you can have non-reproducible behaviors.
1556 </li><li class="listitem">
1557 The request is to also allow changes in the menuconfig to be
1558    applied on the output directory without having to rebuild
1559    everything from scratch. However, this is very difficult to achieve
1560    in a reliable way: what happens when the suboptions of a package
1561    are changed (we would have to detect this, and rebuild the package
1562    from scratch and potentially all its reverse dependencies), what
1563    happens if toolchain options are changed, etc. At the moment, what
1564    Buildroot does is clear and simple so its behaviour is very
1565    reliable and it is easy to support users. If configuration changes
1566    done in menuconfig are applied after the next make, then it has to
1567    work correctly and properly in all situations, and not have some
1568    bizarre corner cases. The risk is to get bug reports like "I have
1569    enabled package A, B and C, then ran make, then disabled package
1570    C and enabled package D and ran make, then re-enabled package C
1571    and enabled package E and then there is a build failure". Or worse
1572    "I did some configuration, then built, then did some changes,
1573    built, some more changes, built, some more changes, built, and now
1574    it fails, but I don’t remember all the changes I did and in which
1575    order". This will be impossible to support.
1576 </li></ul></div><p>For all these reasons, the conclusion is that adding tracking of
1577 installed files to remove them when the package is unselected, or to
1578 generate a repository of binary packages, is something that is very
1579 hard to achieve reliably and will add a lot of complexity.</p><p>On this matter, the Buildroot developers make this position statement:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1580 Buildroot strives to make it easy to generate a root filesystem (hence
1581    the name, by the way.) That is what we want to make Buildroot good at:
1582    building root filesystems.
1583 </li><li class="listitem">
1584 Buildroot is not meant to be a distribution (or rather, a distribution
1585    generator.) It is the opinion of most Buildroot developers that this
1586    is not a goal we should pursue. We believe that there are other tools
1587    better suited to generate a distro than Buildroot is. For example,
1588    <a class="ulink" href="http://openembedded.org/" target="_top">Open Embedded</a>, or <a class="ulink" href="https://openwrt.org/" target="_top">openWRT</a>,
1589    are such tools.
1590 </li><li class="listitem">
1591 We prefer to push Buildroot in a direction that makes it easy (or even
1592    easier) to generate complete root filesystems. This is what makes
1593    Buildroot stands out in the crowd (among other things, of course!)
1594 </li><li class="listitem">
1595 We believe that for most embedded Linux systems, binary packages are
1596    not necessary, and potentially harmful. When binary packages are
1597    used, it means that the system can be partially upgraded, which
1598    creates an enormous number of possible combinations of package
1599    versions that should be tested before doing the upgrade on the
1600    embedded device. On the other hand, by doing complete system
1601    upgrades by upgrading the entire root filesystem image at once,
1602    the image deployed to the embedded system is guaranteed to really
1603    be the one that has been tested and validated.
1604 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="faq-speeding-up-build"></a>10.8. How to speed-up the build process?</h2></div></div></div><p>Since Buildroot often involves doing full rebuilds of the entire
1605 system that can be quite long, we provide below a number of tips to
1606 help reduce the build time:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1607 Use a pre-built external toolchain instead of the default Buildroot
1608    internal toolchain. By using a pre-built Linaro toolchain (on ARM)
1609    or a Sourcery CodeBench toolchain (for ARM, x86, x86-64, MIPS,
1610    etc.), you will save the build time of the toolchain at each
1611    complete rebuild, approximately 15 to 20 minutes. Note that
1612    temporarily using an external toolchain does not prevent you to
1613    switch back to an internal toolchain (that may provide a higher
1614    level of customization) once the rest of your system is working;
1615 </li><li class="listitem">
1616 Use the <code class="literal">ccache</code> compiler cache (see: <a class="xref" href="#ccache" title="8.11.3. Using ccache in Buildroot">Section 8.11.3, “Using <code class="literal">ccache</code> in Buildroot”</a>);
1617 </li><li class="listitem">
1618 Learn about rebuilding only the few packages you actually care
1619    about (see <a class="xref" href="#rebuild-pkg" title="8.3. Understanding how to rebuild packages">Section 8.3, “Understanding how to rebuild packages”</a>), but beware that sometimes full
1620    rebuilds are anyway necessary (see <a class="xref" href="#full-rebuild" title="8.2. Understanding when a full rebuild is necessary">Section 8.2, “Understanding when a full rebuild is necessary”</a>);
1621 </li><li class="listitem">
1622 Make sure you are not using a virtual machine for the Linux system
1623    used to run Buildroot. Most of the virtual machine technologies are
1624    known to cause a significant performance impact on I/O, which is
1625    really important for building source code;
1626 </li><li class="listitem">
1627 Make sure that you’re using only local files: do not attempt to do
1628    a build over NFS, which significantly slows down the build. Having
1629    the Buildroot download folder available locally also helps a bit.
1630 </li><li class="listitem">
1631 Buy new hardware. SSDs and lots of RAM are key to speeding up the
1632    builds.
1633 </li></ul></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_known_issues"></a>Chapter 11. Known issues</h2></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1634 It is not possible to pass extra linker options via <code class="literal">BR2_TARGET_LDFLAGS</code>
1635   if such options contain a <code class="literal">$</code> sign. For example, the following is known
1636   to break: <code class="literal">BR2_TARGET_LDFLAGS="-Wl,-rpath='$ORIGIN/../lib'"</code>
1637 </li><li class="listitem">
1638 The <code class="literal">ltp-testsuite</code> package does not build with the default uClibc
1639   configuration used by the Buildroot toolchain backend. The LTP
1640   testsuite uses several functions that are considered obsolete, such
1641   as sigset() and others. uClibc configuration options such as
1642   DO_XSI_MATH, UCLIBC_HAS_OBSOLETE_BSD_SIGNAL and
1643   UCLIBC_SV4_DEPRECATED are needed if one wants to build the
1644   <code class="literal">ltp-testsuite</code> package with uClibc. You need to either use a glibc
1645   or eglibc based toolchain, or enable the appropriate options in the
1646   uClibc configuration.
1647 </li><li class="listitem">
1648 The <code class="literal">xfsprogs</code> package does not build with the default uClibc
1649   configuration used by the Buildroot toolchain backend. You need to
1650   either use a glibc or eglibc based toolchain, or enable the
1651   appropriate options in the uClibc configuration.
1652 </li><li class="listitem">
1653 The <code class="literal">mrouted</code> package does not build with the default uClibc
1654   configuration used by the Buildroot toolchain backend. You need to
1655   either use a glibc or eglibc based toolchain, or enable the
1656   appropriate options in the uClibc configuration.
1657 </li><li class="listitem">
1658 The <code class="literal">libffi</code> package is not supported on the SuperH 2 and ARC
1659   architectures.
1660 </li><li class="listitem">
1661 The <code class="literal">prboom</code> package triggers a compiler failure with the SuperH 4
1662   compiler from Sourcery CodeBench, version 2012.09.
1663 </li></ul></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="legal-info"></a>Chapter 12. Legal notice and licensing</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_complying_with_open_source_licenses"></a>12.1. Complying with open source licenses</h2></div></div></div><p>All of the end products of Buildroot (toolchain, root filesystem, kernel,
1664 bootloaders) contain open source software, released under various licenses.</p><p>Using open source software gives you the freedom to build rich embedded
1665 systems, choosing from a wide range of packages, but also imposes some
1666 obligations that you must know and honour.
1667 Some licenses require you to publish the license text in the documentation of
1668 your product. Others require you to redistribute the source code of the
1669 software to those that receive your product.</p><p>The exact requirements of each license are documented in each package, and
1670 it is your responsibility (or that of your legal office) to comply with those
1671 requirements.
1672 To make this easier for you, Buildroot can collect for you some material you
1673 will probably need. To produce this material, after you have configured
1674 Buildroot with <code class="literal">make menuconfig</code>, <code class="literal">make xconfig</code> or <code class="literal">make gconfig</code>, run:</p><pre class="screen">make legal-info</pre><p>Buildroot will collect legally-relevant material in your output directory,
1675 under the <code class="literal">legal-info/</code> subdirectory.
1676 There you will find:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1677 A <code class="literal">README</code> file, that summarizes the produced material and contains warnings
1678   about material that Buildroot could not produce.
1679 </li><li class="listitem">
1680 <code class="literal">buildroot.config</code>: this is the Buildroot configuration file that is usually
1681   produced with <code class="literal">make menuconfig</code>, and which is necessary to reproduce the
1682   build.
1683 </li><li class="listitem">
1684 The source code for all packages; this is saved in the <code class="literal">sources/</code> and
1685   <code class="literal">host-sources/</code> subdirectories for target and host packages respectively.
1686   The source code for packages that set <code class="literal">&lt;PKG&gt;_REDISTRIBUTE = NO</code> will not be
1687   saved.
1688   Patches applied to some packages by Buildroot are distributed with the
1689   Buildroot sources and are not duplicated in the <code class="literal">sources/</code> and <code class="literal">host-sources/</code>
1690   subdirectories.
1691 </li><li class="listitem">
1692 A manifest file (one for host and one for target packages) listing the
1693   configured packages, their version, license and related information.
1694   Some of this information might not be defined in Buildroot; such items are
1695   marked as "unknown".
1696 </li><li class="listitem">
1697 The license texts of all packages, in the <code class="literal">licenses/</code> and <code class="literal">host-licenses/</code>
1698   subdirectories for target and host packages respectively.
1699   If the license file(s) are not defined in Buildroot, the file is not produced
1700   and a warning in the <code class="literal">README</code> indicates this.
1701 </li></ul></div><p>Please note that the aim of the <code class="literal">legal-info</code> feature of Buildroot is to
1702 produce all the material that is somehow relevant for legal compliance with the
1703 package licenses. Buildroot does not try to produce the exact material that
1704 you must somehow make public. Certainly, more material is produced than is
1705 needed for a strict legal compliance. For example, it produces the source code
1706 for packages released under BSD-like licenses, that you are not required to
1707 redistribute in source form.</p><p>Moreover, due to technical limitations, Buildroot does not produce some
1708 material that you will or may need, such as the toolchain source code and the
1709 Buildroot source code itself (including patches to packages for which source
1710 distribution is required).
1711 When you run <code class="literal">make legal-info</code>, Buildroot produces warnings in the <code class="literal">README</code>
1712 file to inform you of relevant material that could not be saved.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="legal-info-list-licenses"></a>12.2. License abbreviations</h2></div></div></div><p>Here is a list of the licenses that are most widely used by packages in
1713 Buildroot, with the name used in the manifest files:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1714 <code class="literal">GPLv2</code>:
1715   <a class="ulink" href="http://www.gnu.org/licenses/old-licenses/gpl-2.0.html" target="_top">
1716   GNU General Public License, version 2</a>;
1717 </li><li class="listitem">
1718 <code class="literal">GPLv2+</code>:
1719   <a class="ulink" href="http://www.gnu.org/licenses/old-licenses/gpl-2.0.html" target="_top">
1720   GNU General Public License, version 2</a>
1721   or (at your option) any later version;
1722 </li><li class="listitem">
1723 <code class="literal">GPLv3</code>:
1724   <a class="ulink" href="http://www.gnu.org/licenses/gpl.html" target="_top">
1725   GNU General Public License, version 3</a>;
1726 </li><li class="listitem">
1727 <code class="literal">GPLv3+</code>:
1728   <a class="ulink" href="http://www.gnu.org/licenses/gpl.html" target="_top">
1729   GNU General Public License, version 3</a>
1730   or (at your option) any later version;
1731 </li><li class="listitem">
1732 <code class="literal">GPL</code>:
1733   <a class="ulink" href="http://www.gnu.org/licenses/gpl.html" target="_top">
1734   GNU General Public License</a> (any version);
1735 </li><li class="listitem">
1736 <code class="literal">LGPLv2</code>:
1737   <a class="ulink" href="http://www.gnu.org/licenses/old-licenses/lgpl-2.0.html" target="_top">
1738   GNU Library General Public License, version 2</a>;
1739 </li><li class="listitem">
1740 <code class="literal">LGPLv2+</code>:
1741   <a class="ulink" href="http://www.gnu.org/licenses/old-licenses/lgpl-2.0.html" target="_top">
1742   GNU Library General Public License, version 2</a>
1743   or (at your option) any later version;
1744 </li><li class="listitem">
1745 <code class="literal">LGPLv2.1</code>:
1746   <a class="ulink" href="http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html" target="_top">
1747   GNU Lesser General Public License, version 2.1</a>;
1748 </li><li class="listitem">
1749 <code class="literal">LGPLv2.1+</code>:
1750   <a class="ulink" href="http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html" target="_top">
1751   GNU Lesser General Public License, version 2.1</a>
1752   or (at your option) any later version;
1753 </li><li class="listitem">
1754 <code class="literal">LGPLv3</code>:
1755   <a class="ulink" href="http://www.gnu.org/licenses/lgpl.html" target="_top">
1756   GNU Lesser General Public License, version 3</a>;
1757 </li><li class="listitem">
1758 <code class="literal">LGPLv3+</code>:
1759   <a class="ulink" href="http://www.gnu.org/licenses/lgpl.html" target="_top">
1760   GNU Lesser General Public License, version 3</a>
1761   or (at your option) any later version;
1762 </li><li class="listitem">
1763 <code class="literal">LGPL</code>:
1764   <a class="ulink" href="http://www.gnu.org/licenses/lgpl.html" target="_top">
1765   GNU Lesser General Public License</a> (any version);
1766 </li><li class="listitem">
1767 <code class="literal">BSD-4c</code>:
1768   <a class="ulink" href="http://directory.fsf.org/wiki/License:BSD_4Clause" target="_top">
1769   Original BSD 4-clause license</a>;
1770 </li><li class="listitem">
1771 <code class="literal">BSD-3c</code>:
1772   <a class="ulink" href="http://opensource.org/licenses/BSD-3-Clause" target="_top">
1773   BSD 3-clause license</a>;
1774 </li><li class="listitem">
1775 <code class="literal">BSD-2c</code>:
1776   <a class="ulink" href="http://opensource.org/licenses/BSD-2-Clause" target="_top">
1777   BSD 2-clause license</a>;
1778 </li><li class="listitem">
1779 <code class="literal">MIT</code>:
1780   <a class="ulink" href="http://opensource.org/licenses/mit-license.html" target="_top">
1781   MIT-style license</a>;
1782 </li><li class="listitem">
1783 <code class="literal">Apache-2.0</code>:
1784   <a class="ulink" href="http://apache.org/licenses/LICENSE-2.0.html" target="_top">
1785   Apache License, version 2.0</a>;
1786 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_complying_with_the_buildroot_license"></a>12.3. Complying with the Buildroot license</h2></div></div></div><p>Buildroot itself is an open source software, released under the
1787 <a class="ulink" href="http://www.gnu.org/licenses/old-licenses/gpl-2.0.html" target="_top">GNU General Public
1788 License, version 2</a> or (at your option) any later version.
1789 However, being a build system, it is not normally part of the end product:
1790 if you develop the root filesystem, kernel, bootloader or toolchain for a
1791 device, the code of Buildroot is only present on the development machine, not
1792 in the device storage.</p><p>Nevertheless, the general view of the Buildroot developers is that you should
1793 release the Buildroot source code along with the source code of other packages
1794 when releasing a product that contains GPL-licensed software.
1795 This is because the
1796 <a class="ulink" href="http://www.gnu.org/licenses/old-licenses/gpl-2.0.html" target="_top">GNU GPL</a>
1797 defines the "<span class="emphasis"><em>complete source code</em></span>" for an executable work as "<span class="emphasis"><em>all the
1798 source code for all modules it contains, plus any associated interface
1799 definition files, plus the scripts used to control compilation and installation
1800 of the executable</em></span>".
1801 Buildroot is part of the <span class="emphasis"><em>scripts used to control compilation and
1802 installation of the executable</em></span>, and as such it is considered part of the
1803 material that must be redistributed.</p><p>Keep in mind that this is only the Buildroot developers' opinion, and you
1804 should consult your legal department or lawyer in case of any doubt.</p></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_beyond_buildroot"></a>Chapter 13. Beyond Buildroot</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_boot_the_generated_images"></a>13.1. Boot the generated images</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_nfs_boot"></a>13.1.1. NFS boot</h3></div></div></div><p>To achieve NFS-boot, enable <span class="emphasis"><em>tar root filesystem</em></span> in the <span class="emphasis"><em>Filesystem
1805 images</em></span> menu.</p><p>After a complete build, just run the following commands to setup the
1806 NFS-root directory:</p><pre class="screen">sudo tar -xavf /path/to/output_dir/rootfs.tar -C /path/to/nfs_root_dir</pre><p>Remember to add this path to <code class="literal">/etc/exports</code>.</p><p>Then, you can execute a NFS-boot from your target.</p></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_chroot"></a>13.2. Chroot</h2></div></div></div><p>If you want to chroot in a generated image, then there are few thing
1807 you should be aware of:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1808 you should setup the new root from the <span class="emphasis"><em>tar root filesystem</em></span> image;
1809 </li><li class="listitem">
1810 either the selected target architecture is compatible with your host
1811   machine, or you should use some <code class="literal">qemu-*</code> binary and correctly set it
1812   within the <code class="literal">binfmt</code> properties to be able to run the binaries built
1813   for the target on your host machine;
1814 </li><li class="listitem">
1815 Buildroot does not currently provide <code class="literal">host-qemu</code> and <code class="literal">binfmt</code>
1816   correctly built and set for that kind of use.
1817 </li></ul></div></div></div></div><div class="part"><div class="titlepage"><div><div><h1 class="title"><a id="_developer_guide"></a>Part III. Developer guide</h1></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_how_buildroot_works"></a>Chapter 14. How Buildroot works</h2></div></div></div><p>As mentioned above, Buildroot is basically a set of Makefiles that
1818 download, configure, and compile software with the correct options. It
1819 also includes patches for various software packages - mainly the ones
1820 involved in the cross-compilation toolchain (<code class="literal">gcc</code>, <code class="literal">binutils</code> and
1821 <code class="literal">uClibc</code>).</p><p>There is basically one Makefile per software package, and they are
1822 named with the <code class="literal">.mk</code> extension. Makefiles are split into many different
1823 parts.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1824 The <code class="literal">toolchain/</code> directory contains the Makefiles
1825   and associated files for all software related to the
1826   cross-compilation toolchain: <code class="literal">binutils</code>, <code class="literal">gcc</code>, <code class="literal">gdb</code>,
1827   <code class="literal">kernel-headers</code> and <code class="literal">uClibc</code>.
1828 </li><li class="listitem">
1829 The <code class="literal">arch/</code> directory contains the definitions for all the processor
1830   architectures that are supported by Buildroot.
1831 </li><li class="listitem">
1832 The <code class="literal">package/</code> directory contains the Makefiles and
1833   associated files for all user-space tools and libraries that Buildroot
1834   can compile and add to the target root filesystem. There is one
1835   sub-directory per package.
1836 </li><li class="listitem">
1837 The <code class="literal">linux/</code> directory contains the Makefiles and associated files for
1838   the Linux kernel.
1839 </li><li class="listitem">
1840 The <code class="literal">boot/</code> directory contains the Makefiles and associated files for
1841   the bootloaders supported by Buildroot.
1842 </li><li class="listitem">
1843 The <code class="literal">system/</code> directory contains support for system integration, e.g.
1844   the target filesystem skeleton and the selection of an init system.
1845 </li><li class="listitem">
1846 The <code class="literal">fs/</code> directory contains the Makefiles and
1847   associated files for software related to the generation of the
1848   target root filesystem image.
1849 </li></ul></div><p>Each directory contains at least 2 files:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1850 <code class="literal">something.mk</code> is the Makefile that downloads, configures,
1851   compiles and installs the package <code class="literal">something</code>.
1852 </li><li class="listitem">
1853 <code class="literal">Config.in</code> is a part of the configuration tool
1854   description file. It describes the options related to the
1855   package.
1856 </li></ul></div><p>The main Makefile performs the following steps (once the
1857 configuration is done):</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1858 Create all the output directories: <code class="literal">staging</code>, <code class="literal">target</code>, <code class="literal">build</code>,
1859   etc. in the output directory (<code class="literal">output/</code> by default,
1860   another value can be specified using <code class="literal">O=</code>)
1861 </li><li class="listitem">
1862 Generate the toolchain target. When an internal toolchain is used, this
1863   means generating the cross-compilation toolchain. When an external
1864   toolchain is used, this means checking the features of the external
1865   toolchain and importing it into the Buildroot environment.
1866 </li><li class="listitem">
1867 Generate all the targets listed in the <code class="literal">TARGETS</code> variable. This
1868   variable is filled by all the individual components'
1869   Makefiles. Generating these targets will trigger the compilation of
1870   the userspace packages (libraries, programs), the kernel, the
1871   bootloader and the generation of the root filesystem images,
1872   depending on the configuration.
1873 </li></ul></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_coding_style"></a>Chapter 15. Coding style</h2></div></div></div><p>Overall, these coding style rules are here to help you to add new files in
1874 Buildroot or refactor existing ones.</p><p>If you slightly modify some existing file, the important thing is
1875 to keep the consistency of the whole file, so you can:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1876 either follow the potentially deprecated coding style used in this
1877 file,
1878 </li><li class="listitem">
1879 or entirely rework it in order to make it comply with these rules.
1880 </li></ul></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="writing-rules-config-in"></a>15.1. <code class="literal">Config.in</code> file</h2></div></div></div><p><code class="literal">Config.in</code> files contain entries for almost anything configurable in
1881 Buildroot.</p><p>An entry has the following pattern:</p><pre class="screen">config BR2_PACKAGE_LIBFOO
1882         bool "libfoo"
1883         depends on BR2_PACKAGE_LIBBAZ
1884         select BR2_PACKAGE_LIBBAR
1885         help
1886           This is a comment that explains what libfoo is.
1887
1888           http://foosoftware.org/libfoo/</pre><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1889 The <code class="literal">bool</code>, <code class="literal">depends on</code>, <code class="literal">select</code> and <code class="literal">help</code> lines are indented
1890   with one tab.
1891 </li><li class="listitem">
1892 The help text itself should be indented with one tab and two
1893   spaces.
1894 </li></ul></div><p>The <code class="literal">Config.in</code> files are the input for the configuration tool
1895 used in Buildroot, which is the regular <span class="emphasis"><em>Kconfig</em></span>. For further
1896 details about the <span class="emphasis"><em>Kconfig</em></span> language, refer to
1897 <a class="ulink" href="http://kernel.org/doc/Documentation/kbuild/kconfig-language.txt" target="_top">http://kernel.org/doc/Documentation/kbuild/kconfig-language.txt</a>.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="writing-rules-mk"></a>15.2. The <code class="literal">.mk</code> file</h2></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p class="simpara">
1898 Header: The file starts with a header. It contains the module name,
1899 preferably in lowercase, enclosed between separators made of 80 hashes. A
1900 blank line is mandatory after the header:
1901 </p><pre class="screen">################################################################################
1902 #
1903 # libfoo
1904 #
1905 ################################################################################</pre></li><li class="listitem"><p class="simpara">
1906 Assignment: use <code class="literal">=</code> preceded and followed by one space:
1907 </p><pre class="screen">LIBFOO_VERSION = 1.0
1908 LIBFOO_CONF_OPTS += --without-python-support</pre><p class="simpara">Do not align the <code class="literal">=</code> signs.</p></li><li class="listitem"><p class="simpara">
1909 Indentation: use tab only:
1910 </p><pre class="screen">define LIBFOO_REMOVE_DOC
1911         $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/doc \
1912                 $(TARGET_DIR)/usr/share/man/man3/libfoo*
1913 endef</pre><p class="simpara">Note that commands inside a <code class="literal">define</code> block should always start with a tab,
1914 so <span class="emphasis"><em>make</em></span> recognizes them as commands.</p></li><li class="listitem"><p class="simpara">
1915 Optional dependency:
1916 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem"><p class="simpara">
1917 Prefer multi-line syntax.
1918 </p><p class="simpara">YES:</p><pre class="screen">ifeq ($(BR2_PACKAGE_PYTHON),y)
1919 LIBFOO_CONF_OPTS += --with-python-support
1920 LIBFOO_DEPENDENCIES += python
1921 else
1922 LIBFOO_CONF_OPTS += --without-python-support
1923 endif</pre><p class="simpara">NO:</p><pre class="screen">LIBFOO_CONF_OPTS += --with$(if $(BR2_PACKAGE_PYTHON),,out)-python-support
1924 LIBFOO_DEPENDENCIES += $(if $(BR2_PACKAGE_PYTHON),python,)</pre></li><li class="listitem">
1925 Keep configure options and dependencies close together.
1926 </li></ul></div></li><li class="listitem"><p class="simpara">
1927 Optional hooks: keep hook definition and assignment together in one
1928   if block.
1929 </p><p class="simpara">YES:</p><pre class="screen">ifneq ($(BR2_LIBFOO_INSTALL_DATA),y)
1930 define LIBFOO_REMOVE_DATA
1931         $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/data
1932 endef
1933 LIBFOO_POST_INSTALL_TARGET_HOOKS += LIBFOO_REMOVE_DATA
1934 endif</pre><p class="simpara">NO:</p><pre class="screen">define LIBFOO_REMOVE_DATA
1935         $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/data
1936 endef
1937
1938 ifneq ($(BR2_LIBFOO_INSTALL_DATA),y)
1939 LIBFOO_POST_INSTALL_TARGET_HOOKS += LIBFOO_REMOVE_DATA
1940 endif</pre></li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_the_documentation"></a>15.3. The documentation</h2></div></div></div><p>The documentation uses the
1941 <a class="ulink" href="http://www.methods.co.nz/asciidoc/" target="_top">asciidoc</a> format.</p><p>For further details about the <a class="ulink" href="http://www.methods.co.nz/asciidoc/" target="_top">asciidoc</a>
1942 syntax, refer to <a class="ulink" href="http://www.methods.co.nz/asciidoc/userguide.html" target="_top">http://www.methods.co.nz/asciidoc/userguide.html</a>.</p></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="adding-board-support"></a>Chapter 16. Adding support for a particular board</h2></div></div></div><p>Buildroot contains basic configurations for several publicly available
1943 hardware boards, so that users of such a board can easily build a system
1944 that is known to work. You are welcome to add support for other boards
1945 to Buildroot too.</p><p>To do so, you need to create a normal Buildroot configuration that
1946 builds a basic system for the hardware: toolchain, kernel, bootloader,
1947 filesystem and a simple BusyBox-only userspace. No specific package
1948 should be selected: the configuration should be as minimal as
1949 possible, and should only build a working basic BusyBox system for the
1950 target platform. You can of course use more complicated configurations
1951 for your internal projects, but the Buildroot project will only
1952 integrate basic board configurations. This is because package
1953 selections are highly application-specific.</p><p>Once you have a known working configuration, run <code class="literal">make
1954 savedefconfig</code>. This will generate a minimal <code class="literal">defconfig</code> file at the
1955 root of the Buildroot source tree. Move this file into the <code class="literal">configs/</code>
1956 directory, and rename it <code class="literal">&lt;boardname&gt;_defconfig</code>.</p><p>It is recommended to use as much as possible upstream versions of the
1957 Linux kernel and bootloaders, and to use as much as possible default
1958 kernel and bootloader configurations. If they are incorrect for your
1959 board, or no default exists, we encourage you to send fixes to the
1960 corresponding upstream projects.</p><p>However, in the mean time, you may want to store kernel or bootloader
1961 configuration or patches specific to your target platform. To do so,
1962 create a directory <code class="literal">board/&lt;manufacturer&gt;</code> and a subdirectory
1963 <code class="literal">board/&lt;manufacturer&gt;/&lt;boardname&gt;</code>. You can then store your patches
1964 and configurations in these directories, and reference them from the main
1965 Buildroot configuration. Refer to <a class="xref" href="#customize" title="Chapter 9. Project-specific customization">Chapter 9, <em>Project-specific customization</em></a> for more details.</p></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="adding-packages"></a>Chapter 17. Adding new packages to Buildroot</h2></div></div></div><p>This section covers how new packages (userspace libraries or
1966 applications) can be integrated into Buildroot. It also shows how
1967 existing packages are integrated, which is needed for fixing issues or
1968 tuning their configuration.</p><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_package_directory"></a>17.1. Package directory</h2></div></div></div><p>First of all, create a directory under the <code class="literal">package</code> directory for
1969 your software, for example <code class="literal">libfoo</code>.</p><p>Some packages have been grouped by topic in a sub-directory:
1970 <code class="literal">x11r7</code>, <code class="literal">efl</code> and <code class="literal">matchbox</code>. If your package fits in
1971 one of these categories, then create your package directory in these.
1972 New subdirectories are discouraged, however.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_config_files"></a>17.2. Config files</h2></div></div></div><p>For the package to be displayed in the configuration tool, you need to
1973 create a Config file in your package directory. There are two types:
1974 <code class="literal">Config.in</code> and <code class="literal">Config.in.host</code>.</p><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_literal_config_in_literal_file"></a>17.2.1. <code class="literal">Config.in</code> file</h3></div></div></div><p>For packages used on the target, create a file named <code class="literal">Config.in</code>. This
1975 file will contain the option descriptions related to our <code class="literal">libfoo</code> software
1976 that will be used and displayed in the configuration tool. It should basically
1977 contain:</p><pre class="screen">config BR2_PACKAGE_LIBFOO
1978         bool "libfoo"
1979         help
1980           This is a comment that explains what libfoo is.
1981
1982           http://foosoftware.org/libfoo/</pre><p>The <code class="literal">bool</code> line, <code class="literal">help</code> line and other metadata information about the
1983 configuration option must be indented with one tab. The help text
1984 itself should be indented with one tab and two spaces, and it must
1985 mention the upstream URL of the project.</p><p>You can add other sub-options into a <code class="literal">if
1986 BR2_PACKAGE_LIBFOO…endif</code> statement to configure particular things
1987 in your software. You can look at examples in other packages. The
1988 syntax of the <code class="literal">Config.in</code> file is the same as the one for the kernel
1989 Kconfig file. The documentation for this syntax is available at
1990 <a class="ulink" href="http://kernel.org/doc/Documentation/kbuild/kconfig-language.txt" target="_top">http://kernel.org/doc/Documentation/kbuild/kconfig-language.txt</a></p><p>Finally you have to add your new <code class="literal">libfoo/Config.in</code> to
1991 <code class="literal">package/Config.in</code> (or in a category subdirectory if you decided to
1992 put your package in one of the existing categories). The files
1993 included there are <span class="emphasis"><em>sorted alphabetically</em></span> per category and are <span class="emphasis"><em>NOT</em></span>
1994 supposed to contain anything but the <span class="emphasis"><em>bare</em></span> name of the package.</p><pre class="screen">source "package/libfoo/Config.in"</pre></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_literal_config_in_host_literal_file"></a>17.2.2. <code class="literal">Config.in.host</code> file</h3></div></div></div><p>Some packages also need to be built for the host system. There are two
1995 options here:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
1996 The host package is only required to satisfy build-time
1997   dependencies of one or more target packages. In this case, add
1998   <code class="literal">host-foo</code> to the target package’s <code class="literal">BAR_DEPENDENCIES</code> variable. No
1999   <code class="literal">Config.in.host</code> file should be created.
2000 </li><li class="listitem"><p class="simpara">
2001 The host package should be explicitly selectable by the user from
2002   the configuration menu. In this case, create a <code class="literal">Config.in.host</code> file
2003   for that host package:
2004 </p><pre class="screen">config BR2_PACKAGE_HOST_FOO
2005         bool "host foo"
2006         help
2007           This is a comment that explains what foo for the host is.
2008
2009           http://foosoftware.org/foo/</pre><p class="simpara">The same coding style and options as for the <code class="literal">Config.in</code> file are valid.</p><p class="simpara">Finally you have to add your new <code class="literal">libfoo/Config.in.host</code> to
2010 <code class="literal">package/Config.in.host</code>. The files included there are <span class="emphasis"><em>sorted alphabetically</em></span>
2011 and are <span class="emphasis"><em>NOT</em></span> supposed to contain anything but the <span class="emphasis"><em>bare</em></span> name of the package.</p><pre class="screen">source "package/foo/Config.in.host"</pre><p class="simpara">The host package will then be available from the <code class="literal">Host utilities</code> menu.</p></li></ul></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="depends-on-vs-select"></a>17.2.3. Choosing <code class="literal">depends on</code> or <code class="literal">select</code></h3></div></div></div><p>The <code class="literal">Config.in</code> file of your package must also ensure that
2012 dependencies are enabled. Typically, Buildroot uses the following
2013 rules:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2014 Use a <code class="literal">select</code> type of dependency for dependencies on
2015   libraries. These dependencies are generally not obvious and it
2016   therefore make sense to have the kconfig system ensure that the
2017   dependencies are selected. For example, the <span class="emphasis"><em>libgtk2</em></span> package uses
2018   <code class="literal">select BR2_PACKAGE_LIBGLIB2</code> to make sure this library is also
2019   enabled.
2020   The <code class="literal">select</code> keyword expresses the dependency with a backward
2021   semantic.
2022 </li><li class="listitem">
2023 Use a <code class="literal">depends on</code> type of dependency when the user really needs to
2024   be aware of the dependency. Typically, Buildroot uses this type of
2025   dependency for dependencies on target architecture, MMU support and
2026   toolchain options (see <a class="xref" href="#dependencies-target-toolchain-options" title="17.2.4. Dependencies on target and toolchain options">Section 17.2.4, “Dependencies on target and toolchain options”</a>),
2027   or for dependencies on "big" things, such as the X.org system.
2028   The <code class="literal">depends on</code> keyword expresses the dependency with a forward
2029   semantic.
2030 </li></ul></div><p><strong>Note. </strong>The current problem with the <span class="emphasis"><em>kconfig</em></span> language is that these two
2031 dependency semantics are not internally linked. Therefore, it may be
2032 possible to select a package, whom one of its dependencies/requirement
2033 is not met.</p><p>An example illustrates both the usage of <code class="literal">select</code> and <code class="literal">depends on</code>.</p><pre class="screen">config BR2_PACKAGE_RRDTOOL
2034         bool "rrdtool"
2035         depends on BR2_USE_WCHAR
2036         select BR2_PACKAGE_FREETYPE
2037         select BR2_PACKAGE_LIBART
2038         select BR2_PACKAGE_LIBPNG
2039         select BR2_PACKAGE_ZLIB
2040         help
2041           RRDtool is the OpenSource industry standard, high performance
2042           data logging and graphing system for time series data.
2043
2044           http://oss.oetiker.ch/rrdtool/
2045
2046 comment "rrdtool needs a toolchain w/ wchar"
2047         depends on !BR2_USE_WCHAR</pre><p>Note that these two dependency types are only transitive with the
2048 dependencies of the same kind.</p><p>This means, in the following example:</p><pre class="screen">config BR2_PACKAGE_A
2049         bool "Package A"
2050
2051 config BR2_PACKAGE_B
2052         bool "Package B"
2053         depends on BR2_PACKAGE_A
2054
2055 config BR2_PACKAGE_C
2056         bool "Package C"
2057         depends on BR2_PACKAGE_B
2058
2059 config BR2_PACKAGE_D
2060         bool "Package D"
2061         select BR2_PACKAGE_B
2062
2063 config BR2_PACKAGE_E
2064         bool "Package E"
2065         select BR2_PACKAGE_D</pre><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2066 Selecting <code class="literal">Package C</code> will be visible if <code class="literal">Package B</code> has been
2067   selected, which in turn is only visible if <code class="literal">Package A</code> has been
2068   selected.
2069 </li><li class="listitem">
2070 Selecting <code class="literal">Package E</code> will select <code class="literal">Package D</code>, which will select
2071   <code class="literal">Package B</code>, it will not check for the dependencies of <code class="literal">Package B</code>,
2072   so it will not select <code class="literal">Package A</code>.
2073 </li><li class="listitem">
2074 Since <code class="literal">Package B</code> is selected but <code class="literal">Package A</code> is not, this violates
2075   the dependency of <code class="literal">Package B</code> on <code class="literal">Package A</code>. Therefore, in such a
2076   situation, the transitive dependency has to be added explicitly:
2077 </li></ul></div><pre class="screen">config BR2_PACKAGE_D
2078         bool "Package D"
2079         select BR2_PACKAGE_B
2080         depends on BR2_PACKAGE_A
2081
2082 config BR2_PACKAGE_E
2083         bool "Package E"
2084         select BR2_PACKAGE_D
2085         depends on BR2_PACKAGE_A</pre><p>Overall, for package library dependencies, <code class="literal">select</code> should be
2086 preferred.</p><p>Note that such dependencies will ensure that the dependency option
2087 is also enabled, but not necessarily built before your package. To do
2088 so, the dependency also needs to be expressed in the <code class="literal">.mk</code> file of the
2089 package.</p><p>Further formatting details: see <a class="link" href="#writing-rules-config-in" title="15.1. Config.in file">the
2090 coding style</a>
2091 <a class="xref" href="#writing-rules-config-in" title="15.1. Config.in file">Section 15.1, “<code class="literal">Config.in</code> file”</a>.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="dependencies-target-toolchain-options"></a>17.2.4. Dependencies on target and toolchain options</h3></div></div></div><p>Many packages depend on certain options of the toolchain: the choice of
2092 C library, C++ support, thread support, RPC support, wchar support,
2093 or dynamic library support. Some packages can only be built on certain
2094 target architectures, or if an MMU is available in the processor.</p><p>These dependencies have to be expressed with the appropriate <span class="emphasis"><em>depends
2095 on</em></span> statements in the Config.in file. Additionally, for dependencies on
2096 toolchain options, a <code class="literal">comment</code> should be displayed when the option is
2097 not enabled, so that the user knows why the package is not available.
2098 Dependencies on target architecture or MMU support should not be
2099 made visible in a comment: since it is unlikely that the user can
2100 freely choose another target, it makes little sense to show these
2101 dependencies explicitly.</p><p>The <code class="literal">comment</code> should only be visible if the <code class="literal">config</code> option itself would
2102 be visible when the toolchain option dependencies are met. This means
2103 that all other dependencies of the package (including dependencies on
2104 target architecture and MMU support) have to be repeated on the
2105 <code class="literal">comment</code> definition. To keep it clear, the <code class="literal">depends on</code> statement for
2106 these non-toolchain option should be kept separate from the <code class="literal">depends on</code>
2107 statement for the toolchain options.
2108 If there is a dependency on a config option in that same file (typically
2109 the main package) it is preferable to have a global <code class="literal">if … endif</code>
2110 construct rather than repeating the <code class="literal">depends on</code> statement on the
2111 comment and other config options.</p><p>The general format of a dependency <code class="literal">comment</code> for package foo is:</p><pre class="screen">foo needs a toolchain w/ featA, featB, featC</pre><p>for example:</p><pre class="screen">mpd needs a toolchain w/ C++, threads, wchar</pre><p>or</p><pre class="screen">crda needs a toolchain w/ threads</pre><p>Note that this text is kept brief on purpose, so that it will fit on a
2112 80-character terminal.</p><p>The rest of this section enumerates the different target and toolchain
2113 options, the corresponding config symbols to depend on, and the text to
2114 use in the comment.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p class="simpara">
2115 Target architecture
2116 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2117 Dependency symbol: <code class="literal">BR2_powerpc</code>, <code class="literal">BR2_mips</code>, … (see <code class="literal">arch/Config.in</code>)
2118 </li><li class="listitem">
2119 Comment string: no comment to be added
2120 </li></ul></div></li><li class="listitem"><p class="simpara">
2121 MMU support
2122 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2123 Dependency symbol: <code class="literal">BR2_USE_MMU</code>
2124 </li><li class="listitem">
2125 Comment string: no comment to be added
2126 </li></ul></div></li><li class="listitem"><p class="simpara">
2127 Atomic instructions (whereby the architecture has instructions to
2128   perform some operations atomically, like LOCKCMPXCHG on x86)
2129 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2130 Dependency symbol: <code class="literal">BR2_ARCH_HAS_ATOMICS</code>
2131 </li><li class="listitem">
2132 Comment string: no comment to be added
2133 </li></ul></div></li><li class="listitem"><p class="simpara">
2134 Kernel headers
2135 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2136 Dependency symbol: <code class="literal">BR2_TOOLCHAIN_HEADERS_AT_LEAST_X_Y</code>, (replace
2137    <code class="literal">X_Y</code> with the proper version, see <code class="literal">toolchain/toolchain-common.in</code>)
2138 </li><li class="listitem">
2139 Comment string: <code class="literal">headers &gt;= X.Y</code> and/or <code class="literal">headers &lt;= X.Y</code> (replace
2140    <code class="literal">X.Y</code> with the proper version)
2141 </li></ul></div></li><li class="listitem"><p class="simpara">
2142 C library
2143 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2144 Dependency symbol: <code class="literal">BR2_TOOLCHAIN_USES_GLIBC</code>,
2145    <code class="literal">BR2_TOOLCHAIN_USES_MUSL</code>, <code class="literal">BR2_TOOLCHAIN_USES_UCLIBC</code>
2146 </li><li class="listitem">
2147 Comment string: for the C library, a slightly different comment text
2148    is used: <code class="literal">foo needs an (e)glibc toolchain</code>, or <code class="literal">foo needs an (e)glibc
2149    toolchain w/ C++</code>
2150 </li></ul></div></li><li class="listitem"><p class="simpara">
2151 C++ support
2152 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2153 Dependency symbol: <code class="literal">BR2_INSTALL_LIBSTDCPP</code>
2154 </li><li class="listitem">
2155 Comment string: <code class="literal">C++</code>
2156 </li></ul></div></li><li class="listitem"><p class="simpara">
2157 thread support
2158 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2159 Dependency symbol: <code class="literal">BR2_TOOLCHAIN_HAS_THREADS</code>
2160 </li><li class="listitem">
2161 Comment string: <code class="literal">threads</code> (unless <code class="literal">BR2_TOOLCHAIN_HAS_THREADS_NPTL</code>
2162    is also needed, in which case, specifying only <code class="literal">NPTL</code> is sufficient)
2163 </li></ul></div></li><li class="listitem"><p class="simpara">
2164 NPTL thread support
2165 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2166 Dependency symbol: <code class="literal">BR2_TOOLCHAIN_HAS_THREADS_NPTL</code>
2167 </li><li class="listitem">
2168 Comment string: <code class="literal">NPTL</code>
2169 </li></ul></div></li><li class="listitem"><p class="simpara">
2170 RPC support
2171 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2172 Dependency symbol: <code class="literal">BR2_TOOLCHAIN_HAS_NATIVE_RPC</code>
2173 </li><li class="listitem">
2174 Comment string: <code class="literal">RPC</code>
2175 </li></ul></div></li><li class="listitem"><p class="simpara">
2176 wchar support
2177 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2178 Dependency symbol: <code class="literal">BR2_USE_WCHAR</code>
2179 </li><li class="listitem">
2180 Comment string: <code class="literal">wchar</code>
2181 </li></ul></div></li><li class="listitem"><p class="simpara">
2182 dynamic library
2183 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2184 Dependency symbol: <code class="literal">!BR2_STATIC_LIBS</code>
2185 </li><li class="listitem">
2186 Comment string: <code class="literal">dynamic library</code>
2187 </li></ul></div></li></ul></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_dependencies_on_a_linux_kernel_built_by_buildroot"></a>17.2.5. Dependencies on a Linux kernel built by buildroot</h3></div></div></div><p>Some packages need a Linux kernel to be built by buildroot. These are
2188 typically kernel modules or firmware. A comment should be added in the
2189 Config.in file to express this dependency, similar to dependencies on
2190 toolchain options. The general format is:</p><pre class="screen">foo needs a Linux kernel to be built</pre><p>If there is a dependency on both toolchain options and the Linux
2191 kernel, use this format:</p><pre class="screen">foo needs a toolchain w/ featA, featB, featC and a Linux kernel to be built</pre></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_dependencies_on_udev_dev_management"></a>17.2.6. Dependencies on udev /dev management</h3></div></div></div><p>If a package needs udev /dev management, it should depend on symbol
2192 <code class="literal">BR2_PACKAGE_HAS_UDEV</code>, and the following comment should be added:</p><pre class="screen">foo needs udev /dev management</pre><p>If there is a dependency on both toolchain options and udev /dev
2193 management, use this format:</p><pre class="screen">foo needs udev /dev management and a toolchain w/ featA, featB, featC</pre></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_dependencies_on_features_provided_by_virtual_packages"></a>17.2.7. Dependencies on features provided by virtual packages</h3></div></div></div><p>Some features can be provided by more than one package, such as the
2194 openGL libraries.</p><p>See <a class="xref" href="#virtual-package-tutorial">Section 17.11, “Infrastructure for virtual packages”</a> for more on the virtual packages.</p><p>See <a class="xref" href="#virtual-package-list" title="Chapter 25. List of virtual packages">Chapter 25, <em>List of virtual packages</em></a> for the symbols to depend on if your package
2195 depends on a feature provided by a virtual package.</p></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_the_literal_mk_literal_file"></a>17.3. The <code class="literal">.mk</code> file</h2></div></div></div><p><a id="adding-packages-mk"></a>Finally, here’s the hardest part. Create a file named <code class="literal">libfoo.mk</code>. It
2196 describes how the package should be downloaded, configured, built,
2197 installed, etc.</p><p>Depending on the package type, the <code class="literal">.mk</code> file must be written in a
2198 different way, using different infrastructures:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2199 <span class="strong"><strong>Makefiles for generic packages</strong></span> (not using autotools or CMake):
2200   These are based on an infrastructure similar to the one used for
2201   autotools-based packages, but require a little more work from the
2202   developer. They specify what should be done for the configuration,
2203   compilation and installation of the package. This
2204   infrastructure must be used for all packages that do not use the
2205   autotools as their build system. In the future, other specialized
2206   infrastructures might be written for other build systems. We cover
2207   them through in a <a class="link" href="#generic-package-tutorial" title="17.5.1. generic-package tutorial">tutorial</a>
2208 <a class="xref" href="#generic-package-tutorial" title="17.5.1. generic-package tutorial">Section 17.5.1, “<code class="literal">generic-package</code> tutorial”</a> and a
2209   <a class="link" href="#generic-package-reference" title="17.5.2. generic-package reference">reference</a>
2210 <a class="xref" href="#generic-package-reference" title="17.5.2. generic-package reference">Section 17.5.2, “<code class="literal">generic-package</code> reference”</a>.
2211 </li><li class="listitem">
2212 <span class="strong"><strong>Makefiles for autotools-based software</strong></span> (autoconf, automake, etc.):
2213   We provide a dedicated infrastructure for such packages, since
2214   autotools is a very common build system. This infrastructure <span class="emphasis"><em>must</em></span>
2215   be used for new packages that rely on the autotools as their build
2216   system. We cover them through a <a class="link" href="#autotools-package-tutorial" title="17.6.1. autotools-package tutorial">tutorial</a>
2217 <a class="xref" href="#autotools-package-tutorial" title="17.6.1. autotools-package tutorial">Section 17.6.1, “<code class="literal">autotools-package</code> tutorial”</a>
2218   and <a class="link" href="#autotools-package-reference" title="17.6.2. autotools-package reference">reference</a>
2219 <a class="xref" href="#autotools-package-reference" title="17.6.2. autotools-package reference">Section 17.6.2, “<code class="literal">autotools-package</code> reference”</a>.
2220 </li><li class="listitem">
2221 <span class="strong"><strong>Makefiles for cmake-based software</strong></span>: We provide a dedicated
2222    infrastructure for such packages, as CMake is a more and more
2223    commonly used build system and has a standardized behaviour. This
2224    infrastructure <span class="emphasis"><em>must</em></span> be used for new packages that rely on
2225    CMake. We cover them through a <a class="link" href="#cmake-package-tutorial" title="17.7.1. cmake-package tutorial">tutorial</a>
2226 <a class="xref" href="#cmake-package-tutorial" title="17.7.1. cmake-package tutorial">Section 17.7.1, “<code class="literal">cmake-package</code> tutorial”</a>
2227    and <a class="link" href="#cmake-package-reference" title="17.7.2. cmake-package reference">reference</a>
2228 <a class="xref" href="#cmake-package-reference" title="17.7.2. cmake-package reference">Section 17.7.2, “<code class="literal">cmake-package</code> reference”</a>.
2229 </li><li class="listitem">
2230 <span class="strong"><strong>Makefiles for Python modules</strong></span>: We have a dedicated infrastructure
2231    for Python modules that use either the <code class="literal">distutils</code> or the
2232    <code class="literal">setuptools</code> mechanism. We cover them through a
2233    <a class="link" href="#python-package-tutorial" title="17.8.1. python-package tutorial">tutorial</a>
2234 <a class="xref" href="#python-package-tutorial" title="17.8.1. python-package tutorial">Section 17.8.1, “<code class="literal">python-package</code> tutorial”</a> and a
2235    <a class="link" href="#python-package-reference" title="17.8.2. python-package reference">reference</a>
2236 <a class="xref" href="#python-package-reference" title="17.8.2. python-package reference">Section 17.8.2, “<code class="literal">python-package</code> reference”</a>.
2237 </li><li class="listitem">
2238 <span class="strong"><strong>Makefiles for Lua modules</strong></span>: We have a dedicated infrastructure for
2239    Lua modules available through the LuaRocks web site. We cover them
2240    through a <a class="link" href="#luarocks-package-tutorial" title="17.9.1. luarocks-package tutorial">tutorial</a>
2241 <a class="xref" href="#luarocks-package-tutorial" title="17.9.1. luarocks-package tutorial">Section 17.9.1, “<code class="literal">luarocks-package</code> tutorial”</a> and a
2242    <a class="link" href="#luarocks-package-reference" title="17.9.2. luarocks-package reference">reference</a>
2243 <a class="xref" href="#luarocks-package-reference" title="17.9.2. luarocks-package reference">Section 17.9.2, “<code class="literal">luarocks-package</code> reference”</a>.
2244 </li></ul></div><p>Further formatting details: see <a class="link" href="#writing-rules-mk" title="15.2. The .mk file">the writing
2245 rules</a>
2246 <a class="xref" href="#writing-rules-mk" title="15.2. The .mk file">Section 15.2, “The <code class="literal">.mk</code> file”</a>.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="adding-packages-hash"></a>17.4. The <code class="literal">.hash</code> file</h2></div></div></div><p>Optionally, you can add a third file, named <code class="literal">libfoo.hash</code>, that contains
2247 the hashes of the downloaded files for the <code class="literal">libfoo</code> package.</p><p>The hashes stored in that file are used to validate the integrity of the
2248 downloaded files.</p><p>The format of this file is one line for each file for which to check the
2249 hash, each line being space-separated, with these three fields:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p class="simpara">
2250 the type of hash, one of:
2251 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2252 <code class="literal">md5</code>, <code class="literal">sha1</code>, <code class="literal">sha224</code>, <code class="literal">sha256</code>, <code class="literal">sha384</code>, <code class="literal">sha512</code>, <code class="literal">none</code>
2253 </li></ul></div></li><li class="listitem"><p class="simpara">
2254 the hash of the file:
2255 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2256 for <code class="literal">none</code>, one or more non-space chars, usually just the string <code class="literal">xxx</code>
2257 </li><li class="listitem">
2258 for <code class="literal">md5</code>, 32 hexadecimal characters
2259 </li><li class="listitem">
2260 for <code class="literal">sha1</code>, 40 hexadecimal characters
2261 </li><li class="listitem">
2262 for <code class="literal">sha224</code>, 56 hexadecimal characters
2263 </li><li class="listitem">
2264 for <code class="literal">sha256</code>, 64 hexadecimal characters
2265 </li><li class="listitem">
2266 for <code class="literal">sha384</code>, 96 hexadecimal characters
2267 </li><li class="listitem">
2268 for <code class="literal">sha512</code>, 128 hexadecimal characters
2269 </li></ul></div></li><li class="listitem">
2270 the name of the file, without any directory component
2271 </li></ul></div><p>Lines starting with a <code class="literal">#</code> sign are considered comments, and ignored. Empty
2272 lines are ignored.</p><p>There can be more than one hash for a single file, each on its own line. In
2273 this case, all hashes must match.</p><p><strong>Note. </strong>Ideally, the hashes stored in this file should match the hashes published by
2274 upstream, e.g. on their website, in the e-mail announcement… If upstream
2275 provides more than one type of hash (e.g. <code class="literal">sha1</code> and <code class="literal">sha512</code>), then it is
2276 best to add all those hashes in the <code class="literal">.hash</code> file. If upstream does not
2277 provide any hash, or only provides an <code class="literal">md5</code> hash, then compute at least one
2278 strong hash yourself (preferably <code class="literal">sha256</code>, but not <code class="literal">md5</code>), and mention
2279 this in a comment line above the hashes.</p><p><strong>Note. </strong>If <code class="literal">libfoo</code> is from GitHub (see <a class="xref" href="#github-download-url" title="17.17.2. How to add a package from GitHub">Section 17.17.2, “How to add a package from GitHub”</a> for details), we
2280 can only accept a <code class="literal">.hash</code> file if the package is a released (e.g. uploaded
2281 by the maintainer) tarball. Otherwise, the automatically generated tarball
2282 may change over time, and thus its hashes may be different each time it is
2283 downloaded, causing a <code class="literal">.hash</code> mismatch for that tarball.</p><p><strong>Note. </strong>The number of spaces does not matter, so one can use spaces (or tabs) to
2284 properly align the different fields.</p><p>The <code class="literal">none</code> hash type is reserved to those archives downloaded from a
2285 repository, like a <span class="emphasis"><em>git clone</em></span>, a <span class="emphasis"><em>subversion checkout</em></span>… or archives
2286 downloaded with the <a class="link" href="#github-download-url" title="17.17.2. How to add a package from GitHub">github helper</a>
2287 <a class="xref" href="#github-download-url" title="17.17.2. How to add a package from GitHub">Section 17.17.2, “How to add a package from GitHub”</a>.</p><p>The example below defines a <code class="literal">sha1</code> and a <code class="literal">sha256</code> published by upstream for
2288 the main <code class="literal">libfoo-1.2.3.tar.bz2</code> tarball, an <code class="literal">md5</code> from upstream and a
2289 locally-computed <code class="literal">sha256</code> hashes for a binary blob, a <code class="literal">sha256</code> for a
2290 downloaded patch, and an archive with no hash:</p><pre class="screen"># Hashes from: http://www.foosoftware.org/download/libfoo-1.2.3.tar.bz2.{sha1,sha256}:
2291 sha1   486fb55c3efa71148fe07895fd713ea3a5ae343a                         libfoo-1.2.3.tar.bz2
2292 sha256 efc8103cc3bcb06bda6a781532d12701eb081ad83e8f90004b39ab81b65d4369 libfoo-1.2.3.tar.bz2
2293
2294 # md5 from: http://www.foosoftware.org/download/libfoo-1.2.3.tar.bz2.md5, sha256 locally computed:
2295 md5    2d608f3c318c6b7557d551a5a09314f03452f1a1                         libfoo-data.bin
2296 sha256 01ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546b libfoo-data.bin
2297
2298 # Locally computed:
2299 sha256 ff52101fb90bbfc3fe9475e425688c660f46216d7e751c4bbdb1dc85cdccacb9 libfoo-fix-blabla.patch
2300
2301 # No hash for 1234, comes from the github-helper:
2302 none   xxx                                                              libfoo-1234.tar.gz</pre><p>If the <code class="literal">.hash</code> file is present, and it contains one or more hashes for a
2303 downloaded file, the hash(es) computed by Buildroot (after download) must
2304 match the hash(es) stored in the <code class="literal">.hash</code> file. If one or more hashes do
2305 not match, Buildroot considers this an error, deletes the downloaded file,
2306 and aborts.</p><p>If the <code class="literal">.hash</code> file is present, but it does not contain a hash for a
2307 downloaded file, Buildroot considers this an error and aborts. However,
2308 the downloaded file is left in the download directory since this
2309 typically indicates that the <code class="literal">.hash</code> file is wrong but the downloaded
2310 file is probably OK.</p><p>Sources that are downloaded from a version control system (git, subversion,
2311 etc…) can not have a hash, because the version control system and tar
2312 may not create exactly the same file (dates, files ordering…), so the
2313 hash could be wrong even for a valid download. Therefore, the hash check
2314 is entirely skipped for such sources.</p><p>If the <code class="literal">.hash</code> file is missing, then no check is done at all.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_packages_with_specific_build_systems"></a>17.5. Infrastructure for packages with specific build systems</h2></div></div></div><p>By <span class="emphasis"><em>packages with specific build systems</em></span> we mean all the packages
2315 whose build system is not one of the standard ones, such as
2316 <span class="emphasis"><em>autotools</em></span> or <span class="emphasis"><em>CMake</em></span>. This typically includes packages whose build
2317 system is based on hand-written Makefiles or shell scripts.</p><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="generic-package-tutorial"></a>17.5.1. <code class="literal">generic-package</code> tutorial</h3></div></div></div><pre class="screen">01: ################################################################################
2318 02: #
2319 03: # libfoo
2320 04: #
2321 05: ################################################################################
2322 06:
2323 07: LIBFOO_VERSION = 1.0
2324 08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz
2325 09: LIBFOO_SITE = http://www.foosoftware.org/download
2326 10: LIBFOO_LICENSE = GPLv3+
2327 11: LIBFOO_LICENSE_FILES = COPYING
2328 12: LIBFOO_INSTALL_STAGING = YES
2329 13: LIBFOO_CONFIG_SCRIPTS = libfoo-config
2330 14: LIBFOO_DEPENDENCIES = host-libaaa libbbb
2331 15:
2332 16: define LIBFOO_BUILD_CMDS
2333 17:     $(MAKE) CC="$(TARGET_CC)" LD="$(TARGET_LD)" -C $(@D) all
2334 18: endef
2335 19:
2336 20: define LIBFOO_INSTALL_STAGING_CMDS
2337 21:     $(INSTALL) -D -m 0755 $(@D)/libfoo.a $(STAGING_DIR)/usr/lib/libfoo.a
2338 22:     $(INSTALL) -D -m 0644 $(@D)/foo.h $(STAGING_DIR)/usr/include/foo.h
2339 23:     $(INSTALL) -D -m 0755 $(@D)/libfoo.so* $(STAGING_DIR)/usr/lib
2340 24: endef
2341 25:
2342 26: define LIBFOO_INSTALL_TARGET_CMDS
2343 27:     $(INSTALL) -D -m 0755 $(@D)/libfoo.so* $(TARGET_DIR)/usr/lib
2344 28:     $(INSTALL) -d -m 0755 $(TARGET_DIR)/etc/foo.d
2345 29: endef
2346 30:
2347 31: define LIBFOO_DEVICES
2348 32:     /dev/foo  c  666  0  0  42  0  -  -  -
2349 33: endef
2350 34:
2351 35: define LIBFOO_PERMISSIONS
2352 36:     /bin/foo  f  4755  0  0  -  -  -  -  -
2353 37: endef
2354 38:
2355 39: define LIBFOO_USERS
2356 40:     foo -1 libfoo -1 * - - - LibFoo daemon
2357 41: endef
2358 42:
2359 43: $(eval $(generic-package))</pre><p>The Makefile begins on line 7 to 11 with metadata information: the
2360 version of the package (<code class="literal">LIBFOO_VERSION</code>), the name of the
2361 tarball containing the package (<code class="literal">LIBFOO_SOURCE</code>) (xz-ed tarball recommended)
2362 the Internet location at which the tarball can be downloaded from
2363 (<code class="literal">LIBFOO_SITE</code>), the license (<code class="literal">LIBFOO_LICENSE</code>) and file with the
2364 license text (<code class="literal">LIBFOO_LICENSE_FILES</code>). All variables must start with
2365 the same prefix, <code class="literal">LIBFOO_</code> in this case. This prefix is always the
2366 uppercased version of the package name (see below to understand where
2367 the package name is defined).</p><p>On line 12, we specify that this package wants to install something to
2368 the staging space. This is often needed for libraries, since they must
2369 install header files and other development files in the staging space.
2370 This will ensure that the commands listed in the
2371 <code class="literal">LIBFOO_INSTALL_STAGING_CMDS</code> variable will be executed.</p><p>On line 13, we specify that there is some fixing to be done to some
2372 of the <span class="emphasis"><em>libfoo-config</em></span> files that were installed during
2373 <code class="literal">LIBFOO_INSTALL_STAGING_CMDS</code> phase.
2374 These *-config files are executable shell script files that are
2375 located in <span class="emphasis"><em>$(STAGING_DIR)/usr/bin</em></span> directory and are executed
2376 by other 3rd party packages to find out the location and the linking
2377 flags of this particular package.</p><p>The problem is that all these *-config files by default give wrong,
2378 host system linking flags that are unsuitable for cross-compiling.</p><p>For example:    <span class="emphasis"><em>-I/usr/include</em></span> instead of <span class="emphasis"><em>-I$(STAGING_DIR)/usr/include</em></span>
2379 or:             <span class="emphasis"><em>-L/usr/lib</em></span> instead of <span class="emphasis"><em>-L$(STAGING_DIR)/usr/lib</em></span></p><p>So some sed magic is done to these scripts to make them give correct
2380 flags.
2381 The argument to be given to <code class="literal">LIBFOO_CONFIG_SCRIPTS</code> is the file name(s)
2382 of the shell script(s) needing fixing. All these names are relative to
2383 <span class="emphasis"><em>$(STAGING_DIR)/usr/bin</em></span> and if needed multiple names can be given.</p><p>In addition, the scripts listed in <code class="literal">LIBFOO_CONFIG_SCRIPTS</code> are removed
2384 from <code class="literal">$(TARGET_DIR)/usr/bin</code>, since they are not needed on the target.</p><div class="example"><a id="idm139994498807568"></a><p class="title"><strong>Example 17.1. Config script: <span class="emphasis"><em>divine</em></span> package</strong></p><div class="example-contents"><p>Package divine installs shell script <span class="emphasis"><em>$(STAGING_DIR)/usr/bin/divine-config</em></span>.</p><p>So its fixup would be:</p><pre class="screen">DIVINE_CONFIG_SCRIPTS = divine-config</pre></div></div><br class="example-break" /><div class="example"><a id="idm139994498804640"></a><p class="title"><strong>Example 17.2. Config script: <span class="emphasis"><em>imagemagick</em></span> package:</strong></p><div class="example-contents"><p>Package imagemagick installs the following scripts:
2385 <span class="emphasis"><em>$(STAGING_DIR)/usr/bin/{Magick,Magick++,MagickCore,MagickWand,Wand}-config</em></span></p><p>So it’s fixup would be:</p><pre class="screen">IMAGEMAGICK_CONFIG_SCRIPTS = \
2386    Magick-config Magick++-config \
2387    MagickCore-config MagickWand-config Wand-config</pre></div></div><br class="example-break" /><p>On line 14, we specify the list of dependencies this package relies
2388 on. These dependencies are listed in terms of lower-case package names,
2389 which can be packages for the target (without the <code class="literal">host-</code>
2390 prefix) or packages for the host (with the <code class="literal">host-</code>) prefix).
2391 Buildroot will ensure that all these packages are built and installed
2392 <span class="emphasis"><em>before</em></span> the current package starts its configuration.</p><p>The rest of the Makefile, lines 16..29, defines what should be done
2393 at the different steps of the package configuration, compilation and
2394 installation.
2395 <code class="literal">LIBFOO_BUILD_CMDS</code> tells what steps should be performed to
2396 build the package. <code class="literal">LIBFOO_INSTALL_STAGING_CMDS</code> tells what
2397 steps should be performed to install the package in the staging space.
2398 <code class="literal">LIBFOO_INSTALL_TARGET_CMDS</code> tells what steps should be
2399 performed to install the package in the target space.</p><p>All these steps rely on the <code class="literal">$(@D)</code> variable, which
2400 contains the directory where the source code of the package has been
2401 extracted.</p><p>On line 31..33, we define a device-node file used by this package
2402 (<code class="literal">LIBFOO_DEVICES</code>).</p><p>On line 35..37, we define the permissions to set to specific files
2403 installed by this package (<code class="literal">LIBFOO_PERMISSIONS</code>).</p><p>On lines 39..41, we define a user that is used by this package (e.g.
2404 to run a daemon as non-root) (<code class="literal">LIBFOO_USERS</code>).</p><p>Finally, on line 43, we call the <code class="literal">generic-package</code> function, which
2405 generates, according to the variables defined previously, all the
2406 Makefile code necessary to make your package working.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="generic-package-reference"></a>17.5.2. <code class="literal">generic-package</code> reference</h3></div></div></div><p>There are two variants of the generic target. The <code class="literal">generic-package</code> macro is
2407 used for packages to be cross-compiled for the target. The
2408 <code class="literal">host-generic-package</code> macro is used for host packages, natively compiled
2409 for the host. It is possible to call both of them in a single <code class="literal">.mk</code>
2410 file: once to create the rules to generate a target
2411 package and once to create the rules to generate a host package:</p><pre class="screen">$(eval $(generic-package))
2412 $(eval $(host-generic-package))</pre><p>This might be useful if the compilation of the target package requires
2413 some tools to be installed on the host. If the package name is
2414 <code class="literal">libfoo</code>, then the name of the package for the target is also
2415 <code class="literal">libfoo</code>, while the name of the package for the host is
2416 <code class="literal">host-libfoo</code>. These names should be used in the DEPENDENCIES
2417 variables of other packages, if they depend on <code class="literal">libfoo</code> or
2418 <code class="literal">host-libfoo</code>.</p><p>The call to the <code class="literal">generic-package</code> and/or <code class="literal">host-generic-package</code> macro <span class="strong"><strong>must</strong></span> be
2419 at the end of the <code class="literal">.mk</code> file, after all variable definitions.</p><p>For the target package, the <code class="literal">generic-package</code> uses the variables defined by
2420 the .mk file and prefixed by the uppercased package name:
2421 <code class="literal">LIBFOO_*</code>. <code class="literal">host-generic-package</code> uses the <code class="literal">HOST_LIBFOO_*</code> variables. For
2422 <span class="emphasis"><em>some</em></span> variables, if the <code class="literal">HOST_LIBFOO_</code> prefixed variable doesn’t
2423 exist, the package infrastructure uses the corresponding variable
2424 prefixed by <code class="literal">LIBFOO_</code>. This is done for variables that are likely to
2425 have the same value for both the target and host packages. See below
2426 for details.</p><p>The list of variables that can be set in a <code class="literal">.mk</code> file to give metadata
2427 information is (assuming the package name is <code class="literal">libfoo</code>) :</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2428 <code class="literal">LIBFOO_VERSION</code>, mandatory, must contain the version of the
2429   package. Note that if <code class="literal">HOST_LIBFOO_VERSION</code> doesn’t exist, it is
2430   assumed to be the same as <code class="literal">LIBFOO_VERSION</code>. It can also be a
2431   revision number, branch or tag for packages that are fetched
2432   directly from their revision control system.
2433   Examples:
2434     <code class="literal">LIBFOO_VERSION = 0.1.2</code>
2435     <code class="literal">LIBFOO_VERSION = cb9d6aa9429e838f0e54faa3d455bcbab5eef057</code>
2436     <code class="literal">LIBFOO_VERSION = stable</code>
2437 </li><li class="listitem">
2438 <code class="literal">LIBFOO_SOURCE</code> may contain the name of the tarball of the package,
2439   which Buildroot will use to download the tarball from
2440   <code class="literal">LIBFOO_SITE</code>. If <code class="literal">HOST_LIBFOO_SOURCE</code> is not specified, it defaults
2441   to <code class="literal">LIBFOO_SOURCE</code>. If none are specified, then the value is assumed
2442   to be <code class="literal">libfoo-$(LIBFOO_VERSION).tar.gz</code>.
2443   Example: <code class="literal">LIBFOO_SOURCE = foobar-$(LIBFOO_VERSION).tar.bz2</code>
2444 </li><li class="listitem">
2445 <code class="literal">LIBFOO_PATCH</code> may contain a space-separated list of patch file
2446   names, that Buildroot will download and apply to the package source
2447   code. If an entry contains <code class="literal">://</code>, then Buildroot will assume it is a
2448   full URL and download the patch from this location. Otherwise,
2449   Buildroot will assume that the patch should be downloaded from
2450   <code class="literal">LIBFOO_SITE</code>. If <code class="literal">HOST_LIBFOO_PATCH</code> is not specified, it defaults
2451   to <code class="literal">LIBFOO_PATCH</code>. Note that patches that are included in Buildroot
2452   itself use a different mechanism: all files of the form
2453   <code class="literal">*.patch</code> present in the package directory inside
2454   Buildroot will be applied to the package after extraction (see
2455   <a class="link" href="#patch-policy" title="Chapter 18. Patching a package">patching a package</a>
2456 <a class="xref" href="#patch-policy" title="Chapter 18. Patching a package">Chapter 18, <em>Patching a package</em></a>). Finally, patches listed in
2457   the <code class="literal">LIBFOO_PATCH</code> variable are applied <span class="emphasis"><em>before</em></span> the patches stored
2458   in the Buildroot package directory.
2459 </li><li class="listitem">
2460 <code class="literal">LIBFOO_SITE</code> provides the location of the package, which can be a
2461   URL or a local filesystem path. HTTP, FTP and SCP are supported URL
2462   types for retrieving package tarballs. Git, Subversion, Mercurial,
2463   and Bazaar are supported URL types for retrieving packages directly
2464   from source code management systems. There is a helper function to make
2465   it easier to download source tarballs from GitHub (refer to
2466   <a class="xref" href="#github-download-url" title="17.17.2. How to add a package from GitHub">Section 17.17.2, “How to add a package from GitHub”</a> for details). A filesystem path may be used
2467   to specify either a tarball or a directory containing the package
2468   source code. See <code class="literal">LIBFOO_SITE_METHOD</code> below for more details on how
2469   retrieval works.
2470   Note that SCP URLs should be of the form
2471   <code class="literal">scp://[user@]host:filepath</code>, and that filepath is relative to the
2472   user’s home directory, so you may want to prepend the path with a
2473   slash for absolute paths:
2474   <code class="literal">scp://[user@]host:/absolutepath</code>.
2475   If <code class="literal">HOST_LIBFOO_SITE</code> is not specified, it defaults to
2476   <code class="literal">LIBFOO_SITE</code>.
2477   Examples:
2478     <code class="literal">LIBFOO_SITE=http://www.libfoosoftware.org/libfoo</code>
2479     <code class="literal">LIBFOO_SITE=http://svn.xiph.org/trunk/Tremor</code>
2480     <code class="literal">LIBFOO_SITE=/opt/software/libfoo.tar.gz</code>
2481     <code class="literal">LIBFOO_SITE=$(TOPDIR)/../src/libfoo/</code>
2482 </li><li class="listitem">
2483 <code class="literal">LIBFOO_EXTRA_DOWNLOADS</code> is a space-separated list of additional
2484   files that Buildroot should download. If an entry contains <code class="literal">://</code>
2485   then Buildroot will assume it is a complete URL and will download
2486   the file using this URL. Otherwise, Buildroot will assume the file
2487   to be downloaded is located at <code class="literal">LIBFOO_SITE</code>. Buildroot will not do
2488   anything with those additional files, except download them: it will
2489   be up to the package recipe to use them from <code class="literal">$(BR2_DL_DIR)</code>.
2490 </li><li class="listitem"><p class="simpara">
2491 <code class="literal">LIBFOO_SITE_METHOD</code> determines the method used to fetch or copy the
2492   package source code. In many cases, Buildroot guesses the method
2493   from the contents of <code class="literal">LIBFOO_SITE</code> and setting <code class="literal">LIBFOO_SITE_METHOD</code>
2494   is unnecessary. When <code class="literal">HOST_LIBFOO_SITE_METHOD</code> is not specified, it
2495   defaults to the value of <code class="literal">LIBFOO_SITE_METHOD</code>.
2496   The possible values of <code class="literal">LIBFOO_SITE_METHOD</code> are:
2497 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2498 <code class="literal">wget</code> for normal FTP/HTTP downloads of tarballs. Used by
2499      default when <code class="literal">LIBFOO_SITE</code> begins with <code class="literal">http://</code>, <code class="literal">https://</code> or
2500      <code class="literal">ftp://</code>.
2501 </li><li class="listitem">
2502 <code class="literal">scp</code> for downloads of tarballs over SSH with scp. Used by
2503      default when <code class="literal">LIBFOO_SITE</code> begins with <code class="literal">scp://</code>.
2504 </li><li class="listitem">
2505 <code class="literal">svn</code> for retrieving source code from a Subversion repository.
2506      Used by default when <code class="literal">LIBFOO_SITE</code> begins with <code class="literal">svn://</code>. When a
2507      <code class="literal">http://</code> Subversion repository URL is specified in
2508      <code class="literal">LIBFOO_SITE</code>, one <span class="emphasis"><em>must</em></span> specify <code class="literal">LIBFOO_SITE_METHOD=svn</code>.
2509      Buildroot performs a checkout which is preserved as a tarball in
2510      the download cache; subsequent builds use the tarball instead of
2511      performing another checkout.
2512 </li><li class="listitem">
2513 <code class="literal">cvs</code> for retrieving source code from a CVS repository.
2514      Used by default when <code class="literal">LIBFOO_SITE</code> begins with <code class="literal">cvs://</code>.
2515      The downloaded source code is cached as with the <code class="literal">svn</code> method.
2516      Only anonymous pserver mode is supported.
2517      <code class="literal">LIBFOO_SITE</code> <span class="emphasis"><em>must</em></span> contain the source URL as well as the remote
2518      repository directory. The module is the package name.
2519      <code class="literal">LIBFOO_VERSION</code> is <span class="emphasis"><em>mandatory</em></span> and <span class="emphasis"><em>must</em></span> be a timestamp.
2520 </li><li class="listitem">
2521 <code class="literal">git</code> for retrieving source code from a Git repository. Used by
2522      default when <code class="literal">LIBFOO_SITE</code> begins with <code class="literal">git://</code>. The downloaded
2523      source code is cached as with the <code class="literal">svn</code>
2524      method.
2525 </li><li class="listitem">
2526 <code class="literal">hg</code> for retrieving source code from a Mercurial repository. One
2527      <span class="emphasis"><em>must</em></span> specify <code class="literal">LIBFOO_SITE_METHOD=hg</code> when <code class="literal">LIBFOO_SITE</code>
2528      contains a Mercurial repository URL. The downloaded source code
2529      is cached as with the <code class="literal">svn</code> method.
2530 </li><li class="listitem">
2531 <code class="literal">bzr</code> for retrieving source code from a Bazaar repository. Used
2532      by default when <code class="literal">LIBFOO_SITE</code> begins with <code class="literal">bzr://</code>. The
2533      downloaded source code is cached as with the <code class="literal">svn</code> method.
2534 </li><li class="listitem">
2535 <code class="literal">file</code> for a local tarball. One should use this when
2536      <code class="literal">LIBFOO_SITE</code> specifies a package tarball as a local filename.
2537      Useful for software that isn’t available publicly or in version
2538      control.
2539 </li><li class="listitem">
2540 <code class="literal">local</code> for a local source code directory. One should use this
2541      when <code class="literal">LIBFOO_SITE</code> specifies a local directory path containing
2542      the package source code. Buildroot copies the contents of the
2543      source directory into the package’s build directory.
2544 </li></ul></div></li><li class="listitem">
2545 <code class="literal">LIBFOO_DEPENDENCIES</code> lists the dependencies (in terms of package
2546   name) that are required for the current target package to
2547   compile. These dependencies are guaranteed to be compiled and
2548   installed before the configuration of the current package starts. In
2549   a similar way, <code class="literal">HOST_LIBFOO_DEPENDENCIES</code> lists the dependencies for
2550   the current host package.
2551 </li><li class="listitem">
2552 <code class="literal">LIBFOO_PATCH_DEPENDENCIES</code> lists the dependencies (in terms of
2553   package name) that are required for the current package to be
2554   patched. These dependencies are guaranteed to be extracted and
2555   patched before the current package is patched. In a similar way,
2556   <code class="literal">HOST_LIBFOO_PATCH_DEPENDENCIES</code> lists the dependencies for the
2557   current host package.
2558   This is seldom used; usually, <code class="literal">LIBFOO_DEPENDENCIES</code> is what you
2559   really want to use.
2560 </li><li class="listitem">
2561 <code class="literal">LIBFOO_PROVIDES</code> lists all the virtual packages <code class="literal">libfoo</code> is an
2562   implementation of. See <a class="xref" href="#virtual-package-tutorial">Section 17.11, “Infrastructure for virtual packages”</a>.
2563 </li><li class="listitem">
2564 <code class="literal">LIBFOO_INSTALL_STAGING</code> can be set to <code class="literal">YES</code> or <code class="literal">NO</code> (default). If
2565   set to <code class="literal">YES</code>, then the commands in the <code class="literal">LIBFOO_INSTALL_STAGING_CMDS</code>
2566   variables are executed to install the package into the staging
2567   directory.
2568 </li><li class="listitem">
2569 <code class="literal">LIBFOO_INSTALL_TARGET</code> can be set to <code class="literal">YES</code> (default) or <code class="literal">NO</code>. If
2570   set to <code class="literal">YES</code>, then the commands in the <code class="literal">LIBFOO_INSTALL_TARGET_CMDS</code>
2571   variables are executed to install the package into the target
2572   directory.
2573 </li><li class="listitem">
2574 <code class="literal">LIBFOO_INSTALL_IMAGES</code> can be set to <code class="literal">YES</code> or <code class="literal">NO</code> (default). If
2575   set to <code class="literal">YES</code>, then the commands in the <code class="literal">LIBFOO_INSTALL_IMAGES_CMDS</code>
2576   variable are executed to install the package into the images
2577   directory.
2578 </li><li class="listitem">
2579 <code class="literal">LIBFOO_CONFIG_SCRIPTS</code> lists the names of the files in
2580   <span class="emphasis"><em>$(STAGING_DIR)/usr/bin</em></span> that need some special fixing to make them
2581   cross-compiling friendly. Multiple file names separated by space can
2582   be given and all are relative to <span class="emphasis"><em>$(STAGING_DIR)/usr/bin</em></span>. The files
2583   listed in <code class="literal">LIBFOO_CONFIG_SCRIPTS</code> are also removed from
2584   <code class="literal">$(TARGET_DIR)/usr/bin</code> since they are not needed on the target.
2585 </li><li class="listitem">
2586 <code class="literal">LIBFOO_DEVICES</code> lists the device files to be created by Buildroot
2587   when using the static device table. The syntax to use is the
2588   makedevs one. You can find some documentation for this syntax in the
2589   <a class="xref" href="#makedev-syntax" title="Chapter 22. Makedev syntax documentation">Chapter 22, <em>Makedev syntax documentation</em></a>. This variable is optional.
2590 </li><li class="listitem">
2591 <code class="literal">LIBFOO_PERMISSIONS</code> lists the changes of permissions to be done at
2592   the end of the build process. The syntax is once again the makedevs one.
2593   You can find some documentation for this syntax in the <a class="xref" href="#makedev-syntax" title="Chapter 22. Makedev syntax documentation">Chapter 22, <em>Makedev syntax documentation</em></a>.
2594   This variable is optional.
2595 </li><li class="listitem">
2596 <code class="literal">LIBFOO_USERS</code> lists the users to create for this package, if it installs
2597   a program you want to run as a specific user (e.g. as a daemon, or as a
2598   cron-job). The syntax is similar in spirit to the makedevs one, and is
2599   described in the <a class="xref" href="#makeuser-syntax" title="Chapter 23. Makeusers syntax documentation">Chapter 23, <em>Makeusers syntax documentation</em></a>. This variable is optional.
2600 </li><li class="listitem">
2601 <code class="literal">LIBFOO_LICENSE</code> defines the license (or licenses) under which the package
2602   is released.
2603   This name will appear in the manifest file produced by <code class="literal">make legal-info</code>.
2604   If the license appears in <a class="link" href="#legal-info-list-licenses" title="12.2. License abbreviations">the following list</a>
2605 <a class="xref" href="#legal-info-list-licenses" title="12.2. License abbreviations">Section 12.2, “License abbreviations”</a>,
2606   use the same string to make the manifest file uniform.
2607   Otherwise, describe the license in a precise and concise way, avoiding
2608   ambiguous names such as <code class="literal">BSD</code> which actually name a family of licenses.
2609   This variable is optional. If it is not defined, <code class="literal">unknown</code> will appear in
2610   the <code class="literal">license</code> field of the manifest file for this package.
2611 </li><li class="listitem">
2612 <code class="literal">LIBFOO_LICENSE_FILES</code> is a space-separated list of files in the package
2613   tarball that contain the license(s) under which the package is released.
2614   <code class="literal">make legal-info</code> copies all of these files in the <code class="literal">legal-info</code> directory.
2615   See <a class="xref" href="#legal-info" title="Chapter 12. Legal notice and licensing">Chapter 12, <em>Legal notice and licensing</em></a> for more information.
2616   This variable is optional. If it is not defined, a warning will be produced
2617   to let you know, and <code class="literal">not saved</code> will appear in the <code class="literal">license files</code> field
2618   of the manifest file for this package.
2619 </li><li class="listitem">
2620 <code class="literal">LIBFOO_REDISTRIBUTE</code> can be set to <code class="literal">YES</code> (default) or <code class="literal">NO</code> to indicate if
2621   the package source code is allowed to be redistributed. Set it to <code class="literal">NO</code> for
2622   non-opensource packages: Buildroot will not save the source code for this
2623   package when collecting the <code class="literal">legal-info</code>.
2624 </li><li class="listitem">
2625 <code class="literal">LIBFOO_FLAT_STACKSIZE</code> defines the stack size of an application built into
2626   the FLAT binary format. The application stack size on the NOMMU architecture
2627   processors can’t be enlarged at run time. The default stack size for the
2628   FLAT binary format is only 4k bytes. If the application consumes more stack,
2629   append the required number here.
2630 </li></ul></div><p>The recommended way to define these variables is to use the following
2631 syntax:</p><pre class="screen">LIBFOO_VERSION = 2.32</pre><p>Now, the variables that define what should be performed at the
2632 different steps of the build process.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2633 <code class="literal">LIBFOO_EXTRACT_CMDS</code> lists the actions to be performed to extract
2634   the package. This is generally not needed as tarballs are
2635   automatically handled by Buildroot. However, if the package uses a
2636   non-standard archive format, such as a ZIP or RAR file, or has a
2637   tarball with a non-standard organization, this variable allows to
2638   override the package infrastructure default behavior.
2639 </li><li class="listitem">
2640 <code class="literal">LIBFOO_CONFIGURE_CMDS</code> lists the actions to be performed to
2641   configure the package before its compilation.
2642 </li><li class="listitem">
2643 <code class="literal">LIBFOO_BUILD_CMDS</code> lists the actions to be performed to
2644   compile the package.
2645 </li><li class="listitem">
2646 <code class="literal">HOST_LIBFOO_INSTALL_CMDS</code> lists the actions to be performed
2647   to install the package, when the package is a host package. The
2648   package must install its files to the directory given by
2649   <code class="literal">$(HOST_DIR)</code>. All files, including development files such as
2650   headers should be installed, since other packages might be compiled
2651   on top of this package.
2652 </li><li class="listitem">
2653 <code class="literal">LIBFOO_INSTALL_TARGET_CMDS</code> lists the actions to be
2654   performed to install the package to the target directory, when the
2655   package is a target package. The package must install its files to
2656   the directory given by <code class="literal">$(TARGET_DIR)</code>. Only the files required for
2657   <span class="emphasis"><em>execution</em></span> of the package have to be
2658   installed. Header files, static libraries and documentation will be
2659   removed again when the target filesystem is finalized.
2660 </li><li class="listitem">
2661 <code class="literal">LIBFOO_INSTALL_STAGING_CMDS</code> lists the actions to be
2662   performed to install the package to the staging directory, when the
2663   package is a target package. The package must install its files to
2664   the directory given by <code class="literal">$(STAGING_DIR)</code>. All development files
2665   should be installed, since they might be needed to compile other
2666   packages.
2667 </li><li class="listitem">
2668 <code class="literal">LIBFOO_INSTALL_IMAGES_CMDS</code> lists the actions to be performed to
2669   install the package to the images directory, when the package is a
2670   target package. The package must install its files to the directory
2671   given by <code class="literal">$(BINARIES_DIR)</code>. Only files that are binary images (aka
2672   images) that do not belong in the <code class="literal">TARGET_DIR</code> but are necessary
2673   for booting the board should be placed here. For example, a package
2674   should utilize this step if it has binaries which would be similar
2675   to the kernel image, bootloader or root filesystem images.
2676 </li><li class="listitem">
2677 <code class="literal">LIBFOO_INSTALL_INIT_SYSV</code> and <code class="literal">LIBFOO_INSTALL_INIT_SYSTEMD</code> list the
2678   actions to install init scripts either for the systemV-like init systems
2679   (busybox, sysvinit, etc.) or for the systemd units. These commands
2680   will be run only when the relevant init system is installed (i.e. if
2681   systemd is selected as the init system in the configuration, only
2682   <code class="literal">LIBFOO_INSTALL_INIT_SYSTEMD</code> will be run).
2683 </li></ul></div><p>The preferred way to define these variables is:</p><pre class="screen">define LIBFOO_CONFIGURE_CMDS
2684         action 1
2685         action 2
2686         action 3
2687 endef</pre><p>In the action definitions, you can use the following variables:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2688 <code class="literal">$(@D)</code>, which contains the directory in which the package source
2689   code has been uncompressed.
2690 </li><li class="listitem">
2691 <code class="literal">$(TARGET_CC)</code>, <code class="literal">$(TARGET_LD)</code>, etc. to get the target
2692   cross-compilation utilities
2693 </li><li class="listitem">
2694 <code class="literal">$(TARGET_CROSS)</code> to get the cross-compilation toolchain prefix
2695 </li><li class="listitem">
2696 Of course the <code class="literal">$(HOST_DIR)</code>, <code class="literal">$(STAGING_DIR)</code> and <code class="literal">$(TARGET_DIR)</code>
2697   variables to install the packages properly.
2698 </li></ul></div><p>Finally, you can also use hooks. See <a class="xref" href="#hooks" title="17.15. Hooks available in the various build steps">Section 17.15, “Hooks available in the various build steps”</a> for more information.</p></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_autotools_based_packages"></a>17.6. Infrastructure for autotools-based packages</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="autotools-package-tutorial"></a>17.6.1. <code class="literal">autotools-package</code> tutorial</h3></div></div></div><p>First, let’s see how to write a <code class="literal">.mk</code> file for an autotools-based
2699 package, with an example :</p><pre class="screen">01: ################################################################################
2700 02: #
2701 03: # libfoo
2702 04: #
2703 05: ################################################################################
2704 06:
2705 07: LIBFOO_VERSION = 1.0
2706 08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz
2707 09: LIBFOO_SITE = http://www.foosoftware.org/download
2708 10: LIBFOO_INSTALL_STAGING = YES
2709 11: LIBFOO_INSTALL_TARGET = NO
2710 12: LIBFOO_CONF_OPTS = --disable-shared
2711 13: LIBFOO_DEPENDENCIES = libglib2 host-pkgconf
2712 14:
2713 15: $(eval $(autotools-package))</pre><p>On line 7, we declare the version of the package.</p><p>On line 8 and 9, we declare the name of the tarball (xz-ed tarball recommended)
2714 and the location of the tarball on the Web. Buildroot will automatically
2715 download the tarball from this location.</p><p>On line 10, we tell Buildroot to install the package to the staging
2716 directory. The staging directory, located in <code class="literal">output/staging/</code>
2717 is the directory where all the packages are installed, including their
2718 development files, etc. By default, packages are not installed to the
2719 staging directory, since usually, only libraries need to be installed in
2720 the staging directory: their development files are needed to compile
2721 other libraries or applications depending on them. Also by default, when
2722 staging installation is enabled, packages are installed in this location
2723 using the <code class="literal">make install</code> command.</p><p>On line 11, we tell Buildroot to not install the package to the
2724 target directory. This directory contains what will become the root
2725 filesystem running on the target. For purely static libraries, it is
2726 not necessary to install them in the target directory because they will
2727 not be used at runtime. By default, target installation is enabled; setting
2728 this variable to NO is almost never needed. Also by default, packages are
2729 installed in this location using the <code class="literal">make install</code> command.</p><p>On line 12, we tell Buildroot to pass a custom configure option, that
2730 will be passed to the <code class="literal">./configure</code> script before configuring
2731 and building the package.</p><p>On line 13, we declare our dependencies, so that they are built
2732 before the build process of our package starts.</p><p>Finally, on line line 15, we invoke the <code class="literal">autotools-package</code>
2733 macro that generates all the Makefile rules that actually allows the
2734 package to be built.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="autotools-package-reference"></a>17.6.2. <code class="literal">autotools-package</code> reference</h3></div></div></div><p>The main macro of the autotools package infrastructure is
2735 <code class="literal">autotools-package</code>. It is similar to the <code class="literal">generic-package</code> macro. The ability to
2736 have target and host packages is also available, with the
2737 <code class="literal">host-autotools-package</code> macro.</p><p>Just like the generic infrastructure, the autotools infrastructure
2738 works by defining a number of variables before calling the
2739 <code class="literal">autotools-package</code> macro.</p><p>First, all the package metadata information variables that exist in the
2740 generic infrastructure also exist in the autotools infrastructure:
2741 <code class="literal">LIBFOO_VERSION</code>, <code class="literal">LIBFOO_SOURCE</code>,
2742 <code class="literal">LIBFOO_PATCH</code>, <code class="literal">LIBFOO_SITE</code>,
2743 <code class="literal">LIBFOO_SUBDIR</code>, <code class="literal">LIBFOO_DEPENDENCIES</code>,
2744 <code class="literal">LIBFOO_INSTALL_STAGING</code>, <code class="literal">LIBFOO_INSTALL_TARGET</code>.</p><p>A few additional variables, specific to the autotools infrastructure,
2745 can also be defined. Many of them are only useful in very specific
2746 cases, typical packages will therefore only use a few of them.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2747 <code class="literal">LIBFOO_SUBDIR</code> may contain the name of a subdirectory
2748   inside the package that contains the configure script. This is useful,
2749   if for example, the main configure script is not at the root of the
2750   tree extracted by the tarball. If <code class="literal">HOST_LIBFOO_SUBDIR</code> is
2751   not specified, it defaults to <code class="literal">LIBFOO_SUBDIR</code>.
2752 </li><li class="listitem">
2753 <code class="literal">LIBFOO_CONF_ENV</code>, to specify additional environment
2754   variables to pass to the configure script. By default, empty.
2755 </li><li class="listitem">
2756 <code class="literal">LIBFOO_CONF_OPTS</code>, to specify additional configure
2757   options to pass to the configure script. By default, empty.
2758 </li><li class="listitem">
2759 <code class="literal">LIBFOO_MAKE</code>, to specify an alternate <code class="literal">make</code>
2760   command. This is typically useful when parallel make is enabled in
2761   the configuration (using <code class="literal">BR2_JLEVEL</code>) but that this
2762   feature should be disabled for the given package, for one reason or
2763   another. By default, set to <code class="literal">$(MAKE)</code>. If parallel building
2764   is not supported by the package, then it should be set to
2765   <code class="literal">LIBFOO_MAKE=$(MAKE1)</code>.
2766 </li><li class="listitem">
2767 <code class="literal">LIBFOO_MAKE_ENV</code>, to specify additional environment
2768   variables to pass to make in the build step. These are passed before
2769   the <code class="literal">make</code> command. By default, empty.
2770 </li><li class="listitem">
2771 <code class="literal">LIBFOO_MAKE_OPTS</code>, to specify additional variables to
2772   pass to make in the build step. These are passed after the
2773   <code class="literal">make</code> command. By default, empty.
2774 </li><li class="listitem">
2775 <code class="literal">LIBFOO_AUTORECONF</code>, tells whether the package should
2776   be autoreconfigured or not (i.e. if the configure script and
2777   Makefile.in files should be re-generated by re-running autoconf,
2778   automake, libtool, etc.). Valid values are <code class="literal">YES</code> and
2779   <code class="literal">NO</code>. By default, the value is <code class="literal">NO</code>
2780 </li><li class="listitem">
2781 <code class="literal">LIBFOO_AUTORECONF_ENV</code>, to specify additional environment
2782   variables to pass to the <span class="emphasis"><em>autoreconf</em></span> program if
2783   <code class="literal">LIBFOO_AUTORECONF=YES</code>. These are passed in the environment of
2784   the <span class="emphasis"><em>autoreconf</em></span> command. By default, empty.
2785 </li><li class="listitem">
2786 <code class="literal">LIBFOO_AUTORECONF_OPTS</code> to specify additional options
2787   passed to the <span class="emphasis"><em>autoreconf</em></span> program if
2788   <code class="literal">LIBFOO_AUTORECONF=YES</code>. By default, empty.
2789 </li><li class="listitem">
2790 <code class="literal">LIBFOO_GETTEXTIZE</code>, tells whether the package should be
2791   gettextized or not (i.e. if the package uses a different gettext
2792   version than Buildroot provides, and it is needed to run
2793   <span class="emphasis"><em>gettextize</em></span>.) Only valid when <code class="literal">LIBFOO_AUTORECONF=YES</code>. Valid
2794   values are <code class="literal">YES</code> and <code class="literal">NO</code>. The default is <code class="literal">NO</code>.
2795 </li><li class="listitem">
2796 <code class="literal">LIBFOO_GETTEXTIZE_OPTS</code>, to specify additional options passed to
2797   the <span class="emphasis"><em>gettextize</em></span> program, if <code class="literal">LIBFOO_GETTEXTIZE=YES</code>. You may
2798   use that if, for example, the <code class="literal">.po</code> files are not located in the
2799   standard place (i.e. in <code class="literal">po/</code> at the root of the package.) By
2800   default, <span class="emphasis"><em>-f</em></span>.
2801 </li><li class="listitem">
2802 <code class="literal">LIBFOO_LIBTOOL_PATCH</code> tells whether the Buildroot
2803   patch to fix libtool cross-compilation issues should be applied or
2804   not. Valid values are <code class="literal">YES</code> and <code class="literal">NO</code>. By
2805   default, the value is <code class="literal">YES</code>
2806 </li><li class="listitem">
2807 <code class="literal">LIBFOO_INSTALL_STAGING_OPTS</code> contains the make options
2808   used to install the package to the staging directory. By default, the
2809   value is <code class="literal">DESTDIR=$(STAGING_DIR) install</code>, which is
2810   correct for most autotools packages. It is still possible to override
2811   it.
2812 </li><li class="listitem">
2813 <code class="literal">LIBFOO_INSTALL_TARGET_OPTS</code> contains the make options
2814   used to install the package to the target directory. By default, the
2815   value is <code class="literal">DESTDIR=$(TARGET_DIR) install</code>. The default
2816   value is correct for most autotools packages, but it is still possible
2817   to override it if needed.
2818 </li></ul></div><p>With the autotools infrastructure, all the steps required to build
2819 and install the packages are already defined, and they generally work
2820 well for most autotools-based packages. However, when required, it is
2821 still possible to customize what is done in any particular step:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2822 By adding a post-operation hook (after extract, patch, configure,
2823   build or install). See <a class="xref" href="#hooks" title="17.15. Hooks available in the various build steps">Section 17.15, “Hooks available in the various build steps”</a> for details.
2824 </li><li class="listitem">
2825 By overriding one of the steps. For example, even if the autotools
2826   infrastructure is used, if the package <code class="literal">.mk</code> file defines its
2827   own <code class="literal">LIBFOO_CONFIGURE_CMDS</code> variable, it will be used
2828   instead of the default autotools one. However, using this method
2829   should be restricted to very specific cases. Do not use it in the
2830   general case.
2831 </li></ul></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_cmake_based_packages"></a>17.7. Infrastructure for CMake-based packages</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="cmake-package-tutorial"></a>17.7.1. <code class="literal">cmake-package</code> tutorial</h3></div></div></div><p>First, let’s see how to write a <code class="literal">.mk</code> file for a CMake-based package,
2832 with an example :</p><pre class="screen">01: ################################################################################
2833 02: #
2834 03: # libfoo
2835 04: #
2836 05: ################################################################################
2837 06:
2838 07: LIBFOO_VERSION = 1.0
2839 08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz
2840 09: LIBFOO_SITE = http://www.foosoftware.org/download
2841 10: LIBFOO_INSTALL_STAGING = YES
2842 11: LIBFOO_INSTALL_TARGET = NO
2843 12: LIBFOO_CONF_OPTS = -DBUILD_DEMOS=ON
2844 13: LIBFOO_DEPENDENCIES = libglib2 host-pkgconf
2845 14:
2846 15: $(eval $(cmake-package))</pre><p>On line 7, we declare the version of the package.</p><p>On line 8 and 9, we declare the name of the tarball (xz-ed tarball recommended)
2847 and the location of the tarball on the Web. Buildroot will automatically
2848 download the tarball from this location.</p><p>On line 10, we tell Buildroot to install the package to the staging
2849 directory. The staging directory, located in <code class="literal">output/staging/</code>
2850 is the directory where all the packages are installed, including their
2851 development files, etc. By default, packages are not installed to the
2852 staging directory, since usually, only libraries need to be installed in
2853 the staging directory: their development files are needed to compile
2854 other libraries or applications depending on them. Also by default, when
2855 staging installation is enabled, packages are installed in this location
2856 using the <code class="literal">make install</code> command.</p><p>On line 11, we tell Buildroot to not install the package to the
2857 target directory. This directory contains what will become the root
2858 filesystem running on the target. For purely static libraries, it is
2859 not necessary to install them in the target directory because they will
2860 not be used at runtime. By default, target installation is enabled; setting
2861 this variable to NO is almost never needed. Also by default, packages are
2862 installed in this location using the <code class="literal">make install</code> command.</p><p>On line 12, we tell Buildroot to pass custom options to CMake when it is
2863 configuring the package.</p><p>On line 13, we declare our dependencies, so that they are built
2864 before the build process of our package starts.</p><p>Finally, on line line 15, we invoke the <code class="literal">cmake-package</code>
2865 macro that generates all the Makefile rules that actually allows the
2866 package to be built.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="cmake-package-reference"></a>17.7.2. <code class="literal">cmake-package</code> reference</h3></div></div></div><p>The main macro of the CMake package infrastructure is
2867 <code class="literal">cmake-package</code>. It is similar to the <code class="literal">generic-package</code> macro. The ability to
2868 have target and host packages is also available, with the
2869 <code class="literal">host-cmake-package</code> macro.</p><p>Just like the generic infrastructure, the CMake infrastructure works
2870 by defining a number of variables before calling the <code class="literal">cmake-package</code>
2871 macro.</p><p>First, all the package metadata information variables that exist in
2872 the generic infrastructure also exist in the CMake infrastructure:
2873 <code class="literal">LIBFOO_VERSION</code>, <code class="literal">LIBFOO_SOURCE</code>, <code class="literal">LIBFOO_PATCH</code>, <code class="literal">LIBFOO_SITE</code>,
2874 <code class="literal">LIBFOO_SUBDIR</code>, <code class="literal">LIBFOO_DEPENDENCIES</code>, <code class="literal">LIBFOO_INSTALL_STAGING</code>,
2875 <code class="literal">LIBFOO_INSTALL_TARGET</code>.</p><p>A few additional variables, specific to the CMake infrastructure, can
2876 also be defined. Many of them are only useful in very specific cases,
2877 typical packages will therefore only use a few of them.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2878 <code class="literal">LIBFOO_SUBDIR</code> may contain the name of a subdirectory inside the
2879   package that contains the main CMakeLists.txt file. This is useful,
2880   if for example, the main CMakeLists.txt file is not at the root of
2881   the tree extracted by the tarball. If <code class="literal">HOST_LIBFOO_SUBDIR</code> is not
2882   specified, it defaults to <code class="literal">LIBFOO_SUBDIR</code>.
2883 </li><li class="listitem">
2884 <code class="literal">LIBFOO_CONF_ENV</code>, to specify additional environment variables to
2885   pass to CMake. By default, empty.
2886 </li><li class="listitem"><p class="simpara">
2887 <code class="literal">LIBFOO_CONF_OPTS</code>, to specify additional configure options to pass
2888   to CMake. By default, empty. A number of common CMake options are
2889   set by the <code class="literal">cmake-package</code> infrastructure; so it is normally not
2890   necessary to set them in the package’s <code class="literal">*.mk</code> file unless you want
2891   to override them:
2892 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
2893 <code class="literal">CMAKE_BUILD_TYPE</code> is driven by <code class="literal">BR2_ENABLE_DEBUG</code>;
2894 </li><li class="listitem">
2895 <code class="literal">CMAKE_INSTALL_PREFIX</code>;
2896 </li><li class="listitem">
2897 <code class="literal">BUILD_SHARED_LIBS</code> is driven by <code class="literal">BR2_STATIC_LIBS</code>;
2898 </li><li class="listitem">
2899 <code class="literal">BUILD_DOC</code>, <code class="literal">BUILD_DOCS</code> are disabled;
2900 </li><li class="listitem">
2901 <code class="literal">BUILD_EXAMPLE</code>, <code class="literal">BUILD_EXAMPLES</code> are disabled;
2902 </li><li class="listitem">
2903 <code class="literal">BUILD_TEST</code>, <code class="literal">BUILD_TESTS</code>, <code class="literal">BUILD_TESTING</code> are disabled.
2904 </li></ul></div></li><li class="listitem">
2905 <code class="literal">LIBFOO_SUPPORTS_IN_SOURCE_BUILD = NO</code> should be set when the package
2906   cannot be built inside the source tree but needs a separate build
2907   directory.
2908 </li><li class="listitem">
2909 <code class="literal">LIBFOO_MAKE</code>, to specify an alternate <code class="literal">make</code> command. This is
2910   typically useful when parallel make is enabled in the configuration
2911   (using <code class="literal">BR2_JLEVEL</code>) but that this feature should be disabled for
2912   the given package, for one reason or another. By default, set to
2913   <code class="literal">$(MAKE)</code>. If parallel building is not supported by the package,
2914   then it should be set to <code class="literal">LIBFOO_MAKE=$(MAKE1)</code>.
2915 </li><li class="listitem">
2916 <code class="literal">LIBFOO_MAKE_ENV</code>, to specify additional environment variables to
2917   pass to make in the build step. These are passed before the <code class="literal">make</code>
2918   command. By default, empty.
2919 </li><li class="listitem">
2920 <code class="literal">LIBFOO_MAKE_OPTS</code>, to specify additional variables to pass to make
2921   in the build step. These are passed after the <code class="literal">make</code> command. By
2922   default, empty.
2923 </li><li class="listitem">
2924 <code class="literal">LIBFOO_INSTALL_STAGING_OPTS</code> contains the make options used to
2925   install the package to the staging directory. By default, the value
2926   is <code class="literal">DESTDIR=$(STAGING_DIR) install</code>, which is correct for most
2927   CMake packages. It is still possible to override it.
2928 </li><li class="listitem">
2929 <code class="literal">LIBFOO_INSTALL_TARGET_OPTS</code> contains the make options used to
2930   install the package to the target directory. By default, the value
2931   is <code class="literal">DESTDIR=$(TARGET_DIR) install</code>. The default value is correct
2932   for most CMake packages, but it is still possible to override it if
2933   needed.
2934 </li></ul></div><p>With the CMake infrastructure, all the steps required to build and
2935 install the packages are already defined, and they generally work well
2936 for most CMake-based packages. However, when required, it is still
2937 possible to customize what is done in any particular step:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2938 By adding a post-operation hook (after extract, patch, configure,
2939   build or install). See <a class="xref" href="#hooks" title="17.15. Hooks available in the various build steps">Section 17.15, “Hooks available in the various build steps”</a> for details.
2940 </li><li class="listitem">
2941 By overriding one of the steps. For example, even if the CMake
2942   infrastructure is used, if the package <code class="literal">.mk</code> file defines its own
2943   <code class="literal">LIBFOO_CONFIGURE_CMDS</code> variable, it will be used instead of the
2944   default CMake one. However, using this method should be restricted
2945   to very specific cases. Do not use it in the general case.
2946 </li></ul></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_python_packages"></a>17.8. Infrastructure for Python packages</h2></div></div></div><p>This infrastructure applies to Python packages that use the standard
2947 Python setuptools mechanism as their build system, generally
2948 recognizable by the usage of a <code class="literal">setup.py</code> script.</p><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="python-package-tutorial"></a>17.8.1. <code class="literal">python-package</code> tutorial</h3></div></div></div><p>First, let’s see how to write a <code class="literal">.mk</code> file for a Python package,
2949 with an example :</p><pre class="screen">01: ################################################################################
2950 02: #
2951 03: # python-foo
2952 04: #
2953 05: ################################################################################
2954 06:
2955 07: PYTHON_FOO_VERSION = 1.0
2956 08: PYTHON_FOO_SOURCE = python-foo-$(PYTHON_FOO_VERSION).tar.xz
2957 09: PYTHON_FOO_SITE = http://www.foosoftware.org/download
2958 10: PYTHON_FOO_LICENSE = BSD-3c
2959 11: PYTHON_FOO_LICENSE_FILES = LICENSE
2960 12: PYTHON_FOO_ENV = SOME_VAR=1
2961 13: PYTHON_FOO_DEPENDENCIES = libmad
2962 14: PYTHON_FOO_SETUP_TYPE = distutils
2963 15:
2964 16: $(eval $(python-package))</pre><p>On line 7, we declare the version of the package.</p><p>On line 8 and 9, we declare the name of the tarball (xz-ed tarball
2965 recommended) and the location of the tarball on the Web. Buildroot
2966 will automatically download the tarball from this location.</p><p>On line 10 and 11, we give licensing details about the package (its
2967 license on line 10, and the file containing the license text on line
2968 11).</p><p>On line 12, we tell Buildroot to pass custom options to the Python
2969 <code class="literal">setup.py</code> script when it is configuring the package.</p><p>On line 13, we declare our dependencies, so that they are built
2970 before the build process of our package starts.</p><p>On line 14, we declare the specific Python build system being used. In
2971 this case the <code class="literal">distutils</code> Python build system is used. The two
2972 supported ones are <code class="literal">distutils</code> and <code class="literal">setuptools</code>.</p><p>Finally, on line 16, we invoke the <code class="literal">python-package</code> macro that
2973 generates all the Makefile rules that actually allow the package to be
2974 built.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="python-package-reference"></a>17.8.2. <code class="literal">python-package</code> reference</h3></div></div></div><p>As a policy, packages that merely provide Python modules should all be
2975 named <code class="literal">python-&lt;something&gt;</code> in Buildroot. Other packages that use the
2976 Python build system, but are not Python modules, can freely choose
2977 their name (existing examples in Buildroot are <code class="literal">scons</code> and
2978 <code class="literal">supervisor</code>).</p><p>In their <code class="literal">Config.in</code> file, they should depend on <code class="literal">BR2_PACKAGE_PYTHON</code>
2979 so that when Buildroot will enable Python 3 usage for modules, we will
2980 be able to enable Python modules progressively on Python 3.</p><p>The main macro of the Python package infrastructure is
2981 <code class="literal">python-package</code>. It is similar to the <code class="literal">generic-package</code> macro. It is
2982 also possible to create Python host packages with the
2983 <code class="literal">host-python-package</code> macro.</p><p>Just like the generic infrastructure, the Python infrastructure works
2984 by defining a number of variables before calling the <code class="literal">python-package</code>
2985 or <code class="literal">host-python-package</code> macros.</p><p>All the package metadata information variables that exist in the
2986 <a class="link" href="#generic-package-reference" title="17.5.2. generic-package reference">generic package infrastructure</a>
2987 <a class="xref" href="#generic-package-reference" title="17.5.2. generic-package reference">Section 17.5.2, “<code class="literal">generic-package</code> reference”</a> also
2988 exist in the Python infrastructure: <code class="literal">PYTHON_FOO_VERSION</code>,
2989 <code class="literal">PYTHON_FOO_SOURCE</code>, <code class="literal">PYTHON_FOO_PATCH</code>, <code class="literal">PYTHON_FOO_SITE</code>,
2990 <code class="literal">PYTHON_FOO_SUBDIR</code>, <code class="literal">PYTHON_FOO_DEPENDENCIES</code>, <code class="literal">PYTHON_FOO_LICENSE</code>,
2991 <code class="literal">PYTHON_FOO_LICENSE_FILES</code>, <code class="literal">PYTHON_FOO_INSTALL_STAGING</code>, etc.</p><p>Note that:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
2992 It is not necessary to add <code class="literal">python</code> or <code class="literal">host-python</code> in the
2993    <code class="literal">PYTHON_FOO_DEPENDENCIES</code> variable of a package, since these basic
2994    dependencies are automatically added as needed by the Python
2995    package infrastructure.
2996 </li><li class="listitem">
2997 Similarly, it is not needed to add <code class="literal">host-setuptools</code> and/or
2998    <code class="literal">host-distutilscross</code> dependencies to <code class="literal">PYTHON_FOO_DEPENDENCIES</code> for
2999    setuptools-based packages, since these are automatically added by
3000    the Python infrastructure as needed.
3001 </li></ul></div><p>One variable specific to the Python infrastructure is mandatory:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3002 <code class="literal">PYTHON_FOO_SETUP_TYPE</code>, to define which Python build system is used
3003   by the package. The two supported values are <code class="literal">distutils</code> and
3004   <code class="literal">setuptools</code>. If you don’t know which one is used in your package,
3005   look at the <code class="literal">setup.py</code> file in your package source code, and see
3006   whether it imports things from the <code class="literal">distutils</code> module or the
3007   <code class="literal">setuptools</code> module.
3008 </li></ul></div><p>A few additional variables, specific to the Python infrastructure, can
3009 optionally be defined, depending on the package’s needs. Many of them
3010 are only useful in very specific cases, typical packages will
3011 therefore only use a few of them, or none.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3012 <code class="literal">PYTHON_FOO_ENV</code>, to specify additional environment variables to
3013   pass to the Python <code class="literal">setup.py</code> script (for both the build and install
3014   steps). Note that the infrastructure is automatically passing
3015   several standard variables, defined in <code class="literal">PKG_PYTHON_DISTUTILS_ENV</code>
3016   (for distutils target packages), <code class="literal">HOST_PKG_PYTHON_DISTUTILS_ENV</code>
3017   (for distutils host packages), <code class="literal">PKG_PYTHON_SETUPTOOLS_ENV</code> (for
3018   setuptools target packages) and <code class="literal">HOST_PKG_PYTHON_SETUPTOOLS_ENV</code>
3019   (for setuptools host packages).
3020 </li><li class="listitem">
3021 <code class="literal">PYTHON_FOO_BUILD_OPTS</code>, to specify additional options to pass to the
3022   Python <code class="literal">setup.py</code> script during the build step. For target distutils
3023   packages, the <code class="literal">PKG_PYTHON_DISTUTILS_BUILD_OPTS</code> options are already
3024   passed automatically by the infrastructure.
3025 </li><li class="listitem">
3026 <code class="literal">PYTHON_FOO_INSTALL_TARGET_OPTS</code>, <code class="literal">PYTHON_FOO_INSTALL_STAGING_OPTS</code>,
3027   <code class="literal">HOST_PYTHON_FOO_INSTALL_OPTS</code> to specify additional options to pass
3028   to the Python <code class="literal">setup.py</code> script during the target installation step,
3029   the staging installation step or the host installation,
3030   respectively. Note that the infrastructure is automatically passing
3031   some options, defined in <code class="literal">PKG_PYTHON_DISTUTILS_INSTALL_TARGET_OPTS</code>
3032   or <code class="literal">PKG_PYTHON_DISTUTILS_INSTALL_STAGING_OPTS</code> (for target distutils
3033   packages), <code class="literal">HOST_PKG_PYTHON_DISTUTILS_INSTALL_OPTS</code> (for host
3034   distutils packages), <code class="literal">PKG_PYTHON_SETUPTOOLS_INSTALL_TARGET_OPTS</code> or
3035   <code class="literal">PKG_PYTHON_SETUPTOOLS_INSTALL_STAGING_OPTS</code> (for target setuptools
3036   packages) and <code class="literal">HOST_PKG_PYTHON_SETUPTOOLS_INSTALL_OPTS</code> (for host
3037   setuptools packages).
3038 </li><li class="listitem">
3039 <code class="literal">HOST_PYTHON_FOO_NEEDS_HOST_PYTHON</code>, to define the host python
3040   interpreter. The usage of this variable is limited to host
3041   packages. The two supported value are <code class="literal">python2</code> and <code class="literal">python3</code>. It
3042   will ensures the right host python package is available and will
3043   invoke it for the build. If some build steps are overloaded, the
3044   right python interpreter must be explicitly called in the commands.
3045 </li></ul></div><p>With the Python infrastructure, all the steps required to build and
3046 install the packages are already defined, and they generally work well
3047 for most Python-based packages. However, when required, it is still
3048 possible to customize what is done in any particular step:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3049 By adding a post-operation hook (after extract, patch, configure,
3050   build or install). See <a class="xref" href="#hooks" title="17.15. Hooks available in the various build steps">Section 17.15, “Hooks available in the various build steps”</a> for details.
3051 </li><li class="listitem">
3052 By overriding one of the steps. For example, even if the Python
3053   infrastructure is used, if the package <code class="literal">.mk</code> file defines its own
3054   <code class="literal">PYTHON_FOO_BUILD_CMDS</code> variable, it will be used instead of the
3055   default Python one. However, using this method should be restricted
3056   to very specific cases. Do not use it in the general case.
3057 </li></ul></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_luarocks_based_packages"></a>17.9. Infrastructure for LuaRocks-based packages</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="luarocks-package-tutorial"></a>17.9.1. <code class="literal">luarocks-package</code> tutorial</h3></div></div></div><p>First, let’s see how to write a <code class="literal">.mk</code> file for a LuaRocks-based package,
3058 with an example :</p><pre class="screen">01: ################################################################################
3059 02: #
3060 03: # luafoo
3061 04: #
3062 05: ################################################################################
3063 06:
3064 07: LUAFOO_VERSION = 1.0.2-1
3065 08: LUAFOO_DEPENDENCIES = foo
3066 09:
3067 10: LUAFOO_BUILD_OPTS += FOO_INCDIR=$(STAGING_DIR)/usr/include
3068 11: LUAFOO_BUILD_OPTS += FOO_LIBDIR=$(STAGING_DIR)/usr/lib
3069 12: LUAFOO_LICENSE = luaFoo license
3070 13: LUAFOO_LICENSE_FILES = COPYING
3071 14:
3072 15: $(eval $(luarocks-package))</pre><p>On line 7, we declare the version of the package (the same as in the rockspec,
3073 which is the concatenation of the upstream version and the rockspec revision,
3074 separated by a hyphen <span class="emphasis"><em>-</em></span>).</p><p>On line 8, we declare our dependencies against native libraries, so that they
3075 are built before the build process of our package starts.</p><p>On lines 10-11, we tell Buildroot to pass custom options to LuaRocks when it is
3076 building the package.</p><p>On lines 12-13, we specify the licensing terms for the package.</p><p>Finally, on line 15, we invoke the <code class="literal">luarocks-package</code>
3077 macro that generates all the Makefile rules that actually allows the
3078 package to be built.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="luarocks-package-reference"></a>17.9.2. <code class="literal">luarocks-package</code> reference</h3></div></div></div><p>LuaRocks is a deployment and management system for Lua modules, and supports
3079 various <code class="literal">build.type</code>: <code class="literal">builtin</code>, <code class="literal">make</code> and <code class="literal">cmake</code>. In the context of
3080 Buildroot, the <code class="literal">luarocks-package</code> infrastructure only supports the <code class="literal">builtin</code>
3081 mode. LuaRocks packages that use the <code class="literal">make</code> or <code class="literal">cmake</code> build mechanisms
3082 should instead be packaged using the <code class="literal">generic-package</code> and <code class="literal">cmake-package</code>
3083 infrastructures in Buildroot, respectively.</p><p>The main macro of the LuaRocks package infrastructure is <code class="literal">luarocks-package</code>:
3084 like <code class="literal">generic-package</code> it works by defining a number of variables providing
3085 metadata information about the package, and then calling <code class="literal">luarocks-package</code>. It
3086 is worth mentioning that building LuaRocks packages for the host is not
3087 supported, so the macro <code class="literal">host-luarocks-package</code> is not implemented.</p><p>Just like the generic infrastructure, the LuaRocks infrastructure works
3088 by defining a number of variables before calling the <code class="literal">luarocks-package</code>
3089 macro.</p><p>First, all the package metadata information variables that exist in
3090 the generic infrastructure also exist in the LuaRocks infrastructure:
3091 <code class="literal">LUAFOO_VERSION</code>, <code class="literal">LUAFOO_SOURCE</code>, <code class="literal">LUAFOO_SITE</code>,
3092 <code class="literal">LUAFOO_DEPENDENCIES</code>, <code class="literal">LUAFOO_LICENSE</code>, <code class="literal">LUAFOO_LICENSE_FILES</code>.</p><p>Two of them are populated by the LuaRocks infrastructure (for the
3093 <code class="literal">download</code> step). If your package is not hosted on the LuaRocks mirror
3094 <code class="literal">$(BR2_LUAROCKS_MIRROR)</code>, you can override them:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3095 <code class="literal">LUAFOO_SITE</code>, which defaults to <code class="literal">$(BR2_LUAROCKS_MIRROR)</code>
3096 </li><li class="listitem">
3097 <code class="literal">LUAFOO_SOURCE</code>, which defaults to <code class="literal">luafoo-$(LUAFOO_VERSION).src.rock</code>
3098 </li></ul></div><p>A few additional variables, specific to the LuaRocks infrastructure, are
3099 also defined. They can be overridden in specific cases.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3100 <code class="literal">LUAFOO_ROCKSPEC</code>, which defaults to <code class="literal">luafoo-$(LUAFOO_VERSION).rockspec</code>
3101 </li><li class="listitem">
3102 <code class="literal">LUAFOO_SUBDIR</code>, which defaults to
3103   <code class="literal">luafoo-$(LUAFOO_VERSION_WITHOUT_ROCKSPEC_REVISION)</code>
3104 </li><li class="listitem">
3105 <code class="literal">LUAFOO_BUILD_OPTS</code> contains additional build options for the
3106   <code class="literal">luarocks build</code> call.
3107 </li></ul></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_perl_cpan_packages"></a>17.10. Infrastructure for Perl/CPAN packages</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="perl-package-tutorial"></a>17.10.1. <code class="literal">perl-package</code> tutorial</h3></div></div></div><p>First, let’s see how to write a <code class="literal">.mk</code> file for a Perl/CPAN package,
3108 with an example :</p><pre class="screen">01: ################################################################################
3109 02: #
3110 03: # perl-foo-bar
3111 04: #
3112 05: ################################################################################
3113 06:
3114 07: PERL_FOO_BAR_VERSION = 0.02
3115 08: PERL_FOO_BAR_SOURCE = Foo-Bar-$(PERL_FOO_BAR_VERSION).tar.gz
3116 09: PERL_FOO_BAR_SITE = $(BR2_CPAN_MIRROR)/authors/id/M/MO/MONGER
3117 10: PERL_FOO_BAR_DEPENDENCIES = perl-strictures
3118 11: PERL_FOO_BAR_LICENSE = Artistic or GPLv1+
3119 12: PERL_FOO_BAR_LICENSE_FILES = LICENSE
3120 13:
3121 14: $(eval $(perl-package))</pre><p>On line 7, we declare the version of the package.</p><p>On line 8 and 9, we declare the name of the tarball and the location
3122 of the tarball on a CPAN server. Buildroot will automatically download
3123 the tarball from this location.</p><p>On line 10, we declare our dependencies, so that they are built
3124 before the build process of our package starts.</p><p>On line 11 and 12, we give licensing details about the package (its
3125 license on line 11, and the file containing the license text on line
3126 12).</p><p>Finally, on line 14, we invoke the <code class="literal">perl-package</code> macro that
3127 generates all the Makefile rules that actually allow the package to be
3128 built.</p><p>Most of these data can be retrieved from <a class="ulink" href="https://metacpan.org/" target="_top">https://metacpan.org/</a>.
3129 So, this file and the Config.in can be generated by running
3130 the script <code class="literal">supports/scripts/scancpan Foo-Bar</code> in the Buildroot directory
3131 (or in the <code class="literal">BR2_EXTERNAL</code> directory).
3132 This script creates a Config.in file and foo-bar.mk file for the
3133 requested package, and also recursively for all dependencies specified by
3134 CPAN. You should still manually edit the result. In particular, the
3135 following things should be checked.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3136 If the perl module links with a shared library that is provided by
3137   another (non-perl) package, this dependency is not added automatically.
3138   It has to be added manually to <code class="literal">PERL_FOO_BAR_DEPENDENCIES</code>.
3139 </li><li class="listitem">
3140 The <code class="literal">package/Config.in</code> file has to be updated manually to include the
3141   generated Config.in files. As a hint, the <code class="literal">scancpan</code> script prints out
3142   the required <code class="literal">source "…"</code> statements, sorted alphabetically.
3143 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="perl-package-reference"></a>17.10.2. <code class="literal">perl-package</code> reference</h3></div></div></div><p>As a policy, packages that provide Perl/CPAN modules should all be
3144 named <code class="literal">perl-&lt;something&gt;</code> in Buildroot.</p><p>This infrastructure handles various Perl build systems :
3145 <code class="literal">ExtUtils-MakeMaker</code>, <code class="literal">Module-Build</code> and <code class="literal">Module-Build-Tiny</code>.
3146 <code class="literal">Build.PL</code> is always preferred when a package provides a <code class="literal">Makefile.PL</code>
3147 and a <code class="literal">Build.PL</code>.</p><p>The main macro of the Perl/CPAN package infrastructure is
3148 <code class="literal">perl-package</code>. It is similar to the <code class="literal">generic-package</code> macro. The ability to
3149 have target and host packages is also available, with the
3150 <code class="literal">host-perl-package</code> macro.</p><p>Just like the generic infrastructure, the Perl/CPAN infrastructure
3151 works by defining a number of variables before calling the
3152 <code class="literal">perl-package</code> macro.</p><p>First, all the package metadata information variables that exist in the
3153 generic infrastructure also exist in the Perl/CPAN infrastructure:
3154 <code class="literal">PERL_FOO_VERSION</code>, <code class="literal">PERL_FOO_SOURCE</code>,
3155 <code class="literal">PERL_FOO_PATCH</code>, <code class="literal">PERL_FOO_SITE</code>,
3156 <code class="literal">PERL_FOO_SUBDIR</code>, <code class="literal">PERL_FOO_DEPENDENCIES</code>,
3157 <code class="literal">PERL_FOO_INSTALL_TARGET</code>.</p><p>Note that setting <code class="literal">PERL_FOO_INSTALL_STAGING</code> to <code class="literal">YES</code> has no effect
3158 unless a <code class="literal">PERL_FOO_INSTALL_STAGING_CMDS</code> variable is defined. The perl
3159 infrastructure doesn’t define these commands since Perl modules generally
3160 don’t need to be installed to the <code class="literal">staging</code> directory.</p><p>A few additional variables, specific to the Perl/CPAN infrastructure,
3161 can also be defined. Many of them are only useful in very specific
3162 cases, typical packages will therefore only use a few of them.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3163 <code class="literal">PERL_FOO_CONF_ENV</code>/<code class="literal">HOST_PERL_FOO_CONF_ENV</code>, to specify additional
3164   environment variables to pass to the <code class="literal">perl Makefile.PL</code> or <code class="literal">perl Build.PL</code>.
3165   By default, empty.
3166 </li><li class="listitem">
3167 <code class="literal">PERL_FOO_CONF_OPTS</code>/<code class="literal">HOST_PERL_FOO_CONF_OPTS</code>, to specify additional
3168   configure options to pass to the <code class="literal">perl Makefile.PL</code> or <code class="literal">perl Build.PL</code>.
3169   By default, empty.
3170 </li><li class="listitem">
3171 <code class="literal">PERL_FOO_BUILD_OPTS</code>/<code class="literal">HOST_PERL_FOO_BUILD_OPTS</code>, to specify additional
3172   options to pass to <code class="literal">make pure_all</code> or <code class="literal">perl Build build</code> in the build step.
3173   By default, empty.
3174 </li><li class="listitem">
3175 <code class="literal">PERL_FOO_INSTALL_TARGET_OPTS</code>, to specify additional options to
3176   pass to <code class="literal">make pure_install</code> or <code class="literal">perl Build install</code> in the install step.
3177   By default, empty.
3178 </li><li class="listitem">
3179 <code class="literal">HOST_PERL_FOO_INSTALL_OPTS</code>, to specify additional options to
3180   pass to <code class="literal">make pure_install</code> or <code class="literal">perl Build install</code> in the install step.
3181   By default, empty.
3182 </li></ul></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_virtual_packages"></a>17.11. Infrastructure for virtual packages</h2></div></div></div><p><a id="virtual-package-tutorial"></a>In Buildroot, a virtual package is a package whose functionalities are
3183 provided by one or more packages, referred to as <span class="emphasis"><em>providers</em></span>. The virtual
3184 package management is an extensible mechanism allowing the user to choose
3185 the provider used in the rootfs.</p><p>For example, <span class="emphasis"><em>OpenGL ES</em></span> is an API for 2D and 3D graphics on embedded systems.
3186 The implementation of this API is different for the <span class="emphasis"><em>Allwinner Tech Sunxi</em></span> and
3187 the <span class="emphasis"><em>Texas Instruments OMAP35xx</em></span> platforms. So <code class="literal">libgles</code> will be a virtual
3188 package and <code class="literal">sunxi-mali</code> and <code class="literal">ti-gfx</code> will be the providers.</p><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_literal_virtual_package_literal_tutorial"></a>17.11.1. <code class="literal">virtual-package</code> tutorial</h3></div></div></div><p>In the following example, we will explain how to add a new virtual package
3189 (<span class="emphasis"><em>something-virtual</em></span>) and a provider for it (<span class="emphasis"><em>some-provider</em></span>).</p><p>First, let’s create the virtual package.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_virtual_package_8217_s_literal_config_in_literal_file"></a>17.11.2. Virtual package’s <code class="literal">Config.in</code> file</h3></div></div></div><p>The <code class="literal">Config.in</code> file of virtual package <span class="emphasis"><em>something-virtual</em></span> should contain:</p><pre class="screen">01: config BR2_PACKAGE_HAS_SOMETHING_VIRTUAL
3190 02:     bool
3191 03:
3192 04: config BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL
3193 05:     depends on BR2_PACKAGE_HAS_SOMETHING_VIRTUAL
3194 06:     string</pre><p>In this file, we declare two options, <code class="literal">BR2_PACKAGE_HAS_SOMETHING_VIRTUAL</code> and
3195 <code class="literal">BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL</code>, whose values will be used by the
3196 providers.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_virtual_package_8217_s_literal_mk_literal_file"></a>17.11.3. Virtual package’s <code class="literal">.mk</code> file</h3></div></div></div><p>The <code class="literal">.mk</code> for the virtual package should just evaluate the <code class="literal">virtual-package</code> macro:</p><pre class="screen">01: ################################################################################
3197 02: #
3198 03: # something-virtual
3199 04: #
3200 05: ################################################################################
3201 06:
3202 07: $(eval $(virtual-package))</pre><p>The ability to have target and host packages is also available, with the
3203 <code class="literal">host-virtual-package</code> macro.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_provider_8217_s_literal_config_in_literal_file"></a>17.11.4. Provider’s <code class="literal">Config.in</code> file</h3></div></div></div><p>When adding a package as a provider, only the <code class="literal">Config.in</code> file requires some
3204 modifications.</p><p>The <code class="literal">Config.in</code> file of the package <span class="emphasis"><em>some-provider</em></span>, which provides the
3205 functionalities of <span class="emphasis"><em>something-virtual</em></span>, should contain:</p><pre class="screen">01: config BR2_PACKAGE_SOME_PROVIDER
3206 02:     bool "some-provider"
3207 03:     select BR2_PACKAGE_HAS_SOMETHING_VIRTUAL
3208 04:     help
3209 05:       This is a comment that explains what some-provider is.
3210 06:
3211 07:       http://foosoftware.org/some-provider/
3212 08:
3213 09: if BR2_PACKAGE_SOME_PROVIDER
3214 10: config BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL
3215 11:     default "some-provider"
3216 12: endif</pre><p>On line 3, we select <code class="literal">BR2_PACKAGE_HAS_SOMETHING_VIRTUAL</code>, and on line 11, we
3217 set the value of <code class="literal">BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL</code> to the name of the
3218 provider, but only if it is selected.</p><p>See <a class="xref" href="#virtual-package-list" title="Chapter 25. List of virtual packages">Chapter 25, <em>List of virtual packages</em></a> for the symbols to select if you implement
3219 a new provider for an existing virtual package.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_provider_8217_s_literal_mk_literal_file"></a>17.11.5. Provider’s <code class="literal">.mk</code> file</h3></div></div></div><p>The <code class="literal">.mk</code> file should also declare an additional variable
3220 <code class="literal">SOME_PROVIDER_PROVIDES</code> to contain the names of all the virtual
3221 packages it is an implementation of:</p><pre class="screen">01: SOME_PROVIDER_PROVIDES = something-virtual</pre><p>Of course, do not forget to add the proper build and runtime dependencies for
3222 this package!</p><p>See <a class="xref" href="#virtual-package-list" title="Chapter 25. List of virtual packages">Chapter 25, <em>List of virtual packages</em></a> for the names of virtual packages to provide
3223 if you implement a new provider for an existing virtual package.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_notes_on_depending_on_a_virtual_package"></a>17.11.6. Notes on depending on a virtual package</h3></div></div></div><p>When adding a package that requires a certain <code class="literal">FEATURE</code> provided by a virtual
3224 package, you have to use <code class="literal">depends on BR2_PACKAGE_HAS_FEATURE</code>, like so:</p><pre class="screen">config BR2_PACKAGE_HAS_FEATURE
3225     bool
3226
3227 config BR2_PACKAGE_FOO
3228     bool "foo"
3229     depends on BR2_PACKAGE_HAS_FEATURE</pre></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_notes_on_depending_on_a_specific_provider"></a>17.11.7. Notes on depending on a specific provider</h3></div></div></div><p>If your package really requires a specific provider, then you’ll have to
3230 make your package <code class="literal">depends on</code> this provider; you can <span class="emphasis"><em>not</em></span> <code class="literal">select</code> a
3231 provider.</p><p>Let’s take an example with two providers for a <code class="literal">FEATURE</code>:</p><pre class="screen">config BR2_PACKAGE_HAS_FEATURE
3232     bool
3233
3234 config BR2_PACKAGE_FOO
3235     bool "foo"
3236     select BR2_PACKAGE_HAS_FEATURE
3237
3238 config BR2_PACKAGE_BAR
3239     bool "bar"
3240     select BR2_PACKAGE_HAS_FEATURE</pre><p>And you are adding a package that needs <code class="literal">FEATURE</code> as provided by <code class="literal">foo</code>,
3241 but not as provided by <code class="literal">bar</code>.</p><p>If you were to use <code class="literal">select BR2_PACKAGE_FOO</code>, then the user would still
3242 be able to select <code class="literal">BR2_PACKAGE_BAR</code> in the menuconfig. This would create
3243 a configuration inconsistency, whereby two providers of the same <code class="literal">FEATURE</code>
3244 would be enabled at once, one explicitly set by the user, the other
3245 implicitly by your <code class="literal">select</code>.</p><p>Instead, you have to use <code class="literal">depends on BR2_PACKAGE_FOO</code>, which avoids any
3246 implicit configuration inconsistency.</p></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_packages_using_kconfig_for_configuration_files"></a>17.12. Infrastructure for packages using kconfig for configuration files</h2></div></div></div><p>A popular way for a software package to handle user-specified
3247 configuration is <code class="literal">kconfig</code>. Among others, it is used by the Linux
3248 kernel, Busybox, and Buildroot itself. The presence of a .config file
3249 and a <code class="literal">menuconfig</code> target are two well-known symptoms of kconfig being
3250 used.</p><p>Buildroot features an infrastructure for packages that use kconfig for
3251 their configuration. This infrastructure provides the necessary logic to
3252 expose the package’s <code class="literal">menuconfig</code> target as <code class="literal">foo-menuconfig</code> in
3253 Buildroot, and to handle the copying back and forth of the configuration
3254 file in a correct way.</p><p>The <code class="literal">kconfig-package</code> infrastructure is based on the <code class="literal">generic-package</code>
3255 infrastructure. All variables supported by <code class="literal">generic-package</code> are
3256 available in <code class="literal">kconfig-package</code> as well. See
3257 <a class="xref" href="#generic-package-reference" title="17.5.2. generic-package reference">Section 17.5.2, “<code class="literal">generic-package</code> reference”</a> for more details.</p><p>In order to use the <code class="literal">kconfig-package</code> infrastructure for a Buildroot
3258 package, the minimally required lines in the <code class="literal">.mk</code> file, in addition to
3259 the variables required by the <code class="literal">generic-package</code> infrastructure, are:</p><pre class="screen">FOO_KCONFIG_FILE = reference-to-source-configuration-file
3260
3261 $(eval $(kconfig-package))</pre><p>This snippet creates the following make targets:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3262 <code class="literal">foo-menuconfig</code>, which calls the package’s <code class="literal">menuconfig</code> target
3263 </li><li class="listitem">
3264 <code class="literal">foo-update-config</code>, which copies the configuration back to the source
3265   configuration file.
3266 </li></ul></div><p>and ensures that the source configuration file is copied to the build
3267 directory at the right moment.</p><p>In addition to these minimally required lines, several optional variables can
3268 be set to suit the needs of the package under consideration:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3269 <code class="literal">FOO_KCONFIG_EDITORS</code>: a space-separated list of kconfig editors to
3270   support, for example <span class="emphasis"><em>menuconfig xconfig</em></span>. By default, <span class="emphasis"><em>menuconfig</em></span>.
3271 </li><li class="listitem">
3272 <code class="literal">FOO_KCONFIG_OPTS</code>: extra options to pass when calling the kconfig
3273   editors. This may need to include <span class="emphasis"><em>$(FOO_MAKE_OPTS)</em></span>, for example. By
3274   default, empty.
3275 </li><li class="listitem">
3276 <code class="literal">FOO_KCONFIG_FIXUP_CMDS</code>: a list of shell commands needed to fixup the
3277   configuration file after copying it or running a kconfig editor. Such
3278   commands may be needed to ensure a configuration consistent with other
3279   configuration of Buildroot, for example. By default, empty.
3280 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_rebar_based_packages"></a>17.13. Infrastructure for rebar-based packages</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="rebar-package-tutorial"></a>17.13.1. <code class="literal">rebar-package</code> tutorial</h3></div></div></div><p>First, let’s see how to write a <code class="literal">.mk</code> file for a rebar-based package,
3281 with an example :</p><pre class="screen">01: ################################################################################
3282 02: #
3283 03: # erlang-foobar
3284 04: #
3285 05: ################################################################################
3286 06:
3287 07: ERLANG_FOOBAR_VERSION = 1.0
3288 08: ERLANG_FOOBAR_SOURCE = erlang-foobar-$(ERLANG_FOOBAR_VERSION).tar.xz
3289 09: ERLANG_FOOBAR_SITE = http://www.foosoftware.org/download
3290 10: ERLANG_FOOBAR_DEPENDENCIES = host-libaaa libbbb
3291 11:
3292 12: $(eval $(rebar-package))</pre><p>On line 7, we declare the version of the package.</p><p>On line 8 and 9, we declare the name of the tarball (xz-ed tarball
3293 recommended) and the location of the tarball on the Web. Buildroot
3294 will automatically download the tarball from this location.</p><p>On line 10, we declare our dependencies, so that they are built
3295 before the build process of our package starts.</p><p>Finally, on line 12, we invoke the <code class="literal">rebar-package</code> macro that
3296 generates all the Makefile rules that actually allows the package to
3297 be built.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="rebar-package-reference"></a>17.13.2. <code class="literal">rebar-package</code> reference</h3></div></div></div><p>The main macro of the <code class="literal">rebar</code> package infrastructure is
3298 <code class="literal">rebar-package</code>. It is similar to the <code class="literal">generic-package</code> macro. The
3299 ability to have host packages is also available, with the
3300 <code class="literal">host-rebar-package</code> macro.</p><p>Just like the generic infrastructure, the <code class="literal">rebar</code> infrastructure works
3301 by defining a number of variables before calling the <code class="literal">rebar-package</code>
3302 macro.</p><p>First, all the package metadata information variables that exist in
3303 the generic infrastructure also exist in the <code class="literal">rebar</code> infrastructure:
3304 <code class="literal">ERLANG_FOOBAR_VERSION</code>, <code class="literal">ERLANG_FOOBAR_SOURCE</code>,
3305 <code class="literal">ERLANG_FOOBAR_PATCH</code>, <code class="literal">ERLANG_FOOBAR_SITE</code>,
3306 <code class="literal">ERLANG_FOOBAR_SUBDIR</code>, <code class="literal">ERLANG_FOOBAR_DEPENDENCIES</code>,
3307 <code class="literal">ERLANG_FOOBAR_INSTALL_STAGING</code>, <code class="literal">ERLANG_FOOBAR_INSTALL_TARGET</code>,
3308 <code class="literal">ERLANG_FOOBAR_LICENSE</code> and <code class="literal">ERLANG_FOOBAR_LICENSE_FILES</code>.</p><p>A few additional variables, specific to the <code class="literal">rebar</code> infrastructure,
3309 can also be defined. Many of them are only useful in very specific
3310 cases, typical packages will therefore only use a few of them.</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p class="simpara">
3311 <code class="literal">ERLANG_FOOBAR_USE_AUTOCONF</code>, to specify that the package uses
3312   <span class="emphasis"><em>autoconf</em></span> at the configuration step.  When a package sets this
3313   variable to <code class="literal">YES</code>, the <code class="literal">autotools</code> infrastructure is used.
3314 </p><p><strong>Note. </strong>You can also use some of the variables from the <code class="literal">autotools</code>
3315   infrastructure: <code class="literal">ERLANG_FOOBAR_CONF_ENV</code>, <code class="literal">ERLANG_FOOBAR_CONF_OPTS</code>,
3316   <code class="literal">ERLANG_FOOBAR_AUTORECONF</code>, <code class="literal">ERLANG_FOOBAR_AUTORECONF_ENV</code> and
3317   <code class="literal">ERLANG_FOOBAR_AUTORECONF_OPTS</code>.</p></li><li class="listitem"><p class="simpara">
3318 <code class="literal">ERLANG_FOOBAR_USE_BUNDLED_REBAR</code>, to specify that the package has
3319   a bundled version of <span class="emphasis"><em>rebar</em></span> <span class="strong"><strong>and</strong></span> that it shall be used. Valid
3320   values are <code class="literal">YES</code> or <code class="literal">NO</code> (the default).
3321 </p><p><strong>Note. </strong>If the package bundles a <span class="emphasis"><em>rebar</em></span> utility, but can use the generic
3322   one that Buildroot provides, just say <code class="literal">NO</code> (i.e., do not specify
3323   this variable). Only set if it is mandatory to use the <span class="emphasis"><em>rebar</em></span>
3324   utility bundled in this package.</p></li><li class="listitem">
3325 <code class="literal">ERLANG_FOOBAR_REBAR_ENV</code>, to specify additional environment
3326   variables to pass to the <span class="emphasis"><em>rebar</em></span> utility.
3327 </li></ul></div><p>With the rebar infrastructure, all the steps required to build
3328 and install the packages are already defined, and they generally work
3329 well for most rebar-based packages. However, when required, it is
3330 still possible to customize what is done in any particular step:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3331 By adding a post-operation hook (after extract, patch, configure,
3332   build or install). See <a class="xref" href="#hooks" title="17.15. Hooks available in the various build steps">Section 17.15, “Hooks available in the various build steps”</a> for details.
3333 </li><li class="listitem">
3334 By overriding one of the steps. For example, even if the rebar
3335   infrastructure is used, if the package <code class="literal">.mk</code> file defines its
3336   own <code class="literal">ERLANG_FOOBAR_BUILD_CMDS</code> variable, it will be used instead
3337   of the default rebar one. However, using this method should be
3338   restricted to very specific cases. Do not use it in the general
3339   case.
3340 </li></ul></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_infrastructure_for_asciidoc_documents"></a>17.14. Infrastructure for asciidoc documents</h2></div></div></div><p><a id="asciidoc-documents-tutorial"></a>The Buildroot manual, which you are currently reading, is entirely written
3341 using the <a class="ulink" href="http://asciidoc.org/" target="_top">AsciiDoc</a> mark-up syntax. The manual is then
3342 rendered to many formats:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3343 html
3344 </li><li class="listitem">
3345 split-html
3346 </li><li class="listitem">
3347 pdf
3348 </li><li class="listitem">
3349 epub
3350 </li><li class="listitem">
3351 text
3352 </li></ul></div><p>Although Buildroot only contains one document written in AsciiDoc, there
3353 is, as for packages, an infrastructure for rendering documents using the
3354 AsciiDoc syntax.</p><p>Also as for packages, the AsciiDoc infrastructure is available from
3355 <a class="link" href="#outside-br-custom" title="9.2. Keeping customizations outside of Buildroot">BR2_EXTERNAL</a>
3356 <a class="xref" href="#outside-br-custom" title="9.2. Keeping customizations outside of Buildroot">Section 9.2, “Keeping customizations outside of Buildroot”</a>. This allows documentation for a
3357 BR2_EXTERNAL tree to match the Buildroot documentation, as it will be
3358 rendered to the same formats and use the same layout and theme.</p><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_literal_asciidoc_document_literal_tutorial"></a>17.14.1. <code class="literal">asciidoc-document</code> tutorial</h3></div></div></div><p>Whereas package infrastructures are suffixed with <code class="literal">-package</code>, the document
3359 infrastructures are suffixed with <code class="literal">-document</code>. So, the AsciiDoc infrastructure
3360 is named <code class="literal">asciidoc-document</code>.</p><p>Here is an example to render a simple AsciiDoc document.</p><pre class="screen">01: ################################################################################
3361 02: #
3362 03: # foo-document
3363 04: #
3364 05: ################################################################################
3365 06:
3366 07: FOO_SOURCES = $(sort $(wildcard $(pkgdir)/*))
3367 08: $(eval $(call asciidoc-document))</pre><p>On line 7, the Makefile declares what the sources of the document are.
3368 Currently, it is expected that the document’s sources are only local;
3369 Buildroot will not attempt to download anything to render a document.
3370 Thus, you must indicate where the sources are. Usually, the string
3371 above is sufficient for a document with no sub-directory structure.</p><p>On line 8, we call the <code class="literal">asciidoc-document</code> function, which generates all
3372 the Makefile code necessary to render the document.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_literal_asciidoc_document_literal_reference"></a>17.14.2. <code class="literal">asciidoc-document</code> reference</h3></div></div></div><p>The list of variables that can be set in a <code class="literal">.mk</code> file to give metadata
3373 information is (assuming the document name is <code class="literal">foo</code>) :</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3374 <code class="literal">FOO_SOURCES</code>, mandatory, defines the source files for the document.
3375 </li><li class="listitem">
3376 <code class="literal">FOO_RESOURCES</code>, optional, may contain a space-separated list of paths
3377   to one or more directories containing so-called resources (like CSS or
3378   images). By default, empty.
3379 </li></ul></div><p>There are also additional hooks (see <a class="xref" href="#hooks" title="17.15. Hooks available in the various build steps">Section 17.15, “Hooks available in the various build steps”</a> for general information
3380 on hooks), that a document may set to define extra actions to be done at
3381 various steps:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3382 <code class="literal">FOO_POST_RSYNC_HOOKS</code> to run additional commands after the sources
3383   have been copied by Buildroot. This can for example be used to
3384   generate part of the manual with information extracted from the
3385   tree. As an example, Buildroot uses this hook to generate the tables
3386   in the appendices.
3387 </li><li class="listitem">
3388 <code class="literal">FOO_CHECK_DEPENDENCIES_HOOKS</code> to run additional tests on required
3389   components to generate the document. In AsciiDoc, it is possible to
3390   call filters, that is, programs that will parse an AsciiDoc block and
3391   render it appropriately (e.g. <a class="ulink" href="http://ditaa.sourceforge.net/" target="_top">ditaa</a> or
3392   <a class="ulink" href="https://pythonhosted.org/aafigure/" target="_top">aafigure</a>).
3393 </li><li class="listitem">
3394 <code class="literal">FOO_CHECK_DEPENDENCIES_&lt;FMT&gt;_HOOKS</code>, to run additional tests for
3395   the specified format <code class="literal">&lt;FMT&gt;</code> (see the list of rendered formats, above).
3396 </li></ul></div><p>Here is a complete example that uses all variables and all hooks:</p><pre class="screen">01: ################################################################################
3397 02: #
3398 03: # foo-document
3399 04: #
3400 05: ################################################################################
3401 06:
3402 07: FOO_SOURCES = $(sort $(wildcard $(pkgdir)/*))
3403 08: FOO_RESOURCES = $(sort $(wildcard $(pkgdir)/ressources))
3404 09:
3405 10: define FOO_GEN_EXTRA_DOC
3406 11:     /path/to/generate-script --outdir=$(@D)
3407 12: endef
3408 13: FOO_POST_RSYNC_HOOKS += FOO_GEN_EXTRA_DOC
3409 14:
3410 15: define FOO_CHECK_MY_PROG
3411 16:     if ! which my-prog &gt;/dev/null 2&gt;&amp;1; then \
3412 17:         echo "You need my-prog to generate the foo document"; \
3413 18:         exit 1; \
3414 19:     fi
3415 20: endef
3416 21: FOO_CHECK_DEPENDENCIES_HOOKS += FOO_CHECK_MY_PROG
3417 22:
3418 23: define FOO_CHECK_MY_OTHER_PROG
3419 24:     if ! which my-other-prog &gt;/dev/null 2&gt;&amp;1; then \
3420 25:         echo "You need my-other-prog to generate the foo document as PDF"; \
3421 26:         exit 1; \
3422 27:     fi
3423 28: endef
3424 29: FOO_CHECK_DEPENDENCIES_PDF_HOOKS += FOO_CHECK_MY_OTHER_PROG
3425 30:
3426 31: $(eval $(call asciidoc-document))</pre></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="hooks"></a>17.15. Hooks available in the various build steps</h2></div></div></div><p>The generic infrastructure (and as a result also the derived autotools
3427 and cmake infrastructures) allow packages to specify hooks.
3428 These define further actions to perform after existing steps.
3429 Most hooks aren’t really useful for generic packages, since the <code class="literal">.mk</code>
3430 file already has full control over the actions performed in each step
3431 of the package construction.</p><p>The following hook points are available:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3432 <code class="literal">LIBFOO_PRE_DOWNLOAD_HOOKS</code>
3433 </li><li class="listitem">
3434 <code class="literal">LIBFOO_POST_DOWNLOAD_HOOKS</code>
3435 </li><li class="listitem">
3436 <code class="literal">LIBFOO_PRE_EXTRACT_HOOKS</code>
3437 </li><li class="listitem">
3438 <code class="literal">LIBFOO_POST_EXTRACT_HOOKS</code>
3439 </li><li class="listitem">
3440 <code class="literal">LIBFOO_PRE_RSYNC_HOOKS</code>
3441 </li><li class="listitem">
3442 <code class="literal">LIBFOO_POST_RSYNC_HOOKS</code>
3443 </li><li class="listitem">
3444 <code class="literal">LIBFOO_PRE_PATCH_HOOKS</code>
3445 </li><li class="listitem">
3446 <code class="literal">LIBFOO_POST_PATCH_HOOKS</code>
3447 </li><li class="listitem">
3448 <code class="literal">LIBFOO_PRE_CONFIGURE_HOOKS</code>
3449 </li><li class="listitem">
3450 <code class="literal">LIBFOO_POST_CONFIGURE_HOOKS</code>
3451 </li><li class="listitem">
3452 <code class="literal">LIBFOO_PRE_BUILD_HOOKS</code>
3453 </li><li class="listitem">
3454 <code class="literal">LIBFOO_POST_BUILD_HOOKS</code>
3455 </li><li class="listitem">
3456 <code class="literal">LIBFOO_PRE_INSTALL_HOOKS</code> (for host packages only)
3457 </li><li class="listitem">
3458 <code class="literal">LIBFOO_POST_INSTALL_HOOKS</code> (for host packages only)
3459 </li><li class="listitem">
3460 <code class="literal">LIBFOO_PRE_INSTALL_STAGING_HOOKS</code> (for target packages only)
3461 </li><li class="listitem">
3462 <code class="literal">LIBFOO_POST_INSTALL_STAGING_HOOKS</code> (for target packages only)
3463 </li><li class="listitem">
3464 <code class="literal">LIBFOO_PRE_INSTALL_TARGET_HOOKS</code> (for target packages only)
3465 </li><li class="listitem">
3466 <code class="literal">LIBFOO_POST_INSTALL_TARGET_HOOKS</code> (for target packages only)
3467 </li><li class="listitem">
3468 <code class="literal">LIBFOO_PRE_INSTALL_IMAGES_HOOKS</code>
3469 </li><li class="listitem">
3470 <code class="literal">LIBFOO_POST_INSTALL_IMAGES_HOOKS</code>
3471 </li><li class="listitem">
3472 <code class="literal">LIBFOO_PRE_LEGAL_INFO_HOOKS</code>
3473 </li><li class="listitem">
3474 <code class="literal">LIBFOO_POST_LEGAL_INFO_HOOKS</code>
3475 </li></ul></div><p>These variables are <span class="emphasis"><em>lists</em></span> of variable names containing actions to be
3476 performed at this hook point. This allows several hooks to be
3477 registered at a given hook point. Here is an example:</p><pre class="screen">define LIBFOO_POST_PATCH_FIXUP
3478         action1
3479         action2
3480 endef
3481
3482 LIBFOO_POST_PATCH_HOOKS += LIBFOO_POST_PATCH_FIXUP</pre><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_using_the_literal_post_rsync_literal_hook"></a>17.15.1. Using the <code class="literal">POST_RSYNC</code> hook</h3></div></div></div><p>The <code class="literal">POST_RSYNC</code> hook is run only for packages that use a local source,
3483 either through the <code class="literal">local</code> site method or the <code class="literal">OVERRIDE_SRCDIR</code>
3484 mechanism. In this case, package sources are copied using <code class="literal">rsync</code> from
3485 the local location into the buildroot build directory. The <code class="literal">rsync</code>
3486 command does not copy all files from the source directory, though.
3487 Files belonging to a version control system, like the directories
3488 <code class="literal">.git</code>, <code class="literal">.hg</code>, etc. are not copied. For most packages this is
3489 sufficient, but a given package can perform additional actions using
3490 the <code class="literal">POST_RSYNC</code> hook.</p><p>In principle, the hook can contain any command you want. One specific
3491 use case, though, is the intentional copying of the version control
3492 directory using <code class="literal">rsync</code>. The <code class="literal">rsync</code> command you use in the hook can, among
3493 others, use the following variables:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3494 <code class="literal">$(SRCDIR)</code>: the path to the overridden source directory
3495 </li><li class="listitem">
3496 <code class="literal">$(@D)</code>: the path to the build directory
3497 </li></ul></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_gettext_integration_and_interaction_with_packages"></a>17.16. Gettext integration and interaction with packages</h2></div></div></div><p>Many packages that support internationalization use the gettext
3498 library. Dependencies for this library are fairly complicated and
3499 therefore, deserve some explanation.</p><p>The <span class="emphasis"><em>uClibc</em></span> C library doesn’t implement gettext functionality;
3500 therefore with this C library, a separate gettext must be compiled,
3501 which is provided by the additional <code class="literal">libintl</code> library, part of the
3502 <code class="literal">gettext</code> package.</p><p>On the other hand, the <span class="emphasis"><em>glibc</em></span> C library does integrate its own
3503 gettext library functions, so it is not necessary to build a separate
3504 <code class="literal">libintl</code> library.</p><p>However, certain packages need some gettext utilities on the target,
3505 such as the <code class="literal">gettext</code> program itself, which allows to retrieve
3506 translated strings, from the command line.</p><p>Additionally, some packages (such as <code class="literal">libglib2</code>) do require gettext
3507 functions unconditionally, while other packages (in general, those who
3508 support <code class="literal">--disable-nls</code>) only require gettext functions when locale
3509 support is enabled.</p><p>Therefore, Buildroot defines two configuration options:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3510 <code class="literal">BR2_NEEDS_GETTEXT</code>, which is true as soon as the toolchain doesn’t
3511   provide its own gettext implementation
3512 </li><li class="listitem">
3513 <code class="literal">BR2_NEEDS_GETTEXT_IF_LOCALE</code>, which is true if the toolchain
3514   doesn’t provide its own gettext implementation and if locale support
3515   is enabled
3516 </li></ul></div><p>Packages that need gettext only when locale support is enabled should:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3517 use <code class="literal">select BR2_PACKAGE_GETTEXT if BR2_NEEDS_GETTEXT_IF_LOCALE</code> in the
3518   <code class="literal">Config.in</code> file;
3519 </li><li class="listitem">
3520 use <code class="literal">$(if $(BR2_NEEDS_GETTEXT_IF_LOCALE),gettext)</code> in the package
3521   <code class="literal">DEPENDENCIES</code> variable in the <code class="literal">.mk</code> file.
3522 </li></ul></div><p>Packages that unconditionally need gettext (which should be very rare)
3523 should:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3524 use <code class="literal">select BR2_PACKAGE_GETTEXT if BR2_NEEDS_GETTEXT</code> in the <code class="literal">Config.in</code>
3525   file;
3526 </li><li class="listitem">
3527 use <code class="literal">$(if $(BR2_NEEDS_GETTEXT),gettext)</code> in the package
3528   <code class="literal">DEPENDENCIES</code> variable in the <code class="literal">.mk</code> file.
3529 </li></ul></div><p>Packages that need the <code class="literal">gettext</code> utilities on the target (should be
3530 rare) should:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3531 use <code class="literal">select BR2_PACKAGE_GETTEXT</code> in their <code class="literal">Config.in</code> file,
3532   indicating in a comment above that it’s a runtime dependency only.
3533 </li><li class="listitem">
3534 not add any <code class="literal">gettext</code> dependency in the <code class="literal">DEPENDENCIES</code> variable of
3535   their <code class="literal">.mk</code> file.
3536 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_tips_and_tricks"></a>17.17. Tips and tricks</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="package-name-variable-relation"></a>17.17.1. Package name, config entry name and makefile variable relationship</h3></div></div></div><p>In Buildroot, there is some relationship between:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3537 the <span class="emphasis"><em>package name</em></span>, which is the package directory name (and the
3538   name of the <code class="literal">*.mk</code> file);
3539 </li><li class="listitem">
3540 the config entry name that is declared in the <code class="literal">Config.in</code> file;
3541 </li><li class="listitem">
3542 the makefile variable prefix.
3543 </li></ul></div><p>It is mandatory to maintain consistency between these elements,
3544 using the following rules:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3545 the package directory and the <code class="literal">*.mk</code> name are the <span class="emphasis"><em>package name</em></span>
3546   itself (e.g.: <code class="literal">package/foo-bar_boo/foo-bar_boo.mk</code>);
3547 </li><li class="listitem">
3548 the <span class="emphasis"><em>make</em></span> target name is the <span class="emphasis"><em>package name</em></span> itself (e.g.:
3549   <code class="literal">foo-bar_boo</code>);
3550 </li><li class="listitem">
3551 the config entry is the upper case <span class="emphasis"><em>package name</em></span> with <code class="literal">.</code> and <code class="literal">-</code>
3552   characters substituted with <code class="literal">_</code>, prefixed with <code class="literal">BR2_PACKAGE_</code> (e.g.:
3553   <code class="literal">BR2_PACKAGE_FOO_BAR_BOO</code>);
3554 </li><li class="listitem">
3555 the <code class="literal">*.mk</code> file variable prefix is the upper case <span class="emphasis"><em>package name</em></span>
3556   with <code class="literal">.</code> and <code class="literal">-</code> characters substituted with <code class="literal">_</code> (e.g.:
3557   <code class="literal">FOO_BAR_BOO_VERSION</code>).
3558 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="github-download-url"></a>17.17.2. How to add a package from GitHub</h3></div></div></div><p>Packages on GitHub often don’t have a download area with release tarballs.
3559 However, it is possible to download tarballs directly from the repository
3560 on GitHub. As GitHub is known to have changed download mechanisms in the
3561 past, the <span class="emphasis"><em>github</em></span> helper function should be used as shown below.</p><pre class="screen"># Use a tag or a full commit ID
3562 FOO_VERSION = v1.0
3563 FOO_SITE = $(call github,&lt;user&gt;,&lt;package&gt;,$(FOO_VERSION))</pre><div class="itemizedlist"><p class="title"><strong>Notes</strong></p><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3564 The FOO_VERSION can either be a tag or a commit ID.
3565 </li><li class="listitem">
3566 The tarball name generated by github matches the default one from
3567   Buildroot (e.g.: <code class="literal">foo-f6fb6654af62045239caed5950bc6c7971965e60.tar.gz</code>),
3568   so it is not necessary to specify it in the <code class="literal">.mk</code> file.
3569 </li><li class="listitem">
3570 When using a commit ID as version, you should use the full 40 hex characters.
3571 </li></ul></div><p>If the package you wish to add does have a release section on GitHub, the
3572 maintainer may have uploaded a release tarball, or the release may just point
3573 to the automatically generated tarball from the git tag. If there is a
3574 release tarball uploaded by the maintainer, we prefer to use that since it
3575 may be slightly different (e.g. it contains a configure script so we don’t
3576 need to do AUTORECONF).</p><p>You can see on the release page if it’s an uploaded tarball or a git tag:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3577 If there is a green download button, like
3578   <a class="ulink" href="https://github.com/zedshaw/mongrel2/releases/tag/v1.9.1" target="_top">mongrel2</a>, then it
3579   was uploaded by the maintainer and you should use the link of that button to
3580   specify <code class="literal">FOO_SITE</code>, and not use the <span class="emphasis"><em>github</em></span> helper.
3581 </li><li class="listitem">
3582 If there is grey download button, like
3583   <a class="ulink" href="https://github.com/xbmc/xbmc/releases/tag/13.2-Gotham" target="_top">xbmc</a>, then it’s an
3584   automatically generated tarball and you should use the <span class="emphasis"><em>github</em></span> helper
3585   function.
3586 </li></ul></div></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_conclusion"></a>17.18. Conclusion</h2></div></div></div><p>As you can see, adding a software package to Buildroot is simply a
3587 matter of writing a Makefile using an existing example and modifying it
3588 according to the compilation process required by the package.</p><p>If you package software that might be useful for other people, don’t
3589 forget to send a patch to the Buildroot mailing list (see
3590 <a class="xref" href="#submitting-patches" title="21.5. Submitting patches">Section 21.5, “Submitting patches”</a>)!</p></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="patch-policy"></a>Chapter 18. Patching a package</h2></div></div></div><p>While integrating a new package or updating an existing one, it may be
3591 necessary to patch the source of the software to get it cross-built within
3592 Buildroot.</p><p>Buildroot offers an infrastructure to automatically handle this during
3593 the builds. It supports three ways of applying patch sets: downloaded patches,
3594 patches supplied within buildroot and patches located in a user-defined
3595 global patch directory.</p><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_providing_patches"></a>18.1. Providing patches</h2></div></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_downloaded"></a>18.1.1. Downloaded</h3></div></div></div><p>If it is necessary to apply a patch that is available for download, then add it
3596 to the <code class="literal">&lt;packagename&gt;_PATCH</code> variable. It is downloaded from the same site
3597 as the package itself. It can be a single patch, or a tarball containing a
3598 patch series.</p><p>This method is typically used for packages from Debian.</p></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_within_buildroot"></a>18.1.2. Within Buildroot</h3></div></div></div><p>Most patches are provided within Buildroot, in the package
3599 directory; these typically aim to fix cross-compilation, libc support,
3600 or other such issues.</p><p>These patch files should be named <code class="literal">&lt;number&gt;-&lt;description&gt;.patch</code>.</p><div class="itemizedlist"><p class="title"><strong>Notes</strong></p><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3601 The patch files coming with Buildroot should not contain any package version
3602   reference in their filename.
3603 </li><li class="listitem">
3604 The field <code class="literal">&lt;number&gt;</code> in the patch file name refers to the <span class="emphasis"><em>apply order</em></span>,
3605   and shall start at 1; It is preferred to pad the number with zeros up to 4
3606   digits, like <span class="emphasis"><em>git-format-patch</em></span> does. E.g.: <code class="literal">0001-foobar-the-buz.patch</code>
3607 </li><li class="listitem">
3608 Previously, it was mandatory for patches to be prefixed with the name of
3609   the package, like <code class="literal">&lt;package&gt;-&lt;number&gt;-&lt;description&gt;.patch</code>, but that is
3610   no longer the case. Existing packages will be fixed as time passes. <span class="emphasis"><em>Do
3611   not prefix patches with the package name.</em></span>
3612 </li><li class="listitem">
3613 Previously, a <code class="literal">series</code> file, as used by <code class="literal">quilt</code>, could also be added in
3614   the package directory. In that case, the <code class="literal">series</code> file defines the patch
3615   application order. This is deprecated, and will be removed in the future.
3616   <span class="emphasis"><em>Do not use a series file.</em></span>
3617 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_global_patch_directory"></a>18.1.3. Global patch directory</h3></div></div></div><p>The <code class="literal">BR2_GLOBAL_PATCH_DIR</code> configuration file option can be
3618 used to specify a space separated list of one or more directories
3619 containing global package patches. See <a class="xref" href="#customize-patches" title="9.8. Adding project-specific patches">Section 9.8, “Adding project-specific patches”</a> for
3620 details.</p></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="patch-apply-order"></a>18.2. How patches are applied</h2></div></div></div><div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem">
3621 Run the <code class="literal">&lt;packagename&gt;_PRE_PATCH_HOOKS</code> commands if defined;
3622 </li><li class="listitem">
3623 Cleanup the build directory, removing any existing <code class="literal">*.rej</code> files;
3624 </li><li class="listitem">
3625 If <code class="literal">&lt;packagename&gt;_PATCH</code> is defined, then patches from these
3626   tarballs are applied;
3627 </li><li class="listitem"><p class="simpara">
3628 If there are some <code class="literal">*.patch</code> files in the package’s Buildroot
3629   directory or in a package subdirectory named <code class="literal">&lt;packageversion&gt;</code>,
3630   then:
3631 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3632 If a <code class="literal">series</code> file exists in the package directory, then patches are
3633   applied according to the <code class="literal">series</code> file;
3634 </li><li class="listitem">
3635 Otherwise, patch files matching <code class="literal">&lt;packagename&gt;-*.patch</code>
3636   are applied in alphabetical order.
3637   So, to ensure they are applied in the right order, it is highly
3638   recommended to name the patch files like this:
3639   <code class="literal">&lt;packagename&gt;-&lt;number&gt;-&lt;description&gt;.patch</code>, where <code class="literal">&lt;number&gt;</code>
3640   refers to the <span class="emphasis"><em>apply order</em></span>.
3641 </li></ul></div></li><li class="listitem">
3642 If <code class="literal">BR2_GLOBAL_PATCH_DIR</code> is defined, the directories will be
3643   enumerated in the order they are specified. The patches are applied
3644   as described in the previous step.
3645 </li><li class="listitem">
3646 Run the <code class="literal">&lt;packagename&gt;_POST_PATCH_HOOKS</code> commands if defined.
3647 </li></ol></div><p>If something goes wrong in the steps <span class="emphasis"><em>3</em></span> or <span class="emphasis"><em>4</em></span>, then the build fails.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_format_and_licensing_of_the_package_patches"></a>18.3. Format and licensing of the package patches</h2></div></div></div><p>Patches are released under the same license as the software that is
3648 modified.</p><p>A message explaining what the patch does, and why it is needed, should
3649 be added in the header commentary of the patch.</p><p>You should add a <code class="literal">Signed-off-by</code> statement in the header of the each
3650 patch to help with keeping track of the changes and to certify that the
3651 patch is released under the same license as the software that is modified.</p><p>If the software is under version control, it is recommended to use the
3652 upstream SCM software to generate the patch set.</p><p>Otherwise, concatenate the header with the output of the
3653 <code class="literal">diff -purN package-version.orig/ package-version/</code> command.</p><p>At the end, the patch should look like:</p><pre class="screen">configure.ac: add C++ support test
3654
3655 Signed-off-by: John Doe &lt;john.doe@noname.org&gt;
3656
3657 --- configure.ac.orig
3658 +++ configure.ac
3659 @@ -40,2 +40,12 @@
3660
3661 AC_PROG_MAKE_SET
3662 +
3663 +AC_CACHE_CHECK([whether the C++ compiler works],
3664 +               [rw_cv_prog_cxx_works],
3665 +               [AC_LANG_PUSH([C++])
3666 +                AC_LINK_IFELSE([AC_LANG_PROGRAM([], [])],
3667 +                               [rw_cv_prog_cxx_works=yes],
3668 +                               [rw_cv_prog_cxx_works=no])
3669 +                AC_LANG_POP([C++])])
3670 +
3671 +AM_CONDITIONAL([CXX_WORKS], [test "x$rw_cv_prog_cxx_works" = "xyes"])</pre></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_integrating_patches_found_on_the_web"></a>18.4. Integrating patches found on the Web</h2></div></div></div><p>When integrating a patch of which you are not the author, you have to
3672 add a few things in the header of the patch itself.</p><p>Depending on whether the patch has been obtained from the project
3673 repository itself, or from somewhere on the web, add one of the
3674 following tags:</p><pre class="screen">Backported from: &lt;some commit id&gt;</pre><p>or</p><pre class="screen">Fetch from: &lt;some url&gt;</pre><p>It is also sensible to add a few words about any changes to the patch
3675 that may have been necessary.</p></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="download-infra"></a>Chapter 19. Download infrastructure</h2></div></div></div><p>TODO</p></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="debugging-buildroot"></a>Chapter 20. Debugging Buildroot</h2></div></div></div><p>It is possible to instrument the steps <code class="literal">Buildroot</code> does when building
3676 packages. Define the variable <code class="literal">BR2_INSTRUMENTATION_SCRIPTS</code> to contain
3677 the path of one or more scripts (or other executables), in a
3678 space-separated list, you want called before and after each step. The
3679 scripts are called in sequence, with three parameters:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3680 <code class="literal">start</code> or <code class="literal">end</code> to denote the start (resp. the end) of a step;
3681 </li><li class="listitem">
3682 the name of the step about to be started, or which just ended;
3683 </li><li class="listitem">
3684 the name of the package.
3685 </li></ul></div><p>For example :</p><pre class="screen">make BR2_INSTRUMENTATION_SCRIPTS="/path/to/my/script1 /path/to/my/script2"</pre><p>The list of steps is:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3686 <code class="literal">extract</code>
3687 </li><li class="listitem">
3688 <code class="literal">patch</code>
3689 </li><li class="listitem">
3690 <code class="literal">configure</code>
3691 </li><li class="listitem">
3692 <code class="literal">build</code>
3693 </li><li class="listitem">
3694 <code class="literal">install-host</code>, when a host-package is installed in <code class="literal">$(HOST_DIR)</code>
3695 </li><li class="listitem">
3696 <code class="literal">install-target</code>, when a target-package is installed in <code class="literal">$(TARGET_DIR)</code>
3697 </li><li class="listitem">
3698 <code class="literal">install-staging</code>, when a target-package is installed in <code class="literal">$(STAGING_DIR)</code>
3699 </li><li class="listitem">
3700 <code class="literal">install-image</code>, when a target-package installs files in <code class="literal">$(BINARIES_DIR)</code>
3701 </li></ul></div><p>The script has access to the following variables:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3702 <code class="literal">BR2_CONFIG</code>: the path to the Buildroot .config file
3703 </li><li class="listitem">
3704 <code class="literal">HOST_DIR</code>, <code class="literal">STAGING_DIR</code>, <code class="literal">TARGET_DIR</code>: see
3705     <a class="xref" href="#generic-package-reference" title="17.5.2. generic-package reference">Section 17.5.2, “<code class="literal">generic-package</code> reference”</a>
3706 </li><li class="listitem">
3707 <code class="literal">BUILD_DIR</code>: the directory where packages are extracted and built
3708 </li><li class="listitem">
3709 <code class="literal">BINARIES_DIR</code>: the place where all binary files (aka images) are
3710     stored
3711 </li><li class="listitem">
3712 <code class="literal">BASE_DIR</code>: the base output directory
3713 </li></ul></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="_contributing_to_buildroot"></a>Chapter 21. Contributing to Buildroot</h2></div></div></div><p>There are many ways in which you can contribute to Buildroot: analyzing
3714 and fixing bugs, analyzing and fixing package build failures detected by
3715 the autobuilders, testing and reviewing patches sent by other
3716 developers, working on the items in our TODO list and sending your own
3717 improvements to Buildroot or its manual. The following sections give a
3718 little more detail on each of these items.</p><p>If you are interested in contributing to Buildroot, the first thing you
3719 should do is to subscribe to the Buildroot mailing list. This list is
3720 the main way of interacting with other Buildroot developers and to send
3721 contributions to. If you aren’t subscribed yet, then refer to
3722 <a class="xref" href="#community-resources" title="Chapter 5. Community resources">Chapter 5, <em>Community resources</em></a> for the subscription link.</p><p>If you are going to touch the code, it is highly recommended to use a
3723 git repository of Buildroot, rather than starting from an extracted
3724 source code tarball. Git is the easiest way to develop from and directly
3725 send your patches to the mailing list. Refer to <a class="xref" href="#getting-buildroot" title="Chapter 3. Getting Buildroot">Chapter 3, <em>Getting Buildroot</em></a>
3726 for more information on obtaining a Buildroot git tree.</p><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_reproducing_analyzing_and_fixing_bugs"></a>21.1. Reproducing, analyzing and fixing bugs</h2></div></div></div><p>A first way of contributing is to have a look at the open bug reports in
3727 the <a class="ulink" href="https://bugs.busybox.net/buglist.cgi?product=buildroot" target="_top">Buildroot bug
3728 tracker</a>. As we strive to keep the bug count as small as possible, all
3729 help in reproducing, analyzing and fixing reported bugs is more than
3730 welcome. Don’t hesitate to add a comment to bug reports reporting your
3731 findings, even if you don’t yet see the full picture.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_analyzing_and_fixing_autobuild_failures"></a>21.2. Analyzing and fixing autobuild failures</h2></div></div></div><p>The Buildroot autobuilders are a set of build machines that continuously
3732 run Buildroot builds based on random configurations. This is done for
3733 all architectures supported by Buildroot, with various toolchains, and
3734 with a random selection of packages. With the large commit activity on
3735 Buildroot, these autobuilders are a great help in detecting problems
3736 very early after commit.</p><p>All build results are available at <a class="ulink" href="http://autobuild.buildroot.org" target="_top">http://autobuild.buildroot.org</a>,
3737 statistics are at <a class="ulink" href="http://autobuild.buildroot.org/stats.php" target="_top">http://autobuild.buildroot.org/stats.php</a>. Every day,
3738 an overview of all failed packages is sent to the mailing list.</p><p>Detecting problems is great, but obviously these problems have to be
3739 fixed as well. Your contribution is very welcome here! There are
3740 basically two things that can be done:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3741 Analyzing the problems. The daily summary mails do not contain details
3742   about the actual failures: in order to see what’s going on you have to
3743   open the build log and check the last output. Having someone doing
3744   this for all packages in the mail is very useful for other developers,
3745   as they can make a quick initial analysis based on this output alone.
3746 </li><li class="listitem"><p class="simpara">
3747 Fixing a problem. When fixing autobuild failures, you should follow
3748   these steps:
3749 </p><div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem">
3750 Check if you can reproduce the problem by building with the same
3751     configuration. You can do this manually, or use the
3752     <a class="ulink" href="http://git.buildroot.org/buildroot-test/tree/utils/br-reproduce-build" target="_top">br-reproduce-build</a>
3753     script that will automatically clone a Buildroot git repository,
3754     checkout the correct revision, download and set the right
3755     configuration, and start the build.
3756 </li><li class="listitem">
3757 Analyze the problem and create a fix.
3758 </li><li class="listitem">
3759 Verify that the problem is really fixed by starting from a clean
3760     Buildroot tree and only applying your fix.
3761 </li><li class="listitem">
3762 Send the fix to the Buildroot mailing list (see
3763     <a class="xref" href="#submitting-patches" title="21.5. Submitting patches">Section 21.5, “Submitting patches”</a>). In case you created a patch against the
3764     package sources, you should also send the patch upstream so that the
3765     problem will be fixed in a later release, and the patch in Buildroot
3766     can be removed.
3767     In the commit message of a patch fixing an autobuild failure, add a
3768     reference to the build result directory, as follows:
3769 </li></ol></div></li></ul></div><pre class="screen">Fixes http://autobuild.buildroot.org/results/51000a9d4656afe9e0ea6f07b9f8ed374c2e4069</pre></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_reviewing_and_testing_patches"></a>21.3. Reviewing and testing patches</h2></div></div></div><p>With the amount of patches sent to the mailing list each day, the
3770 maintainer has a very hard job to judge which patches are ready to apply
3771 and which ones aren’t. Contributors can greatly help here by reviewing
3772 and testing these patches.</p><p>In the review process, do not hesitate to respond to patch submissions
3773 for remarks, suggestions or anything that will help everyone to
3774 understand the patches and make them better. Please use internet
3775 style replies in plain text emails when responding to patch
3776 submissions.</p><p>To indicate approval of a patch, there are three formal tags that keep
3777 track of this approval. To add your tag to a patch, reply to it with the
3778 approval tag below the original author’s Signed-off-by line. These tags
3779 will be picked up automatically by patchwork (see
3780 <a class="xref" href="#apply-patches-patchwork" title="21.3.1. Applying Patches from Patchwork">Section 21.3.1, “Applying Patches from Patchwork”</a>) and will be part of the commit log when
3781 the patch is accepted.</p><div class="variablelist"><dl class="variablelist"><dt><span class="term">
3782 Tested-by
3783 </span></dt><dd>
3784 Indicates that the patch has been tested successfully.
3785   You are encouraged to specify what kind of testing you performed
3786   (compile-test on architecture X and Y, runtime test on target A,
3787   …). This additional information helps other testers and the
3788   maintainer.
3789 </dd><dt><span class="term">
3790 Reviewed-by
3791 </span></dt><dd>
3792 Indicates that you code-reviewed the patch and did your
3793   best in spotting problems, but you are not sufficiently familiar with
3794   the area touched to provide an Acked-by tag. This means that there
3795   may be remaining problems in the patch that would be spotted by
3796   someone with more experience in that area. Should such problems be
3797   detected, your Reviewed-by tag remains appropriate and you cannot
3798   be blamed.
3799 </dd><dt><span class="term">
3800 Acked-by
3801 </span></dt><dd>
3802 Indicates that you code-reviewed the patch and you are
3803   familiar enough with the area touched to feel that the patch can be
3804   committed as-is (no additional changes required). In case it later
3805   turns out that something is wrong with the patch, your Acked-by could
3806   be considered inappropriate. The difference between Acked-by and
3807   Reviewed-by is thus mainly that you are prepared to take the blame on
3808   Acked patches, but not on Reviewed ones.
3809 </dd></dl></div><p>If you reviewed a patch and have comments on it, you should simply reply
3810 to the patch stating these comments, without providing a Reviewed-by or
3811 Acked-by tag. These tags should only be provided if you judge the patch
3812 to be good as it is.</p><p>It is important to note that neither Reviewed-by nor Acked-by imply
3813 that testing has been performed. To indicate that you both reviewed and
3814 tested the patch, provide two separate tags (Reviewed/Acked-by and
3815 Tested-by).</p><p>Note also that <span class="emphasis"><em>any developer</em></span> can provide Tested/Reviewed/Acked-by
3816 tags, without exception, and we encourage everyone to do this. Buildroot
3817 does not have a defined group of <span class="emphasis"><em>core</em></span> developers, it just so happens
3818 that some developers are more active than others. The maintainer will
3819 value tags according to the track record of their submitter. Tags
3820 provided by a regular contributor will naturally be trusted more than
3821 tags provided by a newcomer. As you provide tags more regularly, your
3822 <span class="emphasis"><em>trustworthiness</em></span> (in the eyes of the maintainer) will go up, but <span class="emphasis"><em>any</em></span>
3823 tag provided is valuable.</p><p>Buildroot’s Patchwork website can be used to pull in patches for testing
3824 purposes. Please see <a class="xref" href="#apply-patches-patchwork" title="21.3.1. Applying Patches from Patchwork">Section 21.3.1, “Applying Patches from Patchwork”</a> for more
3825 information on using Buildroot’s Patchwork website to apply patches.</p><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="apply-patches-patchwork"></a>21.3.1. Applying Patches from Patchwork</h3></div></div></div><p>The main use of Buildroot’s Patchwork website for a developer is for
3826 pulling in patches into their local git repository for testing
3827 purposes.</p><p>When browsing patches in the patchwork management interface, an <code class="literal">mbox</code>
3828 link is provided at the top of the page. Copy this link address and
3829 run the following commands:</p><pre class="screen">$ git checkout -b &lt;test-branch-name&gt;
3830 $ wget -O - &lt;mbox-url&gt; | git am</pre><p>Another option for applying patches is to create a bundle. A bundle is
3831 a set of patches that you can group together using the patchwork
3832 interface. Once the bundle is created and the bundle is made public,
3833 you can copy the <code class="literal">mbox</code> link for the bundle and apply the bundle
3834 using the above commands.</p></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="_work_on_items_from_the_todo_list"></a>21.4. Work on items from the TODO list</h2></div></div></div><p>If you want to contribute to Buildroot but don’t know where to start,
3835 and you don’t like any of the above topics, you can always work on items
3836 from the <a class="ulink" href="http://elinux.org/Buildroot#Todo_list" target="_top">Buildroot TODO list</a>.
3837 Don’t hesitate to discuss an item first on the mailing list or on IRC.
3838 Do edit the wiki to indicate when you start working on an item, so we
3839 avoid duplicate efforts.</p></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="submitting-patches"></a>21.5. Submitting patches</h2></div></div></div><div class="note" style="margin-left: 0; margin-right: 10%;"><h3 class="title">Note</h3><p><span class="emphasis"><em>Please, do not attach patches to bugs, send them to the mailing list
3840 instead</em></span>.</p></div><p>If you made some changes to Buildroot and you would like to contribute
3841 them to the Buildroot project, proceed as follows. Starting from the
3842 changes committed in your local git view, <span class="emphasis"><em>rebase</em></span> your development
3843 branch on top of the upstream tree before generating a patch set. To do
3844 so, run:</p><pre class="screen">$ git fetch --all --tags
3845 $ git rebase origin/master</pre><p>Now, you are ready to generate then submit your patch set.</p><p>To generate it, run:</p><pre class="screen">$ git format-patch -M -n -s -o outgoing origin/master</pre><p>This will generate patch files in the <code class="literal">outgoing</code> subdirectory,
3846 automatically adding the <code class="literal">Signed-off-by</code> line.</p><p>Once patch files are generated, you can review/edit the commit message
3847 before submitting them, using your favorite text editor.</p><p>Lastly, send/submit your patch set to the Buildroot mailing list:</p><pre class="screen">$ git send-email --to buildroot@buildroot.org outgoing/*</pre><p>Note that <code class="literal">git</code> should be configured to use your mail account.
3848 To configure <code class="literal">git</code>, see <code class="literal">man git-send-email</code> or google it.</p><p>If you do not use <code class="literal">git send-email</code>, make sure posted <span class="strong"><strong>patches are not
3849 line-wrapped</strong></span>, otherwise they cannot easily be applied. In such a case,
3850 fix your e-mail client, or better yet, learn to use <code class="literal">git send-email</code>.</p><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_cover_letter"></a>21.5.1. Cover letter</h3></div></div></div><p>If you want to present the whole patch set in a separate mail, add
3851 <code class="literal">--cover-letter</code> to the <code class="literal">git format-patch</code> command (see <code class="literal">man
3852 git-format-patch</code> for further information). This will generate a
3853 template for an introduction e-mail to your patch series.</p><p>A <span class="emphasis"><em>cover letter</em></span> may be useful to introduce the changes you propose
3854 in the following cases:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3855 large number of commits in the series;
3856 </li><li class="listitem">
3857 deep impact of the changes in the rest of the project;
3858 </li><li class="listitem">
3859 RFC <a href="#ftn.idm139994497851168" class="footnote" id="idm139994497851168"><sup class="footnote">[4]</sup></a>;
3860 </li><li class="listitem">
3861 whenever you feel it will help presenting your work, your choices,
3862   the review process, etc.
3863 </li></ul></div></div><div class="section"><div class="titlepage"><div><div><h3 class="title"><a id="_patch_revision_changelog"></a>21.5.2. Patch revision changelog</h3></div></div></div><p>When improvements are requested, the new revision of each commit
3864 should include a changelog of the modifications between each
3865 submission. Note that when your patch series is introduced by a cover
3866 letter, an overall changelog may be added to the cover letter in
3867 addition to the changelog in the individual commits.
3868 The best thing to rework a patch series is by interactive rebasing:
3869 <code class="literal">git rebase -i origin/master</code>. Consult the git manual for more
3870 information.</p><p>When added to the individual commits, this changelog is added when
3871 editing the commit message. Below the <code class="literal">Signed-off-by</code> section, add
3872 <code class="literal">---</code> and your changelog.</p><p>Although the changelog will be visible for the reviewers in the mail
3873 thread, as well as in <a class="ulink" href="http://patchwork.buildroot.org" target="_top">patchwork</a>, <code class="literal">git</code>
3874 will automatically ignores lines below <code class="literal">---</code> when the patch will be
3875 merged. This is the intended behavior: the changelog is not meant to
3876 be preserved forever in the <code class="literal">git</code> history of the project.</p><p>Hereafter the recommended layout:</p><pre class="screen">Patch title: short explanation, max 72 chars
3877
3878 A paragraph that explains the problem, and how it manifests itself. If
3879 the problem is complex, it is OK to add more paragraphs. All paragraphs
3880 should be wrapped at 72 characters.
3881
3882 A paragraph that explains the root cause of the problem. Again, more
3883 than on paragraph is OK.
3884
3885 Finally, one or more paragraphs that explain how the problem is solved.
3886 Don't hesitate to explain complex solutions in detail.
3887
3888 Signed-off-by: John DOE &lt;john.doe@example.net&gt;
3889
3890 ---
3891 Changes v2 -&gt; v3:
3892   - foo bar  (suggested by Jane)
3893   - bar buz
3894
3895 Changes v1 -&gt; v2:
3896   - alpha bravo  (suggested by John)
3897   - charly delta</pre><p>Any patch revision should include the version number. The version number
3898 is simply composed of the letter <code class="literal">v</code> followed by an <code class="literal">integer</code> greater or
3899 equal to two (i.e. "PATCH v2", "PATCH v3" …).</p><p>This can be easily handled with <code class="literal">git format-patch</code> by using the option
3900 <code class="literal">--subject-prefix</code>:</p><pre class="screen">$ git format-patch --subject-prefix "PATCH v4" \
3901     -M -s -o outgoing origin/master</pre></div></div><div class="section"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a id="reporting-bugs"></a>21.6. Reporting issues/bugs or getting help</h2></div></div></div><p>Before reporting any issue, please check in
3902 <a class="link" href="#community-resources" title="Chapter 5. Community resources">the mailing list archive</a>
3903 <a class="xref" href="#community-resources" title="Chapter 5. Community resources">Chapter 5, <em>Community resources</em></a> whether someone has
3904 already reported and/or fixed a similar problem.</p><p>However you choose to report bugs or get help, either by
3905 opening a bug in the <a class="link" href="#community-resources" title="Chapter 5. Community resources">bug tracker</a>
3906 <a class="xref" href="#community-resources" title="Chapter 5. Community resources">Chapter 5, <em>Community resources</em></a> or by
3907 <a class="link" href="#community-resources" title="Chapter 5. Community resources">sending a mail to the mailing list</a>
3908 <a class="xref" href="#community-resources" title="Chapter 5. Community resources">Chapter 5, <em>Community resources</em></a>, there are
3909 a number of details to provide in order to help people reproduce and
3910 find a solution to the issue.</p><p>Try to think as if you were trying to help someone else; in
3911 that case, what would you need?</p><p>Here is a short list of details to provide in such case:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3912 host machine (OS/release)
3913 </li><li class="listitem">
3914 version of Buildroot
3915 </li><li class="listitem">
3916 target for which the build fails
3917 </li><li class="listitem">
3918 package(s) for which the build fails
3919 </li><li class="listitem">
3920 the command that fails and its output
3921 </li><li class="listitem">
3922 any information you think that may be relevant
3923 </li></ul></div><p>Additionally, you should add the <code class="literal">.config</code> file (or if you know how, a
3924 <code class="literal">defconfig</code>; see <a class="xref" href="#customize-store-buildroot-config" title="9.3. Storing the Buildroot configuration">Section 9.3, “Storing the Buildroot configuration”</a>).</p><p>If some of these details are too large, do not hesitate to use a
3925 pastebin service. Note that not all available pastebin services will
3926 preserve Unix-style line terminators when downloading raw pastes.
3927 Following pastebin services are known to work correctly:
3928 - <a class="ulink" href="https://gist.github.com/" target="_top">https://gist.github.com/</a>
3929 - <a class="ulink" href="http://code.bulix.org/" target="_top">http://code.bulix.org/</a></p></div><div class="footnotes"><br /><hr style="width:100; text-align:left;margin-left: 0" /><div id="ftn.idm139994497851168" class="footnote"><p><a href="#idm139994497851168" class="simpara"><sup class="simpara">[4] </sup></a>RFC: (Request for comments) change proposal</p></div></div></div></div><div class="part"><div class="titlepage"><div><div><h1 class="title"><a id="_appendix"></a>Part IV. Appendix</h1></div></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="makedev-syntax"></a>Chapter 22. Makedev syntax documentation</h2></div></div></div><p>The makedev syntax is used in several places in Buildroot to
3930 define changes to be made for permissions, or which device files to
3931 create and how to create them, in order to avoid calls to mknod.</p><p>This syntax is derived from the makedev utility, and more complete
3932 documentation can be found in the <code class="literal">package/makedevs/README</code> file.</p><p>It takes the form of a space separated list of fields, one file per
3933 line; the fields are:</p><div class="informaltable"><table cellpadding="4px" style="border-collapse: collapse;border-top: 3px solid #527bbd; border-bottom: 3px solid #527bbd; border-left: 3px solid #527bbd; border-right: 3px solid #527bbd; "><colgroup><col class="col_1" /><col class="col_2" /><col class="col_3" /><col class="col_4" /><col class="col_5" /><col class="col_6" /><col class="col_7" /><col class="col_8" /><col class="col_9" /><col class="col_10" /></colgroup><tbody><tr><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>name</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>type</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>mode</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>uid</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>gid</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>major</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>minor</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>start</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>inc</p></td><td style="" align="left" valign="top"><p>count</p></td></tr></tbody></table></div><p>There are a few non-trivial blocks:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3934 <code class="literal">name</code> is the path to the file you want to create/modify
3935 </li><li class="listitem"><p class="simpara">
3936 <code class="literal">type</code> is the type of the file, being one of:
3937 </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; "><li class="listitem">
3938 f: a regular file
3939 </li><li class="listitem">
3940 d: a directory
3941 </li><li class="listitem">
3942 r: a directory recursively
3943 </li><li class="listitem">
3944 c: a character device file
3945 </li><li class="listitem">
3946 b: a block device file
3947 </li><li class="listitem">
3948 p: a named pipe
3949 </li></ul></div></li><li class="listitem">
3950 <code class="literal">mode</code>, <code class="literal">uid</code> and <code class="literal">gid</code> are the usual permissions settings
3951 </li><li class="listitem">
3952 <code class="literal">major</code> and <code class="literal">minor</code> are here for device files - set to - for other
3953   files
3954 </li><li class="listitem">
3955 <code class="literal">start</code>, <code class="literal">inc</code> and <code class="literal">count</code> are for when you want to create a batch
3956   of files, and can be reduced to a loop, beginning at <code class="literal">start</code>,
3957   incrementing its counter by <code class="literal">inc</code> until it reaches <code class="literal">count</code>
3958 </li></ul></div><p>Let’s say you want to change the permissions of a given file; using
3959 this syntax, you will need to put:</p><pre class="screen">/usr/bin/foobar f 644 0 0 - - - - -</pre><p>Alternatively, if you want to change owner/permission of a directory
3960 recursively, you can put:</p><pre class="screen">/usr/share/myapp r 750 myuser myuser - - - - -</pre><p>On the other hand, if you want to create the device file <code class="literal">/dev/hda</code>
3961 and the corresponding 15 files for the partitions, you will need for
3962 <code class="literal">/dev/hda</code>:</p><pre class="screen">/dev/hda b 640 0 0 3 0 0 0 -</pre><p>and then for device files corresponding to the partitions of
3963 <code class="literal">/dev/hda</code>, <code class="literal">/dev/hdaX</code>, <code class="literal">X</code> ranging from 1 to 15:</p><pre class="screen">/dev/hda b 640 0 0 3 1 1 1 15</pre></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="makeuser-syntax"></a>Chapter 23. Makeusers syntax documentation</h2></div></div></div><p>The syntax to create users is inspired by the makedev syntax, above, but
3964 is specific to Buildroot.</p><p>The syntax for adding a user is a space-separated list of fields, one
3965 user per line; the fields are:</p><div class="informaltable"><table cellpadding="4px" style="border-collapse: collapse;border-top: 3px solid #527bbd; border-bottom: 3px solid #527bbd; border-left: 3px solid #527bbd; border-right: 3px solid #527bbd; "><colgroup><col class="col_1" /><col class="col_2" /><col class="col_3" /><col class="col_4" /><col class="col_5" /><col class="col_6" /><col class="col_7" /><col class="col_8" /><col class="col_9" /></colgroup><tbody><tr><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>username</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>uid</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>group</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>gid</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>password</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>home</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>shell</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p>groups</p></td><td style="" align="left" valign="top"><p>comment</p></td></tr></tbody></table></div><p>Where:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
3966 <code class="literal">username</code> is the desired user name (aka login name) for the user.
3967   It can not be <code class="literal">root</code>, and must be unique. If set to <code class="literal">-</code>, then just a
3968   group will be created.
3969 </li><li class="listitem">
3970 <code class="literal">uid</code> is the desired UID for the user. It must be unique, and not
3971   <code class="literal">0</code>. If set to <code class="literal">-1</code>, then a unique UID will be computed by Buildroot
3972   in the range [1000…1999]
3973 </li><li class="listitem">
3974 <code class="literal">group</code> is the desired name for the user’s main group. It can not
3975   be <code class="literal">root</code>. If the group does not exist, it will be created.
3976 </li><li class="listitem">
3977 <code class="literal">gid</code> is the desired GID for the user’s main group. It must be unique,
3978   and not <code class="literal">0</code>. If set to <code class="literal">-1</code>, and the group does not already exist, then
3979   a unique GID will be computed by Buildroot in the range [1000..1999]
3980 </li><li class="listitem">
3981 <code class="literal">password</code> is the crypt(3)-encoded password. If prefixed with <code class="literal">!</code>,
3982   then login is disabled. If prefixed with <code class="literal">=</code>, then it is interpreted
3983   as clear-text, and will be crypt-encoded (using MD5). If prefixed with
3984   <code class="literal">!=</code>, then the password will be crypt-encoded (using MD5) and login
3985   will be disabled. If set to <code class="literal">*</code>, then login is not allowed.
3986 </li><li class="listitem">
3987 <code class="literal">home</code> is the desired home directory for the user. If set to <span class="emphasis"><em>-</em></span>, no
3988   home directory will be created, and the user’s home will be <code class="literal">/</code>.
3989   Explicitly setting <code class="literal">home</code> to <code class="literal">/</code> is not allowed.
3990 </li><li class="listitem">
3991 <code class="literal">shell</code> is the desired shell for the user. If set to <code class="literal">-</code>, then
3992   <code class="literal">/bin/false</code> is set as the user’s shell.
3993 </li><li class="listitem">
3994 <code class="literal">groups</code> is the comma-separated list of additional groups the user
3995   should be part of. If set to <code class="literal">-</code>, then the user will be a member of
3996   no additional group. Missing groups will be created with an arbitrary
3997   <code class="literal">gid</code>.
3998 </li><li class="listitem">
3999 <code class="literal">comment</code> (aka <a class="ulink" href="https://en.wikipedia.org/wiki/Gecos_field" target="_top">GECOS</a>
4000   field) is an almost-free-form text.
4001 </li></ul></div><p>There are a few restrictions on the content of each field:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
4002 except for <code class="literal">comment</code>, all fields are mandatory.
4003 </li><li class="listitem">
4004 except for <code class="literal">comment</code>, fields may not contain spaces.
4005 </li><li class="listitem">
4006 no field may contain a colon (<code class="literal">:</code>).
4007 </li></ul></div><p>If <code class="literal">home</code> is not <code class="literal">-</code>, then the home directory, and all files below,
4008 will belong to the user and its main group.</p><p>Examples:</p><pre class="screen">foo -1 bar -1 !=blabla /home/foo /bin/sh alpha,bravo Foo user</pre><p>This will create this user:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
4009 <code class="literal">username</code> (aka login name) is: <code class="literal">foo</code>
4010 </li><li class="listitem">
4011 <code class="literal">uid</code> is computed by Buildroot
4012 </li><li class="listitem">
4013 main <code class="literal">group</code> is: <code class="literal">bar</code>
4014 </li><li class="listitem">
4015 main group <code class="literal">gid</code> is computed by Buildroot
4016 </li><li class="listitem">
4017 clear-text <code class="literal">password</code> is: <code class="literal">blabla</code>, will be crypt(3)-encoded, and login is disabled.
4018 </li><li class="listitem">
4019 <code class="literal">home</code> is: <code class="literal">/home/foo</code>
4020 </li><li class="listitem">
4021 <code class="literal">shell</code> is: <code class="literal">/bin/sh</code>
4022 </li><li class="listitem">
4023 <code class="literal">foo</code> is also a member of <code class="literal">groups</code>: <code class="literal">alpha</code> and <code class="literal">bravo</code>
4024 </li><li class="listitem">
4025 <code class="literal">comment</code> is: <code class="literal">Foo user</code>
4026 </li></ul></div><pre class="screen">test 8000 wheel -1 = - /bin/sh - Test user</pre><p>This will create this user:</p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem">
4027 <code class="literal">username</code> (aka login name) is: <code class="literal">test</code>
4028 </li><li class="listitem">
4029 <code class="literal">uid</code> is : <code class="literal">8000</code>
4030 </li><li class="listitem">
4031 main <code class="literal">group</code> is: <code class="literal">wheel</code>
4032 </li><li class="listitem">
4033 main group <code class="literal">gid</code> is computed by Buildroot, and will use the value defined in the rootfs skeleton
4034 </li><li class="listitem">
4035 <code class="literal">password</code> is empty (aka no password).
4036 </li><li class="listitem">
4037 <code class="literal">home</code> is <code class="literal">/</code> but will not belong to <code class="literal">test</code>
4038 </li><li class="listitem">
4039 <code class="literal">shell</code> is: <code class="literal">/bin/sh</code>
4040 </li><li class="listitem">
4041 <code class="literal">test</code> is not a member of any additional <code class="literal">groups</code>
4042 </li><li class="listitem">
4043 <code class="literal">comment</code> is: <code class="literal">Test user</code>
4044 </li></ul></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="package-list"></a>Chapter 24. List of target packages available in Buildroot</h2></div></div></div><div class="informaltable"><table cellpadding="4px" style="border-collapse: collapse;border-top: 3px solid #527bbd; border-bottom: 3px solid #527bbd; border-left: 3px solid #527bbd; border-right: 3px solid #527bbd; " width="100%"><colgroup><col class="col_1" /><col class="col_2" /></colgroup><thead><tr><th style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"> Packages                                 </th><th style="border-bottom: 1px solid #527bbd; " align="left" valign="top"> Target packages → …</th></tr></thead><tbody><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>a10disp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>acl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>acpid</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>adwaita icon theme</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>aespipe</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>agent++</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>aiccu</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>aircrack-ng</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>alsa-lib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>alsa-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>alsamixergui</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>am335x-pru-package</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>am33x-cm3</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling → Firmware</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>apache</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>apitrace</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>applewmproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>appres</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>apr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>apr-util</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>argp-standalone</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>argus</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>armadillo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>arptables</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>at</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>atftp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>atk</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>attr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>audiofile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>aumix</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>autossh</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>avahi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>avrdude</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>axel</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>b43-firmware</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling → Firmware</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bandwidthd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bash</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>batctl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bcache tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bcusdk</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bdftopcf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bdwgc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>beecrypt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>beforelight</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bellagio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>benejson</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>berkeleydb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bigreqsproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bind</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>binutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>biosdevname</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bitmap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Bitstream Vera</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>blackbox <span class="strong"><strong>(deprecated)</strong></span></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>blktrace</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bluez-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bluez-utils 5.x</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bmon</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>boa</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bonnie++</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>boost</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bootstrap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bootutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>botan</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bridge-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bsdiff</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>btrfs-progs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bullet</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bustle</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>BusyBox</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p></p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bwm-ng</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>bzip2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Compressors and decompressors</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>c-ares</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>c-periphery</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>CA Certificates</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cache-calibrator</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cairo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>can-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>canfestival</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cblas/clapack</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cc-tool</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ccid</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ccrypt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cdrkit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cegui06</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>celt051</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cgic</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cgilua</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>chrony</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cifs-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>civetweb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cJSON</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>clamav</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>classpath</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>collectd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>compositeproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>connman</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>conntrack-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>copas</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>coreutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cosmo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>coxpcall</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cppcms</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cppdb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cppunit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cppzmq</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cpuload</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cramfs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>crda</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cryptodev-linux</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto → cryptodev variant</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cryptsetup</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ctorrent</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cups <span class="strong"><strong>(deprecated)</strong></span></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>curlftpfs (FUSE)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cvs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cwiid</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>czmq</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dado</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>damageproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dash</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dbus</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dbus-c++</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dbus-glib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dbus-python</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dbus-triggerd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dcron</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>debianutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Declarative module</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>DejaVu fonts</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>devmem2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dhcp (ISC)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dhcpcd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dhcpdump</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dhrystone</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dialog</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>diffutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dillo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ding-libs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>directfb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>directfb examples</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>directfb virtual input extension</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dmalloc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dmidecode</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dmraid</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dmxproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dnsmasq</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>docker</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dosfstools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dovecot</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Mail</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dovecot-pigeonhole</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Mail</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>drbd-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dri2proto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dri3proto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dropbear</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dropwatch</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dsp-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dstat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dtach</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dtc (libfdt)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dtv-scan-tables</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>duma</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dvb-apps</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dvbsnoop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dvdauthor</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>dvdrw-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>e2fsprogs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>e2tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ebtables</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ecryptfs-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ed</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Text editors and viewers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>editres</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>eeprog</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>eigen</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ejabberd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>elfutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>empty</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>enchant</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>encodings</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>enlightenment</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Enlightenment Foundation Libraries</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>enscript</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>epoxy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-goldrush</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-lager</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-cache-tab</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-iconv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-sip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-stringprep</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-stun</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-tls</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-xml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-yaml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>erlang-p1-zlib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Erlang libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>espeak</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ethtool</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>eudev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>evemu</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>evtest</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>exFAT (FUSE)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>exfat-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>exim</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Mail</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>exiv2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>expat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>expect</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → tcl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>expedite</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>explorercanvas</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ezxml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>f2fs-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>faad2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>faifa</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fan-ctrl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fb-test-app</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fbdump (Framebuffer Capture Tool)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fbgrab</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fbset</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fbterm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fbv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fconfig</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fdk-aac</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>feh</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fetchmail</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Mail</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ffmpeg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fftw</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>file</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>filemq</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>findutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>firmware-imx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fis</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fixesproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>flac</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>flann</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>flashbench</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>flashrom</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>flex</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>flickcurl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>flite</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>flot</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fltk</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fluxbox</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fmc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fmlib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fmtools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-adobe-100dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-adobe-75dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-adobe-utopia-100dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-adobe-utopia-75dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-adobe-utopia-type1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-alias</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-arabic-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-bh-100dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-bh-75dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-bh-lucidatypewriter-100dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-bh-lucidatypewriter-75dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-bh-ttf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-bh-type1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-bitstream-100dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-bitstream-75dpi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-bitstream-type1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-cronyx-cyrillic</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-cursor-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-daewoo-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-dec-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-ibm-type1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-isas-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-jis-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-micro-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-misc-cyrillic</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-misc-ethiopic</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-misc-meltho</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-misc-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-mutt-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-schumacher-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-screen-cyrillic</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-sony-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-sun-misc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-util</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-winitzki-cyrillic</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>font-xfree86-type1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Fonts</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fontcacheproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fontconfig</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fontsproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fonttosfnt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>foomatic_filters <span class="strong"><strong>(deprecated)</strong></span></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fping</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>freeradius-client</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>freerdp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Freescale i.MX libraries</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>freetype</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fslsfonts</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fstobdf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fswebcam</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ftop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>fxload</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gadgetfs-test</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gamin</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Filesystem</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gawk</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gdb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gdbm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gdk-pixbuf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>genext2fs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>genpart</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>genromfs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>geoip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gesftpserver</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>getent</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gettext</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ghostscript-fonts</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>giblib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>giflib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>git</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>glib-networking</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>glibmm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>glm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>glmark2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>glproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gmp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gmpc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gnu-efi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gnuchess</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Games</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gnupg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gnupg2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gnuplot</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gnuradio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gnutls</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Google font directory</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>google-breakpad</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gperf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gpm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gpsd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gptfdisk</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gpu-amd-bin-mx51 (also imx53)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gpu-viv-bin-mx6q</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gqview</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>grantlee</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>grep</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gsl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-dsp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-ffmpeg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-fsl-plugins</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-omapfb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-omx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-plugin-x170</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-plugins-bad</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-plugins-base</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-plugins-good</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst-plugins-ugly</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst1-imx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst1-libav</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst1-plugins-bad</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst1-plugins-base</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst1-plugins-good</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst1-plugins-ugly</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gst1-validate</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gstreamer 0.10</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gstreamer 1.x</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gtest</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gtk engines</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gtkperf (performance test for GTK2)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>guile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gutenprint <span class="strong"><strong>(deprecated)</strong></span></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gvfs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gzip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Compressors and decompressors</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>hans</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>harfbuzz</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>haserl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>haveged</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>hdparm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>heirloom-mailx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Mail</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>hiawatha</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>hicolor icon theme</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>hostapd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>hplip <span class="strong"><strong>(deprecated)</strong></span></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>htop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>httping</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>hwdata</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>hwloc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>i2c-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iceauth</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ico</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>icu</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ifplugd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iftop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ifupdown</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>igh-ethercat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>igmpproxy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ijs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>imagemagick</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>imlib2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>imx-lib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>imx-vpu</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>inadyn</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>inconsolata</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>infozip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Compressors and decompressors</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>inotify-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>input-event-daemon</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>input-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>inputproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>intel-microcode</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>intltool</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iodine</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iostat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iotop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iozone</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iperf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iperf3</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ipkg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Package managers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ipmitool</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ipmiutil</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iproute2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iprutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ipsec-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ipset</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iptables</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iptraf-ng</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iputils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>irda-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>irqbalance</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iucode-tool</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>iw</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jack2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jamvm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jansson</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>janus-gateway</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jasper</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jhead</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jimtcl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>joe</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Text editors and viewers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jpeg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics → jpeg variant</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jpeg-turbo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics → jpeg variant</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jq</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jQuery</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jQuery keyboard</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jQuery UI</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jQuery UI themes</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jquery-mobile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jQuery-Sparkline</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jQuery-Validation</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jsmin</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>json-c</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>json-glib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>json-javascript</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Javascript</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jsoncpp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kbd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kbproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kexec</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kexec-lite</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>keyutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kismet</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kmod</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>knock</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kobs-ng</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kodi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kodi-addon-xvdr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kodi-audioencoder-flac</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kodi-audioencoder-lame</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kodi-audioencoder-vorbis</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kodi-audioencoder-wav</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>kodi-pvr-addons</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ktap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lame</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>latencytop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lbase64</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>LBreakout2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Games</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lcdapi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lcdproc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lcms2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>leafnode2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>leafpad</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>less</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Text editors and viewers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lesstif</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>leveldb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lftp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libaio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libao</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libarchive</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Compression and decompression</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libargtable2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libart</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libass</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libassuan</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libatasmart</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libatomic_ops</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libbluray</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libbsd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcap-ng</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcdaudio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcdio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcec</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcgi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcgicc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcgroup</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcli</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcofi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libconfig</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Filesystem</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libconfuse</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Filesystem</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcue</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcuefile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libcurl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdaemon</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdcadec</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdmtx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdmx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdnet</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdri2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdrm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdvbcsa</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdvbsi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdvdnav</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libdvdread</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libebml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libecore</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libedbus</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libedit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libedje</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libee</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libeet</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libefreet</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libeina</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libeio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libelementary</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libembryo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libenca</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Liberation (Free fonts)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libesmtp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Mail</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libestr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libethumb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libevas</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libevas generic loaders</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libevdev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libevent</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libexif</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libeXosip2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libfcgi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libffi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libfontenc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libfreefare</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libfreeimage</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libfribidi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libFS</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libfslcodec</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libfslparser</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libfslvpuwrap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libftdi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libftdi1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libfuse</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Filesystem</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgail</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgcrypt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgeotiff</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libglade</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libglew</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libglib2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libglu</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgpg-error</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgpgme</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgsasl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgtk2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgtk3</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libhid</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libical</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libICE</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libiconv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libid3tag</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libidn</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libiio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libinput</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libiqrf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libiscsi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libjson</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libksba</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>liblinear</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libllcp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>liblo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>liblockfile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Filesystem</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>liblog4c-localtime</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Logging</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>liblogging</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Logging</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmad</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmatroska</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmbim</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmbus</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmcrypt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmemcached</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmhash</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmicrohttpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmms</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmnl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmodbus</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmodplug</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmpdclient</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libmpeg2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libndp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libneon</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnetfilter_acct</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnetfilter_conntrack</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnetfilter_cthelper</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnetfilter_cttimeout</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnetfilter_log</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnetfilter_queue</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnfc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnfnetlink</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnfs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Filesystem</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnftnl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnice</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnspr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libnss</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>liboauth</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libogg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>liboping</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libosip2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libpcap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libpciaccess</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libpfm4</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libphidget</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libplayer</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libplist</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libpng</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libpthread-stubs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libpthsem</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libqmi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libqrencode</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libraw</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libraw1394</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libreplaygain</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>librsvg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>librsync</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>librtlsdr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>librtmp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsamplerate</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libseccomp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsecret</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libselinux</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Security</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsemanage</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Security</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsepol</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Security</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libserial</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libserialport</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsexy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsha1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libshairplay</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libshout</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsidplay2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsigc++</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsigrok</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsigrokdecode</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsigsegv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libSM</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsndfile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsoc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsocketcan</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsoup</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsoxr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsrtp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libssh2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libstrophe</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsvg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsvg-cairo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsvgtiny</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libsysfs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Filesystem</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libtasn1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libtheora</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libtirpc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libtool</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libtorrent</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libtpl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libubox</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libuci</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libungif <span class="strong"><strong>(deprecated)</strong></span></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libunistring</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libunwind</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libupnp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libupnpp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>liburcu</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>liburiparser</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libusb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libusb-compat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libuv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libv4l</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libva</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libva-intel-driver</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libvips</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libvncserver</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libvorbis</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libvpx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libwebsock</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libwebsockets</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libX11</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXau</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXaw</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libxcb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXcomposite</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXcursor</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXdamage</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXdmcp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXext</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXfixes</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXfont</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXft</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXinerama</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libxkbcommon</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libxkbfile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libxml++</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libxml2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libxmlrpc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXmu</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXpm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXrandr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXrender</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXres</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXScrnSaver</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libxshmfence</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libxslt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXtst</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXvMC</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXxf86dga</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libXxf86vm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libyaml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libz160</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libzip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Compression and decompression</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lightning</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lighttpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>linenoise</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>linknx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>links</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>linphone</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>linux-firmware</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling → Firmware</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>linux-fusion communication layer for DirectFB multi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>linux-pam</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>linux-zigbee</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lirc-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>listres</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>LiTE (toolbox engine)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>live555</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ljlinenoise</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ljsyscall</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lm-sensors</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lmbench</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lockdev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Filesystem</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lockfile programs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>log4cplus</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Logging</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>log4cxx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Logging</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>logrotate</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>logsurfer</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lpeg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lpty</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lrandom</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lrzsz</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lshw</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lsof</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lsqlite3</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lsuio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ltp-testsuite</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ltrace</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>LTris</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Games</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lttng-babeltrace</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lttng-libust</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lttng-modules</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lttng-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua-cjson</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua-coat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua-coatpersistent</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua-csnappy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua-ev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua-messagepack</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua-msgpack-native</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua-periphery</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lua-testmore</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luabitop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luacrypto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luaexpat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luaexpatutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luafilesystem</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luajit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luajson</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lualogging</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luaposix</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luasec</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luasocket</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luasql-sqlite3</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lunit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lvm2 &amp; device mapper</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lxc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lz4</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Compressors and decompressors</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lzip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Compressors and decompressors</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lzlib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lzo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Compression and decompression</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>lzop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Compressors and decompressors</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>macchanger</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>madplay</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>make</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>makedepend</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>makedevs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Matchbox Desktop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Matchbox Panel</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Matchbox session common files</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Matchbox Virtual Keyboard</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>MatchBox Window Manager</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Text editors and viewers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mcelog</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mcookie</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mcrypt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mdadm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>media-ctl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mediastreamer</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>memcached</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>memstat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>memtest86</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>memtester</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mesa3d</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mesa3d-demos</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>metacity</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>midori</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mii-diag</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Mini-XML</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>minicom</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>minidlna</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mjpegtools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mjpg-streamer</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mkfontdir</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mkfontscale</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mmc-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mobile-broadband-provider-info</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>modemmanager</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>modplugtools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mongoose</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mongrel2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>monit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mono</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mosquitto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mp4v2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mpc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mpd-mpc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mpdecimal</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mpfr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mpg123</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mplayer</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mrouted</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>msgpack</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>msmtp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Mail</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mtd, jffs2 and ubi/ubifs tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mtdev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mtdev2tuio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mtools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mtr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Multimedia Module</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>musepack</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>mutt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Mail</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>MySQL</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nano</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Text editors and viewers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nanocom</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nbd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ncdu</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ncftp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ncmpc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ncurses</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ndisc6 tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ne10</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>neard</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>neardal</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>net-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>netatalk</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>netcat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>netcat-openbsd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>netperf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>netplug</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>netsnmp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>netstat-nat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nettle</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>networkmanager</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>newt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nfacct</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nfs-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nftables</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nginx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ngircd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ngrep</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nmap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nodejs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>noip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nss-mdns</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ntfs-3g</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ntp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>numactl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nut</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nuttcp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nvidia-driver</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nvidia-tegra23</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nvidia-tegra23 binaries</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>nvidia-tegra23 codecs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ocf-linux</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto → cryptodev variant</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>oclock</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ocrad</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>odhcp6c</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>odhcploc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ofono</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ola (open lighting architecture)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>olsrd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>omniorb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>on2-8170-libs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>on2-8170-modules</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>open-plc-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>open2300</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>opencore-amr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>opencv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openjpeg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openldap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openntpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openobex</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openocd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openpgm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openpowerlink</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openssh</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openssl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openswan</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>OpenTyrian</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Games</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>OpenTyrian data</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Games</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openvmtools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>openvpn</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>opkg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Package managers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>oprofile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>opus</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>opus-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>opusfile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>orbit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>orc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>oRTP</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>owl-linux</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>p11-kit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>p910nd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pango</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>parted</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>patch</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pax-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pciutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pcmanfm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pcre</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pcsc-lite</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-crypt-openssl-random</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-crypt-openssl-rsa</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-datetime-tiny</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-db-file</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-digest-hmac</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-digest-sha1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-encode-detect</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-encode-locale</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-file-listing</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-file-util</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-gd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-gdgraph</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-gdtextutil</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-html-parser</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-html-tagset</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-http-cookies</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-http-daemon</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-http-date</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-http-message</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-http-negotiate</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-io-html</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-io-socket-ssl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-json-tiny</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-libwww-perl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-lwp-mediatypes</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-mail-dkim</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-mailtools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-mime-base64</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-mojolicious</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-net-dns</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-net-http</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-net-ssleay</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-netaddr-ip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-path-tiny</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-time-hires</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-timedate</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-try-tiny</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-uri</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-www-robotrules</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-xml-libxml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-xml-namespacesupport</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-xml-sax</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>perl-xml-sax-base</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Perl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>phidgetwebservice</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>php</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>php-geoip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → External php extensions</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>php-gnupg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → External php extensions</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>php-imagick</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → External php extensions</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>php-memcached</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → External php extensions</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>php-ssh2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → External php extensions</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>php-yaml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → External php extensions</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>php-zmq</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → External php extensions</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>picocom</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pifmrds</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pinentry</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pixman</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pkgconf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>poco</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>polarssl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Crypto</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>polkit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>poppler</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>popt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>portaudio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>portmap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>postgresql</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>powerpc-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>powertop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pppd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pps-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pptp-linux</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>prboom</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Games</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>presentproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>procps-ng</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>proftpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>protobuf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>protobuf-c</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>proxychains-ng</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>psmisc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>psplash</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ptpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ptpd2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pulseaudio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pulseview</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pure-ftpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>pwgen</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-alsaaudio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-bottle</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-certifi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-cffi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-cheetah</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-cherrypy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-coherence</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-configobj</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-configshell-fb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-crc16</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-daemon</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-dialog</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-django</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-docopt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-dpkt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-enum</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-enum34</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-flask</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-flup</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-gobject</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-httplib2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-id3</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-ipaddr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-ipy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-ipython</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-itsdangerous</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-jinja2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-json-schema-validator</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-keyring</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-libconfig</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-lxml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-mad</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-mako</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-markdown</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-markupsafe</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-meld3</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-msgpack</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-netifaces</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-networkmanager</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-nfc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-numpy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pam</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-posix-ipc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-protobuf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-psutil</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pyasn</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pycrypto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pyftpdlib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pygame</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pyinotify</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pyparsing</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pypcap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pyqt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pyro</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pysendfile</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pysnmp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pysnmp-apps</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pysnmp-mibs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pyusb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pyxb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-pyzmq</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-requests</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-rtslib-fb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-serial</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-setuptools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-simplejson</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-sip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-six</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-spidev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-thrift</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-tornado</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-twisted</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-urwid</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-versiontools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-webpy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-werkzeug</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-ws4py</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python-zope-interface</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → external python modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>python3</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qdecoder</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>QEMU</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qextserialport</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qhull</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qjson</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qlibc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qpdf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Qt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt-webkit-kiosk</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Qt5</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5base</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5cinex</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5connectivity</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5declarative</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5enginio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5graphicaleffects</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5imageformats</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5multimedia</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5quick1</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5quickcontrols</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5script</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5sensors</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5serialport</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5svg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5webkit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5webkit examples</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5websockets</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5x11extras</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qt5xmlpatterns</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qtuio</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>quagga</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>quota</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>qwt</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>radvd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ramspeed</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ramspeed/smp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>randrproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rapidjson</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rdesktop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>read-edid</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>readline</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>recordproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>redis</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>renderproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>resourceproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rgb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rings</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rng-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>roxml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rp-pppoe</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rpcbind</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rpi-firmware</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling → Firmware</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rpi-userland</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rpm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Package managers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rrdtool</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rsh-redone</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rstart</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rsync</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rsyslog</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rt-tests</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rtai</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Real-Time</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rtorrent</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rtptools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>rubix</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Games</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ruby</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>samba <span class="strong"><strong>(deprecated)</strong></span></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>samba4</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sane-backends</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SawMan (Window Manager)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>schifra</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sconeserver</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>screen</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Script Module</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>scripts</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>scrnsaverproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SDL</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SDL_gfx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SDL_image</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SDL_mixer</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SDL_net</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SDL_sound</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SDL_TTF</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sdparm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sed</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ser2net</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sessreg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>setserial</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>setxkbmap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sg3-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>shairport-sync</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>shared-mime-info</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>shareware Doom WAD file</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Games</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>showfont</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sigrok-cli</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>simicsfs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sispmctl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Games</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>slang</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>slirp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>smack</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>smartmontools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>smcroute</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>smproxy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>smstools3</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>snappy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Compression and decompression</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>snmp++</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>snowball-hdmiservice</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>snowball-init</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>socat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>socketcand</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sofia-sip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>softether</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sound-theme-borealis</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sound-theme-freedesktop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Fonts, icons, sounds and themes</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sox</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>spawn-fcgi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>speex</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>spice protocol</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>spice server</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>spidev_test</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sqlcipher</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sqlite</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>squashfs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>squid</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sredird</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sshfs (FUSE)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sshpass</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sstrip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>start-stop-daemon</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>startup-notification</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Other</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>statserial</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>strace</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>stress</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>strongswan</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>stunnel</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>subversion</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sudo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sunxi nand-part</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sunxi script.bin board file</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling → Firmware</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sunxi-cedarx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sunxi-mali</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>supervisor</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SVG Module</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sylpheed</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Mail</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>synergy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sysdig</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>syslogd &amp; klogd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sysprof</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sysstat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>systemd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sysvinit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>szip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Compression and decompression</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>taglib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tar</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>targetcli-fb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tcl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tclap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tcllib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → tcl libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tcpdump</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tcping</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tcpreplay</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tftpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>thrift</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>thttpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ti-gfx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ti-uim</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ti-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tidsp-binaries</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tiff</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>time</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tinc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tinyalsa</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tinyhttpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tinymembench</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tinyxml</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tinyxml2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tmux</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tn5250</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tor</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>torsmo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tovid</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>trace-cmd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>transmission</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tree</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tremor (fixed point vorbis decoder)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>triggerhappy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>trinity</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tslib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tstools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>tvheadend</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>twm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>twolame</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>u-boot tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>udisks</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>udpcast</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>uemacs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Text editors and viewers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ulogd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>unionfs (FUSE)</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>unixodbc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Database</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>upmpdcli</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>urg</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>usb_modeswitch</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>usb_modeswitch_data</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>usbmount</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>usbredir</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>usbutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ushare</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ussp-push</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ustr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Text and terminal handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>util-linux</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ System tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>util-macros</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ux500-firmware</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling → Firmware</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>valgrind</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>vde2</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>videoproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>viewres</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>vim</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Text editors and viewers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>vlc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>vnstat</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>vo-aacenc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>vorbis-tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>vpnc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>vsftpd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>vtun</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>w_scan</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wavpack</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wayland</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>webkit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>WebKit Module</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>webp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>webrtc-audio-processing</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Audio/Sound</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>weston</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wf111</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wget</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>whetstone</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Debugging, profiling and benchmark</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>which</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>whois</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>windowswmproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wine</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Miscellaneous</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wipe</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wireless tools</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wireless-regdb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wireshark</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wmctrl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wpa_supplicant</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wsapi</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wvdial</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>wvstreams</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>x11perf</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>x11vnc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>x264</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Multimedia</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xauth</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xavante</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Interpreter languages and scripting → Lua libraries/modules</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xbacklight</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xbiff</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xbitmaps</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Other data</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcalc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcb-proto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcb-util</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcb-util-cursor</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcb-util-image</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcb-util-keysyms</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcb-util-renderutil</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcb-util-wm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xclipboard</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xclock</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcmiscproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcmsdb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcompmgr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xconsole</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcursor-transparent-theme</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Other data</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xcursorgen</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xdata_xcursor-themes</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Other data</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xdbedizzy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xditview</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xdm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xdpyinfo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xdriinfo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xedit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Xenomai Userspace</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Real-Time</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xerces-c++</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xextproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xeyes</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-evdev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-joystick</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-keyboard</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-libinput</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-mouse</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-synaptics</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-tslib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-vmmouse</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-void <span class="strong"><strong>(deprecated)</strong></span></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-ark</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-ast</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-ati</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-cirrus</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-dummy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-fbdev</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-geode</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-glide</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-glint</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-i128</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-imx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-imx-viv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-intel</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-mach64</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-mga</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-neomagic</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-nv</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-openchrome</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-r128</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-savage</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-siliconmotion</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-sis</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-tdfx</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-tga</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-trident</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-v4l</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-vesa</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-vmware</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-voodoo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-video-wsfb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86bigfontproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86dga</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86dgaproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86driproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86vidmodeproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xfd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xfindproxy</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xfontsel</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xfs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xfsinfo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xfsprogs</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Filesystem and flash utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xgamma</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xgc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xhost</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xineramaproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xinetd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xinit</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xinput</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xinput-calibrator</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xkbcomp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xkbevd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xkbprint</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xkbutils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xkeyboard-config</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xkill</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xl2tp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xload</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xlogo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xlsatoms</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xlsclients</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xlsfonts</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xmag</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xman</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xmessage</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xmh</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>XML Patterns Module</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xmlstarlet</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xmodmap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xmore</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xorg-server</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Servers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xorriso</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xpr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xprop</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xproto</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xproxymanagementprotocol</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 X protocols</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xrandr</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xrdb</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xrefresh</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xscreensaver</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xset</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xsetmode</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xsetpointer</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xsetroot</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xsm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xstdcmap</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xtables-addons</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xterm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xtrans</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Libraries</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xvidtune</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xvinfo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xvkbd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xwd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xwininfo</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xwud</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Graphic libraries and applications (graphic/text) → X11R7 Applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xz-utils</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Compressors and decompressors</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>yajl</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>yaml-cpp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → JSON/XML</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>yasm</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Development tools</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>yavta</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>ympd</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Audio and video applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>zd1211-firmware</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Hardware handling → Firmware</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>zeromq</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>zlib</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Compression and decompression</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>zlog</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Logging</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>zmqpp</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Networking</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>znc</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>zsh</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Shell and utilities</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>zxing</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>→ Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; " align="center" valign="top"><p>zyre</p></td><td style="" align="left" valign="top"><p>→ Libraries → Networking</p></td></tr></tbody></table></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="virtual-package-list"></a>Chapter 25. List of virtual packages</h2></div></div></div><p>These are the virtual packages known to <code class="literal">Buildroot</code>, with the
4045 corresponding symbols and providers.</p><div class="informaltable"><table cellpadding="4px" style="border-collapse: collapse;border-top: 3px solid #527bbd; border-bottom: 3px solid #527bbd; border-left: 3px solid #527bbd; border-right: 3px solid #527bbd; " width="100%"><colgroup><col class="col_1" /><col class="col_2" /><col class="col_3" /></colgroup><thead><tr><th style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"> Virtual packages     </th><th style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"> Symbols                          </th><th style="border-bottom: 1px solid #527bbd; " align="left" valign="top"> Providers</th></tr></thead><tbody><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cryptodev</p></td><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_CRYPTODEV</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>cryptodev-linux, ocf-linux</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>jpeg</p></td><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_JPEG</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>jpeg, jpeg-turbo</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libegl</p></td><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_LIBEGL</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>mesa3d (w/ OpenGL EGL), gpu-amd-bin-mx51 (also imx53), gpu-viv-bin-mx6q, nvidia-driver (w/ X.org drivers), nvidia-tegra23 binaries, rpi-userland, sunxi-mali, ti-gfx</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgl</p></td><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_LIBGL</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>mesa3d (w/ DRI swrast driver), mesa3d (w/ DRI i915 driver), mesa3d (w/ DRI i965 driver), mesa3d (w/ DRI radeon driver), xf86-video-imx-viv, nvidia-driver (w/ X.org drivers)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libgles</p></td><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_LIBGLES</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>mesa3d (w/ OpenGL ES), gpu-amd-bin-mx51 (also imx53), gpu-viv-bin-mx6q, nvidia-driver (w/ X.org drivers), nvidia-tegra23 binaries, rpi-userland, sunxi-mali, ti-gfx</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libopenmax</p></td><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_LIBOPENMAX</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>bellagio, nvidia-tegra23 binaries, rpi-userland</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libopenvg</p></td><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_LIBOPENVG</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>gpu-amd-bin-mx51 (also imx53), gpu-viv-bin-mx6q, rpi-userland</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>luainterpreter</p></td><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_LUAINTERPRETER</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>lua, luajit</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>powervr</p></td><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_POWERVR</code></p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>ti-gfx</p></td></tr><tr><td style="border-right: 1px solid #527bbd; " align="center" valign="top"><p>udev</p></td><td style="border-right: 1px solid #527bbd; " align="left" valign="top"><p><code class="literal">BR2_PACKAGE_HAS_UDEV</code></p></td><td style="" align="left" valign="top"><p>eudev, systemd</p></td></tr></tbody></table></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="host-package-list"></a>Chapter 26. List of host utilities available in Buildroot</h2></div></div></div><p>The following packages are all available in the menu <code class="literal">Host utilities</code>.</p><div class="informaltable"><table cellpadding="4px" style="border-collapse: collapse;border-top: 3px solid #527bbd; border-bottom: 3px solid #527bbd; border-left: 3px solid #527bbd; border-right: 3px solid #527bbd; " width="30%"><colgroup><col class="col_1" /></colgroup><thead><tr><th style="border-bottom: 1px solid #527bbd; " align="center" valign="top"> Packages</th></tr></thead><tbody><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host checkpolicy</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host cramfs</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host dfu-util</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host dos2unix</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host dosfstools</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host e2fsprogs</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host e2tools</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host genext2fs</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host genimage</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host genpart</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host lpc3250loader</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host mke2img</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host mtd, jffs2 and ubi/ubifs tools</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host mtools</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host omap-u-boot-utils</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host openocd</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host parted</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host patchelf</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host pwgen</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host qemu</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host sam-ba</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host squashfs</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host sunxi-tools</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host u-boot tools</p></td></tr><tr><td style="border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>host util-linux</p></td></tr><tr><td style="" align="center" valign="top"><p>host-imx-usb loader</p></td></tr></tbody></table></div></div><div class="chapter"><div class="titlepage"><div><div><h2 class="title"><a id="deprecated-list"></a>Chapter 27. Deprecated features</h2></div></div></div><p>The following features are marked as <span class="emphasis"><em>deprecated</em></span> in Buildroot due to
4046 them being either too old or unmaintained. They will be removed at
4047 some point, so stop using them.
4048 Each deprecated symbol in kconfig depends on a symbol
4049 <code class="literal">BR2_DEPRECATED_SINCE_xxxx_xx</code>, which provides an indication of when
4050 the feature can be removed: features will not be removed within the
4051 year following deprecation. For example, a symbol depending on
4052 <code class="literal">BR2_DEPRECATED_SINCE_2013_05</code> can be removed from 2014.05 onwards.</p><div class="informaltable"><table cellpadding="4px" style="border-collapse: collapse;border-top: 3px solid #527bbd; border-bottom: 3px solid #527bbd; border-left: 3px solid #527bbd; border-right: 3px solid #527bbd; " width="100%"><colgroup><col class="col_1" /><col class="col_2" /></colgroup><thead><tr><th style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"> Features                                 </th><th style="border-bottom: 1px solid #527bbd; " align="left" valign="top"> Location</th></tr></thead><tbody><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>SuperH64</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Target options → Target Architecture</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>sstrip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Build options → strip command for binaries on target</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Linux 3.0.x kernel headers</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Toolchain → Kernel Headers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Linux 3.11.x kernel headers</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Toolchain → Kernel Headers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Linux 3.13.x kernel headers</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Toolchain → Kernel Headers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Linux 3.15.x kernel headers</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Toolchain → Kernel Headers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Linux 3.16.x kernel headers</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Toolchain → Kernel Headers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>Linux 3.17.x kernel headers</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Toolchain → Kernel Headers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gcc 4.5.x</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Toolchain → GCC compiler Version</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gdb 7.7.x</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Toolchain → GDB debugger Version</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>xf86-input-void</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Target packages → Graphic libraries and applications (graphic/text) → X11R7 Drivers</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>blackbox</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Target packages → Graphic libraries and applications (graphic/text)</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>libungif</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Target packages → Libraries → Graphics</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>cups</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Target packages → Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>foomatic_filters</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Target packages → Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>gutenprint</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Target packages → Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>hplip</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Target packages → Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>samba</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Target packages → Networking applications</p></td></tr><tr><td style="border-right: 1px solid #527bbd; border-bottom: 1px solid #527bbd; " align="center" valign="top"><p>custom patch dir</p></td><td style="border-bottom: 1px solid #527bbd; " align="left" valign="top"><p>Bootloaders</p></td></tr><tr><td style="border-right: 1px solid #527bbd; " align="center" valign="top"><p>Custom Network Settings</p></td><td style="" align="left" valign="top"><p>Bootloaders</p></td></tr></tbody></table></div></div></div></div></body></html>