devices.xml 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <?xml version="1.0" encoding="ISO-8859-1"?>
  2. <!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN" "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" [
  3. <!ENTITY % general-entities SYSTEM "../general.ent">
  4. %general-entities;
  5. ]>
  6. <sect1 id="ch-system-devices" xreflabel="devices">
  7. <title>Populating /dev with device nodes</title>
  8. <?dbhtml filename="devices.html"?>
  9. <indexterm zone="ch-system-devices"><primary sortas="e-Devices">Devices</primary></indexterm>
  10. <sect2>
  11. <title>Creating initial device nodes</title>
  12. <para>When the kernel boots the system, it requires the presence of a few device
  13. nodes, in particular the <filename class="devicefile">console</filename> and
  14. <filename class="devicefile">null</filename> devices:</para>
  15. <screen><userinput>mknod -m 600 /dev/console c 5 1
  16. mknod -m 666 /dev/null c 1 3</userinput></screen>
  17. </sect2>
  18. <sect2>
  19. <title>Mounting ramfs and populating /dev</title>
  20. <para>The ideal way to populate <filename class="directory">/dev</filename> is
  21. to mount a <systemitem class="filesystem">ramfs</systemitem> onto <filename class="directory">/dev </filename>
  22. like <systemitem class="filesystem">tmpfs</systemitem>, but it
  23. cannot be swapped) and create the devices on there during each bootup. Since we haven't
  24. booted the system, we have to do what the bootscripts would otherwise do for us, and
  25. populate <filename class="directory">/dev</filename> ourselves. Begin by mounting <filename class="directory">/dev</filename>:</para>
  26. <screen><userinput>mount -n -t ramfs none /dev</userinput></screen>
  27. <para>Now use the provided udevstart utility to create the initial devices based on
  28. all the information in <filename class="directory">/sys</filename>:</para>
  29. <screen><userinput>/tools/sbin/udevstart</userinput></screen>
  30. <para>There are some symlinks and directories required by LFS that are not created by
  31. Udev, so we create those ourselves here:</para>
  32. <screen><userinput>ln -s /proc/self/fd /dev/fd
  33. ln -s /proc/self/fd/0 /dev/stdin
  34. ln -s /proc/self/fd/1 /dev/stdout
  35. ln -s /proc/self/fd/2 /dev/stderr
  36. ln -s /proc/kcore /dev/core
  37. mkdir /dev/pts
  38. mkdir /dev/shm</userinput></screen>
  39. <para>Finally, mount the proper virtual (kernel) file systems on the directories we just
  40. created:</para>
  41. <screen><userinput>mount -t devpts -o gid=4,mode=620 none /dev/pts
  42. mount -t tmpfs none /dev/shm</userinput></screen>
  43. </sect2>
  44. </sect1>