source: chapter02/hostreqs.xml@ 0f18f2b

12.0 12.0-rc1 12.1 12.1-rc1 multilib renodr/libudev-from-systemd trunk xry111/arm64 xry111/arm64-12.0 xry111/clfs-ng xry111/loongarch xry111/loongarch-12.0 xry111/loongarch-12.1 xry111/mips64el xry111/update-glibc
Last change on this file since 0f18f2b was 0f18f2b, checked in by Xi Ruoyao <xry111@…>, 11 months ago

housekeeping after min-kernel bump

Update the rationale for min-kernel in hostreqs. Add a note in
general.ent about the EOL of current min-kernel. Realign the
backslashes in glibc instructions.

  • Property mode set to 100644
File size: 8.8 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../general.ent">
5 %general-entities;
6]>
7
8<sect1 id="ch-partitioning-hostreqs" xreflabel="Host System Requirements">
9 <?dbhtml filename="hostreqs.html"?>
10
11 <title>Host System Requirements</title>
12
13 <sect2>
14 <title>Hardware</title>
15
16 <para>The LFS editors recommend that the system CPU have at least
17 four cores and that the system have at least 8 GB of memory.
18 Older systems that do not meet these requirements will still work,
19 but the time to build packages will be significantly longer
20 than documented.
21 </para>
22
23 </sect2>
24
25 <sect2>
26 <title>Software</title>
27
28 <para>Your host system should have the following software with the
29 minimum versions indicated. This should not be an issue for most
30 modern Linux distributions. Also note that many distributions will
31 place software headers into separate packages, often in the form of
32 <quote>&lt;package-name&gt;-devel</quote> or
33 <quote>&lt;package-name&gt;-dev</quote>. Be sure to install those if
34 your distribution provides them.</para>
35
36 <para>Earlier versions of the listed software packages may work, but have
37 not been tested.</para>
38
39 <itemizedlist spacing="compact">
40
41 <listitem>
42 <para><emphasis role="strong">Bash-3.2</emphasis> (/bin/sh
43 should be a symbolic or hard link to bash)</para>
44 </listitem>
45
46 <listitem>
47 <para><emphasis role="strong">Binutils-2.13.1</emphasis> (Versions
48 greater than &binutils-version; are not recommended as they have
49 not been tested)</para>
50 </listitem>
51
52 <listitem>
53 <para><emphasis role="strong">Bison-2.7</emphasis> (/usr/bin/yacc
54 should be a link to bison or a small script that executes bison)</para>
55 </listitem>
56
57 <listitem>
58 <para><emphasis role="strong">Coreutils-7.0</emphasis></para>
59 </listitem>
60
61 <listitem>
62 <para><emphasis role="strong">Diffutils-2.8.1</emphasis></para>
63 </listitem>
64
65 <listitem>
66 <para><emphasis role="strong">Findutils-4.2.31</emphasis></para>
67 </listitem>
68
69 <listitem>
70 <para><emphasis role="strong">Gawk-4.0.1</emphasis> (/usr/bin/awk
71 should be a link to gawk)</para>
72 </listitem>
73
74 <listitem>
75 <para><emphasis role="strong">GCC-5.1</emphasis> including the C++
76 compiler, <command>g++</command> (Versions greater than &gcc-version; are
77 not recommended as they have not been tested). C and C++ standard
78 libraries (with headers) must also be present so the C++ compiler can
79 build hosted programs</para>
80 </listitem>
81
82 <listitem>
83 <para><emphasis role="strong">Grep-2.5.1a</emphasis></para>
84 </listitem>
85
86 <listitem>
87 <para><emphasis role="strong">Gzip-1.3.12</emphasis></para>
88 </listitem>
89
90 <listitem>
91 <para><emphasis role="strong">Linux Kernel-&min-kernel;</emphasis></para>
92
93 <para>The reason for the kernel version requirement is that we specify
94 that version when building <application>glibc</application> in
95 <xref linkend="chapter-cross-tools"/> and
96 <xref linkend="chapter-building-system"/>, so the workarounds for
97 older kernels are not enabled and the compiled
98 <application>glibc</application> is slightly faster and smaller.
99 As at June 2023, &min-kernel; is the oldest kernel release still
100 supported by the kernel developers.</para>
101
102 <para>If the host kernel is earlier than &min-kernel; you will need to replace
103 the kernel with a more up-to-date version. There are two ways
104 you can go about this. First, see if your Linux vendor provides a &min-kernel;
105 or later kernel package. If so, you may wish to install it. If your
106 vendor doesn't offer an acceptable kernel package, or you would prefer not to
107 install it, you can compile a kernel yourself. Instructions for
108 compiling the kernel and configuring the boot loader (assuming the host
109 uses GRUB) are located in <xref linkend="chapter-bootable"/>.</para>
110
111 <para>We require the host kernel to support UNIX 98 pseudo terminal
112 (PTY). It should be enabled on all desktop or server distros shipping
113 Linux &min-kernel; or a newer kernel. If you are building a custom
114 host kernel, ensure <option>CONFIG_UNIX98_PTYS</option> is set to
115 <literal>y</literal> in the kernel configuration.</para>
116
117 </listitem>
118
119 <listitem>
120 <para><emphasis role="strong">M4-1.4.10</emphasis></para>
121 </listitem>
122
123 <listitem>
124 <para><emphasis role="strong">Make-4.0</emphasis></para>
125 </listitem>
126
127 <listitem>
128 <para><emphasis role="strong">Patch-2.5.4</emphasis></para>
129 </listitem>
130
131 <listitem>
132 <para><emphasis role="strong">Perl-5.8.8</emphasis></para>
133 </listitem>
134
135 <listitem>
136 <para><emphasis role="strong">Python-3.4</emphasis></para>
137 </listitem>
138
139 <listitem>
140 <para><emphasis role="strong">Sed-4.1.5</emphasis></para>
141 </listitem>
142
143 <listitem>
144 <para><emphasis role="strong">Tar-1.22</emphasis></para>
145 </listitem>
146
147 <listitem>
148 <para><emphasis role="strong">Texinfo-4.7</emphasis></para>
149 </listitem>
150
151 <listitem>
152 <para><emphasis role="strong">Xz-5.0.0</emphasis></para>
153 </listitem>
154
155 </itemizedlist>
156
157 <important>
158 <para>Note that the symlinks mentioned above are required to build an LFS
159 system using the instructions contained within this book. Symlinks that
160 point to other software (such as dash, mawk, etc.) may work, but are not
161 tested or supported by the LFS development team, and may require either
162 deviation from the instructions or additional patches to some
163 packages.</para>
164 </important>
165
166 <!-- Use an empty sect2 element to prevent a pdf warning. -->
167 <bridgehead renderas="sect2"
168 id="version-check"
169 xreflabel="Host System Requirements">
170 </bridgehead>
171 <!--<title> </title>-->
172
173 <para >To see whether your host system has all the appropriate versions, and
174 the ability to compile programs, run the following commands:</para>
175
176<screen role="nodump"><userinput>cat &gt; version-check.sh &lt;&lt; "EOF"
177<literal>#!/bin/bash
178# A script to list version numbers of critical development tools
179
180# If you have tools installed in other directories, adjust PATH here AND
181# in ~lfs/.bashrc (section 4.4) as well.
182
183LC_ALL=C
184PATH=/usr/bin:/bin
185
186bail() { echo "FATAL: $1"; exit 1; }
187grep --version > /dev/null 2> /dev/null || bail "grep does not work"
188sed '' /dev/null || bail "sed does not work"
189sort /dev/null || bail "sort does not work"
190
191ver_check()
192{
193 if ! type -p $2 &amp;>/dev/null
194 then
195 echo "ERROR: Cannot find $2 ($1)"; return 1;
196 fi
197 v=$($2 --version 2>&amp;1 | grep -E -o '[0-9]+\.[0-9\.]+[a-z]*' | head -n1)
198 if printf '%s\n' $3 $v | sort --version-sort --check &amp;>/dev/null
199 then
200 printf "OK: %-9s %-6s >= $3\n" "$1" "$v"; return 0;
201 else
202 printf "ERROR: %-9s is TOO OLD ($3 or later required)\n" "$1";
203 return 1;
204 fi
205}
206
207ver_kernel()
208{
209 kver=$(uname -r | grep -E -o '^[0-9\.]+')
210 if printf '%s\n' $1 $kver | sort --version-sort --check &amp;>/dev/null
211 then
212 printf "OK: Linux Kernel $kver >= $1\n"; return 0;
213 else
214 printf "ERROR: Linux Kernel ($kver) is TOO OLD ($1 or later required)\n" "$kver";
215 return 1;
216 fi
217}
218
219# Coreutils first because-sort needs Coreutils >= 7.0
220ver_check Coreutils sort 7.0 || bail "--version-sort unsupported"
221ver_check Bash bash 3.2
222ver_check Binutils ld 2.13.1
223ver_check Bison bison 2.7
224ver_check Diffutils diff 2.8.1
225ver_check Findutils find 4.2.31
226ver_check Gawk gawk 4.0.1
227ver_check GCC gcc 5.1
228ver_check "GCC (C++)" g++ 5.1
229ver_check Grep grep 2.5.1a
230ver_check Gzip gzip 1.3.12
231ver_check M4 m4 1.4.10
232ver_check Make make 4.0
233ver_check Patch patch 2.5.4
234ver_check Perl perl 5.8.8
235ver_check Python python3 3.4
236ver_check Sed sed 4.1.5
237ver_check Tar tar 1.22
238ver_check Texinfo texi2any 4.7
239ver_check Xz xz 5.0.0
240ver_kernel &min-kernel;
241
242if mount | grep -q 'devpts on /dev/pts' &amp;&amp; [ -e /dev/ptmx ]
243then echo "OK: Linux Kernel supports UNIX 98 PTY";
244else echo "ERROR: Linux Kernel does NOT support UNIX 98 PTY"; fi
245
246alias_check() {
247 if $1 --version 2>&amp;1 | grep -qi $2
248 then printf "OK: %-4s is $2\n" "$1";
249 else printf "ERROR: %-4s is NOT $2\n" "$1"; fi
250}
251echo "Aliases:"
252alias_check awk GNU
253alias_check yacc Bison
254alias_check sh Bash
255
256echo "Compiler check:"
257if printf "int main(){}" | g++ -x c++ -
258then echo "OK: g++ works";
259else echo "ERROR: g++ does NOT work"; fi
260rm -f a.out</literal>
261EOF
262
263bash version-check.sh</userinput></screen>
264
265 </sect2>
266</sect1>
Note: See TracBrowser for help on using the repository browser.