changes.rst 12.6 KB
Newer Older
1 2
.. _changes:

3
Minimal requirements to compile the Kernel
4 5
++++++++++++++++++++++++++++++++++++++++++

L
Linus Torvalds 已提交
6 7 8 9
Intro
=====

This document is designed to provide a list of the minimum levels of
10
software necessary to run the 4.x kernels.
L
Linus Torvalds 已提交
11 12 13 14 15 16 17

This document is originally based on my "Changes" file for 2.0.x kernels
and therefore owes credit to the same people as that file (Jared Mauch,
Axel Boldt, Alessandro Sigala, and countless other users all over the
'net).

Current Minimal Requirements
18
****************************
L
Linus Torvalds 已提交
19

20
Upgrade to at **least** these software revisions before thinking you've
L
Linus Torvalds 已提交
21 22 23
encountered a bug!  If you're unsure what version you're currently
running, the suggested command should tell you.

24 25 26 27
Again, keep in mind that this list assumes you are already functionally
running a Linux kernel.  Also, not all tools are necessary on all
systems; obviously, if you don't have any ISDN hardware, for example,
you probably needn't concern yourself with isdn4k-utils.
L
Linus Torvalds 已提交
28

29 30 31 32
====================== ===============  ========================================
        Program        Minimal version       Command to check the version
====================== ===============  ========================================
GNU C                  3.2              gcc --version
33
GNU make               3.81             make --version
34
binutils               2.20             ld -v
35 36
flex                   2.5.35           flex --version
bison                  2.0              bison --version
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
util-linux             2.10o            fdformat --version
module-init-tools      0.9.10           depmod -V
e2fsprogs              1.41.4           e2fsck -V
jfsutils               1.1.3            fsck.jfs -V
reiserfsprogs          3.6.3            reiserfsck -V
xfsprogs               2.6.0            xfs_db -V
squashfs-tools         4.0              mksquashfs -version
btrfs-progs            0.18             btrfsck
pcmciautils            004              pccardctl -V
quota-tools            3.09             quota -V
PPP                    2.4.0            pppd --version
isdn4k-utils           3.1pre1          isdnctrl 2>&1|grep version
nfs-utils              1.0.5            showmount --version
procps                 3.2.0            ps --version
oprofile               0.9              oprofiled --version
udev                   081              udevd --version
grub                   0.93             grub --version || grub-install --version
mcelog                 0.6              mcelog --version
iptables               1.4.2            iptables -V
openssl & libcrypto    1.0.0            openssl version
bc                     1.06.95          bc --version
58
Sphinx\ [#f1]_	       1.3		sphinx-build --version
59
====================== ===============  ========================================
60

61
.. [#f1] Sphinx is needed only to build the Kernel documentation
L
Linus Torvalds 已提交
62 63

Kernel compilation
64
******************
L
Linus Torvalds 已提交
65 66 67 68 69

GCC
---

The gcc version requirements may vary depending on the type of CPU in your
A
Andrew Morton 已提交
70
computer.
L
Linus Torvalds 已提交
71 72 73 74

Make
----

75
You will need GNU make 3.81 or later to build the kernel.
L
Linus Torvalds 已提交
76 77 78 79

Binutils
--------

80
The build system has, as of 4.13, switched to using thin archives (`ar T`)
81
rather than incremental linking (`ld -r`) for built-in.a intermediate steps.
82
This requires binutils 2.20 or newer.
L
Linus Torvalds 已提交
83

84 85 86 87 88 89 90 91
pkg-config
----------

The build system, as of 4.18, requires pkg-config to check for installed
kconfig tools and to determine flags settings for use in
'make {menu,n,g,x}config'.  Previously pkg-config was being used but not
verified or documented.

92 93 94 95 96 97 98 99 100 101 102 103 104
Flex
----

Since Linux 4.16, the build system generates lexical analyzers
during build.  This requires flex 2.5.35 or later.


Bison
-----

Since Linux 4.16, the build system generates parsers
during build.  This requires bison 2.0 or later.

105 106 107
Perl
----

108 109
You will need perl 5 and the following modules: ``Getopt::Long``,
``Getopt::Std``, ``File::Basename``, and ``File::Find`` to build the kernel.
110

111 112 113 114 115
BC
--

You will need bc to build kernels 3.10 and higher

116

117 118 119 120 121 122 123 124 125 126 127
OpenSSL
-------

Module signing and external certificate handling use the OpenSSL program and
crypto library to do key creation and signature generation.

You will need openssl to build kernels 3.7 and higher if module signing is
enabled.  You will also need openssl development packages to build kernels 4.3
and higher.


L
Linus Torvalds 已提交
128
System utilities
129
****************
L
Linus Torvalds 已提交
130 131 132 133 134 135 136 137 138 139 140

Architectural changes
---------------------

DevFS has been obsoleted in favour of udev
(http://www.kernel.org/pub/linux/utils/kernel/hotplug/)

32-bit UID support is now in place.  Have fun!

Linux documentation for functions is transitioning to inline
documentation via specially-formatted comments near their
141 142 143 144 145
definitions in the source.  These comments can be combined with ReST
files the Documentation/ directory to make enriched documentation, which can
then be converted to PostScript, HTML, LaTex, ePUB and PDF files.
In order to convert from ReST format to a format of your choice, you'll need
Sphinx.
L
Linus Torvalds 已提交
146 147 148 149

Util-linux
----------

150
New versions of util-linux provide ``fdisk`` support for larger disks,
L
Linus Torvalds 已提交
151 152 153 154 155 156 157
support new options to mount, recognize more supported partition
types, have a fdformat which works with 2.4 kernels, and similar goodies.
You'll probably want to upgrade.

Ksymoops
--------

J
Jesper Juhl 已提交
158 159
If the unthinkable happens and your kernel oopses, you may need the
ksymoops tool to decode it, but in most cases you don't.
160
It is generally preferred to build the kernel with ``CONFIG_KALLSYMS`` so
161 162
that it produces readable dumps that can be used as-is (this also
produces better output than ksymoops).  If for some reason your kernel
163
is not build with ``CONFIG_KALLSYMS`` and you have no way to rebuild and
164 165
reproduce the Oops with that option, then you can still decode that Oops
with ksymoops.
L
Linus Torvalds 已提交
166 167 168 169

Module-Init-Tools
-----------------

170
A new module loader is now in the kernel that requires ``module-init-tools``
L
Linus Torvalds 已提交
171 172 173 174 175
to use.  It is backward compatible with the 2.4.x series kernels.

Mkinitrd
--------

176
These changes to the ``/lib/modules`` file tree layout also require that
L
Linus Torvalds 已提交
177 178 179 180 181
mkinitrd be upgraded.

E2fsprogs
---------

182
The latest version of ``e2fsprogs`` fixes several bugs in fsck and
L
Linus Torvalds 已提交
183 184 185 186 187
debugfs.  Obviously, it's a good idea to upgrade.

JFSutils
--------

188
The ``jfsutils`` package contains the utilities for the file system.
L
Linus Torvalds 已提交
189
The following utilities are available:
190 191

- ``fsck.jfs`` - initiate replay of the transaction log, and check
L
Linus Torvalds 已提交
192
  and repair a JFS formatted partition.
193 194 195 196

- ``mkfs.jfs`` - create a JFS formatted partition.

- other file system utilities are also available in this package.
L
Linus Torvalds 已提交
197 198 199 200 201 202

Reiserfsprogs
-------------

The reiserfsprogs package should be used for reiserfs-3.6.x
(Linux kernels 2.4.x). It is a combined package and contains working
203 204
versions of ``mkreiserfs``, ``resize_reiserfs``, ``debugreiserfs`` and
``reiserfsck``. These utils work on both i386 and alpha platforms.
L
Linus Torvalds 已提交
205 206 207 208

Xfsprogs
--------

209 210
The latest version of ``xfsprogs`` contains ``mkfs.xfs``, ``xfs_db``, and the
``xfs_repair`` utilities, among others, for the XFS filesystem.  It is
L
Linus Torvalds 已提交
211 212 213 214
architecture independent and any version from 2.0.0 onward should
work correctly with this version of the XFS kernel code (2.6.0 or
later is recommended, due to some significant improvements).

215 216 217
PCMCIAutils
-----------

218
PCMCIAutils replaces ``pcmcia-cs``. It properly sets up
219 220 221
PCMCIA sockets at system startup and loads the appropriate modules
for 16-bit PCMCIA devices if the kernel is modularized and the hotplug
subsystem is used.
L
Linus Torvalds 已提交
222 223 224 225 226 227 228 229 230 231 232 233 234

Quota-tools
-----------

Support for 32 bit uid's and gid's is required if you want to use
the newer version 2 quota format.  Quota-tools version 3.07 and
newer has this support.  Use the recommended version or newer
from the table above.

Intel IA32 microcode
--------------------

A driver has been added to allow updating of Intel IA32 microcode,
235
accessible as a normal (misc) character device.  If you are not using
J
Jonathan Corbet 已提交
236
udev you may need to::
237 238 239 240

  mkdir /dev/cpu
  mknod /dev/cpu/microcode c 10 184
  chmod 0644 /dev/cpu/microcode
L
Linus Torvalds 已提交
241 242 243 244 245 246

as root before you can use this.  You'll probably also want to
get the user-space microcode_ctl utility to use with this.

udev
----
247 248 249

``udev`` is a userspace application for populating ``/dev`` dynamically with
only entries for devices actually present. ``udev`` replaces the basic
J
Jan Engelhardt 已提交
250
functionality of devfs, while allowing persistent device naming for
251
devices.
L
Linus Torvalds 已提交
252

253 254 255 256
FUSE
----

Needs libfuse 2.4.0 or later.  Absolute minimum is 2.3.0 but mount
257
options ``direct_io`` and ``kernel_cache`` won't work.
258

L
Linus Torvalds 已提交
259
Networking
260
**********
L
Linus Torvalds 已提交
261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280

General changes
---------------

If you have advanced network configuration needs, you should probably
consider using the network tools from ip-route2.

Packet Filter / NAT
-------------------
The packet filtering and NAT code uses the same tools like the previous 2.4.x
kernel series (iptables).  It still includes backwards-compatibility modules
for 2.2.x-style ipchains and 2.0.x-style ipfwadm.

PPP
---

The PPP driver has been restructured to support multilink and to
enable it to operate over diverse media layers.  If you use PPP,
upgrade pppd to at least 2.4.0.

281
If you are not using udev, you must have the device file /dev/ppp
J
Jonathan Corbet 已提交
282
which can be made by::
283 284

  mknod /dev/ppp c 108 0
L
Linus Torvalds 已提交
285 286 287 288 289 290 291 292 293 294 295 296

as root.

Isdn4k-utils
------------

Due to changes in the length of the phone number field, isdn4k-utils
needs to be recompiled or (preferably) upgraded.

NFS-utils
---------

297 298
In ancient (2.4 and earlier) kernels, the nfs server needed to know
about any client that expected to be able to access files via NFS.  This
299 300 301
information would be given to the kernel by ``mountd`` when the client
mounted the filesystem, or by ``exportfs`` at system startup.  exportfs
would take information about active clients from ``/var/lib/nfs/rmtab``.
L
Linus Torvalds 已提交
302 303 304

This approach is quite fragile as it depends on rmtab being correct
which is not always easy, particularly when trying to implement
305
fail-over.  Even when the system is working well, ``rmtab`` suffers from
L
Linus Torvalds 已提交
306 307
getting lots of old entries that never get removed.

308 309 310
With modern kernels we have the option of having the kernel tell mountd
when it gets a request from an unknown host, and mountd can give
appropriate export information to the kernel.  This removes the
311
dependency on ``rmtab`` and means that the kernel only needs to know about
312
currently active clients.
L
Linus Torvalds 已提交
313

J
Jonathan Corbet 已提交
314
To enable this new functionality, you need to::
315

316
  mount -t nfsd nfsd /proc/fs/nfsd
L
Linus Torvalds 已提交
317 318 319 320 321

before running exportfs or mountd.  It is recommended that all NFS
services be protected from the internet-at-large by a firewall where
that is possible.

322 323 324
mcelog
------

325
On x86 kernels the mcelog utility is needed to process and log machine check
326 327
events when ``CONFIG_X86_MCE`` is enabled. Machine check events are errors
reported by the CPU. Processing them is strongly encouraged.
328

329 330 331 332 333 334
Kernel documentation
********************

Sphinx
------

335 336
Please see :ref:`sphinx_install` in ``Documentation/doc-guide/sphinx.rst``
for details about Sphinx requirements.
337

L
Linus Torvalds 已提交
338 339 340 341 342 343
Getting updated software
========================

Kernel compilation
******************

A
Andrew Morton 已提交
344 345
gcc
---
346 347

- <ftp://ftp.gnu.org/gnu/gcc/>
L
Linus Torvalds 已提交
348 349 350

Make
----
351 352

- <ftp://ftp.gnu.org/gnu/make/>
L
Linus Torvalds 已提交
353 354 355

Binutils
--------
356

357
- <https://www.kernel.org/pub/linux/devel/binutils/>
L
Linus Torvalds 已提交
358

359 360 361 362 363 364 365 366 367 368
Flex
----

- <https://github.com/westes/flex/releases>

Bison
-----

- <ftp://ftp.gnu.org/gnu/bison/>

369 370
OpenSSL
-------
371 372

- <https://www.openssl.org/>
373

L
Linus Torvalds 已提交
374 375 376 377 378
System utilities
****************

Util-linux
----------
379

380
- <https://www.kernel.org/pub/linux/utils/util-linux/>
L
Linus Torvalds 已提交
381 382 383

Ksymoops
--------
384

385
- <https://www.kernel.org/pub/linux/utils/kernel/ksymoops/v2.4/>
L
Linus Torvalds 已提交
386 387 388

Module-Init-Tools
-----------------
389

390
- <https://www.kernel.org/pub/linux/utils/kernel/module-init-tools/>
L
Linus Torvalds 已提交
391 392 393

Mkinitrd
--------
394 395

- <https://code.launchpad.net/initrd-tools/main>
L
Linus Torvalds 已提交
396 397 398

E2fsprogs
---------
399 400

- <http://prdownloads.sourceforge.net/e2fsprogs/e2fsprogs-1.29.tar.gz>
L
Linus Torvalds 已提交
401 402 403

JFSutils
--------
404 405

- <http://jfs.sourceforge.net/>
L
Linus Torvalds 已提交
406 407 408

Reiserfsprogs
-------------
409 410

- <http://www.kernel.org/pub/linux/utils/fs/reiserfs/>
L
Linus Torvalds 已提交
411 412 413

Xfsprogs
--------
414 415

- <ftp://oss.sgi.com/projects/xfs/>
L
Linus Torvalds 已提交
416

417 418
Pcmciautils
-----------
419

420
- <https://www.kernel.org/pub/linux/utils/kernel/pcmcia/>
421

L
Linus Torvalds 已提交
422
Quota-tools
423 424 425
-----------

- <http://sourceforge.net/projects/linuxquota/>
L
Linus Torvalds 已提交
426

427

L
Linus Torvalds 已提交
428 429
Intel P6 microcode
------------------
430 431

- <https://downloadcenter.intel.com/>
L
Linus Torvalds 已提交
432 433 434

udev
----
435 436

- <http://www.freedesktop.org/software/systemd/man/udev.html>
L
Linus Torvalds 已提交
437

438 439
FUSE
----
440

441
- <https://github.com/libfuse/libfuse/releases>
442

443 444
mcelog
------
445 446

- <http://www.mcelog.org/>
447

L
Linus Torvalds 已提交
448 449 450 451 452
Networking
**********

PPP
---
453 454

- <ftp://ftp.samba.org/pub/ppp/>
L
Linus Torvalds 已提交
455 456 457

Isdn4k-utils
------------
458 459

- <ftp://ftp.isdn4linux.de/pub/isdn4linux/utils/>
L
Linus Torvalds 已提交
460 461 462

NFS-utils
---------
463 464

- <http://sourceforge.net/project/showfiles.php?group_id=14>
L
Linus Torvalds 已提交
465 466 467

Iptables
--------
468 469

- <http://www.iptables.org/downloads.html>
L
Linus Torvalds 已提交
470 471 472

Ip-route2
---------
473 474

- <https://www.kernel.org/pub/linux/utils/net/iproute2/>
L
Linus Torvalds 已提交
475 476 477

OProfile
--------
478 479

- <http://oprofile.sf.net/download/>
L
Linus Torvalds 已提交
480 481 482

NFS-Utils
---------
483 484

- <http://nfs.sourceforge.net/>
485 486 487 488 489 490 491 492

Kernel documentation
********************

Sphinx
------

- <http://www.sphinx-doc.org/>