source: chapter06/devices.xml@ e28de80

6.1 6.1.1
Last change on this file since e28de80 was aabd480, checked in by Archaic <archaic@…>, 19 years ago

Brought all occurences of LFS-Bootscripts into conformity. (merged from trunk r6288)

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

  • Property mode set to 100644
File size: 3.3 KB
RevLine 
[9dfc02f]1<?xml version="1.0" encoding="ISO-8859-1"?>
[1770019]2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.4//EN" "http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd" [
[9dfc02f]3 <!ENTITY % general-entities SYSTEM "../general.ent">
4 %general-entities;
5]>
[81fd230]6<sect1 id="ch-system-devices">
[4f74577]7<title>Populating /dev</title>
[9dfc02f]8<?dbhtml filename="devices.html"?>
9
[32b21a1]10<indexterm zone="ch-system-devices"><primary sortas="e-/dev/">/dev/*</primary></indexterm>
[81fd230]11
12<sect2>
13<title>Creating Initial Device Nodes</title>
14
15<para>When the kernel boots the system, it requires the presence of a few device
16nodes, in particular the <filename class="devicefile">console</filename> and
17<filename class="devicefile">null</filename> devices. Create these by
18running the following commands:</para>
[9dfc02f]19
20<screen><userinput>mknod -m 600 /dev/console c 5 1
21mknod -m 666 /dev/null c 1 3</userinput></screen>
[81fd230]22</sect2>
23
24<sect2>
[d16b770c]25<title>Mounting tmpfs and Populating /dev</title>
[9dfc02f]26
[373a708]27<para>The recommended method of populating the <filename
28class="directory">/dev</filename> directory with devices is to mount a virtual
[d16b770c]29filesystem (such as <systemitem class="filesystem">tmpfs</systemitem>) on the
30<filename class="directory">/dev</filename> directory, and allow the devices to
31be created dynamically on that virtual filesystem as they are detected or
32accessed. This is generally done during the boot process. Since this new system
[aabd480]33has not been booted, it is necessary to do what the LFS-Bootscripts package would
34otherwise do by mounting <filename class="directory">/dev</filename>:</para>
[9dfc02f]35
[d16b770c]36<screen><userinput>mount -n -t tmpfs none /dev</userinput></screen>
[9dfc02f]37
[373a708]38<para>The Udev package is what actually creates the devices in the <filename
39class="directory">/dev</filename> directory. Since it will not be installed
40until later on in the process, manually create the minimal set of device nodes
41needed to complete the building of this system:</para>
[9dfc02f]42
[0a9b2e0]43<screen><userinput>mknod -m 622 /dev/console c 5 1
44mknod -m 666 /dev/null c 1 3
45mknod -m 666 /dev/zero c 1 5
46mknod -m 666 /dev/ptmx c 5 2
[84dee3b4]47mknod -m 666 /dev/tty c 5 0
48mknod -m 444 /dev/random c 1 8
49mknod -m 444 /dev/urandom c 1 9
50chown root:tty /dev/{console,ptmx,tty}</userinput></screen>
[81fd230]51<!-- -->
[9dfc02f]52
[d16b770c]53<para>There are some symlinks and directories required by LFS that are created
[aabd480]54during system startup by the LFS-Bootscripts package. Since this is a chroot
55environment and not a booted environment, those symlinks and directories need to
56be created here:</para>
[9dfc02f]57
58<screen><userinput>ln -s /proc/self/fd /dev/fd
59ln -s /proc/self/fd/0 /dev/stdin
60ln -s /proc/self/fd/1 /dev/stdout
61ln -s /proc/self/fd/2 /dev/stderr
62ln -s /proc/kcore /dev/core
63mkdir /dev/pts
64mkdir /dev/shm</userinput></screen>
65
[81fd230]66<para>Finally, mount the proper virtual (kernel) file systems on the
67newly-created directories:</para>
[9dfc02f]68
69<screen><userinput>mount -t devpts -o gid=4,mode=620 none /dev/pts
70mount -t tmpfs none /dev/shm</userinput></screen>
[af133c3]71
[81fd230]72<para>The <command>mount</command> commands executed above may result
73in the following warning message:</para>
74
75<screen><computeroutput>can't open /etc/fstab: No such file or directory.</computeroutput></screen>
76
77<para>This file&mdash;<filename>/etc/fstab</filename>&mdash;has not
78been created yet but is also not required for the file systems to be
79properly mounted. As such, the warning can be safely ignored.</para>
80</sect2>
[9dfc02f]81
82</sect1>
[81fd230]83
Note: See TracBrowser for help on using the repository browser.