source: chapter02/hostreqs.xml@ 4e897cf

multilib
Last change on this file since 4e897cf was 4e897cf, checked in by Thomas Trepl <thomas@…>, 14 months ago

Fix conflicts

  • Property mode set to 100644
File size: 9.0 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-6.9</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"/>,
97 at the recommendation of the developers.</para>
98
99 <para>If the host kernel is earlier than &min-kernel; you will need to replace
100 the kernel with a more up-to-date version. There are two ways
101 you can go about this. First, see if your Linux vendor provides a &min-kernel;
102 or later kernel package. If so, you may wish to install it. If your
103 vendor doesn't offer an acceptable kernel package, or you would prefer not to
104 install it, you can compile a kernel yourself. Instructions for
105 compiling the kernel and configuring the boot loader (assuming the host
106 uses GRUB) are located in <xref linkend="chapter-bootable"/>.</para>
107
108 </listitem>
109
110 <listitem>
111 <para><emphasis role="strong">M4-1.4.10</emphasis></para>
112 </listitem>
113
114 <listitem>
115 <para><emphasis role="strong">Make-4.0</emphasis></para>
116 </listitem>
117
118 <listitem>
119 <para><emphasis role="strong">Patch-2.5.4</emphasis></para>
120 </listitem>
121
122 <listitem>
123 <para><emphasis role="strong">Perl-5.8.8</emphasis></para>
124 </listitem>
125
126 <listitem>
127 <para><emphasis role="strong">Python-3.4</emphasis></para>
128 </listitem>
129
130 <listitem>
131 <para><emphasis role="strong">Sed-4.1.5</emphasis></para>
132 </listitem>
133
134 <listitem>
135 <para><emphasis role="strong">Tar-1.22</emphasis></para>
136 </listitem>
137
138 <listitem>
139 <para><emphasis role="strong">Texinfo-4.7</emphasis></para>
140 </listitem>
141
142 <listitem>
143 <para><emphasis role="strong">Xz-5.0.0</emphasis></para>
144 </listitem>
145
146 </itemizedlist>
147
148 <important>
149 <para>Note that the symlinks mentioned above are required to build an LFS
150 system using the instructions contained within this book. Symlinks that
151 point to other software (such as dash, mawk, etc.) may work, but are not
152 tested or supported by the LFS development team, and may require either
153 deviation from the instructions or additional patches to some
154 packages.</para>
155 </important>
156
157 <!-- Use an empty sect2 element to prevent a pdf warning. -->
158 <bridgehead renderas="sect2"
159 id="version-check"
160 xreflabel="Host System Requirements">
161 </bridgehead>
162 <!--<title> </title>-->
163
164 <para >To see whether your host system has all the appropriate versions, and
165 the ability to compile programs, run the following commands:</para>
166
167<screen role="nodump"><userinput>cat &gt; version-check.sh &lt;&lt; "EOF"
168<literal> #!/bin/bash
169# A script to list version numbers of critical development tools
170
171# If you have tools installed in other directories, adjust PATH here AND
172# in ~lfs/.bashrc (section 4.4) as well.
173
174LC_ALL=C
175PATH=/usr/bin:/bin
176
177bail() { echo "FATAL: $1"; exit 1; }
178grep --version > /dev/null 2> /dev/null || bail "grep does not work"
179sed '' /dev/null || bail "sed does not work"
180sort /dev/null || bail "sort does not work"
181
182ver_check()
183{
184 if ! type -p $2 &amp;>/dev/null
185 then
186 echo "ERROR: Cannot find $2 ($1)"; return 1;
187 fi
188 v=$($2 --version 2>&amp;1 | grep -E -o '[0-9]+\.[0-9\.]+' | head -n1)
189 if printf '%s\n' $3 $v | sort --version-sort --check &amp;>/dev/null
190 then
191 printf "OK: %-9s %-6s >= $3\n" "$1" "$v"; return 0;
192 else
193 printf "ERROR: %-9s is TOO OLD ($3 or later required)\n" "$1";
194 return 1;
195 fi
196}
197
198ver_kernel()
199{
200 kver=$(uname -r | sed -E 's/^([0-9\.]+).*/\1/')
201 if printf '%s\n' $1 $kver | sort --version-sort --check &amp;>/dev/null
202 then
203 printf "OK: Linux Kernel $kver >= $1\n"; return 0;
204 else
205 printf "ERROR: Linux Kernel ($kver) is TOO OLD ($1 or later required)\n" "$kver";
206 return 1;
207 fi
208}
209
210# Coreutils first because-sort needs Coreutils >= 7.0
211ver_check Coreutils sort 7.0 || bail "--version-sort unsupported"
212ver_check Bash bash 3.2
213ver_check Binutils ld 2.13.1
214ver_check Bison bison 2.7
215ver_check Diffutils diff 2.8.1
216ver_check Findutils find 4.2.31
217ver_check Gawk gawk 4.0.1
218ver_check GCC gcc 5.1
219ver_check "GCC (C++)" g++ 5.1
220ver_check Grep grep 2.6.1
221ver_check Gzip gzip 1.3.12
222ver_check M4 m4 1.4.10
223ver_check Make make 4.0
224ver_check Patch patch 2.5.4
225ver_check Perl perl 5.8.8
226ver_check Python python3 3.4
227ver_check Sed sed 4.1.5
228ver_check Tar tar 1.22
229ver_check Texinfo texi2any 4.7
230ver_check Xz xz 5.0.0
231#ver_check "Linux Kernel" "" 3.2 'cat /proc/version'
232ver_kernel 3.2
233
234alias_check() {
235 if $1 --version 2>&amp;1 | grep -qi $2
236 then printf "OK: %-4s is $2\n" "$1";
237 else printf "ERROR: %-4s is NOT $2\n" "$1"; fi
238}
239echo "Aliases:"
240alias_check awk GNU
241alias_check yacc Bison
242alias_check sh Bash
243
244echo "Compiler check"
245if printf "int main(){}" | g++ -x c++ -
246then echo "OK: g++ works";
247else echo "ERROR: g++ does NOT work"; fi
248rm -f a.out</literal>
249EOF
250
251bash version-check.sh</userinput></screen>
252
253 <para arch="ml_32,ml_x32,ml_all">
254 Building multilib support requires the kernel of the host system
255 to have 32-bit emulation support included.
256 </para>
257<screen arch="ml_32,ml_x32,ml_all">Binary Emulations ---&gt;
258 [*] IA32 Emulation
259 &lt;M&gt; IA32 a.out support
260 [*] x32 ABI for 64-bit mode
261</screen>
262
263 <para arch="ml_32,ml_x32,ml_all">The option 'IA32 a.out support' is
264 optional. In case your kernel does not have 'x32 ABI for 64-bit mode'
265 enabled but only 'IA32 Emulation', you can continue to build your
266 system but you have to leave out any sections showing instructions
267 for building x32 objects. If neither 'IA32 Emulation' nor
268 'x32 ABI for 64-bit mode' is enabled, you will run in errors
269 latest when building <application>glibc</application> in Chapter 6,
270 so an upgrade of your host system kernel is required.
271 </para>
272
273 </sect2>
274
275</sect1>
Note: See TracBrowser for help on using the repository browser.