home *** CD-ROM | disk | FTP | other *** search
/ PC World 1999 August / PCWorld_1999-08_cd.bin / doc / HOWTO / unmaintained / mini / Swap-Space < prev    next >
Text File  |  1998-01-14  |  10KB  |  248 lines

  1. [ 15 January 1998
  2.   The Linux Swap Space mini-HOWTO is not being maintained by 
  3.   the author any more.  If you are interested in maintaining the 
  4.   Swap Space mini-HOWTO, please get in touch with me at 
  5.   <gregh@sunsite.unc.edu>. ]
  6.  
  7.        SHARING SWAP SPACES BETWEEN LINUX AND MS-WINDOWS
  8.  
  9.                  A mini-HOWTO
  10.                   by
  11.                 H. Peter Anvin
  12.              <hpa@yggdrasil.com>
  13.  
  14.         Copyright ⌐ 1994, 1995 H. Peter Anvin
  15.  
  16. VERSION: 1.3                        Date: 19 Jun 1995
  17.  
  18. 0. ABSTRACT
  19.  
  20. Many people use both Linux and MS-Windows.  The ability to do so is an
  21. important part of "the Linux revolution"; i.e. letting people
  22. experiment with (and get hooked on) Linux while still being able to
  23. run their off-the-shelf software.  Since both Linux and MS-Windows use
  24. virtual memory with swap to disk, a frequently occurring question in
  25. comp.os.linux.setup is how to share swap spaces, in order to reduce the
  26. amount of disk space needed.
  27.  
  28. There are several methods for sharing swap spaces, the one described
  29. in this document is probably the most complicated one but is the only
  30. one I have encountered that allows maximum performance for both
  31. environments without the risk of trashing a disk partition.
  32.  
  33. NOTE: If you have used a previous version of this document and have
  34. had problems with swap space not getting properly restored (Windows
  35. claims your permanent swapfile is corrupt), try the slighly revised
  36. shutdown script in this version.
  37.  
  38. 1. WHAT YOU NEED
  39.  
  40. This procedure have a few requirements that need to be filled.  I
  41. strongly recommend that you fill these requirements *anyway*, as there
  42. are several problems with older versions.
  43.  
  44.     * MS-DOS 5.0 or newer
  45.     * MS-Windows 3.1 or newer
  46.     * A shutdown/init that knows to run a file on shutdown.
  47.       (The SysVinit-2.50 package can do this, for example.
  48.       SysVinit-2.50 is available from sunsite.unc.edu in
  49.       /pub/Linux/system/Daemons.  Almost all current distributions
  50.           use this init package.)
  51.           
  52. 2. THE PROCEDURE
  53.   
  54. * Boot DOS.  Create a DOS partition (using FDISK) the size = the size
  55.   swap space you want.  It will be assigned a drive letter; use that
  56.   drive letter instead of X whenever these instructions lists a
  57.   command like "LABEL X:" or "COPY FOO X:DUMMY.DAT"
  58.  
  59. * Format this partition using the DOS FORMAT command.
  60.     FORMAT X:
  61.  
  62. * Set the volume label on this partition to "SWAP SPACE" using the DOS
  63.   LABEL command.  Verify it by the DIR command.  Please do this as a
  64.   separate step.  Some versions of FORMAT do not seem to put the
  65.   volume label in the boot sector as it should.  [Note: some people
  66.   has written me saying the volume label is stored in the root
  67.   directory.  Yes, but at least since DOS 5.0 it has also been in the
  68.   boot sector.]
  69.     LABEL X:
  70.     DIR X:
  71.  
  72. * Start Windows.  Go to the Control Panel, select "386 Enhanced".
  73.   Select "Virtual Memory" and create a Windows Permanent swap file on
  74.   drive X: of maximum size (Windows will tell you the maximum size).
  75.   Windows may complain saying it will not use a swap file that big.
  76.   Ignore the message and create the file anyway.
  77.  
  78. * Exit Windows.
  79.  
  80. * Boot Linux, then log in as root.
  81.  
  82. * Use the fdisk command to find the name of the partition and its size
  83.   in blocks.  Create a symbolic link from /dev/winswap to this
  84.   partition.  If the paritition is hda7, then type:
  85.     ln -s /dev/hda7 /dev/winswap
  86.  
  87.   [NOTE TO PURISTS: Please use a symlink.  The name of this partition
  88.   is going to go into several configuration files and inconsistencies
  89.   could be fatal.]
  90.  
  91. * The following is a uuencoded binary that analyzes the partition and
  92.   derives some special information; uudecode the following file,
  93.   gunzip it and run it as:
  94.  
  95.     msinfo /dev/winswap
  96.  
  97. begin 755 msinfo.gz
  98. M'XL(`$$YNRT"`Y557TQ;51@_MW]HZ0AM'"$U-.28W([..>84%1%D2QH>',9*
  99. M2S&VC);V=FV]T*;WWBD+1I)K'YH;DOJF#YH80GPR^J""D"R8-K('MS2;#Q*S
  100. M%Y,E-P&592A$V:[?.;?M"FP/?DG/G^_[?7_Z_3G7PL313TT(?8P0<J"CI':8
  101. M$5H^#:=5<KT^MQ`^UAQ1O*QUH0<.]B7S/FC[U!98Y;))]<*N^AG"^LB((J%E
  102. MAFIM[A9U0O`;%:*7N#[L%G!_-IH34V(J,WUZ.CK%O6I#N4DTE,E-144Q-7T)
  103. M>]_PX\M<3@!`'ZZ26[`-I7A.F!%$;JK.;21`!#.\-,5A/CK)\=B3FL:3F8PH
  104. M<#$QDSO91Q%^>L%"Z@KW*"-NR3;""5SN,A?'NI[0=P0Q=#[P&&$5@3UNZ3VW
  105. M=-(V`NYQ/)6CX)DC2F`KD!&C/!:R7"Q%]L-6`8'D+=]8T*^$V8@RR\;5\P9(
  106. M^;\&T:F]E`Q`EI,_6YHCZBT#BJ09M0VV9!:XVKLF]0NX%'Z4R];\W](3A-%J
  107. MI:`_&12!>@33QC0S'V8]?O5+0`;3UC23K)!"?@97N8R#:29MF/>R)PI>UJF)
  108. MK%/-4QR39OSJE8,8MHZ)UC#`?1ZX'N!ZU`L'X;@.?X["C<1DUT%,9QW32C''
  109. M"<98PQR#8#=(L'>96NQWR/4W1@>H3\'!OC3,MMN_"[,=A1OVK^XEH($[$S^H
  110. MY@28=MB78-$/`=8)(L=\P*$5*I_LS@)_G7!=\Z9V@F"``Y$XQM[T!T>(WHNU
  111. M/T9CH)YIZI("&9ZK32AR=DTN/QNZ."&7?27H_<(=_^=Q"U1N3Y.>!-E`$BY(
  112. M;(4ZG)/[\_0F_54HY7\5[<!33)\2M%:Y(.THX_N%K?%2L9&(O=4>8F^@IV9(
  113. M,<HEDU:17T'23M)GA#ANW-<F'J5-]>6!G2;BU+YN)@<RL.JBIFD4[:<###UG
  114. MO3Z77WO?L?O+@@G\+(-<"X&QT"&#_N7@_\2;JGAEF&U1`JR#ZCD/Z]7HJ'ZH
  115. M09_JNAZGJ^N?X5.39_AXMY!!?3@6G>X2,9^)QG%\!IZ@5`SSJ>EWN!SN>HCK
  116. MLJ%F08R*J5B4YV=T0-R&J#UYJW>4#"7/#D,0/GG`0ZI@__`;6->]K!>C[<GD
  117. M31/IQP>:!B]D?DT,*<;Y6=9Y]3:P][^W`?+>8F(1!*ZY7B1:BN=@D_XY9?0I
  118. M'?ZT0=V@BBWIIV$47#Y@7-,9Q>0<*=7;NMW-NS2>9#_X3V)8()?A$;!`ALRW
  119. M#&\%RO_^@9F6TP<]'M8J@'AFA"[JM]0(WCQ!`[.826!F&A@HG4JWU5R_KKL&
  120. M9GNQF$;J[?NZ\YUZ?B].C,OEWI*\94J`:6LB?U,RK^2.([0QRQK(W!D2[K5M
  121. M,G>&0B7A'K03F"'17*&L#9XU@+U2L9K4-GCIG(K(NE:SM,>SM,?;X,T:&U6,
  122. MT./E%NAUTNE_$,^E(A0M!B7K[D'>X6'\FC25Q3W=+V3YLR^CXJW.S0>#54*#
  123. M#ZE^AI+N-35^_>![U4!?@VQ%ET<L!BC>MC5"\GH->"T6'4/2NS>((N0,DT>_
  124. 9K6^!S%65KRS`,`,UVB43\!]-BKG]B`<``#5"
  125. `
  126. end
  127.  
  128.   Take note at the number saying "Total special sectors", and verify
  129.   that the volume label says "SWAP SPACE".  If it does not, reboot DOS
  130.   and re-do the LABEL command.  If it still does not work, please
  131.   inform me about which version of DOS you are running, and I will try
  132.   to help you out.
  133.  
  134. * [Optional step] Windows may occationally leave some space on the
  135.   partition, even if it is told not to.  Don't attempt to use this
  136.   space, since it will be erased any time you run Linux.  If you want
  137.   to avoid accidentally using it (and lose data), you can create a
  138.   dummy file that fills that space by using the following commands:
  139.     mkdir /mnt
  140.     mount -t msdos /dev/winswap /mnt
  141.     dd if=/dev/zero of=/mnt/dummy.fil
  142.     umount /mnt  
  143.  
  144.   The dd command will report "No space left on device".  This is
  145.   exactly what you want.
  146.  
  147. * Check the name of the shutdown file.  For SysVinit this is the file
  148.   listed in the following line of /etc/inittab; add it if you don't
  149.   have it.
  150.  
  151.     # Runlevel 0 means shut down the system
  152.     l0:0:wait:/etc/brc
  153.  
  154.   For the remainder of this file, I will assume the filename was
  155.   /etc/brc.
  156.  
  157. * Type:
  158.  
  159.     dd if=/dev/winswap bs=512 count=XXX | gzip -9 > /etc/winswap.gz
  160.                                         ^^^
  161.                                         Replace
  162.   ... where XXX is replaced with the "Total special sectors" number.
  163.  
  164. * Add the following piece of code to your /etc/rc file (or whatever
  165.   your init calls it), right before the command "swapon -a" (if there
  166.   is no such command, add it to your /etc/rc file right before any
  167.   mount commands). 
  168.  
  169.   If you have a directory /etc/rc.d, the file you want to put this in
  170.   should be called "/etc/rc.d/rc.S" or "/etc/rc.d/rc.boot".
  171.  
  172.   If your swapon is in /etc, replace /sbin/swapon with /etc/swapon.
  173.   If it is in /bin, replace with /bin/swapon.  Do the same for mkswap.
  174.  
  175.   Replace XXXXX with the actual size of the partition in blocks, as
  176.   given by fdisk.
  177.  
  178. ---[BEGIN CODE SEGMENT]---
  179. #
  180. # Verify and initialize swap space
  181. #
  182. echo -n 'Verifying swap space... '
  183. if [ "`/bin/dd 2>/dev/null if=/dev/winswap bs=1 count=10 skip=4086`" \
  184.    = 'SWAP-SPACE' ]; then
  185.   echo 'Linux signature found'
  186.   /sbin/swapon /dev/winswap
  187. elif [ "`/bin/dd 2>/dev/null if=/dev/winswap bs=1 count=11 skip=43`" \
  188.    = 'SWAP SPACE ' ]; then
  189.   echo 'DOS signature found'
  190.   /sbin/mkswap /dev/winswap XXXXX
  191.   /sbin/swapon /dev/winswap
  192. else
  193.   echo 'No signature found'
  194.   echo 'ERROR: Will not swap'
  195. fi
  196. ---[END CODE SEGMENT]---
  197.  
  198. * Add the following piece of code to your /etc/brc file (or whatever
  199.   it is called -- it is /etc/rc.d/rc.0 or /etc/rc.d/rc.halt if you
  200.   have an /etc/rc.d directory); put this after any command that might
  201.   need swap to be in place.
  202.  
  203. ---[BEGIN CODE SEGMENT]---
  204. #
  205. # Terminate swapping and restore DOS/Windows swap info
  206. #
  207. /sbin/swapoff /dev/winswap
  208. if [ "`/bin/dd 2>/dev/null if=/dev/winswap bs=1 count=10 skip=4086`" \
  209.    = 'SWAP-SPACE' ]; then
  210.   echo 'Restoring DOS/Windows swap info'
  211.   /bin/zcat /etc/winswap.gz > /dev/winswap
  212. else
  213.   echo 'ERROR: /dev/winswap lacks swap signature, skipping restore'
  214. fi
  215. ---[END CODE SEGMENT]---
  216.  
  217. * Reboot Linux.  You should now have swapping on the new swap device.
  218.  
  219. 3. A COUPLE OF NOTES
  220.  
  221. * There is no need to add /dev/winswap to your /etc/fstab file.  In
  222.   fact, it is probably wise not to do so (except possibly as a
  223.   comment).
  224.  
  225. * If your Linux session crashes or otherwise exits without running
  226.   /etc/brc, you will need to reboot and exit Linux before swapping in
  227.   Windows will work.  It is also possible to FORMAT X: and re-create
  228.   the Windows swapfile.  The only way around this would be to put the
  229.   equivalent of the /etc/brc commands in the DOS AUTOEXEC.BAT file;
  230.   unfortunately I don't know of any way of doing that in DOS!
  231.  
  232. * If DOS' FDISK reports the partition as a "logical DOS drive", it has
  233.   a number of 5 (as in /dev/hda5) or higher.  It is *NOT* the
  234.   partition labelled "extended" which has a number of 4 or less!!  If
  235.   your Linux fdisk does not display logical partitions, you have a
  236.   broken Linux fdisk (Slackware 2.2 included a broken fdisk, for
  237.   example.)  You can try "cfdisk" if your distribution has it, or you
  238.   will have to get a working fdisk.
  239.  
  240. * If you get a floating point exception when running msinfo, you are
  241.   almost certainly running it on the wrong partition.  See the above
  242.   note.
  243.  
  244. * Please do not mail me unless you have checked and re-checked that
  245.   you copied your scripts correctly.  More than half of the problems
  246.   reported with this Mini-HOWTO have been due to typos when copying
  247.   the scripts.  (Use cut-and-paste if you can!)
  248.