VirtualBox

Changeset 16716 in vbox for trunk/src/VBox/Main/cbinding


Ignore:
Timestamp:
Feb 12, 2009 5:43:13 PM (16 years ago)
Author:
vboxsync
Message:

cbinding: spelled out the dynamic glue code.

Location:
trunk/src/VBox/Main/cbinding
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Main/cbinding/Makefile.kmk

    r16705 r16716  
    7878  tstXPCOMC_LIBS = \
    7979        $(VBoxXPCOMC_1_TARGET)
     80
     81  #
     82  # The testcase (also in samples).
     83  #
     84  PROGRAMS.linux += tstXPCOMCDynLink
     85  tstXPCOMCDynLink_TEMPLATE = VBOXR3
     86  tstXPCOMCDynLink_DEFS = MOZ_UNICODE
     87  tstXPCOMCDynLink_INCS = \
     88        $(VBOX_PATH_SDK)/bindings/xpcom/include \
     89        $(VBOX_PATH_SDK)/bindings/xpcom/include/nsprpub
     90  tstXPCOMCDynLink_INTERMEDIATES = \
     91        $(VBOX_PATH_SDK)/bindings/xpcom/include/VirtualBox_CXPCOM.h
     92  tstXPCOMCDynLink_SOURCES = \
     93        tstdlOpen.c
    8094 endif
    8195
  • trunk/src/VBox/Main/cbinding/tstdlOpen.c

    r16714 r16716  
    309309}
    310310
    311 #if 0 /* finish this. */
     311#ifdef USE_DYNAMIC_GLUE
     312/** The dlopen handle for VBoxXPCOM. */
     313void *g_hVBoxXPCOMC = NULL;
     314/** The last load error. */
     315char g_szVBoxXPCOMErrMsg[256];
     316
     317#if defined(__linux__) || defined(__linux_gnu__) || defined(__sun__)
     318# define SYM_PREFIX     ""
     319# define DYNLIB_NAME    "VBoxXPCOM.so"
     320#elif defined(__APPLE__)
     321# define SYM_PREFIX     "_"
     322# define DYNLIB_NAME    "VBoxXPCOM.dylib"
     323#else
     324# error "Port me"
     325#endif
     326
    312327/**
    313328 * Try load VBoxXPCOMC.so/dylib/dll from the specified location and resolve all
     
    315330 *
    316331 * @returns 0 on success, -1 on failure.
    317  * @param   pszName         The shared object / dylib / DLL to try load.
    318  * @param   fComplain       Whether to complain to stderr or not when symbols
    319  *                          are missing.
     332 * @param   pszHome         The director where to try load VBoxXPCOMC from. Can be NULL.
     333 * @param   pszMsgPrefix    Error message prefix. NULL means no error messages.
    320334 */
    321 int tryLoadOne(const char *pszName, int fComplain)
     335static int tryLoadOne(const char *pszHome, const char *pszMsgPrefix)
    322336{
    323337    static struct
     
    325339        const char *pszSymbol;
    326340        void **ppvSym;
    327     } s_aSyms[] =
    328     {
    329         { "VBoxComInitialize", (void **)&VBoxComInitializePtr },
    330         ....
     341    } const s_aSyms[] =
     342    {
     343        { SYM_PREFIX "VBoxComUninitialize",         (void **)&VBoxComUninitializePtr          },
     344        { SYM_PREFIX "VBoxComUnallocMem",           (void **)&VBoxComUnallocMemPtr            },
     345        { SYM_PREFIX "VBoxUtf16Free",               (void **)&VBoxUtf16FreePtr                },
     346        { SYM_PREFIX "VBoxUtf8Free",                (void **)&VBoxUtf8FreePtr                 },
     347        { SYM_PREFIX "VBoxConvertPRUnichartoAscii", (void **)&VBoxConvertPRUnichartoAsciiPtr  },
     348        { SYM_PREFIX "VBoxConvertAsciitoPRUnichar", (void **)&VBoxConvertAsciitoPRUnicharPtr  },
     349        { SYM_PREFIX "VBoxUtf16ToUtf8",             (void **)&VBoxUtf16ToUtf8Ptr              },
     350        { SYM_PREFIX "VBoxUtf8ToUtf16",             (void **)&VBoxUtf8ToUtf16Ptr              },
     351        { SYM_PREFIX "VBoxGetEnv",                  (void **)&VBoxGetEnvPtr                   },
     352        { SYM_PREFIX "VBoxSetEnv",                  (void **)&VBoxSetEnvPtr                   }
    331353    };
    332 
    333     /* Just try dlopen it and run over the s_aSyms table calling dlsym on
    334        each entry. */
    335     return 0
     354    size_t      cchHome = pszHome ? strlen(pszHome) : 0;
     355    size_t      cbBuf;
     356    char *      pszBuf;
     357    int         rc = 0;
     358
     359    /*
     360     * Construct the full name.
     361     */
     362    cbBuf = cchHome + sizeof("/" DYNLIB_NAME);
     363    pszBuf = (char *)malloc(cbBuf);
     364    if (!pszBuf)
     365    {
     366        sprintf(g_szVBoxXPCOMErrMsg, "malloc(%u) failed", (unsigned)cbBuf);
     367        if (pszMsgPrefix)
     368            fprintf(stderr, "%s%s\n", pszMsgPrefix, g_szVBoxXPCOMErrMsg);
     369        return -1;
     370    }
     371    if (pszHome)
     372    {
     373        memcpy(pszBuf, pszHome, cchHome);
     374        pszBuf[cchHome] = '/';
     375        cchHome++;
     376    }
     377    memcpy(&pszBuf[cchHome], DYNLIB_NAME, sizeof(DYNLIB_NAME));
     378
     379    /*
     380     * Try load it by that name, setting the VBOX_APP_HOME first (for now).
     381     */
     382    setenv("VBOX_APP_HOME", pszBuf, 0 /* no need to overwrite */);
     383    g_hVBoxXPCOMC = dlopen(pszBuf, RTLD_NOW | RTLD_LOCAL);
     384    if (g_hVBoxXPCOMC)
     385    {
     386        unsigned i = sizeof(s_aSyms) / sizeof(s_aSyms[0]);
     387        while (i-- > 0)
     388        {
     389            void *pv = dlsym(g_hVBoxXPCOMC, s_aSyms[i].pszSymbol);
     390            if (!pv)
     391            {
     392                sprintf(g_szVBoxXPCOMErrMsg, "dlsym(%.80s/%.32s): %128s",
     393                        pszBuf, s_aSyms[i].pszSymbol, dlerror());
     394                if (pszMsgPrefix)
     395                    fprintf(stderr, "%s%s\n", pszMsgPrefix, g_szVBoxXPCOMErrMsg);
     396                rc = -1;
     397                break;
     398            }
     399            *s_aSyms[i].ppvSym = pv;
     400        }
     401    }
     402    else
     403    {
     404        sprintf(g_szVBoxXPCOMErrMsg, "dlopen(%.80s): %128s", pszBuf, dlerror());
     405        rc = -1;
     406    }
     407    free(pszBuf);
     408    return rc;
    336409}
    337410
     
    341414 *
    342415 * @returns 0 on success, -1 on failure.
    343  * @param   fComplain       Whether to complain to stderr or not.
     416 * @param   pszMsgPrefix    Error message prefix. NULL means no error messages.
    344417 *
    345418 * @remark  This should be considered moved into a separate glue library since
     
    348421 *          source code all around the place.
    349422 */
    350 int tryLoad(int fComplain)
     423static int tryLoad(const char *pszMsgPrefix)
    351424{
    352     /* Check getenv("VBOX_APP_HOME") first, then try the standard
    353        locations for this platform, finally try load it without a path. */
     425    /*
     426     * If the user specifies the location, try only that.
     427     */
     428    const char *pszHome = getenv("VBOX_APP_HOME");
     429    if (pszHome)
     430        return tryLoadOne(pszHome, pszMsgPrefix);
     431
     432    /*
     433     * Try the known standard locations.
     434     */
     435#if defined(__gnu__linux__) || defined(__linux__)
     436    if (tryLoadOne("/opt/VirtualBox", pszMsgPrefix) == 0)
     437        return 0;
     438    if (tryLoadOne("/usr/lib/virtualbox", pszMsgPrefix) == 0)
     439        return 0;
     440#elif defined(__sun__)
     441    if (tryLoadOne("/opt/VirtualBox/amd64", pszMsgPrefix) == 0)
     442        return 0;
     443    if (tryLoadOne("/opt/VirtualBox/i386", pszMsgPrefix) == 0)
     444        return 0;
     445#elif defined(__APPLE__)
     446    if (tryLoadOne("/Application/VirtualBox.app/Contents/MacOS", pszMsgPrefix) == 0)
     447        return 0;
     448#else
     449# error "port me"
     450#endif
     451
     452    /*
     453     * Finally try the dynamic linker search path.
     454     */
     455    if (tryLoadOne(NULL, pszMsgPrefix) == 0)
     456        return 0;
     457
     458    /* No luck, return failure. */
     459    if (pszMsgPrefix)
     460        fprintf(stderr, "%sFailed to locate VBoxXPCOMC\n", pszMsgPrefix);
    354461    return -1;
    355462}
     
    366473    PRUnichar  *versionUtf16     = NULL;
    367474    PRUnichar  *homefolderUtf16  = NULL;
     475    nsresult    rc;     /* Result code of various function (method) calls. */
     476#ifndef USE_DYNAMIC_GLUE
    368477    void       *xpcomHandle      = NULL;
    369478    const char *xpcomdlError;
    370479    struct stat stIgnored;
    371     nsresult    rc;     /* Result code of various function (method) calls. */
    372480
    373481    /*
     
    406514        VBoxSetEnvPtr("VBOX_APP_HOME","/usr/lib/virtualbox/");
    407515    }
     516#else
     517    /*
     518     * Initialize the dynamic linking glue.
     519     */
     520
     521    if (tryLoad(NULL) != 0)
     522    {
     523        fprintf(stderr, "%s: FATAL: %s\n", argv[0], g_szVBoxXPCOMErrMsg);
     524        return EXIT_FAILURE;
     525    }
     526#endif
    408527
    409528    printf("Starting Main\n");
     
    416535     */
    417536
     537#ifndef USE_DYNAMIC_GLUE
    418538    dlerror();    /* Clear any existing error */
    419539    *(void **) (&VBoxComInitializePtr) = dlsym(xpcomHandle, "VBoxComInitialize");
     
    422542        return EXIT_FAILURE;
    423543    }
     544#endif
    424545    VBoxComInitializePtr(&vbox, &session);
    425546
     
    435556    }
    436557
     558#ifndef USE_DYNAMIC_GLUE
    437559    *(void **) (&VBoxUtf16ToUtf8Ptr) = dlsym(xpcomHandle, "VBoxUtf16ToUtf8");
    438560    if ((xpcomdlError = dlerror()) != NULL)  {
     
    460582        return EXIT_FAILURE;
    461583    }
     584#endif
     585
    462586    /*
    463587     * Now ask for revision, version and home folder information of
     
    524648     */
    525649
     650#ifndef USE_DYNAMIC_GLUE
    526651    *(void **) (&VBoxComUninitializePtr) = dlsym(xpcomHandle, "VBoxComUninitialize");
    527652    if ((xpcomdlError = dlerror()) != NULL)  {
     
    529654        return EXIT_FAILURE;
    530655    }
     656#endif
    531657    VBoxComUninitializePtr();
     658#ifndef USE_DYNAMIC_GLUE
    532659    dlclose(xpcomHandle);
     660#endif
    533661    printf("Finished Main\n");
    534662
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette