rld man page on IRIX

Man page or keyword search:  
man Server   31559 pages
apropos Keyword Search (all sections)
Output format
IRIX logo
[printable version]


RLD(5)								     RLD(5)

NAME
     rld, rld.debug - Runtime linker and runtime linker with debugging
     support

IMPLEMENTATION
     IRIX systems

DESCRIPTION
     rld, the runtime linker, exists in appropriate versions for
     executables in each Application Binary Interface (ABI) available.	rld
     is invoked when running a dynamic executable.  It maps in shared
     objects used by the executable, resolves relocations as ld(1) does at
     static link time, and allocates common, if required.

     When any dynamic executable is run, the system first runs an
     interpreter, which is responsible for collecting the appropriate
     objects, mapping them into memory, and resolving references during
     runtime.  The name of the interpreter is included in the executable
     file.  Dynamic execution is only supported with ELF-format
     executables.  Such executables will have an INTERP section that
     specifies the name of the interpreter.  The default name of the
     interpreter is /usr/lib/libc.so.1.	 Any binary that hopes to conform
     to the old 32-bit MIPS SVR4 ABI should name /usr/lib/libc.so.1 as its
     interpreter.

     For 64-bit ABI programs, the name of the interpreter is
     /usr/lib64/libc.so.1.  The information on this man page applies to
     64-bit programs if the directory /usr/lib64 is substituted for the
     directory /usr/lib, and the directory /lib64 is substituted for /lib.

     For new 32-bit ABI programs, the name of the interpreter is
     /usr/lib32/libc.so.1.  The information on this man page applies to new
     32-bit ABI programs if the directory /usr/lib32 is substituted for the
     directory	/usr/lib, and the directory /lib32 is substituted for /lib.

     The file /usr/lib/libc.so.1 is the standard C (or system) library in
     the form of a shared object.  In addition, /usr/lib/libc.so.1 contains
     code that loads the interpreter into its address space and sets it to
     work.  The default interpreter is /lib/rld.

     One of the primary features of dynamic linking is that it gives users
     the ability to change library implementations without recompiling the
     executable.  Some mechanisms for doing this are listed below.
     However, /usr/lib/libc.so.1 is not subject to any of the mechanisms
     listed below, since it is known to the executable as the interpreter
     as well as a needed shared object.	 If you want to substitute
     /usr/lib/libc.so.1, the best way is to make use of ld(1) command's -I
     option.  The -I option can be passed from the compiler command line by
     specifying the -Wl,-I,myinterpname option. However, any such shared
     object specified must be able to act as interpreter (or invoke rld).

     rld constructs an explicit shared object list based on the information
     listed in the .liblist section.  For old 32-bit ABI programs, if the
     environment variable _RLD_LIST is set, it overrides the dynamic
     executable's original list (after the original list is constructed).
     The corresponding environment variable for 64-bit programs is
     _RLD64_LIST, and for new 32-bit ABI programs it is _RLDN32_LIST.

     For new 32-bit ABI or 64-bit ABI programs, if _RLDN32_LIST or
     _RLD64_LIST is not specified, rld honors _RLD_LIST, if specified.

     The user can include DEFAULT in _RLD_LIST (or _RLDN32_LIST or
     _RLD64_LIST) to include the executable's original object list and
     instruct rld to add new shared objects just before and/or after it.
     The object list is specified as a colon-separated list of shared
     objects.  The liblists of shared objects newly added from _RLD_LIST,
     _RLDN32_LIST, or _RLD64_LIST are intentionally not processed:  it is
     up to the user to make the list complete.

LIBRARY SEARCH PATHS
     NOTE:  Because there are three distinct ABIs used by IRIX programs
     with accompanying libraries, there are three distinct sets of rld
     search paths.  In addition, there are usually 3 environment variables
     for each purpose, one for each ABI.

     The default library search path for old 32-bit ABI programs is
     /usr/lib:/usr/lib/internal:/lib:/lib/cmplrs/cc:/usr/lib/cmplrs/cc:/opt/lib,
     which can be overridden by either the _RLD_ROOT or the LD_LIBRARY_PATH
     environment variable.

     The default library search path for 64-bit ABI programs is
     /usr/lib64:/usr/lib64/internal:/lib64:/opt/lib64, which can be
     overridden by either the _RLD64_ROOT or the LD_LIBRARY64_PATH
     environment variable.

     The default library search path for new 32-bit ABI programs is
     /usr/lib32:/usr/lib32/internal:/lib32:/opt/lib32, which can be
     overridden by either the _RLDN32_ROOT or the LD_LIBRARYN32_PATH
     environment variable.

     For new 32-bit or 64-bit programs, if LD_LIBRARYN32_PATH or
     LD_LIBRARY64_PATH is not specified, rld honors LD_LIBRARY_PATH, if
     specified.	 As a result, if LD_LIBRARY_PATH is set for an old 32-bit
     program, it is recommended that you also set LD_LIBRARYN32_PATH and
     LD_LIBRARY64_PATH to something ("", for example) to avoid having
     LD_LIBRARY_PATH apply accidentally to new 32-bit and 64-bit
     applications in that environment.

     The search path for shared objects is as follows:

     1. The path of the shared object, if specified in the liblist.  That
	is, if the soname of the shared object has a path.  For more
	information, see the ld(1) man page.

     2. DT_RPATH, if it is defined in the executable or any DSO that rld
	has opened.

     3. Use LD_LIBRARY_PATH, if it is defined in the environment at the
	time of execution.

     4. The default library search path.

     DT_RPATH is a colon-separated list of directories.	 In the library
     search algorithm outlined above, DT_RPATH refers to the net list of
     paths at the time the search is done.  It is actually a tag in the
     .dynamic section of a DSO or executable whose value is a string.
     DT_RPATH is set in any given DSO or the executable by specifying the
     -rpath option to the ld(1) command when the executable or DSO is
     created.  Each DT_RPATH appends to the list of directories at the time
     the executable or DSO is loaded.  There is no mechanism to remove
     anything from the list of directories that rld builds for the
     executable.

     LD_LIBRARY_PATH is a colon-separated list of directories.	If defined,
     it specifies an extra set of directories in which rld is to look when
     searching for shared objects.  LD_LIBRARY64_PATH and
     LD_LIBRARYN32_PATH are treated in a similar fashion.

     _RLD_ROOT is a colon-separated list of directories.  If defined, the
     list is appended to the front of DT_RPATH and the default path.
     _RLD64_ROOT and _RLDN32_ROOT are treated in a similar fashion.

     To ensure compatibility, applications can choose to disallow library
     replacement at exec(2) execution time or at runtime.  If the
     dynamic-section flag, RHF_NO_LIBRARY_REPLACE, is set in an executable
     or DSO and if the application's real userid is not zero (root), then
     from the time the executable or DSO with RHF_NO_LIBRARY_REPLACE set is
     mapped in to the end of the execution, LD_LIBRARY[n]_PATH and any
     _RLD[n]_ROOT specifications are ignored.  RHF_NO_LIBRARY_REPLACE can
     be set at link time by specifying the ld(1) command's
     -no_library_replace option.

     Security dictates that rld should not allow library replacement or
     other rld environment variables to be honored for setuid and setgid
     programs unless the user is root.	If capabilities apply to an
     executable, the capability change also creates security concerns.	In
     these cases, library replacement and other rld environment variables
     are not honored.  For more information on capabilities, see exec(2),
     capability(4) and capabilities(4).

     Users can replace the default rld binary by setting the environment
     variable _RLD_PATH to the full path of another runtime linker.
     rld.debug is a version of rld that has debugging support.	By setting
     the environment variable _RLD_PATH to /usr/lib/rld.debug, it replaces
     the default rld as the runtime linker, and the debugging features it
     supports are available.  For 64-bit programs, the environment variable
     is _RLD64_PATH, and the debugging version of rld is
     /usr/lib64/rld.debug.  For new 32-bit ABI programs, the environment
     variable is _RLDN32_PATH, and the debugging version of rld is
     /usr/lib32/rld.debug.

     rld also supports the environment variable LD_BIND_NOW, as documented
     in the System V Application Binary Interface, Revised First Edition,
     Prentice-Hall, ISBN 0-13-880410-9.	 If LD_BIND_NOW is set to 1 or on,
     the dynamic linker processes all relocation before transferring
     control to the program; if LD_BIND_NOW is set to 0 or off, or if it
     does not occur in the environment, the dynamic linker can perform
     symbol resolution and relocation for functions lazily, meaning that it
     avoids them until the functions are called.

RUNTIME LINKING INTERFACE
     dlopen(3C), dlsym(3C), dlclose(3C), dlerror(3C) sgidlopen_version(3C),
     and sgidladd(3C) are provided to supply users with the on-demand
     loading of objects.  These routines are found in /usr/lib/libc.so.1.
     No special options are needed at link time to access them.

RLD OPTIONS
     The rld options are not needed to run properly coded and linked
     executables, but they may be useful in special situations and for
     debugging.	 To specify rld options, set the _RLD_ARGS environment
     variable to any combination of the following options:

     Option	    Purpose

     -clearstack    For programs that assume local variables to be
		    initialized to zero upon function entry, this option
		    forces rld to zero any stack it uses before before
		    calling the application's main program.  Properly
		    written programs never assume that the stack is zeroed;
		    therefore, properly written programs do not expect
		    local variables to be automatically initialized except
		    as provided for in the programming language definition.
		    At startup, if a program or any of its DSOs' dynamic
		    section flags do not have RHF_SGI_ONLY set, -clearstack
		    is automatically turned on.

     -f		    Fast mode.	Turns off reresolution of symbols on
		    dlclose(3C).  This option is on by default.	 It makes
		    rld's behavior closer to that of other systems with
		    dynamic loading and can substantially improve
		    dlclose(3C) performance.  To turn off this mode and
		    specify slower, full reresolution, specify the -s
		    option.

		    When this option is specified, any symbol from the
		    application that is bound to a symbol in the DSO closed
		    by dlclose(3C) is a stale binding.	Any reference to a
		    stale binding can crash the application.

     -idv	    Ignores delay-loaded versions.  By default, rld honors
		    version checking when loading a delay-loaded DSO.  For
		    more information on version checking, see dso(5).

		    This behavior is nonstandard.  It matches the behavior
		    of rld in previous releases.  Specifying this option
		    restores previous behavior so that erroneous
		    applications can be made to work.

     -ignore_all_versions
		    Ignores versions on all objects.

     -ignore_version shared_object
		    Ignores the version stamp checking on the object
		    specified.	This option can be specified multiple times
		    (in case multiple shared objects should have their
		    versions ignored).

     -ignore_unresolved
		    Does not issue messages or abort when rld cannot
		    resolve unresolved data symbols.

     -log file	    Prints all messages to file instead of to the device
		    /dev/tty.  If /dev/tty is not available, the system log
		    /var/adm/SYSLOG is used instead.

     -s		    Slow mode.	Performs full reresolution of symbols on
		    dlclose(3C).  Behavior obtained when this option is
		    specified is the opposite of that obtained when -f is
		    specified.	This makes dlclose(3C) slower and can
		    result in a symbol binding effectively moving from a
		    previous binding (eliminated by the dlclose(3C) itself)
		    to a new one.

		    This behavior is nonstandard.  It matches the behavior
		    of rld in previous releases.  Specifying this option
		    restores previous behavior so that erroneous
		    applications can be made to work.

RLD.DEBUG OPTIONS
     For rld.debug to be invoked, certain environment variables must be
     set, as follows:

     ABI		 Environment Variable and Setting

     Old 32-bit ABI	 _RLD_PATH set to /usr/lib/rld.debug

     New 32-bit ABI	 _RLDN32_PATH set to /usr/lib32/rld.debug

     64-bit ABI		 _RLD64_PATH set to /usr/lib64/rld.debug.

     The options to rld described in the previous section are honored by
     rld.debug.	 In addition to those options, rld.debug supports
     additional options; these, too, must be set in the _RLD_ARGS
     environment variable.  The rld.debug options are as follows:

     Option		 Purpose

     -debug symbol	 Prints a verbose description of the actions taken
			 resolving all symbols.	 The option consists of the
			 two literal words debug and symbol.  This produces
			 a lot of output, so it is normally most useful to
			 also use the -log option to direct the output to a
			 file.	If you know the symbols you are interested
			 in, use one or more instances of the -y option.

     -quickstart_info	 Informs the user whether or not Quickstart has
			 failed.

     -trace		 Shows rld code flow and prints individual symbol
			 actions.

     -v			 Prints rld actions at the level of the DSO not at
			 the symbol level.  -v is less verbose than -trace.

     -yname		 Prints a verbose description of the actions taken
			 resolving name.  Note that there is no space
			 permitted after the -y.  As many -y options as
			 needed can be specified.   For example, to print
			 descriptions of the actions on symbols pear and
			 grape, specify the following:

			      -ypear -ygrape

RLD ENTRY POINTS
     rld commences execution when exec(2) starts up a program using a DSO
     and when lazy text resolution commences during program execution.

     When exiting, programs or objects call _rld_new_interface(_SHUT_DOWN)
     to ensure that the program executes all of the code specified by the
     -fini option to ld(1).  _exit(2) calls _rld_new_interface(_SHUT_DOWN).
     Any call to _rld_new_interface(_SHUT_DOWN) runs the -fini code on all
     objects, meaning that it cannot safely be done just anywhere.  Note
     that _rld_new_interface(_SHUT_DOWN) is an internal routine and should
     not be called by any application.

SYSTEM DEVELOPER'S INTERFACE
     rld keeps a doubly linked list of structures.  crt1.o contains a
     pointer, __rld_obj_head, to the head of the list of object structures.
     This pointer's targets depend on the ABI, as follows:

     * For an old 32-bit executable, __rld_obj_head points to a linked list
       of objList structures (/usr/include/obj_list.h).	 Each of these
       structures has a data element that is a pointer to a struct obj
       (/usr/include/obj.h), even though the field is not declared as a
       pointer.

     * For a new 32-bit executable, __rld_obj_head points to a linked list
       of Elf32_Obj_Info structures:  /usr/include/objlist.h.

     * For a 64-bit executable, __rld_obj_head points to a linked list of
       Elf64_Obj_Info structures:  /usr/include/objlist.h.

     The oi_magic element of each Elf32_Obj_Info or Elf64_Obj_Info is all-
     bits-on (0xffffffff) to make it easier to determine which list type in
     use is a 32-bit executable.

ENTRY POINTS
     NOTE:  The interfaces described in this subsection are for system
     development only.	They are not recommended nor supported for use in
     end-user code.  They are described here for the benefit of system
     developers.

     The declarations for the interfaces are in
     /usr/include/rld_interface.h.

     The following is a list of currently defined operations:

     * (int)_rld_new_interface(_SHUT_DOWN).  This function calls the
       routine specified by the -fini option to ld(1) on all open DSOs (and
       the main program) in the reverse of the order that the -init
       sections were run.

     * (char *)_rld_new_interface(_RLD_FIRST_PATHNAME).	 This function
       returns the string MAIN and resets an rld internal pointer to set up
       for calls to (char *)_rld_new_interface(_RLD_NEXT_PATHNAME)

       This interface is not thread-safe.  Multiple threads doing this will
       get erroneous results.  Any call to
       _rld_new_interface(_RLD_MODIFY_LIST,p) after calling
       _rld_new_interface(_RLD_FIRST_PATHNAME) and before calling
       _rld_new_interface(_RLD_NEXT_PATHNAME) interferes with the
       correctness of the rld_new_interface(_RLD_NEXT_PATHNAME) returns.

       Any operation (including delay-loading a DSO as a result of lazy
       function evaluation) that causes the DSO list to be altered can
       interfere with the correctness of
       _rld_new_interface(_RLD_NEXT_PATHNAME) returns.

     * (char *)_rld_new_interface(_RLD_NEXT_PATHNAME).	This function
       returns the next path name in rld's object list and increments its
       internal pointer.  It returns NULL when rld reaches the end of the
       list.  This interface is not thread-safe; multiple threads doing
       this will get erroneous results.

       Calls to _rld_new_interface(_RLD_NEXT_PATHNAME) cannot be
       interspersed with calls to _rld_new_interface(_RLD_MODIFY_LIST,....
       Doing so will interfere with the correctness of the
       _rld_new_interface(_RLD_NEXT_PATHNAME) returns.	Any operation,
       including delay-loading a DSO as a result of lazy function
       evaluation, that alters the DSO list may interfere with the
       correctness of the _rld_new_interface(_RLD_NEXT_PATHNAME) returns.

     * (char *)_rld_new_interface(_RLD_MODIFY_LIST, Elf32_Word operation,
       char *original_pathname, char *name).  This function allows users to
       link and unlink objects.	 When users insert or add an object, they
       must specify the new object in name.  They may specify a full path
       or take advantage of rld's searching mechanism.	Users are not
       allowed to insert before MAIN.  If original_pathname is zero, rld
       operates on the last element in the list.  The exact function
       performed depends on the parameter operation, which can take the
       following values:

	operation	    Function Performed

	_RLD_OP_NONE	    Does nothing.

	_RLD_OP_INSERT	    Adds a new object specified by name before the
			    object specified by original_pathname.  Objects
			    cannot be added before main().

	_RLD_OP_ADD	    Adds a new object specified by name after the
			    object specified by original_pathname.  If
			    original_pathname is omitted, the new object is
			    appended to the object list.

	_RLD_OP_DELETE	    Deletes original_pathname from the object list.

	_RLD_OP_REPLACE	    Replaces original_pathname with the object
			    specified by name in the object list.

     * (char *)_rld_new_interface(_RLD_ADDR_TO_NAME, Elf32_Addr address).
       This function returns either the symbol name of address argument or
       NULL (if no symbol corresponds to that address in the current
       process).  In a 64-bit application, the second argument is of type
       Elf64_Addr.

     * (Elf32_Addr)_rld_new_interface(_RLD_NAME_TO_ADDR, char *name).  This
       function returns the actual address of name.  It returns NULL if rld
       cannot find the passed argument.	 In a 64-bit application, the value
       returned is of type Elf64_addr.

     * (char *)_rld_new_interface(_RLD_VERSION_EXPECTED, char *soname).
       This function returns the version string in MAIN's liblist entry for
       soname.

     * (Elf32_Addr)_rld_new_interface(_RLD_SPROC_NOTIFY).  This function
       signals to rld that sproc(2) has been called and that rld has to
       handle multiple sproc threads.  The call is made by libc.so.

     * (Elf32_Addr)_rld_new_interface(_RLD_SHUTDOWN_THREAD).  This function
       signals to rld that a thread is trying to exit.	Currently does
       nothing when invoked.

     * (Elf32_Addr)_rld_new_interface(_RLD_SPROC_FINI).	 This function
       signals to rld that multiple sproc(2) threads support can be turned
       off.  It is called on behalf of, and in, the child process after a
       fork(2) by the fork code in libc.so.

EXAMPLES
     The following csh(1) aliases control rld tracing.	There are three
     sets of tracing aliases, one for each ABI.	 See file(1) for
     information on how to identify the ABI of a particular executable.

     The following alias pertains to old 32-bit executables:

	  #  trace o32 rld issues
	     alias ra	  \
		'setenv _RLD_PATH /usr/lib/rld.debug	   ;'\
		'setenv _RLD_ARGS "\!*"			   ;'
	     alias nora	  \
		'unsetenv _RLD_ARGS			   ;'\
		'setenv _RLD_PATH /lib/rld		   ;'

     The following alias pertains to new 32-bit executables:

	  #  trace n32 rld issues
	     alias ra32	  \
		'setenv _RLDN32_PATH /usr/lib32/rld.debug  ;'\
		'setenv _RLD_ARGS "\!*"			   ;'
	     alias nora32 \
		'unsetenv _RLD_ARGS			   ;'\
		'setenv _RLDN32_PATH /lib32/rld		   ;'

     The following alias pertains to 64-bit executables:

	  #  trace 64 rld issues
	     alias ra64	  \
		'setenv _RLD64_PATH /usr/lib64/rld.debug   ;'\
		'setenv _RLD_ARGS "\!*"			   ;'
	     alias nora64 \
		'unsetenv _RLD_ARGS			   ;'\
		'setenv _RLD64_PATH /lib64/rld		   ;'

     The following examples shows how the aliases are used.

     The first traces rld when it is running an old 32-bit binary (ls(1)):

       % ra -trace	       <-- turns on tracing of o32 rld
       % ls
       27312:[rld] Entering RLD through MAIN
       27312:ls: [rld] mapped ls at 0x400000
       27312:ls: [rld] mapped /lib/libc.so.1 at 0xfa00000
       27312:ls: [rld] found _end in ls for libc.so.1 at 0x10007000
       27312:ls: [rld] number of objs in the objlist is 2
       27312:ls: [rld] Exiting RLD through MAIN
       RCS	     libX11.so.2   libc.so	 libl.a	       setup
       acrt1.o	     libXaw.a	   libc.so.1	 libm.a	       sgicc.cfg
       crt1.o	     libXext.a	   libc.so.O	 libmld.a      sgild.cfg

       % nora		       <-- turns off all o32 rld debugging options.

     The following traces rld when it is running a new 32-bit binary
     (ci(1)):

       % ra32 -v	       <-- turns on verbose mode in n32 rld
       % ci -l c.c
       14891:_RLD_ARGS = "-v"
       14891:_RLD_ROOT = /
       14891:LD_LIBRARYN32_PATH = none
       14891:ci: mapped ci at 0x10000000
       14891:ci: mapped /usr/lib32/libc.so.1 at 0xfa00000
       RCS/c.c,v  <--  c.c
       file is unchanged; reverting to previous revision 1.1
       done

       % nora32		       <-- turns off all n32 rld debugging options.

ERROR REPORTING
     Most error messages are written to /dev/tty.  If rld encounters an
     error condition for a process without a valid /dev/tty attached, it
     writes the message to /var/adm/SYSLOG.  The system log is written
     using calls to syslog(3C).

CHANGING ROOT
     A copy of the device /dev/zero is essential to the operation of rld.
     In most uses of chroot(1M), it is necessary to put a copy of /dev/zero
     in the newly-created root.

NOTES
     Listing a particular DSO in _RLD_LIST is likely to lead to problems
     and failures unless all three ABI-specific environment variables are
     set.  A typical result is a message such as the following:

	  rld: Fatal Error: Cannot Successfully map soname

     For example, consider an old 32-bit test application a.out and a
     specific old 32-bit DSO, /tmp/mydso.so:

	  unsetenv _RLDN32_LIST _RLD64_LIST
	  setenv _RLD_LIST "/tmp/mydso.so:DEFAULT"
	  ./a.out

     This will likely fail because some command, or the application itself,
     will attempt to fork(2) or exec(2) some new 32-bit application, and
     /tmp/mydso.so is an old 32-bit DSO, not a new 32-bit DSO.
     _RLDN32_LIST and _RLD64_LIST do not suffer from this; they are only
     interpreted in a single ABI each. See the description of _RLD_LIST
     earlier in this man page.

     Adding the following will fix the problem in this example:

	  setenv _RLDN32_LIST DEFAULT
	  setenv _RLD64_LIST DEFAULT

DIAGNOSTICS
     The meaning of the following message from rld is difficult to
     understand:

	  The aggregate IEEE exceptions required (OEX_FPU_MIN)
	  (0xnn) not as complete as the aggregate IEEE
	  exceptions permitted (OEX_FPU_MAX>>8)(0xnn).

     As the executable and each DSO is accessed before the application
     begins to run, information in the .MIPS.options section is used to
     compute an aggregate set of floating-point exceptions to enable.  The
     .MIPS.options section can be examined with the elfdump(1) command's
     -op option.

     For example, specifying the -trapuv compiler option results in a
     request that invalid exception trapping be enabled.  Using certain
     high optimizations in conjunction with the -mips4 and -mips3 compiler
     options, however, requires that those exceptions be turned off so that
     speculative loads of floating-point values can be executed silently.

     For more information, see the compiler options
     -TARG:exc_max=[I][U][O][Z][V], -TARG:exc_min=[I][U][O][Z][V], and
     -TENV:X=0..5.

     Delay-loaded DSOs and DSOs opened with dlopen(3C) or loaded with
     sgidladd(3C) are not factored in until the actual sgidladd(3C) or
     dlopen(3C) is called.  The OEX_FPU_MIN field of each object is OR'd
     with the others.  The nonzero bits represent the set of floating-point
     exceptions that the application wants to catch (more precisely,
     exceptions that some part of the application or a DSO want to catch).
     The OR'd-together OEX_FPU_MIN fields are used to determine what
     set_fpc_csr() fields to set to 1; rld never sets any set_fpc_csr()
     fields to zero.

     The OEX_FPU_MAX field of each object is AND'd with the others.  The
     zero bits represent floating-point exceptions that must not be caught.
     For example, if the code generator is issuing speculative loads, the
     invalid-value exception should not be caught.  If some bits are OFF in
     OEX_FPU_MAX that are ON in OEX_FPU_MIN, that represents an impossible
     scenario:	exceptions must be caught and simultaneously must not be.
     For example, this could happen if an object is compiled requesting
     that uninitialized variables be trapped and a high optimization that
     results in the code generator issuing speculative loads.

     As each DSO is opened with dlopen(3C), delay-loaded, loaded using
     sgidladd(3C), or closed with dlclose(3C), these flags are
     recalculated.  If user or library code has changed the five
     exception-flag-enable fields from a previous setting by using rld, rld
     stops updating the exception-enable fields for the execution.

     rld never turns off exception-enable flags once it has turned them on.

     Use the following to see the OEX fields of an executable or DSOs:

	  elfdump -op objectname

SEE ALSO
     cc(1), chroot(1M), ci(1), csh(1), elfdump(1), file(1), ld(1), ls(1).

     exec(2), exit(2), fork(2), sproc(2).

     dlclose(3C), dlerror(3C), dlopen(3C), dlsym(3C), sgidladd(3C),
     sgidlopen_version(3C), sgigetdsoversion(3C), syslog(3C).

     capabilities(4), capability(4).

     dso(5), gp_overflow(5).

     System V Application Binary Interface

     System V Application Binary Interface: MIPS Processor Supplement

     MIPSpro N32 ABI Handbook
[top]

List of man pages available for IRIX

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net