LOADLIN User Guide                                                  96-04-28

============================================================================

   LOADLIN v1.6 (C) 1996 Hans Lermen (lermen@elserv.ffm.fgan.de)
                (C) 2008..2010 Samuel Thibault (samuel.thibault@ens-lyon.org)

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation, either version 2 of the License or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You may have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software
   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.


============================================================================



      CONTENTS
      ========

1.    Why use LOADLIN ?

2.    Features of LOADLIN

3.    How to use LOADLIN
3.1.  What you need
3.2.  Booting from the DOS prompt
3.2.1 Quick start
3.2.2 Quick help
3.2.3 Starting linux from a batch file (LINUX.BAT)
3.2.4 Loading Ramdisks with newer kernels
3.2.5 Floppys and Ramdisks using older kernels ( Linux < 1.3.48 )
3.2.6 System constraints
3.3   Booting from CONFIG.SYS
3.3.1 Example of a CONFIG.SYS file (DOS)
3.3.2 Example of a CONFIG.SYS file (Windows 95)
3.3.3 Constraints in CONFIG.SYS syntax

4.    The LOADLIN command line parameters
4.1   Maximum length of the command line

5.    If you have problems
5.1   Problems detecting V86
5.2.  Description of debug output (-v,-t,-d)

6.    Where to send comments and bug reports

7.    Contributions and Credits


                         --------- +++  --------



1.    Why use LOADLIN ?
      =================

      LOADLIN is the safest way to boot Linux from your hard disk,
      if you have a bootable DOS-partition besides Linux on your machine.

      Most Linux-newbees are too impatient to read the very good (but also
      long) documentation of LILO (the standard Linux loader), and start
      using it incorrectly, resulting in an unbootable DOS after this
      (the MBR gets overwritten, 'fdisk /MBR' not always repairs).
      For those impatient ones LOADLIN is the best loader to start with.

      LOADLIN needs not to be installed in any way, it is usable as is
      and the kernel images can reside on any DOS accessable medium
      (even on a network drive). This also makes LOADLIN an exellent
      tool, if it comes to boot your Linux after a crash and a
      filesystem restore from backup medium (you must run LILO after
      this, but you can't if you have not yet booted, isn't it?).

      Many CDrom producers already have seen the advantage of starting
      the Linux-installation process by means of LOADLIN, because it
      runs out of the box. And using DOS to push Linux on the road
      isn't wrong, if you have DOS (or Windows 95 DOS mode) available.
      With LOADLIN you can directly boot Linux from the CD without
      needing an intermediate bootfloppy.

                         --------- +++  --------


2.    Features of LOADLIN
      ===================

      LOADLIN is highly adaptable to different DOS configurations, and now
      has very few loading restrictions. It makes use of extended memory and
      also can load big kernels (bzImages) and ramdisk images (initrd)
      directly high. The bzImage+initrd standard was jointly developed
      by the LILO-author (Werner Almesberger) and the LOADLIN-author (me)
      and is part of the official kernel since version 1.3.73.

      It is also capable of booting a UMSDOS-based system from a DOS drive.

      Some options (-v, -t, -d) produce debug information, so if you have
      problems, you can follow what is really being done by LOADLIN.

      LOADLIN also can load out of Virtual-86 mode (which is normal when
      using EMS drivers) if a VCPI server is present.



                         --------- +++  --------



3.    How to use LOADLIN
      ==================

      NOTE:

      LOADLIN is a utility which starts a "logical reload" of your machine,
      causing DOS to be completely overlaid with Linux.  When you wish to
      return to DOS you must use the Linux "reboot" command.


3.1.  What you need
      -------------

      1. A 386 or higher CPU (of course!),
         DOS or WINDOWS95 installed on your machine.

      2. Any compressed linux kernel image  (zImage, bzImage).
         NOTE: zImage is the old kernel binary format, bzImage is the
         new one ( kernel version >= 1.3.73), which can have a commpressed
         size of 1Meg, hence taking kernels up to 2Meg uncompressed.
         In the following we will refer only to zImage, though you may
         put a bzImage in place of it.

      3. The  LODLIN16.TGZ  package, which includes among other things:

          ( Note: these are DOSish files )
          LOADLIN.EXE
          DOC\MANUAL.TXT (this file)
          Example parameters file, DOC\TEST.PAR
          DOC\PARAMS.DOC


3.2.  Booting from the DOS prompt
      ---------------------------

3.2.1 Quick start
      -----------

      For the rest of this documentation I will assume that you have
      unpacked  LODLIN16.TGZ  into the directory  C:\LOADLIN.

      At the DOS prompt you can type, for example:

         C:> CD \LOADLIN
         C:\LOADLIN> LOADLIN zimage /dev/hdb1 ro vga=ask

      or, if you want to load a big kernel together with a RAM disk:

         C:\LOADLIN> LOADLIN bzimage /dev/ram rw initrd=diskimage

      or, if you have more parameters than will fit into the 128-byte
      DOS command line:

         C:\LOADLIN> LOADLIN @params

      An example params file is "test.par".    Please read it.

      A detailed collection (extracted from kernel sources) of most
      command line parameters can be found in the file  PARAMS.DOC
      ( however, it is a bit out of date now )
      A much better list of boot parameters can be found in Paul Gortmakers
      BootPrompt-HOWTO, which can be access by WWW:

          http://sunsite.unc.edu/mdw/HOWTO/BootPrompt-HOWTO.html
      or
          http://rsphy1.anu.edu/~gpg109/BootPrompt-HOWTO.html


3.2.2 Quick help
      ----------

      You can get online help and configuration analysis by typing:

         C:\LOADLIN> loadlin <enter>

      or, perhaps a bit more helpful:

         C:\LOADLIN> loadlin | more <enter>


      You then get an output like this (from my machine) ....

      - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
      LOADLIN v1.6 (C) 1994..1996 Hans Lermen <lermen@elserv.ffm.fgan.de>
                   (C) 2008..2010 Samuel Thibault (samuel.thibault@ens-lyon.org)

      USAGE:
        LOADLIN @params
        LOADLIN [zimage_file] [options] [boot_params]
          without any params, LOADLIN displays this help message.
          @params:
             params is a DOS file containing all other options
          zimage_file:
             DOS file name of compressed Linux kernel image
          options:
             -v        verbose, show information on params and configuration
             -t        test mode, do all but starting Linux, also sets -v
             -d file   debug mode, same as -t, but duplicates output to "file"
             -clone    ( Please read MANUAL.TXT before using this switch! )
             -n        no translation for root=/dev/...
             -txmode   switch to textmode 80x25 on startup
             -noheap   disable use of setup heap
             -wait=nn  after loading wait nn (DOS)ticks before booting Linux
             -dskreset after loading reset all disks before booting Linux
          boot_params:
             root=xxx  filesystem to be mounted by Linux as "/"
                       (string passed unchanged to the kernel)
                  xxx = hex number (e.g. root=201 for /dev/fd1)
                      = /dev/mmmn (e.g. root=/dev/hda2)
                             mmm = fd,hda,hdb,sda,sdb...
                             n   = 1..10.. decimal
             ro        mount "/" readonly
             rw        mount "/" read/write
             initrd=x  (for kernels > 1.3.72) load file x into /dev/ram. If FS in x
                       contains /linuxrc, execute it, and then remount to root=xxx.
                       If root=/dev/ram, just load, bypass execution of /linuxrc

          for more boot params see PARAMS.TXT or Paul Gortmakers HOWTO:
            http://sunsite.unc.edu/mdw/HOWTO/BootPrompt-HOWTO.html
            http://rsphy1.anu.edu/~gpg109/BootPrompt-HOWTO.html

      Your current DOS/CPU configuration is:
        load buffer size: 0x0082D000 VCPI, setup buffer size:  0x3E00 (reloc setup)
        lowmem buffer:    0x0006DC00 (part of load buffer)
        total memory:     0x01000000
        CPU is in V86 mode
        SetupIntercept: YES, patching setup code
        stat4: VCPI_present, physmap=logmap, all OK for switch to realmode
        input params (size 0x0000):

        LOADLIN started from DOS-prompt

      - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

      NOTE: All LOADLIN options (such as -t,... ) MUST come before
            the Linux command_line params


3.2.3 Starting linux from a batch file (LINUX.BAT)
      --------------------------------------------

      Most DOS users have disk caching (e.g. SMARTDRV) activated.
      If "write-behind" caching is supported by the cache program,
      then any unwritten cache buffers MUST be flushed before
      LOADLIN is called.

      Example:

       C\LOADLIN> smartdrv /C    do this to "sync" your disk (usually not
                                  needed for DOS 6.2, but it doesn't hurt)
       C\LOADLIN> loadlin ....


      It would be much smarter to use a batch file something like this:

      +-------------------- start of LINUX.BAT
      |
      |  SMARTDRV /C
      |  C:\LOADLIN\LOADLIN C:\LOADLIN\ZIMAGE root=/dev/hdb2 ro vga=3
      |
      +-------------------- end of LINUX.BAT


      So you could simply type:

       C> linux

      ... and you are on the road!

      A sample LINUX.BAT file is provided with the LOADLIN package.



3.2.4 Loading Ramdisks with newer kernels
      -----------------------------------

      If you have a kernel image which is newer than version 1.3.72,
      LOADLIN can load the ramdisk directly from a file and let
      Linux mount the ramdisk (/dev/ram) as root filesystem.
      The file must contain the image of any Linux supported
      file system, such as minix or ext2. The technique used is
      called 'initrd' and is more flexible than the old loading
      from floppy. There can be the following cases:

      A) You simple want to load the ramdisk and have that mounted as
         root FS.

         C\LOADLIN> loadlin zimage root=/dev/ram rw initrd=imagefile

         You will see two LOADING.... sequences, one for the kernel
         and the other for the ramdisk.

      B) You want to have the ramdisk loaded and mounted only to
         bootstrap a bigger system. Your kernel has only support
         for few driver, but not all. Well, then the contents
         of your ramdisk image must contain an executable '/linuxrc'
         which is able to load kernel modules (via insmod). After
         /linuxrc has terminated, the root FS is remounted either
         to the device you supplied via root=/dev/..., or to the
         device that /linuxrc has chosen. This technique is described
         in detail in the file linux/Documentation/initrd.txt which is
         part of the kernel source. The LOADLIN call for
         loading such a configuration is:

         C\LOADLIN> loadlin zimage root=/dev/hda1 ro initrd=imagefile

      The non-initrd method, i.e. _not_ LOADLIN loads the ramdisk
      but the kernel does it from a floppy, has changed with Linux 1.3.48.
      It now look like this:

         C\LOADLIN> loadlin zimage root=/dev/fd0 rw load_ramdisk=1

      or, if you want have a prompt before inserting the floppy:

         C\LOADLIN> loadlin zimage root=/dev/fd0 rw load_ramdisk=1 prompt_ramdisk=1

      The size of the ramdisk is allocated dynamically.
      NOTE: In all cases the ramdisk image may be compressed (gziped)



3.2.5 Floppys and Ramdisks using older kernels ( Linux < 1.3.48 )
      -----------------------------------------------------------

      If LOADLIN encounters  ramdisk=xxxx  together with  root=/dev/fdx
      it loads the kernel image into memory, but before starting up
      Linux it prompts for insertion of the root floppy.

      This enables you to boot DOS (and start LOADLIN) from the same
      floppy drive as the root disk.

      Of course, this is a two-floppy boot, but with Linux becoming
      bigger and bigger there will be no room on the root floppy to
      hold both the kernel image and the root filesystem.  With
      LOADLIN there is no need for any fancy tricks to install a
      distribution when your drive configuration doesn't match that
      of the distribution.

      Examples:

        LST distribution comes only with a 3.5 inch floppy
        but your drive A: is 5.25 inch.

        Slackware 3.0 has a big directory tree with lots of possible
        drive constellations.  With LOADLIN you need only the image disk
        and an appropriate root disk.


3.2.6 System constraints
      ------------------

      With LOADLIN-1.6 there are _very_ few contraints left, given you
      use a newer kernel, because the kernel now supports LOADLIN and
      aids to overcome the restrictions of old LOADLIN-1.5.
      The * (asterix) marked parts below only apply, if your kernel
      is an old one (not supporting LOADLIN).

      *  There must be enough memory to load the compressed kernel image
         (between the start of LOADLIN and 090000h).

      -  If loading newer kernels, you must have enough konventional
         plus extended/XMS/VCPI memory to temporary hold the image
         (and eventually the ramdisk image)

      -  The field "load buffer size" of the LOADLIN verbose output
         tells you what you really have.

      *  The setup program and LOADLIN itself go into 090000h ... 09B000h,
         therefor you MUST have 640 K byte of base memory.

      -  Starting with Linux 1.1.43 the setup program does no longer
         fit into 2 K, so it is made of variable size and will grow
         over the time. Currently (1.3.91) setup is 9 * 512 bytes
         long and the setup buffer of LOADLIN has 31 * 512 bytes,
         so this will work for a long time.

      -  The field "setup buffer size" of the LOADLIN verbose output
         tells you what you really have.

      *  The remaining 12 Kbyte memory on top of the 640 K is
         hopefully enough for BIOS- and highloaded driver-data.


      -  DOS programs can be executed only in the so-called real mode
         (or on >386 in virtual-86 mode (V86)).

         Linux, however, runs in protected mode, and the kernel must be
         able to enter privilege level 0 (P0, supervisor mode).  However,
         from V86 it is impossible to switch to protected mode P0 if the
         V86 server does not allow this (as is the case with DPMI).

         Therefore:
         - You must be in 86 real mode (no EMS driver, no WINDOWS,
           no Windows 95 Graphics mode ...).
             or
         - You must have the VCPI server enabled in your EMS driver (still
           not running WINDOWS or Windows 95, however).
           Using EMM386 please avoid the NOVCPI-option, but NOEMS doesn't hurt.

         VCPI allows P0 and is supported by most EMS drivers, but never under
         MS-WINDOWS or Windows 95 (MICROSOFT doesn't like P0 for users).

      -  Physical-to-Virtual memory mapping must be identical for the first
         640K of RAM, which is a given under normal conditions but which
         also can be forced, typically by an EMS driver option like:

           EXCLUDE=1000-A000     (for 386MAX)
             or
           B=A000                (for EMM386.EXE, but normally not needed).


         Check the manual for your EMS driver for details.
         Don't worry, if something is missing LOADLIN will tell you.

         NOTE:

         May be that your VCPI server does garbage collection before
         entering protected mode, so please BE PATIENT, especially
         on systems with many mega bytes !

      -  Of course you must not execute LOADLIN out of Linux DOSEMU !
         If you do it, fortunately DOSEMU terminates because DOSEMU has
         no VCPI server, so your file systems remain intact.



3.3   Booting from CONFIG.SYS
      -----------------------

      Starting with DOS version 6.0 it is possible to boot different
      configurations during the startup of MSDOS. This is handled at the
      time of CONFIG.SYS interpretation.  Therefore this is often a good
      place to put the LOADLIN/Linux stuff.

      Even if you have decided to boot DOS, you can boot Linux later,
      either from the DOS command line or from a batch file.



3.3.1 Example of a CONFIG.SYS file (DOS)
      ---------------------------------

      - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
      SWITCHES=/F

      [MENU]
      menuitem=DOS, DOS boot
      menuitem=LINUX_1, LINUX boot
      menuitem=LINUX_2, LINUX boot via param file
      menuitem=LINUX_3, LINUX boot via param file, but overwrite root device
      menuitem=LINUX_4, Create a dump file for bug report


      [DOS]
      device=c:\dos\himem.sys
      device=c:\dos\emm386.exe 2048 ram
      DOS=HIGH,UMB
      SHELL=C:\COMMAND.COM C:\ /e:1024 /p
      ...   etc.,  etc.,  etc.


      [LINUX_1]
      shell=c:\loadlin\loadlin.exe c:\loadlin\zimage root=/dev/hdb2 ro


      [LINUX_2]
      shell=c:\loadlin\loadlin.exe @c:\loadlin\linux.par


      [LINUX_3]
      shell=c:\loadlin\loadlin.exe @c:\loadlin\linux.par root=/dev/hdb2


      [LINUX_4]
      shell=c:\loadlin\loadlin.exe c:\loadlin\zimage -d c:\dump.txt root=/dev/hda1
      rem                                            ^^^^^^^^^^^^^^
      rem  This writes debug information to a file ---------^
      rem  All is set up as usual, but Linux is not loaded and LOADLIN idles.
      rem  CAUTION: Don't do this if you haven't a [MENU] in CONFIG.SYS,
      rem           because you then need a DOS System floppy to boot normally.


      [COMMON]
      rem   Here we put any other "common" configuration stuff ....

      - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -


3.3.2 Example of a CONFIG.SYS file (Windows 95)
      -----------------------------------------

      Having Windows 95 and Linux together on your machine, requires that
      you switch off some option in the hidden C:\MSDOS.SYS file.
      (which is a text file in Windows 95).
      NOTE:   DO NOT TRY TO START LOADLIN FROM WITHIN THE GUI !
      Change attribs of C:\MSDOS.SYS, so that it becomes visible and edit it:

      C:\MSDOS.SYS --------------------------------------
      BootGUI=0
      Logo=0
      ...
      ---------------------------------------------------

      This will avoid booting directly into the GUI and will you get a
      normal DOS prompt when chosing menuitem W95.
      ( To enter the GUI you only have to type:     C:>win    )
      Logo=0 switches the (graphics) logo off.
      There have been reports, that together with some graphic cards,
      Linux may come up with a 'blind' screen, if the Logo is displayed
      prior to booting.

      C:\CONFIG.SYS -------------------------------------
      [menu]
      menuitem=W95, Boot W95 DOS
      menuitem=LINUX, Boot Linux
      menudefault=W95,10

      [W95]
      rem all what you need for DOS
      ...

      [LINUX]
      shell=c:\loadlin\loadlin.exe @C:\loadlin\linuxpar.1

      [COMMON]
      rem THERE SHOULD BE NOTHING for COMMON
      rem move all you have to W95 part
      ---------------------------------------------------



3.3.3 Constraints in CONFIG.SYS syntax
      --------------------------------

      1. All parameters on the "shell=" lines are converted to uppercase
         by DOS, but Linux parameters are case sensitive. LOADLIN converts
         the following parameters back to lowercase:

           root=...
           ro
           rw
           mem=...
           no387
           single
           auto
           debug
           no-hlt
           reserve=...
           hd=...
           xd=...
           bmouse=...
           max_scsi_luns=

         Also, when using 'shell=loadlin.exe @params more_params'
         out of CONFIG.SYS, all of 'more_params' will be converted to lowercase.

         The following parameters are not put onto the commandline, but
         converted to numeric values for the boot sector:

           vga=...
           ramdisk=


      2. You can bypass the uppercase/lowercase problem by using a parameter
         file.   An example  CONFIG.SYS  line would be:

         [LINUX]
         shell=c:\loadlin\loadlin.exe @c:\loadlin\params

         You may ovewrite params which are _in_ the file by
         those coming behind the @..., such as

         [LINUX]
         shell=c:\loadlin\loadlin.exe @c:\loadlin\params root=/dev/other

         An example parameter file is "test.par".  Please read it.


                         --------- +++  --------




4.    The LOADLIN command line parameters
      ===================================

      Note that if you use a parameters file (for example  @TEST.PAR),
      this must be the FIRST parameter you use on the LOADLIN command
      line.  Other parameters, including the name of the zImage file,
      are contained within the parameters file.

      All parameter behind the @.. will be inserted after the
      parameters file has been read, and equal keywords are replaced.
      The first name within the parameters file _must_ be the
      kernel image file, if you want to overwrite it, you have to
      use the keyword 'image=' such as:

         C:> loadlin @test.par image=otherfile

      When Linux boots it gets a runstring passed from setup
      (the program that checks the basic hardware configuration
      and puts the machine into protected mode ). This string, the
      command line, is then checked for some well known compiled-in
      keywords.  Some are used to change kernel variables (such as
      mem=, root=, ro, rw, no387), some are passed to the device
      drivers (such as ether=, hd=, sound=) and some (such as single
      and auto) are passed as options to /etc/init (or /bin/init or
      /sbin/init, whatever is found first).

      See the file "PARAMS.DOC" for details.

      Any unknown keywords of format "keyword=value" are placed in
      "envp_init", which is also passed to /linuxrc (if you have initrd=)
      and to /etc/init.  This environment string can be checked in /etc/rc*
      (/etc/rc.d/rc.*). The whole commandline also is available
      via /proc/cmdline.


4.1   Maximum length of the command line
      ----------------------------------

      The length of a DOS command line can be 127 bytes (including
      the program name).  With a params file (@param)
      the length of the string passed to the kernel can in theory be
      2047 bytes, but the string is held in a temporary place and must
      be copied by the kernel to a save static buffer in init/main.
      This forces the maximum length to a compiled-in constant, which
      currently is 256 bytes.
      If you need a greater size, you can simply change COMMAND_LINE_SIZE
      in arch/i386/kernel/setup.c.




                         --------- +++  --------



5.    If you have problems
      ====================

      With the thousands of possible hardware/software configurations of a PC,
      a program can never be totally bug-free.
      So please, I need your feedback regarding problems you encounter.

      If you recognize a bug, please don't work around it, mail it to me !

      But, if you report a problem, I need information!  Something like
      "My screen always displays in blue, what is wrong?"  is not enough.

      LOADLIN can produce information for me (and for you) if you use
      the -d or -t switch.



5.1   Problems detecting V86
      ----------------------

      On some 486 clones we have problems with CR0 while probing for V86 mode.
      (as reported by Jacek Zapala zapala@if.pw.edu.pl ).
      It can happen that the CPU is in realmode, but PAGING is enabled !
      This is possible, but neither documented nor supported by INTEL.
      May be the motherboard's BIOS is mapping shadow ram this way,
      or one of those old and strange EMM managers is used,
      but probably this is an indication of a not exactly compatible
      486 clone. The -clone switch byepasses the CR0 check and assumes
      V86 if an EMM manger is found.
      But of course this EMM manager must not use real paging !

      On the other hand, if LOADLIN detects V86 _and_ you are sure that the
      machine is in _real_ realmode, then you may use the -f switch
      in order to force LOADLIN to 'detect' realmode.
      NOTE: This option intentionaly is not mentioned elsewere, because
      it realy is dangerous.


5.2.  Description of debug output (-v,-t,-d)
      --------------------------------------

      The ouput produced by the -v, -t or -d options occurs at the point at
      which the boot sector and setup are loaded and updated by LOADLIN.
      The information is that seen by Linux, but in the case of -t and -d,
      the zimage file is not loaded and linux is not started.

      Description:

      Your current LINUX kernel boot configuration is:
        image file:       d:\tmp\1-1-47.0     <- filename of kernel image
        kernel size:     0x5BFF0              setup size:  0x0A00
                         ^                    ^- size of setup in bytes
                         |---------------------- size of kernel in bytes
        kernel version:   1.1.47 (root@el15) #4 Mon Aug 00:57:07 MET DST 1994
                          ^---- this only if setup.S has the LOADLIN patches
        VGA mode:         0xFFFF              <- video mode at startup
        command line (size 0x0015):           <- contents of command_line as
          BOOT_IMAGE=zimage                      seen by Linux

      Your current DOS/CPU configuration is:
                                     +-----------using VCPI buffer, this also
                                     |           can be EXT or XMS.
        load buffer size: 0x0081F000 VCPI, setup buffer size:  0x3E00
                         ^                    ^- size of buffer in bytes which
                         |                       holds the setup code.
                         |                       must be >= "setup size"
                         |---------------------- buffer space in bytes which
                                                 can hold the uncompressed image
                                                 and the initrd.
        lowmem buffer:    0x0006D000 (part of load buffer)
                           ^-------------------- the low mem part of buffer space
        total memory:     0x0FE0000           <- highest RAM address as seen
                                                  by Linux, calculated from the
                                                  INT15 information
        CPU is in V86 mode                    <- if in Virtual-86 mode
      or
        CPU is in REAL mode
      or
        CPU is in undocumented REAL PAGING mode, trying any way


        SetupIntercept: NO                    <- using LOADLIN-1.4 mode
      or
        SetupIntercept: YES, patching setup code  <- using Javier's method
      or
        SetupIntercept: YES, legal intercept      <- dito, but legal Setup
                                                     (compiled in patches)


      One of four possible status messages may appear here:

        stat1: cpu in real 386 mode
        stat2: cpu_V86, but no VCPI available (check aborted)
        stat3: VCPI_present, but physmap != logmap (check aborted)
        stat4: VCPI_present, physmap=logmap, all OK for switch to realmode


      The following may come from the DOS command line or from the params file:

        input params (size 0x000c):           <- contents of DOS command line
          ..\zimage -t


      Some additional information and/or warnings can follow:

        LOADLIN started from DOS-prompt       <- one of these two Lines
           "       "     "   CONFIG.SYS       <- (LOADLIN assumes the environ.
                                                  has a  COMSPEC=  for DOS)

        You are running under MS-WINDOWS      <- this warning, if in WINDOWS.
                                                 (LOADLIN assumes the environ.
                                                  has a  WINDIR=  for WINDOWS)



                         --------- +++  --------



6.    Where to send comments and bug reports
      ======================================

      Comments and bug reports are welcome and may be sent to:

      E-Mail:    samuel.thibault@ens-lyon.org

      ... and PLEASE, PLEASE, PLEASE:
          Check your "Reply to" path for a valid E-Mail address,
          I get many "bounced" mails back ! It's not a fun having
          answered your mail for the trash.

                         --------- +++  --------



7.    Contributions and Credits
      =========================

      Version-1.6 of LOADLIN ist part of a jointly developed new
      booting strategie (bzImage+initrd) for both LILO and LOADLIN,
      so I say many thanks to Werner Almesberger for cooperating with me.

      Thanks to Hubert Mantel from S.u.S.E GmbH, who compiled 'lots'
      of kernels with the bzImage+initr patches, and testet them havily
      on several  machines. Without him the patches never would have
      stabilized as quickly.
      He also was the first to realize a reasonable working /linuxrc.

      This program would be absolutely superfluous without Linus Torvalds,
      and thanks to him for putting our patches into the official kernel.

      This program could not have been written as quickly without the
      information found in the source code of F.Coutant's BOOTLIN.

      Jacques Gelinas encouraged me in realizing the VCPI-support.

      Alessandro Rubini contributed some code from his linuxEXE package
      and gave some important hints.

      Chuck Munro gave hints concerning problems with QEMM and ALPHA-
      tested version 1.4.
      He also did much work for better documentation.

      Javier Achirica invented the switch-out-of-setup method (LOADLIN-1.5).
      The trick is: let setup run in V86 and intercept just before
      going to protected mode.


      Important problem and bug reports came from:

      Mitchum Dsouza, UK
      Claus Tondering, Denmark
      Johann Friedrich Heinrichmeyer, Germany
      Jacek Zapala, Poland
      Jon Peatfield, UK
      Matthias Sattler, Germany
      Pim Zandenberg, Netherlands

      Thanks also to all the ALPHA testers, who responded on my
      "call for testers". The list is too long to put it here,
      but some of them did heavy testings:

      Michael Goddard, US
      Shih-Hua Chao, US
      Rene Baart, Netherlands
      Asad Khan,
      Jan Lien, Sweden


      Many thanks also to those people, who did not have any
      problems with LOADLIN, but nevertheless mailed me "it works"
      ( positive feedback is the best one ).


                         --------- END --------