2L(10.1)                                                 2L(10.1)

     NAME
          0l, 1l, 2l, 5l, 8l, kl, ql, vl - loaders

     SYNOPSIS
          0l [ option ... ] [ file ... ]
          1l [ option ... ] [ file ... ]
          2l [ option ... ] [ file ... ]
          6l [ option ... ] [ file ... ]
          8l [ option ... ] [ file ... ]
          kl [ option ... ] [ file ... ]
          ql [ option ... ] [ file ... ]
          vl [ option ... ] [ file ... ]

     DESCRIPTION
          0l, 1l, 2l, 5l, 8l, kl, ql, and vl load the named files into
          MIPS-LE, MC68000, MC68020, ARM, i386, SPARC, PowerPC, and
          MIPS executable files.  The files should be object files or
          libraries (archives of object files) for the appropriate
          architecture.  Also, a name like -lext represents the
          library libext.a in /$objtype/lib, where objtype is one of
          spim, 68000, 68020, arm, 386, sparc, power, or mips.  The
          libraries must have tables of contents (see iar(10.1)).

          In practice, -l options are rarely necessary as the header
          files for the libraries cause their archives to be included
          automatically in the load (see 2c(10.1)). For example, any
          program that includes header file libc.h causes the loader
          to search the C library /$objtype/lib/libc.a.  Also, the
          loader creates an undefined symbol _main (or _mainp if pro-
          filing is enabled) to force loading of the startup linkage
          from the C library.

          The order of search to resolve undefined symbols is to load
          all files and libraries mentioned explicitly on the command
          line, and then to resolve remaining symbols by searching in
          topological order libraries mentioned in header files
          included by files already loaded.  When scanning such
          libraries, the algorithm is to scan each library repeatedly
          until no new undefined symbols are picked up, then to start
          on the next library.  Thus if library A needs B which needs
          A again, it may be necessary to mention A explicitly so it
          will be read a second time.

          The loader options are:

          -l        (As a bare option.)  Suppress the default loading
                    of the startup linkage and libraries specified by
                    header files.

          -o out    Place output in file out. Default is O.out, where

     Page 1                       Plan 9            (printed 12/22/24)

     2L(10.1)                                                 2L(10.1)

                    O is the first letter of the loader name.

          -p        Insert profiling code into the executable output;
                    no special action is needed during compilation or
                    assembly.

          -s        Strip the symbol tables from the output file.

          -a        Print the object code in assembly language, with
                    addresses.

          -v        Print debugging output that annotates the activi-
                    ties of the load.

          -M        (Kl only) Generate instructions rather than calls
                    to emulation routines for multiply and divide.

          -Esymbol  The entry point for the binary is symbol (default
                    _main; _mainp under -p).

          -Hn       Executable header is type n. The meaning of the
                    types is architecture-dependent; typically type 1
                    is Plan 9 boot format and type 2 is the regular
                    Plan 9 format, the default.  These are reversed on
                    the MIPS.  The Next boot format is 3.  Type 4 in
                    vl creates a MIPS executable for an SGI Unix sys-
                    tem.

          -Tt       The text segment starts at address t.

          -Dd       The data segment starts at address d.

          -Rr       The text segment is rounded to a multiple of r (if
                    r is nonzero).

          The numbers in the above options can begin with `0x' or `0'
          to change the default base from decimal to hexadecimal or
          octal.  The defaults for the values depend on the compiler
          and the header type.

          The loaded image has several symbols inserted by the loader:
          etext is the address of the end of the text segment; bdata
          is the address of the beginning of the data segment; edata
          is the address of the end of the data segment; and end is
          the address of the end of the bss segment, and of the pro-
          gram.

     FILES
          /$objtype/lib  for -llib arguments.

     SOURCE
          /utils/2l etc.

     Page 2                       Plan 9            (printed 12/22/24)

     2L(10.1)                                                 2L(10.1)

     SEE ALSO
          2c(10.1), 2a(10.1), iar(10.1), nm(10.1)

          Rob Pike, ``How to Use the Plan 9 C Compiler''

     Page 3                       Plan 9            (printed 12/22/24)