Changeset 21046 in vbox
- Timestamp:
- Jun 30, 2009 1:11:28 AM (16 years ago)
- Location:
- trunk
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/include/iprt/err.h
r20799 r21046 979 979 /** The specified address range wraps around. */ 980 980 #define VERR_DBG_ADDRESS_WRAP (-664) 981 /** The file is not a valid NM map file. */ 982 #define VERR_DBG_NOT_NM_MAP_FILE (-665) 983 /** The file is not a valid /proc/kallsyms file. */ 984 #define VERR_DBG_NOT_LINUX_KALLSYMS (-666) 985 /** No debug module interpreter matching the debug info. */ 986 #define VERR_DBG_NO_MATCHING_INTERPRETER (-667) 981 987 /** @} */ 982 988 -
trunk/src/VBox/Runtime/Makefile.kmk
r20933 r21046 204 204 common/dbg/dbgmod.cpp \ 205 205 common/dbg/dbgmodcontainer.cpp \ 206 common/dbg/dbgmodnm.cpp \ 206 207 common/err/errmsg.cpp \ 207 208 common/err/RTErrConvertFromErrno.cpp \ -
trunk/src/VBox/Runtime/common/dbg/dbgmod.cpp
r20801 r21046 42 42 #include <iprt/once.h> 43 43 #include <iprt/param.h> 44 #include <iprt/path.h> 44 45 #include <iprt/semaphore.h> 45 46 #include <iprt/strcache.h> … … 112 113 static RTSEMRW g_hDbgModRWSem = NIL_RTSEMRW; 113 114 /** List of registered image interpreters. */ 114 static RTDBGMODREGIMGg_pImgHead;115 static PRTDBGMODREGIMG g_pImgHead; 115 116 /** List of registered debug infor interpreters. */ 116 static RTDBGMODREGDBGg_pDbgHead;117 static PRTDBGMODREGDBG g_pDbgHead; 117 118 /** String cache for the debug info interpreters. 118 119 * RTSTRCACHE is thread safe. */ 119 120 DECLHIDDEN(RTSTRCACHE) g_hDbgModStrCache = NIL_RTSTRCACHE; 121 120 122 121 123 … … 137 139 g_hDbgModStrCache = NIL_RTSTRCACHE; 138 140 139 /** @todo deregister interpreters. */ 141 PRTDBGMODREGDBG pCur = g_pDbgHead; 142 g_pDbgHead = NULL; 143 while (pCur) 144 { 145 PRTDBGMODREGDBG pNext = pCur->pNext; 146 AssertMsg(pCur->cUsers == 0, ("%#x %s\n", pCur->cUsers, pCur->pVt->pszName)); 147 RTMemFree(pCur); 148 pCur = pNext; 149 } 150 151 Assert(!g_pImgHead); 140 152 } 153 } 154 155 156 /** 157 * Internal worker for register a debug interpreter. 158 * 159 * Called while owning the write lock or when locking isn't required. 160 * 161 * @returns IPRT status code. 162 * @retval VERR_NO_MEMORY 163 * @retval VERR_ALREADY_EXISTS 164 * 165 * @param pVt The virtual function table of the debug 166 * module interpreter. 167 */ 168 static int rtDbgModDebugInterpreterRegister(PCRTDBGMODVTDBG pVt) 169 { 170 /* 171 * Search or duplicate registration. 172 */ 173 PRTDBGMODREGDBG pPrev = NULL; 174 for (PRTDBGMODREGDBG pCur = g_pDbgHead; pCur; pCur = pCur->pNext) 175 { 176 if (pCur->pVt == pVt) 177 return VERR_ALREADY_EXISTS; 178 if (!strcmp(pCur->pVt->pszName, pVt->pszName)) 179 return VERR_ALREADY_EXISTS; 180 pPrev = pCur; 181 } 182 183 /* 184 * Create a new record and add it to the end of the list. 185 */ 186 PRTDBGMODREGDBG pReg = (PRTDBGMODREGDBG)RTMemAlloc(sizeof(*pReg)); 187 if (!pReg) 188 return VERR_NO_MEMORY; 189 pReg->pVt = pVt; 190 pReg->cUsers = 0; 191 pReg->pNext = NULL; 192 if (pPrev) 193 pPrev->pNext = pReg; 194 else 195 g_pDbgHead = pReg; 196 return VINF_SUCCESS; 141 197 } 142 198 … … 164 220 * Register the interpreters. 165 221 */ 166 /** @todo */ 167 222 rc = rtDbgModDebugInterpreterRegister(&g_rtDbgModVtDbgNm); 168 223 if (RT_SUCCESS(rc)) 169 224 { … … 174 229 if (RT_SUCCESS(rc)) 175 230 return VINF_SUCCESS; 231 232 /* bail out: use the termination callback. */ 176 233 } 177 178 RTStrCacheDestroy(g_hDbgModStrCache);234 } 235 else 179 236 g_hDbgModStrCache = NIL_RTSTRCACHE; 180 } 181 182 RTSemRWDestroy(g_hDbgModRWSem); 183 g_hDbgModRWSem = NIL_RTSEMRW; 184 237 rtDbgModTermCallback(RTTERMREASON_UNLOAD, 0, NULL); 185 238 return rc; 186 239 } … … 265 318 } 266 319 267 RTDECL(int) RTDbgModCreateFromMap(PRTDBGMOD phDbgMod, const char *pszFilename, const char *pszName, RTUINTPTR uSubtrahend, uint32_t fFlags) 268 { 269 return VERR_NOT_IMPLEMENTED; 320 321 RTDECL(int) RTDbgModCreateFromMap(PRTDBGMOD phDbgMod, const char *pszFilename, const char *pszName, RTUINTPTR uSubtrahend, uint32_t fFlags) 322 { 323 /* 324 * Input validation and lazy initialization. 325 */ 326 AssertPtrReturn(phDbgMod, VERR_INVALID_POINTER); 327 *phDbgMod = NIL_RTDBGMOD; 328 AssertPtrReturn(pszFilename, VERR_INVALID_POINTER); 329 AssertReturn(*pszFilename, VERR_INVALID_PARAMETER); 330 AssertPtrNullReturn(pszName, VERR_INVALID_POINTER); 331 AssertReturn(fFlags == 0, VERR_INVALID_PARAMETER); 332 333 int rc = rtDbgModLazyInit(); 334 if (RT_FAILURE(rc)) 335 return rc; 336 337 if (!pszName) 338 pszName = RTPathFilename(pszFilename); 339 340 /* 341 * Allocate a new module instance. 342 */ 343 PRTDBGMODINT pDbgMod = (PRTDBGMODINT)RTMemAllocZ(sizeof(*pDbgMod)); 344 if (!pDbgMod) 345 return VERR_NO_MEMORY; 346 pDbgMod->u32Magic = RTDBGMOD_MAGIC; 347 pDbgMod->cRefs = 1; 348 rc = RTCritSectInit(&pDbgMod->CritSect); 349 if (RT_SUCCESS(rc)) 350 { 351 pDbgMod->pszName = RTStrCacheEnter(g_hDbgModStrCache, pszName); 352 if (pDbgMod->pszName) 353 { 354 pDbgMod->pszDbgFile = RTStrCacheEnter(g_hDbgModStrCache, pszFilename); 355 if (pDbgMod->pszDbgFile) 356 { 357 /* 358 * Try the map file readers. 359 */ 360 rc = RTSemRWRequestRead(g_hDbgModRWSem, RT_INDEFINITE_WAIT); 361 if (RT_SUCCESS(rc)) 362 { 363 rc = VERR_DBG_NO_MATCHING_INTERPRETER; 364 for (PRTDBGMODREGDBG pCur = g_pDbgHead; pCur; pCur = pCur->pNext) 365 { 366 if (pCur->pVt->fSupports & RT_DBGTYPE_MAP) 367 { 368 pDbgMod->pDbgVt = pCur->pVt; 369 pDbgMod->pvDbgPriv = NULL; 370 rc = pCur->pVt->pfnTryOpen(pDbgMod); 371 if (RT_SUCCESS(rc)) 372 { 373 ASMAtomicIncU32(&pCur->cUsers); 374 RTSemRWReleaseRead(g_hDbgModRWSem); 375 376 *phDbgMod = pDbgMod; 377 return rc; 378 } 379 } 380 } 381 382 /* bail out */ 383 RTSemRWReleaseRead(g_hDbgModRWSem); 384 } 385 RTStrCacheRelease(g_hDbgModStrCache, pDbgMod->pszName); 386 } 387 RTStrCacheRelease(g_hDbgModStrCache, pDbgMod->pszDbgFile); 388 } 389 RTCritSectDelete(&pDbgMod->CritSect); 390 } 391 392 RTMemFree(pDbgMod); 393 return rc; 270 394 } 271 395 … … 454 578 RTDBGMOD_VALID_RETURN_RC(pDbgMod, VERR_INVALID_HANDLE); 455 579 AssertMsgReturn(uRva + cb >= uRva, ("uRva=%RTptr cb=%RTptr\n", uRva, cb), VERR_DBG_ADDRESS_WRAP); 456 Assert Ptr(*pszName);580 Assert(*pszName); 457 581 size_t cchName = strlen(pszName); 458 582 AssertReturn(cchName > 0, VERR_DBG_SEGMENT_NAME_OUT_OF_RANGE); … … 525 649 526 650 RTDBGMOD_UNLOCK(pDbgMod); 527 return RT_SUCCESS(rc);651 return rc; 528 652 } 529 653 -
trunk/src/VBox/Runtime/common/dbg/dbgmodcontainer.cpp
r21005 r21046 247 247 AssertMsgReturn(iSeg < pThis->cSegs, ("iSeg=%#x cSegs=%#x\n", pThis->cSegs), 248 248 VERR_DBG_INVALID_SEGMENT_INDEX); 249 AssertMsgReturn( pThis->paSegs[iSeg].cb < off, ("off=%RTptr cbSeg=%RTptr\n", off, pThis->paSegs[iSeg].cb),249 AssertMsgReturn(off < pThis->paSegs[iSeg].cb, ("off=%RTptr cbSeg=%RTptr\n", off, pThis->paSegs[iSeg].cb), 250 250 VERR_DBG_INVALID_SEGMENT_OFFSET); 251 251 … … 385 385 VERR_DBG_INVALID_SEGMENT_INDEX); 386 386 AssertMsgReturn( iSeg >= RTDBGSEGIDX_SPECIAL_FIRST 387 || pThis->paSegs[iSeg].cb <= off +cb,387 || off + cb <= pThis->paSegs[iSeg].cb, 388 388 ("off=%RTptr cb=%RTptr cbSeg=%RTptr\n", off, cb, pThis->paSegs[iSeg].cb), 389 389 VERR_DBG_INVALID_SEGMENT_OFFSET); … … 397 397 398 398 pSymbol->AddrCore.Key = off; 399 pSymbol->AddrCore.KeyLast = off + RT_MAX(cb, 1);399 pSymbol->AddrCore.KeyLast = off + (cb ? cb - 1 : 0); 400 400 pSymbol->OrdinalCore.Key = pThis->iNextSymbolOrdinal; 401 401 pSymbol->iSeg = iSeg; -
trunk/src/VBox/Runtime/include/internal/dbgmod.h
r20801 r21046 400 400 401 401 402 extern DECLHIDDEN(RTSTRCACHE) g_hDbgModStrCache;403 402 extern DECLHIDDEN(RTSTRCACHE) g_hDbgModStrCache; 403 extern DECLHIDDEN(RTDBGMODVTDBG const) g_rtDbgModVtDbgNm; 404 404 405 405 int rtDbgModContainerCreate(PRTDBGMODINT pMod, RTUINTPTR cbSeg);
Note:
See TracChangeset
for help on using the changeset viewer.