Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-4170412

green thread's dlsym(RTLD_NEXT, ...) cannot distinguish library caller

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Fixed
    • Icon: P4 P4
    • 1.2.0
    • 1.2.0
    • hotspot
    • None
    • 1.2fcs
    • generic, sparc
    • solaris_2.6

      The behavior of dlsym(RTLD_NEXT, ...) is defined to search for the symbol
      starting at the library that contains the caller:

           In the latter [RTLD_NEXT] case dlsym() will search for the named symbol
           in the objects that were loaded following the object from
           which the dlsym() call is being made. If these subsequent
           objects were loaded from dlopen() calls, dlsym() will search
           the object only if the caller is part of the same dlopen()
           dependency hierarchy, or the object was given global search
           access (see dlopen() with reference to the mode
           RTLD_GLOBAL).

      The wrapper for dlsym() in green thread's breaks this, resulting in the
      caller always being the library that contains iomgr.o. A library,
      such as libawt.so, could call _dlsym directly, but then it would bypass the
      wrapper and cause synchronization problems.

      dean.long@Eng 1998-08-31

            never Tom Rodriguez
            dlong Dean Long
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

              Created:
              Updated:
              Resolved:
              Imported:
              Indexed: