source: chapter06/devices.xml@ a9fde34e

Last change on this file since a9fde34e was 6a0e6f3, checked in by Matthew Burgess <matthew@…>, 20 years ago
  • Remove the spurious <info> tags that I thought were necessary but evidently aren't

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

  • Property mode set to 100644
File size: 2.5 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE section [
3 <!ENTITY % general-entities SYSTEM "../general.ent">
4 %general-entities;
5]>
6<section xmlns="http://docbook.org/docbook-ng"
7 xml:id="ch-system-devices" xreflabel="devices">
8<title>Populating /dev</title>
9<?dbhtml filename="devices.html"?>
10
11<indexterm zone="ch-system-devices"><primary sortas="e-Devices">Devices</primary></indexterm>
12
13<section>
14<title>Creating initial device nodes</title>
15
16<para>When the kernel boots the system, it requires the presence of a few device
17nodes, in particular the <filename class="devicefile">console</filename> and
18<filename class="devicefile">null</filename> devices:</para>
19
20<screen><userinput>mknod -m 600 /dev/console c 5 1
21mknod -m 666 /dev/null c 1 3</userinput></screen>
22</section>
23
24<section>
25<title>Mounting ramfs and populating /dev</title>
26
27<para>The ideal way to populate <filename class="directory">/dev</filename> is
28to mount a <systemitem class="filesystem">ramfs</systemitem> onto <filename class="directory">/dev </filename>
29like <systemitem class="filesystem">tmpfs</systemitem>, but it
30cannot be swapped) and create the devices on there during each bootup. Since we haven't
31booted the system, we have to do what the bootscripts would otherwise do for us, and
32populate <filename class="directory">/dev</filename> ourselves. Begin by mounting <filename class="directory">/dev</filename>:</para>
33
34<screen><userinput>mount -n -t ramfs none /dev</userinput></screen>
35
36<para>Since we do not have the Udev package installed yet, we'll create a
37minimal set of device nodes to use for building:</para>
38
39<screen><userinput>mknod -m 622 /dev/console c 5 1
40mknod -m 666 /dev/null c 1 3
41mknod -m 666 /dev/zero c 1 5
42mknod -m 666 /dev/ptmx c 5 2
43mknod -m 666 /dev/tty c 5 0
44mknod -m 444 /dev/random c 1 8
45mknod -m 444 /dev/urandom c 1 9
46chown root:tty /dev/{console,ptmx,tty}</userinput></screen>
47
48<para>There are some symlinks and directories required by LFS that are not created by
49Udev, so we create those ourselves here:</para>
50
51<screen><userinput>ln -s /proc/self/fd /dev/fd
52ln -s /proc/self/fd/0 /dev/stdin
53ln -s /proc/self/fd/1 /dev/stdout
54ln -s /proc/self/fd/2 /dev/stderr
55ln -s /proc/kcore /dev/core
56mkdir /dev/pts
57mkdir /dev/shm</userinput></screen>
58
59<para>Finally, mount the proper virtual (kernel) file systems on the directories we just
60created:</para>
61
62<screen><userinput>mount -t devpts -o gid=4,mode=620 none /dev/pts
63mount -t tmpfs none /dev/shm</userinput></screen>
64</section>
65
66
67</section>
Note: See TracBrowser for help on using the repository browser.