hostreqs.xml 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  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="pre-hostreqs">
  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. <itemizedlist spacing="compact">
  18. <listitem>
  19. <para><emphasis role="strong">Bash-2.05a</emphasis> (/bin/sh
  20. must be a symbolic or hard link to bash)</para>
  21. </listitem>
  22. <listitem>
  23. <para><emphasis role="strong">Binutils-2.12</emphasis> (Versions
  24. greater than &binutils-version; are not recommended as they have
  25. not been tested)</para>
  26. </listitem>
  27. <listitem>
  28. <para><emphasis role="strong">Bison-1.875</emphasis> (/usr/bin/yacc
  29. must be a link to bison or small script that executes bison)</para>
  30. </listitem>
  31. <listitem>
  32. <para><emphasis role="strong">Bzip2-1.0.2</emphasis></para>
  33. </listitem>
  34. <listitem>
  35. <para><emphasis role="strong">Coreutils-5.0</emphasis> (or Sh-Utils-2.0,
  36. Textutils-2.0, and Fileutils-4.1)</para>
  37. </listitem>
  38. <listitem>
  39. <para><emphasis role="strong">Diffutils-2.8</emphasis></para>
  40. </listitem>
  41. <listitem>
  42. <para><emphasis role="strong">Findutils-4.1.20</emphasis></para>
  43. </listitem>
  44. <listitem>
  45. <para><emphasis role="strong">Gawk-3.0</emphasis> (/usr/bin/awk
  46. must be a link to gawk)</para>
  47. </listitem>
  48. <listitem>
  49. <!-- Gcc-2.95.3 breaks feature tests when using CC="gcc -B/usr/bin/"
  50. in the *-pass1 sections -->
  51. <para><emphasis role="strong">Gcc-3.0.1</emphasis> (Versions
  52. greater than &gcc-version; are not recommended as they have not
  53. been tested)</para>
  54. </listitem>
  55. <listitem>
  56. <para><emphasis role="strong">Glibc-2.2.5</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</emphasis></para>
  62. </listitem>
  63. <listitem>
  64. <para><emphasis role="strong">Gzip-1.2.4</emphasis></para>
  65. </listitem>
  66. <listitem>
  67. <para><emphasis role="strong">Linux Kernel-2.6.x</emphasis>
  68. (having been compiled with GCC-3.0 or greater)</para>
  69. <para>The reason for the kernel version requirement is that thread-local
  70. storage support in Binutils will not be built and the Native POSIX
  71. Threading Library (NPTL) test suite will segfault if the host's kernel
  72. isn't at least a 2.6.x version compiled with a 3.0 or later release of
  73. GCC.</para>
  74. <para>If the host kernel is either earlier than 2.6.x, or it was not
  75. compiled using a GCC-3.0 (or later) compiler, you will have to replace
  76. the kernel with one adhering to the specifications. There are two methods
  77. you can take to solve this. First, see if your Linux vendor provides a
  78. 2.6 kernel package. If so, you may wish to install it. If your vendor
  79. doesn't offer a 2.6 kernel package, or you would prefer not to install it,
  80. then you can compile a 2.6 kernel yourself. Instructions for compiling the
  81. kernel and configuring the boot loader (assuming the host uses GRUB) are
  82. located in <xref linkend="chapter-bootable"/>.</para>
  83. </listitem>
  84. <listitem>
  85. <para><emphasis role="strong">Make-3.79.1</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.6.0</emphasis></para>
  92. </listitem>
  93. <listitem>
  94. <para><emphasis role="strong">Sed-3.0.2</emphasis></para>
  95. </listitem>
  96. <listitem>
  97. <para><emphasis role="strong">Tar-1.14</emphasis></para>
  98. </listitem>
  99. <!-- Needed by the apparently broken Binutils-2.18 -->
  100. <listitem>
  101. <para><emphasis role="strong">Texinfo-4.8</emphasis></para>
  102. </listitem>
  103. </itemizedlist>
  104. <para>To see whether your host system has all the appropriate versions, run the following:</para>
  105. <screen role="nodump"><userinput>cat &gt; version-check.sh &lt;&lt; "EOF"
  106. <literal>#!/bin/bash
  107. export LC_ALL=C
  108. # Simple script to list version numbers of critical development tools
  109. bash --version | head -n1 | cut -d" " -f2-4
  110. echo "/bin/sh -> `readlink -f /bin/sh`"
  111. echo -n "Binutils: "; ld --version | head -n1 | cut -d" " -f3-
  112. bison --version | head -n1
  113. if [ -e /usr/bin/yacc ]; then echo "/usr/bin/yacc -> `readlink -f /usr/bin/yacc`";
  114. else echo "yacc not found"; fi
  115. bzip2 --version 2&gt;&amp;1 &lt; /dev/null | head -n1 | cut -d" " -f1,6-
  116. echo -n "Coreutils: "; chown --version | head -n1 | cut -d")" -f2
  117. diff --version | head -n1
  118. find --version | head -n1
  119. gawk --version | head -n1
  120. if [ -e /usr/bin/awk ]; then echo "/usr/bin/awk -> `readlink -f /usr/bin/awk`";
  121. else echo "awk not found"; fi
  122. gcc --version | head -n1
  123. /lib/libc.so.6 | head -n1 | cut -d" " -f1-7
  124. grep --version | head -n1
  125. gzip --version | head -n1
  126. cat /proc/version
  127. make --version | head -n1
  128. patch --version | head -n1
  129. sed --version | head -n1
  130. tar --version | head -n1
  131. makeinfo --version | head -n1
  132. </literal>
  133. EOF
  134. bash version-check.sh</userinput></screen>
  135. </sect1>