glibc-inst.xml 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. <sect2><title>&nbsp;</title><para>&nbsp;</para></sect2>
  2. <sect2>
  3. <title>Glibc installation</title>
  4. <para>The Glibc build system is very well self-contained and will install
  5. perfectly, even though our compiler specs file and linker are still pointing
  6. at <filename>/tools</filename>. We cannot adjust the specs and linker before
  7. the Glibc install, because the Glibc autoconf tests would then give bogus
  8. results and thus defeat our goal of achieving a clean build.</para>
  9. <note><para>The test suite for Glibc in this section is considered <emphasis>
  10. critical</emphasis>. Our advice is to not skip it under any
  11. circumstances.</para></note>
  12. <para>Before starting to build Glibc, remember to unpack the Glibc-linuxthreads
  13. again inside the <filename>glibc-&glibc-version;</filename> directory, and to
  14. unset any environment variables that override the default optimization
  15. flags.</para>
  16. <para>Then apply the same patch we used previously:</para>
  17. <para><screen><userinput>patch -Np1 -i ../glibc-2.3.2-sscanf-1.patch
  18. </userinput></screen></para>
  19. <para>The Glibc documentation recommends building Glibc outside of the source
  20. directory in a dedicated build directory:</para>
  21. <para><screen><userinput>mkdir ../glibc-build
  22. cd ../glibc-build</userinput></screen></para>
  23. <para>Now prepare Glibc for compilation:</para>
  24. <para><screen><userinput>../glibc-&glibc-version;/configure --prefix=/usr \
  25. &nbsp;&nbsp;&nbsp;&nbsp;--disable-profile --enable-add-ons \
  26. &nbsp;&nbsp;&nbsp;&nbsp;--libexecdir=/usr/bin --with-headers=/usr/include</userinput></screen></para>
  27. <para>The meaning of the new configure options:</para>
  28. <itemizedlist>
  29. <listitem><para><userinput>--libexecdir=/usr/bin</userinput>: This will
  30. cause the <filename>pt_chown</filename> program to be installed in the
  31. <filename>/usr/bin</filename> directory.</para></listitem>
  32. <listitem><para><userinput>--with-headers=/usr/include</userinput>: This
  33. ensures that the kernel headers in <filename>/usr/include</filename> are used
  34. for this build. If you don't pass this switch then the headers from
  35. <filename>/tools/include</filename> are used which of course is not ideal
  36. (although they should be identical). Using this switch has the advantage
  37. that you will be informed immediately should you have forgotten to install the
  38. kernel headers into <filename>/usr/include</filename>.</para></listitem>
  39. </itemizedlist>
  40. <para>Compile the package:</para>
  41. <para><screen><userinput>make</userinput></screen></para>
  42. <para>Test the results:</para>
  43. <para><screen><userinput>make check</userinput></screen></para>
  44. <para>And install the package:</para>
  45. <para><screen><userinput>make install</userinput></screen></para>
  46. <para>The locales that can make your system respond in a different language
  47. weren't installed by the above command. Do it with this:</para>
  48. <para><screen><userinput>make localedata/install-locales</userinput></screen></para>
  49. <para>An alternative to running the previous command is to install only those
  50. locales which you need or want. This can be achieved using the
  51. <userinput>localedef</userinput> command. Information on this can be found in
  52. the <filename>INSTALL</filename> file in the
  53. <filename>glibc-&glibc-version;</filename> tree. However, there are a number
  54. of locales that are essential for the tests of future packages to pass
  55. correctly. The following instructions, in place of the install-locales
  56. command above, will install the minimum set of locales necessary for the
  57. tests to run successfully:</para>
  58. <para><screen><userinput>mkdir -p /usr/lib/locale
  59. localedef -i de_DE -f ISO-8859-1 de_DE
  60. localedef -i de_DE@euro -f ISO-8859-15 de_DE@euro
  61. localedef -i en_HK -f ISO-8859-1 en_HK
  62. localedef -i en_PH -f ISO-8859-1 en_PH
  63. localedef -i en_US -f ISO-8859-1 en_US
  64. localedef -i es_MX -f ISO-8859-1 es_MX
  65. localedef -i fr_FR -f ISO-8859-1 fr_FR
  66. localedef -i fr_FR@euro -f ISO-8859-15 fr_FR@euro
  67. localedef -i it_IT -f ISO-8859-1 it_IT
  68. localedef -i ja_JP -f EUC-JP ja_JP</userinput></screen></para>
  69. <para>Finally, build the linuxthreads man pages:</para>
  70. <para><screen><userinput>make -C ../glibc-2.3.2/linuxthreads/man</userinput></screen></para>
  71. <para>And install these pages:</para>
  72. <para><screen><userinput>make -C ../glibc-2.3.2/linuxthreads/man install</userinput></screen></para>
  73. </sect2>