hostreqs.xml 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  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. <sect1 id="ch-partitioning-hostreqs" xreflabel="Host System Requirements">
  8. <?dbhtml filename="hostreqs.html"?>
  9. <title>Host System Requirements</title>
  10. <para>Your host system should have the following software with the
  11. minimum versions indicated. This should not be an issue for most
  12. modern Linux distributions. Also note that many distributions will
  13. place software headers into separate packages, often in the form of
  14. <quote>&lt;package-name&gt;-devel</quote> or
  15. <quote>&lt;package-name&gt;-dev</quote>. Be sure to install those if
  16. your distribution provides them.</para>
  17. <para>Earlier versions of the listed software packages may work, but have
  18. not been tested.</para>
  19. <itemizedlist spacing="compact">
  20. <listitem>
  21. <para><emphasis role="strong">Bash-3.2</emphasis> (/bin/sh
  22. should be a symbolic or hard link to bash)</para>
  23. </listitem>
  24. <listitem>
  25. <para><emphasis role="strong">Binutils-2.25</emphasis> (Versions
  26. greater than &binutils-version; are not recommended as they have
  27. not been tested)</para>
  28. </listitem>
  29. <listitem>
  30. <para><emphasis role="strong">Bison-2.7</emphasis> (/usr/bin/yacc
  31. should be a link to bison or small script that executes bison)</para>
  32. </listitem>
  33. <listitem>
  34. <para><emphasis role="strong">Bzip2-1.0.4</emphasis></para>
  35. </listitem>
  36. <listitem>
  37. <para><emphasis role="strong">Coreutils-6.9</emphasis></para>
  38. </listitem>
  39. <listitem>
  40. <para><emphasis role="strong">Diffutils-2.8.1</emphasis></para>
  41. </listitem>
  42. <listitem>
  43. <para><emphasis role="strong">Findutils-4.2.31</emphasis></para>
  44. </listitem>
  45. <listitem>
  46. <para><emphasis role="strong">Gawk-4.0.1</emphasis> (/usr/bin/awk
  47. should be a link to gawk)</para>
  48. </listitem>
  49. <!-- glibc-2.30 requires gcc-6.2 or later -->
  50. <listitem>
  51. <para><emphasis role="strong">GCC-6.2</emphasis> including the C++
  52. compiler, <command>g++</command> (Versions greater than &gcc-version; are
  53. not recommended as they have not been tested)</para>
  54. </listitem>
  55. <listitem>
  56. <para><emphasis role="strong">Glibc-2.11</emphasis> (Versions
  57. greater than &glibc-version; are not recommended as they have
  58. not been tested)</para>
  59. </listitem>
  60. <listitem>
  61. <para><emphasis role="strong">Grep-2.5.1a</emphasis></para>
  62. </listitem>
  63. <listitem>
  64. <para><emphasis role="strong">Gzip-1.3.12</emphasis></para>
  65. </listitem>
  66. <listitem>
  67. <para><emphasis role="strong">Linux Kernel-&min-kernel;</emphasis></para>
  68. <para>The reason for the kernel version requirement is that we specify
  69. that version when building <application>glibc</application> in Chapter&nbsp;6
  70. at the recommendation of the developers. It is also required by
  71. udev.</para>
  72. <para>If the host kernel is earlier than &min-kernel; you will need to replace
  73. the kernel with a more up to date version. There are two ways
  74. you can go about this. First, see if your Linux vendor provides a &min-kernel;
  75. or later kernel package. If so, you may wish to install it. If your
  76. vendor doesn't offer an acceptable kernel package, or you would prefer not to
  77. install it, you can compile a kernel yourself. Instructions for
  78. compiling the kernel and configuring the boot loader (assuming the host
  79. uses GRUB) are located in <xref linkend="chapter-bootable"/>.</para>
  80. </listitem>
  81. <listitem>
  82. <para><emphasis role="strong">M4-1.4.10</emphasis></para>
  83. </listitem>
  84. <listitem>
  85. <para><emphasis role="strong">Make-4.0</emphasis></para>
  86. </listitem>
  87. <listitem>
  88. <para><emphasis role="strong">Patch-2.5.4</emphasis></para>
  89. </listitem>
  90. <listitem>
  91. <para><emphasis role="strong">Perl-5.8.8</emphasis></para>
  92. </listitem>
  93. <listitem>
  94. <para><emphasis role="strong">Python-3.4</emphasis></para>
  95. </listitem>
  96. <listitem>
  97. <para><emphasis role="strong">Sed-4.1.5</emphasis></para>
  98. </listitem>
  99. <listitem>
  100. <para><emphasis role="strong">Tar-1.22</emphasis></para>
  101. </listitem>
  102. <listitem>
  103. <para><emphasis role="strong">Texinfo-4.7</emphasis></para>
  104. </listitem>
  105. <listitem>
  106. <para><emphasis role="strong">Xz-5.0.0</emphasis></para>
  107. </listitem>
  108. </itemizedlist>
  109. <important>
  110. <para>Note that the symlinks mentioned above are required to build an LFS
  111. system using the instructions contained within this book. Symlinks that
  112. point to other software (such as dash, mawk, etc.) may work, but are not
  113. tested or supported by the LFS development team, and may require either
  114. deviation from the instructions or additional patches to some
  115. packages.</para>
  116. </important>
  117. <!-- Use an empty sect2 element to prevent a pdf warning. -->
  118. <bridgehead renderas="sect2"
  119. id="version-check"
  120. xreflabel="Host System Requirements">
  121. </bridgehead>
  122. <!--<title> </title>-->
  123. <para >To see whether your host system has all the appropriate versions, and
  124. the ability to compile programs, run the following:</para>
  125. <!-- ANY additional lines in the script cause a pdf rendering problem-->
  126. <screen role="nodump"><userinput>cat &gt; version-check.sh &lt;&lt; "EOF"
  127. <literal>#!/bin/bash
  128. # Simple script to list version numbers of critical development tools
  129. export LC_ALL=C
  130. bash --version | head -n1 | cut -d" " -f2-4
  131. MYSH=$(readlink -f /bin/sh)
  132. echo "/bin/sh -&gt; $MYSH"
  133. echo $MYSH | grep -q bash || echo "ERROR: /bin/sh does not point to bash"
  134. unset MYSH
  135. echo -n "Binutils: "; ld --version | head -n1 | cut -d" " -f3-
  136. bison --version | head -n1
  137. if [ -h /usr/bin/yacc ]; then
  138. echo "/usr/bin/yacc -> `readlink -f /usr/bin/yacc`";
  139. elif [ -x /usr/bin/yacc ]; then
  140. echo yacc is `/usr/bin/yacc --version | head -n1`
  141. else
  142. echo "yacc not found"
  143. fi
  144. bzip2 --version 2&gt;&amp;1 &lt; /dev/null | head -n1 | cut -d" " -f1,6-
  145. echo -n "Coreutils: "; chown --version | head -n1 | cut -d")" -f2
  146. diff --version | head -n1
  147. find --version | head -n1
  148. gawk --version | head -n1
  149. if [ -h /usr/bin/awk ]; then
  150. echo "/usr/bin/awk -&gt; `readlink -f /usr/bin/awk`";
  151. elif [ -x /usr/bin/awk ]; then
  152. echo awk is `/usr/bin/awk --version | head -n1`
  153. else
  154. echo "awk not found"
  155. fi
  156. gcc --version | head -n1
  157. g++ --version | head -n1
  158. ldd --version | head -n1 | cut -d" " -f2- # glibc version
  159. grep --version | head -n1
  160. gzip --version | head -n1
  161. cat /proc/version
  162. m4 --version | head -n1
  163. make --version | head -n1
  164. patch --version | head -n1
  165. echo Perl `perl -V:version`
  166. python3 --version
  167. sed --version | head -n1
  168. tar --version | head -n1
  169. makeinfo --version | head -n1 # texinfo version
  170. xz --version | head -n1
  171. <?hard-pagebreak?>
  172. echo 'int main(){}' &gt; dummy.c &amp;&amp; g++ -o dummy dummy.c
  173. if [ -x dummy ]
  174. then echo "g++ compilation OK";
  175. else echo "g++ compilation failed"; fi
  176. rm -f dummy.c dummy</literal>
  177. EOF
  178. bash version-check.sh</userinput></screen>
  179. <!--
  180. <para>Also check for some library consistency:</para>
  181. <screen role="nodump"><userinput>cat &gt; library-check.sh &lt;&lt; "EOF"
  182. <literal>#!/bin/bash
  183. for lib in lib{gmp,mpfr,mpc}.la; do
  184. echo $lib: $(if find /usr/lib* -name $lib|
  185. grep -q $lib;then :;else echo not;fi) found
  186. done
  187. unset lib</literal>
  188. EOF
  189. bash library-check.sh</userinput></screen>
  190. <para>The files identified by this script should be all present
  191. or all absent, but not only one or two present.</para>
  192. -->
  193. <para arch="ml_32,ml_x32,ml_all">
  194. Building multilib support requires the kernel of the host system
  195. to have 32-bit emulation support included.
  196. </para>
  197. <screen arch="ml_32,ml_x32,ml_all">Binary Emulations ---&gt;
  198. [*] IA32 Emulation
  199. &lt;M&gt; IA32 a.out support
  200. [*] x32 ABI for 64-bit mode
  201. </screen>
  202. <para arch="ml_32,ml_x32,ml_all">The option 'IA32 a.out support' is
  203. optional. In case your kernel does not have 'x32 ABI for 64-bit mode'
  204. enabled but only 'IA32 Emulation', you can continue to build your
  205. system but you have to leave out any sections showing instructions
  206. for building x32 objects. If neither 'IA32 Emulation' nor
  207. 'x32 ABI for 64-bit mode' is enabled, you will run in errors
  208. latest when building <application>glibc</application> in Chapter 6,
  209. so an upgrade of your host system is required.
  210. </para>
  211. </sect1>