source: chapter04/settingenviron.xml@ ede49cd

multilib-10.1
Last change on this file since ede49cd was ede49cd, checked in by Thomas Trepl <thomas@…>, 4 years ago

MultiLib: Merge changes from trunk

git-svn-id: http://svn.linuxfromscratch.org/LFS/branches/multilib@11747 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689

  • Property mode set to 100644
File size: 4.9 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-preps-settingenviron">
9 <?dbhtml filename="settingenvironment.html"?>
10
11 <title>Setting Up the Environment</title>
12
13 <para>Set up a good working environment by creating two new startup files
14 for the <command>bash</command> shell. While logged in as user
15 <systemitem class="username">lfs</systemitem>, issue the following command
16 to create a new <filename>.bash_profile</filename>:</para>
17
18<screen><userinput>cat &gt; ~/.bash_profile &lt;&lt; "EOF"
19<literal>exec env -i HOME=$HOME TERM=$TERM PS1='\u:\w\$ ' /bin/bash</literal>
20EOF</userinput></screen>
21
22 <para>When logged on as user <systemitem class="username">lfs</systemitem>,
23 the initial shell is usually a <emphasis>login</emphasis> shell which reads
24 the <filename>/etc/profile</filename> of the host (probably containing some
25 settings and environment variables) and then <filename>.bash_profile</filename>.
26 The <command>exec env -i.../bin/bash</command> command in the
27 <filename>.bash_profile</filename> file replaces the running shell with a new
28 one with a completely empty environment, except for the <envar>HOME</envar>,
29 <envar>TERM</envar>, and <envar>PS1</envar> variables. This ensures that no
30 unwanted and potentially hazardous environment variables from the host system
31 leak into the build environment. The technique used here achieves the goal of
32 ensuring a clean environment.</para>
33
34 <para>The new instance of the shell is a <emphasis>non-login</emphasis>
35 shell, which does not read the <filename>/etc/profile</filename> or
36 <filename>.bash_profile</filename> files, but rather reads the
37 <filename>.bashrc</filename> file instead. Create the
38 <filename>.bashrc</filename> file now:</para>
39
40<screen arch="default"><userinput>cat &gt; ~/.bashrc &lt;&lt; "EOF"
41<literal>set +h
42umask 022
43LFS=/mnt/lfs
44LC_ALL=POSIX
45LFS_TGT=$(uname -m)-lfs-linux-gnu
46PATH=/tools/bin:/bin:/usr/bin
47export LFS LC_ALL LFS_TGT PATH</literal>
48EOF</userinput></screen>
49
50<screen arch="ml_32,ml_x32,ml_all"><userinput>cat &gt; ~/.bashrc &lt;&lt; "EOF"
51<literal>set +h
52umask 022
53LFS=/mnt/lfs
54LC_ALL=POSIX
55LFS_TGT=x86_64-lfs-linux-gnu
56LFS_TGT32=i686-lfs-linux-gnu
57LFS_TGTX32=x86_64-lfs-linux-gnux32
58PATH=/tools/bin:/bin:/usr/bin
59export LFS LC_ALL LFS_TGT LFS_TGT32 LFS_TGTX32 PATH</literal>
60EOF</userinput></screen>
61
62 <para>The <command>set +h</command> command turns off
63 <command>bash</command>'s hash function. Hashing is ordinarily a useful
64 feature&mdash;<command>bash</command> uses a hash table to remember the
65 full path of executable files to avoid searching the <envar>PATH</envar>
66 time and again to find the same executable. However, the new tools should
67 be used as soon as they are installed. By switching off the hash function,
68 the shell will always search the <envar>PATH</envar> when a program is to
69 be run. As such, the shell will find the newly compiled tools in
70 <filename class="directory">$LFS/tools</filename> as soon as they are
71 available without remembering a previous version of the same program in a
72 different location.</para>
73
74 <para>Setting the user file-creation mask (umask) to 022 ensures that newly
75 created files and directories are only writable by their owner, but are
76 readable and executable by anyone (assuming default modes are used by the
77 <function>open(2)</function> system call, new files will end up with permission
78 mode 644 and directories with mode 755).</para>
79
80 <para>The <envar>LFS</envar> variable should be set to the chosen mount
81 point.</para>
82
83 <para>The <envar>LC_ALL</envar> variable controls the localization of certain
84 programs, making their messages follow the conventions of a specified country.
85 Setting <envar>LC_ALL</envar> to <quote>POSIX</quote> or <quote>C</quote>
86 (the two are equivalent) ensures that everything will work as expected in
87 the chroot environment.</para>
88
89 <para>The <envar>LFS_TGT</envar> variable sets a non-default, but compatible machine
90 description for use when building our cross compiler and linker and when cross
91 compiling our temporary toolchain. More information is contained in
92 <xref linkend="ch-tools-toolchaintechnotes" role=""/>.</para>
93
94 <para>By putting <filename class="directory">/tools/bin</filename> ahead of the
95 standard <envar>PATH</envar>, all the programs installed in <xref
96 linkend="chapter-temporary-tools"/> are picked up by the shell immediately after
97 their installation. This, combined with turning off hashing, limits the risk
98 that old programs are used from the host when the same programs are available in
99 the chapter 5 environment.</para>
100
101 <para>Finally, to have the environment fully prepared for building the
102 temporary tools, source the just-created user profile:</para>
103
104<screen><userinput>source ~/.bash_profile</userinput></screen>
105
106</sect1>
Note: See TracBrowser for help on using the repository browser.