aboutsummaryrefslogtreecommitdiffstats
path: root/prologue/why.xml
blob: 3996e3c2d1f64aa542073b941ca4baef78faafa8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
  "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
  <!ENTITY % general-entities SYSTEM "../general.ent">
  %general-entities;
]>

<sect1 id="pre-why">
  <?dbhtml filename="package-choices.html"?>

  <title>Rationale for Packages in the Book</title>

    <para>As stated earlier, the goal of LFS is to build a complete and usable
    foundation-level system.  This includes all packages needed to replicate
    itself while providing a relatively minimal base from which to customize
    a more complete system based on the choices of the user.  This does not
    mean that LFS is the smallest system possible.  Several important packages
    are included that are not strictly required.  The lists below document the
    rationale for each package in the book.</para>

    <itemizedlist>

      <listitem>
        <para>Acl</para>

        <para>This package contains utilities to administer Access 
        Control Lists, which are used to define more fine-grained 
        discretionary access rights for files and directories. 
        </para>
      </listitem>

      <listitem>
        <para>Attr</para>

        <para>This package contains programs for administering  
        extended attributes on filesystem objects. 
        </para>
      </listitem>

      <listitem>
        <para>Autoconf</para>

        <para>This package contains programs for producing shell scripts that
        can automatically configure source code from a developer's
        template. It is often needed to rebuild a package after updates
        to the build procedures.</para>
      </listitem>

      <listitem>
        <para>Automake</para>

        <para>This package contains programs for generating Make files from
        a template. It is often needed to rebuild a package after updates
        to the build procedures.</para>
      </listitem>

      <listitem>
        <para>Bash</para>

        <para>This package satisfies an LSB core requirement to provide
        a Bourne Shell interface to the system.  It was chosen over
        other shell packages because of its common usage and extensive
        capabilities beyond basic shell functions.</para>
      </listitem>

      <listitem>
        <para>Bc</para>

        <para>This package provides an arbitrary precision numeric processing language. 
        It satisfies a requirement needed when building the Linux kernel.</para>
      </listitem>

      <listitem>
        <para>Binutils</para>

        <para>This package contains a linker, an assembler, and other
        tools for handling object files. The programs in this package are
        needed to compile most of the packages in an LFS system and beyond.</para>
      </listitem>

      <listitem>
        <para>Bison</para>

        <para>This package contains the GNU version of yacc (Yet Another
        Compiler Compiler) needed to build several other LFS programs.</para>
      </listitem>

      <listitem>
        <para>Bzip2</para>

        <para>This package contains programs for compressing and decompressing
        files.  It is required to decompress many LFS packages.</para>
      </listitem>

      <listitem>
        <para>Check</para>

        <para>This package contains a test harness for other programs.</para>
      </listitem>

      <listitem>
        <para>Coreutils</para>

        <para>This package contains a number of essential programs for viewing
        and manipulating files and directories. These programs are needed for
        command line file management, and are necessary for the installation
        procedures of every package in LFS.</para>
      </listitem>

      <listitem revision="systemd">
        <para>D-Bus</para>

        <para>This package contains programs to implement a message bus system, 
        which a simple way for applications to talk to one another.
        </para>
      </listitem>

      <listitem>
        <para>DejaGNU</para>

        <para>This package contains a framework for testing other programs.</para>
      </listitem>

      <listitem>
        <para>Diffutils</para>

        <para>This package contains programs that show the differences
        between files or directories. These programs can be used to create
        patches, and are also used in many packages' build procedures.</para>
      </listitem>

      <listitem>
        <para>E2fsprogs</para>

        <para>This package contains the utilities for handling the ext2, ext3
        and ext4 file systems.  These are the most common and thoroughly
        tested file systems that Linux supports.</para>
      </listitem>

      <listitem revision="sysv">
        <para>Eudev</para>

        <para>This package is a device manager.  It dynamically controls the ownership,
        permissions, names, and symbolic links of devices in the /dev directory as 
        devices are added or removed from the system.
        </para>
      </listitem>

      <listitem>
        <para>Expat</para>

        <para>This package contains a relatively small XML parsing library.  It
        is required by the XML::Parser Perl module.</para>
      </listitem>

      <listitem>
        <para>Expect</para>

        <para>This package contains a program for carrying out scripted
        dialogues with other interactive programs.  It is commonly used
        for testing other packages.  It is only installed in the temporary
        toolchain.</para>
      </listitem>

      <listitem>
        <para>File</para>

        <para>This package contains a utility for determining the type of a
        given file or files. A few packages need it in their build scripts.</para>
      </listitem>

      <listitem>
        <para>Findutils</para>

        <para>This package contains programs to find files in a file system.
        It is used in many packages' build scripts.</para>
      </listitem>

      <listitem>
        <para>Flex</para>

        <para>This package contains a utility for generating programs that
        recognize patterns in text.  It is the GNU version of the lex
        (lexical analyzer) program.  It is required to build several
        LFS packages.</para>
      </listitem>

      <listitem>
        <para>Gawk</para>

        <para>This package contains programs for manipulating text files.
        It is the GNU version of awk (Aho-Weinberg-Kernighan). It is used in
        many other packages' build scripts.</para>
      </listitem>

      <listitem>
        <para>GCC</para>

        <para>This package is the Gnu Compiler Collection.  It contains the
        C and C++ compilers as well as several others not built by LFS.
        </para>
      </listitem>

      <listitem>
        <para>GDBM</para>

        <para>This package contains the GNU Database Manager library.  It
        is used by one other LFS package, Man-DB.</para>
      </listitem>

      <listitem>
        <para>Gettext</para>

        <para>This package contains utilities and libraries for
        internationalization and localization of numerous packages.</para>
      </listitem>

      <listitem>
        <para>Glibc</para>

        <para>This package contains the main C library.  Linux programs will
        not run without it.</para>
      </listitem>

      <listitem>
        <para>GMP</para>

        <para>This package contains math libraries that provide useful functions
        for arbitrary precision arithmetic.  It is required to build GCC.</para>
      </listitem>

      <listitem>
        <para>Gperf</para>

        <para>This package contains a program that generates a perfect hash
        function from a key set. It is required for Eudev.</para>
      </listitem>

      <listitem>
        <para>Grep</para>

        <para>This package contains programs for searching through files. These
        programs are used by most packages' build scripts.</para>
      </listitem>

      <listitem>
        <para>Groff</para>

        <para>This package contains programs for processing and formatting text.
        One important function of these programs is to format man pages.</para>
      </listitem>

      <listitem>
        <para>GRUB</para>

        <para>This package is the Grand Unified Boot Loader.  It is one
        of several boot loaders available, but is the most flexible.
        </para>
      </listitem>

      <listitem>
        <para>Gzip</para>

        <para>This package contains programs for compressing and
        decompressing files. It is needed to decompress many packages in LFS
        and beyond.</para>
      </listitem>

      <listitem>
        <para>Iana-etc</para>

        <para>This package provides data for network services and protocols.
        It is needed to enable proper networking capabilities.</para>
      </listitem>

      <listitem>
        <para>Inetutils</para>

        <para>This package contains programs for basic network
        administration.</para>
      </listitem>

      <listitem>
        <para>Intltool</para>

        <para>This package contains tools for extracting translatable 
        strings from source files.</para>
      </listitem>

      <listitem>
        <para>IProute2</para>

        <para>This package contains programs for basic and advanced IPv4 and
        IPv6 networking.  It was chosen over the other common network
        tools package (net-tools) for its IPv6 capabilities.  </para>
      </listitem>

      <listitem revision="systemd">
        <para>Jinja2</para>

        <para>This package is a Python module for text templating.
        It's required to build Systemd.</para>
      </listitem>

      <listitem>
        <para>Kbd</para>

        <para>This package contains key-table files, keyboard utilities
        for non-US keyboards, and a number of console fonts.</para>
      </listitem>

      <listitem>
        <para>Kmod</para>

        <para>This package contains programs needed to administer Linux
        kernel modules.</para>
      </listitem>

      <listitem>
        <para>Less</para>

        <para>This package contains a very nice text file viewer that
        allows scrolling up or down when viewing a file. It is also used by
        Man-DB for viewing manpages.</para>
      </listitem>

      <listitem>
        <para>Libcap</para>

        <para>This package implements the user-space interfaces to 
        the POSIX 1003.1e capabilities available in Linux kernels. 
        </para>
      </listitem>

      <listitem>
        <para>Libelf</para>

        <para>The elfutils project provides libraries and tools for ELF files
        and DWARF data.  Most utilities in this package are available in
        other packages, but the library is needed to build the Linux
        kernel using the default (and most efficient) configuration.</para>

      </listitem>

      <listitem>
        <para>Libffi</para>

        <para>This package implements a portable, high level programming
        interface to various calling conventions.  Some programs may not know
        at the time of compilation what arguments are to be passed to a
        function. For instance, an interpreter may be told at run-time about
        the number and types of arguments used to call a given function. Libffi
        can be used in such programs to provide a bridge from the interpreter
        program to compiled code.</para>

      </listitem>

      <listitem>
        <para>Libpipeline</para>

        <para>The Libpipeline package contains a library for manipulating
        pipelines of subprocesses in a flexible and convenient way. It is
        required by the Man-DB package.</para>
      </listitem>

      <listitem>
        <para>Libtool</para>

        <para>This package contains the GNU generic library support
        script. It wraps the complexity of using shared libraries in a
        consistent, portable interface.  It is needed by the test
        suites in other LFS packages.</para>
      </listitem>

      <listitem>
        <para>Linux Kernel</para>

        <para>This package is the Operating System.  It is the Linux in
        the GNU/Linux environment.</para>
      </listitem>

      <listitem>
        <para>M4</para>

        <para>This package contains a general text macro processor useful
        as a build tool for other programs.</para>
      </listitem>

      <listitem>
        <para>Make</para>

        <para>This package contains a program for directing the building
        of packages.  It is required by almost every package in LFS.</para>
      </listitem>

      <listitem revision="systemd">
        <para>MarkupSafe</para>

        <para>This package is a Python module for processing strings in
        HTML/XHTML/XML safely.  Jinja2 requires this pacakge.</para>
      </listitem>

      <listitem>
        <para>Man-DB</para>

        <para>This package contains programs for finding and viewing man pages.
        It was chosen instead of the <application>man</application> package
        due to superior internationalization capabilities.  It supplies
        the man program.</para>
      </listitem>

      <listitem>
        <para>Man-pages</para>

        <para>This package contains the actual contents of the basic
        Linux man pages.</para>
      </listitem>

      <listitem>
        <para>Meson</para>

        <para>This package provides a software tool for automating the building
        of software. The main goal for Meson is to minimize the amount of time
        that software developers need to spend configuring their build
        system.  It's required to build Systemd, as well as many BLFS
        packages.</para>

      </listitem>

      <listitem>
        <para>MPC</para>

        <para>This package contains functions for the arithmetic of complex
        numbers. It is required by GCC.</para>
      </listitem>

      <listitem>
        <para>MPFR</para>

        <para>This package contains functions for multiple precision
        arithmetic.  It is required by GCC.</para>
      </listitem>

      <listitem>
        <para>Ninja</para>

        <para>This package contains a small build system with a focus on speed.
        It is designed to have its input files generated by a higher-level build
        system, and to run builds as fast as possible.
        This package is required by Meson.</para>

      </listitem>

      <listitem>
        <para>Ncurses</para>

        <para>This package contains libraries for terminal-independent
        handling of character screens.  It is often used to provide
        cursor control for a menuing system. It is needed by a number of
        packages in LFS.</para>
      </listitem>

      <listitem>
        <para>Openssl</para>

        <para>This package provides management tools and libraries relating to
        cryptography. These are useful for providing cryptographic functions to
        other packages, including the Linux kernel.</para>
      </listitem>

      <listitem>
        <para>Patch</para>

        <para>This package contains a program for modifying or creating files by
        applying a <emphasis>patch</emphasis> file typically created
        by the <application>diff</application> program.  It is needed by
        the build procedure for several LFS packages.</para>
      </listitem>

      <listitem>
        <para>Perl</para>

        <para>This package is an interpreter for the runtime language
        PERL. It is needed for the installation and test suites of several LFS
        packages.</para>
      </listitem>

      <listitem>
        <para>Pkg-config</para>

        <para>This package provides a program that returns meta-data about an
        installed library or package.</para>
      </listitem>

      <listitem>
        <para>Procps-NG</para>

        <para>This package contains programs for monitoring processes. These
        programs are useful for system administration, and are also used by
        the LFS Bootscripts.</para>
      </listitem>

      <listitem>
        <para>Psmisc</para>

        <para>This package contains programs for displaying information
        about running processes. These programs are useful for system
        administration.</para>
      </listitem>

      <listitem>
        <para>Python 3</para>

        <para>This package provides an interpreted language that has a design
        philosophy that emphasizes code readability.</para>

      </listitem>

      <listitem>
        <para>Readline</para>

        <para>This package is a set of libraries that offers command-line
        editing and history capabilities.  It is used by Bash.</para>
      </listitem>

      <listitem>
        <para>Sed</para>

        <para>This package allows editing of text without opening it in a
        text editor. It is also needed by most LFS packages' configure
        scripts.</para>
      </listitem>

      <listitem>
        <para>Shadow</para>

        <para>This package contains programs for handling passwords
        in a secure way.</para>
      </listitem>

      <listitem revision="sysv">
        <para>Sysklogd</para>

        <para>This package contains programs for logging system messages,
        such as those given by the kernel or daemon processes when unusual
        events occur.</para>
      </listitem>

      <listitem revision="systemd">
        <para>Systemd</para>

        <para>This package provides an <application>init</application> program
        and several additional boot and system control capabilities as an
        alternative to Sysvinit.  It is used by many commercial distributions.
        </para>
      </listitem>

      <listitem revision="sysv">
        <para>Sysvinit</para>

        <para>This package provides the <application>init</application>
        program, which is the parent of all other processes on the Linux
        system. </para>
      </listitem>

      <listitem>
        <para>Tar</para>

        <para>This package provides archiving and extraction capabilities
        of virtually all packages used in LFS.</para>
      </listitem>

      <listitem>
        <para>Tcl</para>

        <para>This package contains the Tool Command Language used
        in many test suites in LFS packages.</para>
      </listitem>

      <listitem>
        <para>Texinfo</para>

        <para>This package contains programs for reading, writing, and
        converting info pages.  It is used in the installation
        procedures of many LFS packages.</para>
      </listitem>

      <listitem>
        <para>Util-linux</para>

        <para>This package contains miscellaneous utility programs.
        Among them are utilities for handling file systems, consoles,
        partitions, and messages.</para>
      </listitem>

      <listitem>
        <para>Vim</para>

        <para>This package contains an editor. It was chosen because of its
        compatibility with the classic vi editor and its huge number of powerful
        capabilities.  An editor is a very personal choice for
        many users and any other editor could be substituted if desired.</para>
      </listitem>

      <listitem>
        <para>XML::Parser</para>

        <para>This package is a Perl module that interfaces with Expat.</para>
      </listitem>

      <listitem>
        <para>XZ Utils</para>

        <para>This package contains programs for compressing and decompressing
        files.  It provides the highest compression generally available
        and is useful for decompressing packages in XZ or LZMA format.</para>
      </listitem>

      <listitem>
        <para>Zlib</para>

        <para>This package contains compression and decompression routines
        used by some programs.</para>
      </listitem>

      <listitem>
        <para>Zstd</para>

        <para>This package contains compression and decompression routines
        used by some programs. It provide high compression ratios and a very 
        wide range of compression / speed trade-offs.</para>
      </listitem>

    </itemizedlist>

</sect1>