source: chapter07/kernfs.xml@ 7ae2811

11.3 11.3-rc1 12.0 12.0-rc1 12.1 12.1-rc1 12.2 12.2-rc1 bdubbs/gcc13 multilib renodr/libudev-from-systemd trunk xry111/arm64 xry111/arm64-12.0 xry111/clfs-ng xry111/loongarch xry111/loongarch-12.0 xry111/loongarch-12.1 xry111/loongarch-12.2 xry111/mips64el xry111/multilib xry111/update-glibc
Last change on this file since 7ae2811 was 7ae2811, checked in by David Bryant <david@…>, 22 months ago

Standardize spelling of "userspace".

  • Property mode set to 100644
File size: 4.8 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-tools-kernfs">
9 <?dbhtml filename="kernfs.html"?>
10
11 <title>Preparing Virtual Kernel File Systems</title>
12
13 <indexterm zone="ch-tools-kernfs">
14 <primary sortas="e-/dev/">/dev/*</primary>
15 </indexterm>
16
17 <para>Applications running in userspace utilize various file
18 systems created by the kernel to communicate
19 with the kernel itself. These file systems are virtual: no disk
20 space is used for them. The content of these file systems resides in
21 memory. These file systems must be mounted in the $LFS directory tree
22 so the applications can find them in the chroot environment.</para>
23
24 <para>Begin by creating the directories on which these virtual file systems will be
25 mounted:</para>
26
27<screen><userinput>mkdir -pv $LFS/{dev,proc,sys,run}</userinput></screen>
28
29 <sect2 id="ch-tools-bindmount">
30 <title>Mounting and Populating /dev</title>
31
32 <para>During a normal boot of an LFS system, the kernel automatically
33 mounts the <systemitem class="filesystem">devtmpfs</systemitem>
34 file system on the
35 <filename class="directory">/dev</filename> directory; the kernel
36 creates device nodes on that virtual file system during the boot process,
37 or when a device is first detected or accessed. The udev daemon may
38 change the ownership or permissions of the device nodes created by the
39 kernel, and create new device nodes or symlinks, to ease the work of
40 distro maintainers and system administrators. (See
41 <xref linkend='ch-config-udev-device-node-creation'/> for details.)
42 If the host kernel supports &devtmpfs;, we can simply mount a
43 &devtmpfs; at <filename class='directory'>$LFS/dev</filename> and rely
44 on the kernel to populate it.</para>
45
46 <para>But some host kernels lack &devtmpfs; support; these
47 host distros use different methods to create the content of
48 <filename class="directory">/dev</filename>.
49 So the only host-agnostic way to populate the
50 <filename class="directory">$LFS/dev</filename> directory is
51 by bind mounting the host system's
52 <filename class="directory">/dev</filename> directory. A bind mount is
53 a special type of mount that makes a directory subtree or a file
54 visible at some other location. Use the following
55 command to do this.</para>
56
57<screen><userinput>mount -v --bind /dev $LFS/dev</userinput></screen>
58
59 </sect2>
60
61 <sect2 id="ch-tools-kernfsmount">
62 <title>Mounting Virtual Kernel File Systems</title>
63
64 <para>Now mount the remaining virtual kernel file systems:</para>
65
66<screen><userinput>mount -v --bind /dev/pts $LFS/dev/pts
67mount -vt proc proc $LFS/proc
68mount -vt sysfs sysfs $LFS/sys
69mount -vt tmpfs tmpfs $LFS/run</userinput></screen>
70<!--
71 <variablelist>
72 <title>The meaning of the mount options for devpts:</title>
73
74 <varlistentry>
75 <term><parameter>gid=5</parameter></term>
76 <listitem>
77 <para>This ensures that all devpts-created device nodes are owned by
78 group ID 5. This is the ID we will use later on for the <systemitem
79 class="groupname">tty</systemitem> group. We use the group ID instead
80 of a name, since the host system might use a different ID for its
81 <systemitem class="groupname">tty</systemitem> group.</para>
82 </listitem>
83 </varlistentry>
84
85 <varlistentry>
86 <term><parameter>mode=0620</parameter></term>
87 <listitem>
88 <para>This ensures that all devpts-created device nodes have mode 0620
89 (user readable and writable, group writable). Together with the
90 option above, this ensures that devpts will create device nodes that
91 meet the requirements of grantpt(), meaning the Glibc
92 <command>pt_chown</command> helper binary (which is not installed by
93 default) is not necessary.</para>
94 </listitem>
95 </varlistentry>
96
97 </variablelist>
98-->
99 <para>In some host systems, <filename>/dev/shm</filename> is a
100 symbolic link to <filename class="directory">/run/shm</filename>.
101 The /run tmpfs was mounted above so in this case only a
102 directory needs to be created.</para>
103
104 <para>In other host systems <filename>/dev/shm</filename> is a mount point
105 for a tmpfs. In that case the mount of /dev above will only create
106 /dev/shm as a directory in the chroot environment. In this situation
107 we must explicitly mount a tmpfs:</para>
108
109<screen><userinput>if [ -h $LFS/dev/shm ]; then
110 mkdir -pv $LFS/$(readlink $LFS/dev/shm)
111else
112 mount -t tmpfs -o nosuid,nodev tmpfs $LFS/dev/shm
113fi</userinput></screen>
114
115 </sect2>
116
117</sect1>
Note: See TracBrowser for help on using the repository browser.