menuconfig

Menuconfig
menuconfig for Linux version 3.10.0-rc2
Written in C
Operating system GNU/Linux
Type build automation tool
License GNU General Public License
Website www.kernel.org

make menuconfig is one of five similar tools that can configure Linux source, a necessary early step needed to compile the source code. make menuconfig, with a menu-driven user interface, allows the user to choose the features of Linux (and other options) that will be compiled. It is normally invoked using the command make menuconfig, menuconfig is a target in Linux Makefile.

History

make menuconfig was not in the first version of Linux. The predecessor tool is a question-and-answer-based utility (make config, make oldconfig). A third tool for Linux configuration is make xconfig, which requires Qt. There is also make gconfig, which uses GTK+, and make nconfig, which is similar to make menuconfig.

All these tools use internally Kconfig language. Kconfig is also used in other projects, such as bootloader Das U-Boot and tool for generating embedded Linux systems Buildroot.

Advantages over earlier versions

Despite being a simple design, make menuconfig offers considerable advantages to the question-and-answer-based configuration tool make oldconfig, the most notable being a basic search system and the ability to load and save files with filenames different from “.config”. make menuconfig gives the user an ability to navigate forwards or backwards directly between features, rather than using make config by pressing the ↵ Enter key many, many times just to navigate linearly to the configuration for a specific feature.

If the user is satisfied with a previous .config file, using make oldconfig uses this previous file to answer all questions that it can, only interactively presenting the new features. This is intended for a version upgrade, but may be appropriate at other times.

make menuconfig is a light load on system resources unlike make xconfig (uses Qt as of version 2.6.31.1, formerly Tk) or make gconfig, which utilizes GTK+. It's possible to ignore most of the features with make config, and doing so makes it more likely that one will configure an incomplete or oversized kernel. It's recommended to start with the .config file included with GNU/Linux distribution, which makes it easier to configure a custom kernel.

Better than editing the .config by hand, make menuconfig shows the descriptions of each feature (?), and adds some (primitive in version 2.6.31.1) dependency checking. With make oldconfig, dependency checking can be done in one step, but requires the user to locate the features that were changed, by hand, to be sure that the needed ones are still enabled.

Practically, using both make menuconfig and make oldconfig, diff, (also cvs and a decent text editor) provides the most flexibility and most dependability. Configuring Linux is a significant labor, so users are strongly advised to make backups of it (i.e. cp /usr/src/linux*/.config ~/savemywork.config).

The help information is distributed throughout the kernel source tree in the various files called Kconfig.

Dependencies

To use make menuconfig, Linux source is a requirement, a make tool, a C compiler, and the ncurses library.

Key strokes

Main Key strokes
Key stroke Meaning
?Option description and tips/Help
PgUp PgDnNavigate through the kernel features and menuconfig commands.
Esc+EscExit menuconfig or cancel the command.
↵ EnterActivate a command, or expand a branch.
yCompile and include this feature inside of the kernel.
mCompile this feature as a module, separate from the kernel.
nDo not compile the feature.
/Search configuration parameter.

Symbols

To the left of the features is the setting (y, M, or empty) enclosed in two punctuation marks.

Dependency information
Symbol Meaning
< >No dependencies.
[ ]A dependency requires this to be compiled-in (y), or not compiled (n).
{ }A dependency requires this to be a module (m) or compiled-in (y).
- -A dependency requires this to be compiled-in (y).

Note that the supplied dependency information is primitive, it does not tell you the names of the depentant features.

Other symbols
Symbol Meaning
--->Use ↵ Enter to expand this branch as a new window.
(Experimental)Less/Unstable code, beware.
(New)An option not in an old version of Linux.

The user is encouraged to read the GNU/Linux README, since there are also many other make targets (beyond modules_install and install). Each will configure the kernel, but with different features activated, or using a different interactive interface.

simple (but effective) workflow

  1. make menuconfig
  2. Next build the compressed kernel and its modules, a long process. make.
  3. Install using your favorite method such as make modules_install, make install.

See also

References

    This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.