changes.rst 12.3 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
Again, keep in mind that this list assumes you are already functionally
running a Linux kernel.  Also, not all tools are necessary on all
A
Arnd Bergmann 已提交
26 27
systems; obviously, if you don't have any PC Card hardware, for example,
you probably needn't concern yourself with pcmciautils.
L
Linus Torvalds 已提交
28

29 30 31
====================== ===============  ========================================
        Program        Minimal version       Command to check the version
====================== ===============  ========================================
32
GNU C                  4.8              gcc --version
33
GNU make               3.81             make --version
34
binutils               2.23             ld -v
35 36
flex                   2.5.35           flex --version
bison                  2.0              bison --version
37
util-linux             2.10o            fdformat --version
38
kmod                   13               depmod -V
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
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
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
57
Sphinx\ [#f1]_	       1.3		sphinx-build --version
58
====================== ===============  ========================================
59

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

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

GCC
---

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

Make
----

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

Binutils
--------

79
Binutils 2.23 or newer is needed to build the kernel.
L
Linus Torvalds 已提交
80

81 82 83 84 85
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
86
'make {g,x}config'.  Previously pkg-config was being used but not
87 88
verified or documented.

89 90 91 92 93 94 95 96 97 98 99 100 101
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.

102 103 104
Perl
----

105 106
You will need perl 5 and the following modules: ``Getopt::Long``,
``Getopt::Std``, ``File::Basename``, and ``File::Find`` to build the kernel.
107

108 109 110 111 112
BC
--

You will need bc to build kernels 3.10 and higher

113

114 115 116 117 118 119 120 121 122 123 124
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 已提交
125
System utilities
126
****************
L
Linus Torvalds 已提交
127 128 129 130 131 132 133 134 135 136 137

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
138 139 140 141 142
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 已提交
143 144 145 146

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

147
New versions of util-linux provide ``fdisk`` support for larger disks,
L
Linus Torvalds 已提交
148 149 150 151 152 153 154
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 已提交
155 156
If the unthinkable happens and your kernel oopses, you may need the
ksymoops tool to decode it, but in most cases you don't.
157
It is generally preferred to build the kernel with ``CONFIG_KALLSYMS`` so
158 159
that it produces readable dumps that can be used as-is (this also
produces better output than ksymoops).  If for some reason your kernel
160
is not build with ``CONFIG_KALLSYMS`` and you have no way to rebuild and
161 162
reproduce the Oops with that option, then you can still decode that Oops
with ksymoops.
L
Linus Torvalds 已提交
163 164 165 166

Mkinitrd
--------

167
These changes to the ``/lib/modules`` file tree layout also require that
L
Linus Torvalds 已提交
168 169 170 171 172
mkinitrd be upgraded.

E2fsprogs
---------

173
The latest version of ``e2fsprogs`` fixes several bugs in fsck and
L
Linus Torvalds 已提交
174 175 176 177 178
debugfs.  Obviously, it's a good idea to upgrade.

JFSutils
--------

179
The ``jfsutils`` package contains the utilities for the file system.
L
Linus Torvalds 已提交
180
The following utilities are available:
181 182

- ``fsck.jfs`` - initiate replay of the transaction log, and check
L
Linus Torvalds 已提交
183
  and repair a JFS formatted partition.
184 185 186 187

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

- other file system utilities are also available in this package.
L
Linus Torvalds 已提交
188 189 190 191 192 193

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
194 195
versions of ``mkreiserfs``, ``resize_reiserfs``, ``debugreiserfs`` and
``reiserfsck``. These utils work on both i386 and alpha platforms.
L
Linus Torvalds 已提交
196 197 198 199

Xfsprogs
--------

200 201
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 已提交
202 203 204 205
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).

206 207 208
PCMCIAutils
-----------

209
PCMCIAutils replaces ``pcmcia-cs``. It properly sets up
210 211 212
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 已提交
213 214 215 216 217 218 219 220 221 222 223 224 225

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,
226
accessible as a normal (misc) character device.  If you are not using
J
Jonathan Corbet 已提交
227
udev you may need to::
228 229 230 231

  mkdir /dev/cpu
  mknod /dev/cpu/microcode c 10 184
  chmod 0644 /dev/cpu/microcode
L
Linus Torvalds 已提交
232 233 234 235 236 237

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
----
238 239 240

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

244 245 246 247
FUSE
----

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

L
Linus Torvalds 已提交
250
Networking
251
**********
L
Linus Torvalds 已提交
252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271

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.

272
If you are not using udev, you must have the device file /dev/ppp
J
Jonathan Corbet 已提交
273
which can be made by::
274 275

  mknod /dev/ppp c 108 0
L
Linus Torvalds 已提交
276 277 278 279 280 281

as root.

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

282 283
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
284 285 286
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 已提交
287 288 289

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

293 294 295
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
296
dependency on ``rmtab`` and means that the kernel only needs to know about
297
currently active clients.
L
Linus Torvalds 已提交
298

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

301
  mount -t nfsd nfsd /proc/fs/nfsd
L
Linus Torvalds 已提交
302 303 304 305 306

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.

307 308 309
mcelog
------

310
On x86 kernels the mcelog utility is needed to process and log machine check
311 312
events when ``CONFIG_X86_MCE`` is enabled. Machine check events are errors
reported by the CPU. Processing them is strongly encouraged.
313

314 315 316 317 318 319
Kernel documentation
********************

Sphinx
------

320
Please see :ref:`sphinx_install` in :ref:`Documentation/doc-guide/sphinx.rst <sphinxdoc>`
321
for details about Sphinx requirements.
322

L
Linus Torvalds 已提交
323 324 325 326 327 328
Getting updated software
========================

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

A
Andrew Morton 已提交
329 330
gcc
---
331 332

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

Make
----
336 337

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

Binutils
--------
341

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

344 345 346 347 348 349 350 351 352 353
Flex
----

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

Bison
-----

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

354 355
OpenSSL
-------
356 357

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

L
Linus Torvalds 已提交
359 360 361 362 363
System utilities
****************

Util-linux
----------
364

365
- <https://www.kernel.org/pub/linux/utils/util-linux/>
L
Linus Torvalds 已提交
366

367 368 369 370 371 372
Kmod
----

- <https://www.kernel.org/pub/linux/utils/kernel/kmod/>
- <https://git.kernel.org/pub/scm/utils/kernel/kmod/kmod.git>

L
Linus Torvalds 已提交
373 374
Ksymoops
--------
375

376
- <https://www.kernel.org/pub/linux/utils/kernel/ksymoops/v2.4/>
L
Linus Torvalds 已提交
377 378 379

Mkinitrd
--------
380 381

- <https://code.launchpad.net/initrd-tools/main>
L
Linus Torvalds 已提交
382 383 384

E2fsprogs
---------
385

386 387
- <https://www.kernel.org/pub/linux/kernel/people/tytso/e2fsprogs/>
- <https://git.kernel.org/pub/scm/fs/ext2/e2fsprogs.git/>
L
Linus Torvalds 已提交
388 389 390

JFSutils
--------
391 392

- <http://jfs.sourceforge.net/>
L
Linus Torvalds 已提交
393 394 395

Reiserfsprogs
-------------
396

397
- <https://git.kernel.org/pub/scm/linux/kernel/git/jeffm/reiserfsprogs.git/>
L
Linus Torvalds 已提交
398 399 400

Xfsprogs
--------
401

402 403
- <https://git.kernel.org/pub/scm/fs/xfs/xfsprogs-dev.git>
- <https://www.kernel.org/pub/linux/utils/fs/xfs/xfsprogs/>
L
Linus Torvalds 已提交
404

405 406
Pcmciautils
-----------
407

408
- <https://www.kernel.org/pub/linux/utils/kernel/pcmcia/>
409

L
Linus Torvalds 已提交
410
Quota-tools
411 412 413
-----------

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

415

L
Linus Torvalds 已提交
416 417
Intel P6 microcode
------------------
418 419

- <https://downloadcenter.intel.com/>
L
Linus Torvalds 已提交
420 421 422

udev
----
423 424

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

426 427
FUSE
----
428

429
- <https://github.com/libfuse/libfuse/releases>
430

431 432
mcelog
------
433 434

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

L
Linus Torvalds 已提交
436 437 438 439 440
Networking
**********

PPP
---
441

442 443 444
- <https://download.samba.org/pub/ppp/>
- <https://git.ozlabs.org/?p=ppp.git>
- <https://github.com/paulusmack/ppp/>
L
Linus Torvalds 已提交
445 446 447

NFS-utils
---------
448 449

- <http://sourceforge.net/project/showfiles.php?group_id=14>
L
Linus Torvalds 已提交
450 451 452

Iptables
--------
453

454
- <https://netfilter.org/projects/iptables/index.html>
L
Linus Torvalds 已提交
455 456 457

Ip-route2
---------
458 459

- <https://www.kernel.org/pub/linux/utils/net/iproute2/>
L
Linus Torvalds 已提交
460 461 462

OProfile
--------
463 464

- <http://oprofile.sf.net/download/>
L
Linus Torvalds 已提交
465 466 467

NFS-Utils
---------
468 469

- <http://nfs.sourceforge.net/>
470 471 472 473 474 475 476 477

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

Sphinx
------

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