VirtualBox

Changeset 100954 in vbox for trunk/src


Ignore:
Timestamp:
Aug 23, 2023 11:13:42 AM (17 months ago)
Author:
vboxsync
Message:

IPRT/dbgmod: Improved the logic for guessing the .pdb/.dbg filename.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Runtime/common/dbg/dbgmod.cpp

    r100948 r100954  
    583583rtDbgModOpenDebugInfoExternalToImageCallback(RTLDRMOD hLdrMod, PCRTLDRDBGINFO pDbgInfo, void *pvUser)
    584584{
    585     RTDBGMODOPENDIETI *pArgs = (RTDBGMODOPENDIETI *)pvUser;
     585    RTDBGMODOPENDIETI * const pArgs   = (RTDBGMODOPENDIETI *)pvUser;
     586    PRTDBGMODINT const        pDbgMod = pArgs->pDbgMod;
    586587    RT_NOREF_PV(hLdrMod);
    587588
     
    591592    {
    592593        /*
    593          * If a external debug type comes without a file name, calculate a
    594          * likely debug filename for it. (Hack for NT4 drivers.)
     594         * If a external debug type comes without a file name, calculate a likely
     595         * debug filename for it. (Hack for NT4 drivers and the 'nt' module for
     596         * NT and W2K.)  Prefer the image name rather than the module name, since
     597         * the latter can be normalized or using a different name (e.g. 'nt').
    595598         */
    596599        const char *pszExt = NULL;
     
    600603                 || pDbgInfo->enmType == RTLDRDBGINFOTYPE_CODEVIEW_PDB70)
    601604            pszExt = ".pdb";
    602         if (pszExt && pArgs->pDbgMod->pszName)
    603         {
    604             size_t cchName = strlen(pArgs->pDbgMod->pszName);
    605             char *psz = (char *)alloca(cchName + strlen(pszExt) + 1);
    606             if (psz)
     605        if (pszExt)
     606        {
     607            const char * const pszName = pDbgMod->pszImgFile
     608                                       ? RTPathFilenameEx(pDbgMod->pszImgFile, RTPATH_STR_F_STYLE_DOS)
     609                                       : pDbgMod->pszName;
     610            if (pszName)
    607611            {
    608                 memcpy(psz, pArgs->pDbgMod->pszName, cchName + 1);
    609                 RTPathStripSuffix(psz);
    610                 pszExtFile = strcat(psz, pszExt);
     612                size_t cchName = strlen(pszName);
     613                char *pszExtFileBuf = (char *)alloca(cchName + strlen(pszExt) + 1);
     614                if (pszExtFileBuf)
     615                {
     616                    memcpy(pszExtFileBuf, pszName, cchName + 1);
     617                    RTPathStripSuffix(pszExtFileBuf);
     618                    pszExtFile = strcat(pszExtFileBuf, pszExt);
     619                }
    611620            }
    612621        }
    613 
    614622        if (!pszExtFile)
    615623        {
     
    629637                                   &pDbgInfo->u.Pdb70.Uuid,
    630638                                   pDbgInfo->u.Pdb70.uAge,
    631                                    rtDbgModExtDbgInfoOpenCallback, pArgs->pDbgMod, (void *)pDbgInfo);
     639                                   rtDbgModExtDbgInfoOpenCallback, pDbgMod, (void *)pDbgInfo);
    632640            break;
    633641
     
    637645                                   pDbgInfo->u.Pdb20.uTimestamp,
    638646                                   pDbgInfo->u.Pdb20.uAge,
    639                                    rtDbgModExtDbgInfoOpenCallback, pArgs->pDbgMod, (void *)pDbgInfo);
     647                                   rtDbgModExtDbgInfoOpenCallback, pDbgMod, (void *)pDbgInfo);
    640648            break;
    641649
     
    644652                                 pDbgInfo->u.Dbg.cbImage,
    645653                                 pDbgInfo->u.Dbg.uTimestamp,
    646                                  rtDbgModExtDbgInfoOpenCallback, pArgs->pDbgMod, (void *)pDbgInfo);
     654                                 rtDbgModExtDbgInfoOpenCallback, pDbgMod, (void *)pDbgInfo);
    647655            break;
    648656
     
    650658            rc = RTDbgCfgOpenDwo(pArgs->hDbgCfg, pszExtFile,
    651659                                 pDbgInfo->u.Dwo.uCrc32,
    652                                  rtDbgModExtDbgInfoOpenCallback, pArgs->pDbgMod, (void *)pDbgInfo);
     660                                 rtDbgModExtDbgInfoOpenCallback, pDbgMod, (void *)pDbgInfo);
    653661            break;
    654662
     
    661669    {
    662670        LogFlow(("RTDbgMod: Successfully opened external debug info '%s' for '%s'\n",
    663                  pArgs->pDbgMod->pszDbgFile, pArgs->pDbgMod->pszImgFile));
     671                 pDbgMod->pszDbgFile, pDbgMod->pszImgFile));
    664672        return VINF_CALLBACK_RETURN;
    665673    }
    666674    Log(("rtDbgModOpenDebugInfoExternalToImageCallback: '%s' (enmType=%d) for '%s'  -> %Rrc\n",
    667          pszExtFile, pDbgInfo->enmType, pArgs->pDbgMod->pszImgFile, rc));
     675         pszExtFile, pDbgInfo->enmType, pDbgMod->pszImgFile, rc));
    668676    return rc;
    669677}
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