| 
					
				 | 
			
			
				@@ -3,19 +3,25 @@ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <sect2> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <title>Glibc installation</title> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<para>The Glibc build system is very well self-contained and will install 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+perfectly, even though our compiler specs file and linker scripts are still 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+pointing at <filename>/stage1</filename>. We cannot adjust the specs and 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ldscripts before the Glibc install, because the Glibc autoconf tests would then 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+give bogus results and thus defeat our goal of achieving a clean build.</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para>The documentation that comes with Glibc recommends to build the package 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 not in the source directory but in a separate, dedicated directory:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para><screen><userinput>mkdir ../glibc-build 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 cd ../glibc-build</userinput></screen></para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-<para>Next, prepare Glibc to be compiled:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<para>Now prepare Glibc for compilation:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para><screen><userinput>../glibc-&glibc-version;/configure --prefix=/usr \ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				     --disable-profile --enable-add-ons \ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				     --libexecdir=/usr/bin --with-headers=/usr/include</userinput></screen></para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-<para>The meaning of the configure options are:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<para>The meaning of the configure options:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <itemizedlist> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <listitem><para><userinput>--disable-profile</userinput>: This disables the 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -28,38 +34,44 @@ add-ons that we installed with Glibc, in our case Linuxthreads.</para></listitem 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <listitem><para><userinput>--libexecdir=/usr/bin</userinput>: This will 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 cause the <filename>pt_chown</filename> program to be installed in the 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <filename>/usr/bin</filename> directory.</para></listitem> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<listitem><para><userinput>--with-headers=/usr/include</userinput>: This 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ensures that the kernel headers in <filename>/usr/include</filename> are used 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+for this build. If you don't pass this switch then the headers from 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<filename>/stage1/include</filename> are used which of course is not ideal 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+(although they should be identical). Using the switch has the advantage 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+that you will be informed immediately should you have forgotten to install the 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+kernel headers into <filename>/usr/include</filename>.</para></listitem> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 </itemizedlist> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-<para>Continue with compiling the package:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<para>Compile the package:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para><screen><userinput>make</userinput></screen></para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-<para>We'll continue with installing the package. The Linuxthreads man 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-pages are not going to be installed at this point because it requires a 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-working Perl installation. We'll install Perl later on in this chapter, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-and the man pages will be installed when Glibc is installed for the second 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-time at the end of this chapter.</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<para>Check the results:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para><screen><userinput>make check</userinput></screen></para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<para>And install the package:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para><screen><userinput>make install</userinput></screen></para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-<para>The locales (used by Glibc to make your Linux system talk in a different 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-language) weren't installed when you ran the previous command, so we have to 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-do that ourselves now:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<para>The locales that can make your system respond in a different language 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+weren't installed by the above command. Do it with this:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para><screen><userinput>make localedata/install-locales</userinput></screen></para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para>An alternative to running the previous command is to install only those 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-locales which you need or want. This can be achieved using the localedef 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-command. Information on this can be found in the <filename>INSTALL</filename> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-file in the <filename>glibc-&glibc-version;</filename> tree.</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+locales which you need or want. This can be achieved using the 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<userinput>localedef</userinput> command. Information on this can be found in 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+the <filename>INSTALL</filename> file in the 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<filename>glibc-&glibc-version;</filename> tree.</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-<para>Build the linuxthreads man pages:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<para>Finally, build the linuxthreads man pages:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para><screen><userinput>make -C ../glibc-2.3.2/linuxthreads/man</userinput></screen></para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-<para>Install the man pages:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+<para>And install these pages:</para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <para><screen><userinput>make -C ../glibc-2.3.2/linuxthreads/man install</userinput></screen></para> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 |