changes.rst 12.4 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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
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
56
Sphinx\ [#f1]_	       1.3		sphinx-build --version
57
====================== ===============  ========================================
58

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

Kernel compilation
62
******************
L
Linus Torvalds 已提交
63 64 65 66 67

GCC
---

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

Make
----

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

Binutils
--------

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

82 83 84
Perl
----

85 86
You will need perl 5 and the following modules: ``Getopt::Long``,
``Getopt::Std``, ``File::Basename``, and ``File::Find`` to build the kernel.
87

88 89 90 91 92
BC
--

You will need bc to build kernels 3.10 and higher

93

94 95 96 97 98 99 100 101 102 103 104
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 已提交
105
System utilities
106
****************
L
Linus Torvalds 已提交
107 108 109 110 111 112 113 114 115 116 117

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
118 119 120 121 122
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 已提交
123 124 125 126

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

127
New versions of util-linux provide ``fdisk`` support for larger disks,
L
Linus Torvalds 已提交
128 129 130 131 132 133 134
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 已提交
135 136
If the unthinkable happens and your kernel oopses, you may need the
ksymoops tool to decode it, but in most cases you don't.
137
It is generally preferred to build the kernel with ``CONFIG_KALLSYMS`` so
138 139
that it produces readable dumps that can be used as-is (this also
produces better output than ksymoops).  If for some reason your kernel
140
is not build with ``CONFIG_KALLSYMS`` and you have no way to rebuild and
141 142
reproduce the Oops with that option, then you can still decode that Oops
with ksymoops.
L
Linus Torvalds 已提交
143 144 145 146

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

147
A new module loader is now in the kernel that requires ``module-init-tools``
L
Linus Torvalds 已提交
148 149 150 151 152
to use.  It is backward compatible with the 2.4.x series kernels.

Mkinitrd
--------

153
These changes to the ``/lib/modules`` file tree layout also require that
L
Linus Torvalds 已提交
154 155 156 157 158
mkinitrd be upgraded.

E2fsprogs
---------

159
The latest version of ``e2fsprogs`` fixes several bugs in fsck and
L
Linus Torvalds 已提交
160 161 162 163 164
debugfs.  Obviously, it's a good idea to upgrade.

JFSutils
--------

165
The ``jfsutils`` package contains the utilities for the file system.
L
Linus Torvalds 已提交
166
The following utilities are available:
167 168

- ``fsck.jfs`` - initiate replay of the transaction log, and check
L
Linus Torvalds 已提交
169
  and repair a JFS formatted partition.
170 171 172 173

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

- other file system utilities are also available in this package.
L
Linus Torvalds 已提交
174 175 176 177 178 179

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
180 181
versions of ``mkreiserfs``, ``resize_reiserfs``, ``debugreiserfs`` and
``reiserfsck``. These utils work on both i386 and alpha platforms.
L
Linus Torvalds 已提交
182 183 184 185

Xfsprogs
--------

186 187
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 已提交
188 189 190 191
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).

192 193 194
PCMCIAutils
-----------

195
PCMCIAutils replaces ``pcmcia-cs``. It properly sets up
196 197 198
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 已提交
199 200 201 202 203 204 205 206 207 208 209 210 211

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,
212
accessible as a normal (misc) character device.  If you are not using
J
Jonathan Corbet 已提交
213
udev you may need to::
214 215 216 217

  mkdir /dev/cpu
  mknod /dev/cpu/microcode c 10 184
  chmod 0644 /dev/cpu/microcode
L
Linus Torvalds 已提交
218 219 220 221 222 223

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
----
224 225 226

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

230 231 232 233
FUSE
----

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

L
Linus Torvalds 已提交
236
Networking
237
**********
L
Linus Torvalds 已提交
238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257

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.

258
If you are not using udev, you must have the device file /dev/ppp
J
Jonathan Corbet 已提交
259
which can be made by::
260 261

  mknod /dev/ppp c 108 0
L
Linus Torvalds 已提交
262 263 264 265 266 267 268 269 270 271 272 273

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
---------

274 275
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
276 277 278
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 已提交
279 280 281

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

285 286 287
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
288
dependency on ``rmtab`` and means that the kernel only needs to know about
289
currently active clients.
L
Linus Torvalds 已提交
290

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

293
  mount -t nfsd nfsd /proc/fs/nfsd
L
Linus Torvalds 已提交
294 295 296 297 298

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.

299 300 301
mcelog
------

302
On x86 kernels the mcelog utility is needed to process and log machine check
303 304
events when ``CONFIG_X86_MCE`` is enabled. Machine check events are errors
reported by the CPU. Processing them is strongly encouraged.
305

306 307 308 309 310 311 312
Kernel documentation
********************

Sphinx
------

The ReST markups currently used by the Documentation/ files are meant to be
313 314
built with ``Sphinx`` version 1.3 or upper. If you're desiring to build
PDF outputs, it is recommended to use version 1.4.6 or upper.
315 316 317 318

.. note::

  Please notice that, for PDF and LaTeX output, you'll also need ``XeLaTeX``
319 320 321 322
  version 3.14159265. Depending on the distribution, you may also need to
  install a series of ``texlive`` packages that provide the minimal set of
  functionalities required for ``XeLaTex`` to work. For PDF output you'll also
  need ``convert(1)`` from ImageMagick (https://www.imagemagick.org).
323 324


L
Linus Torvalds 已提交
325 326 327 328 329 330
Getting updated software
========================

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

A
Andrew Morton 已提交
331 332
gcc
---
333 334

- <ftp://ftp.gnu.org/gnu/gcc/>
L
Linus Torvalds 已提交
335 336 337

Make
----
338 339

- <ftp://ftp.gnu.org/gnu/make/>
L
Linus Torvalds 已提交
340 341 342

Binutils
--------
343

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

346 347
OpenSSL
-------
348 349

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

L
Linus Torvalds 已提交
351 352 353 354 355
System utilities
****************

Util-linux
----------
356

357
- <https://www.kernel.org/pub/linux/utils/util-linux/>
L
Linus Torvalds 已提交
358 359 360

Ksymoops
--------
361

362
- <https://www.kernel.org/pub/linux/utils/kernel/ksymoops/v2.4/>
L
Linus Torvalds 已提交
363 364 365

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

367
- <https://www.kernel.org/pub/linux/utils/kernel/module-init-tools/>
L
Linus Torvalds 已提交
368 369 370

Mkinitrd
--------
371 372

- <https://code.launchpad.net/initrd-tools/main>
L
Linus Torvalds 已提交
373 374 375

E2fsprogs
---------
376 377

- <http://prdownloads.sourceforge.net/e2fsprogs/e2fsprogs-1.29.tar.gz>
L
Linus Torvalds 已提交
378 379 380

JFSutils
--------
381 382

- <http://jfs.sourceforge.net/>
L
Linus Torvalds 已提交
383 384 385

Reiserfsprogs
-------------
386 387

- <http://www.kernel.org/pub/linux/utils/fs/reiserfs/>
L
Linus Torvalds 已提交
388 389 390

Xfsprogs
--------
391 392

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

394 395
Pcmciautils
-----------
396

397
- <https://www.kernel.org/pub/linux/utils/kernel/pcmcia/>
398

L
Linus Torvalds 已提交
399
Quota-tools
400 401 402
-----------

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

404

L
Linus Torvalds 已提交
405 406
Intel P6 microcode
------------------
407 408

- <https://downloadcenter.intel.com/>
L
Linus Torvalds 已提交
409 410 411

udev
----
412 413

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

415 416
FUSE
----
417 418

- <http://sourceforge.net/projects/fuse>
419

420 421
mcelog
------
422 423

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

L
Linus Torvalds 已提交
425 426 427 428 429
Networking
**********

PPP
---
430 431

- <ftp://ftp.samba.org/pub/ppp/>
L
Linus Torvalds 已提交
432 433 434

Isdn4k-utils
------------
435 436

- <ftp://ftp.isdn4linux.de/pub/isdn4linux/utils/>
L
Linus Torvalds 已提交
437 438 439

NFS-utils
---------
440 441

- <http://sourceforge.net/project/showfiles.php?group_id=14>
L
Linus Torvalds 已提交
442 443 444

Iptables
--------
445 446

- <http://www.iptables.org/downloads.html>
L
Linus Torvalds 已提交
447 448 449

Ip-route2
---------
450 451

- <https://www.kernel.org/pub/linux/utils/net/iproute2/>
L
Linus Torvalds 已提交
452 453 454

OProfile
--------
455 456

- <http://oprofile.sf.net/download/>
L
Linus Torvalds 已提交
457 458 459

NFS-Utils
---------
460 461

- <http://nfs.sourceforge.net/>
462 463 464 465 466 467 468 469

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

Sphinx
------

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