dbgmodldr.cpp revision ae82af535a3425a343289a639468f832ec316dee
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * IPRT - Debug Module Image Interpretation by RTLdr.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * Copyright (C) 2011 Oracle Corporation
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * available from http://www.virtualbox.org. This file is free software;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * you can redistribute it and/or modify it under the terms of the GNU
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * General Public License (GPL) as published by the Free Software
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * The contents of this file may alternatively be used under the terms
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * of the Common Development and Distribution License Version 1.0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * VirtualBox OSE distribution, in which case the provisions of the
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * CDDL are applicable instead of those of the GPL.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * You may elect to license modified versions of this file under the
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * terms and conditions of either the GPL or the CDDL or both.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/*******************************************************************************
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync* Header Files *
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync*******************************************************************************/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/*******************************************************************************
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync* Structures and Typedefs *
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync*******************************************************************************/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync * The instance data of the RTLdr based image reader.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsynctypedef struct RTDBGMODLDR
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync /** The loader handle. */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync /** File handle for the image. */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** Pointer to instance data NM map reader. */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** @interface_method_impl{RTDBGMODVTIMG,pfnUnmapPart} */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncstatic DECLCALLBACK(int) rtDbgModLdr_UnmapPart(PRTDBGMODINT pMod, size_t cb, void const **ppvMap)
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** @interface_method_impl{RTDBGMODVTIMG,pfnMapPart} */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncstatic DECLCALLBACK(int) rtDbgModLdr_MapPart(PRTDBGMODINT pMod, RTFOFF off, size_t cb, void const **ppvMap)
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PRTDBGMODLDR pThis = (PRTDBGMODLDR)pMod->pvImgPriv;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync int rc = RTFileReadAt(pThis->hFile, off, pvMap, cb, NULL);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** @interface_method_impl{RTDBGMODVTIMG,pfnGetLoadedSize} */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncstatic DECLCALLBACK(RTUINTPTR) rtDbgModLdr_GetLoadedSize(PRTDBGMODINT pMod)
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PRTDBGMODLDR pThis = (PRTDBGMODLDR)pMod->pvImgPriv;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** @interface_method_impl{RTDBGMODVTIMG,pfnLinkAddressToSegOffset} */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncstatic DECLCALLBACK(int) rtDbgModLdr_LinkAddressToSegOffset(PRTDBGMODINT pMod, RTLDRADDR LinkAddress,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PRTDBGMODLDR pThis = (PRTDBGMODLDR)pMod->pvImgPriv;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return RTLdrLinkAddressToSegOffset(pThis->hLdrMod, LinkAddress, piSeg, poffSeg);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** @interface_method_impl{RTDBGMODVTIMG,pfnEnumSegments} */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncstatic DECLCALLBACK(int) rtDbgModLdr_EnumSegments(PRTDBGMODINT pMod, PFNRTLDRENUMSEGS pfnCallback, void *pvUser)
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PRTDBGMODLDR pThis = (PRTDBGMODLDR)pMod->pvImgPriv;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return RTLdrEnumSegments(pThis->hLdrMod, pfnCallback, pvUser);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** @interface_method_impl{RTDBGMODVTIMG,pfnEnumDbgInfo} */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncstatic DECLCALLBACK(int) rtDbgModLdr_EnumDbgInfo(PRTDBGMODINT pMod, PFNRTLDRENUMDBG pfnCallback, void *pvUser)
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PRTDBGMODLDR pThis = (PRTDBGMODLDR)pMod->pvImgPriv;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return RTLdrEnumDbgInfo(pThis->hLdrMod, NULL, pfnCallback, pvUser);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** @interface_method_impl{RTDBGMODVTIMG,pfnClose} */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncstatic DECLCALLBACK(int) rtDbgModLdr_Close(PRTDBGMODINT pMod)
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PRTDBGMODLDR pThis = (PRTDBGMODLDR)pMod->pvImgPriv;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** @interface_method_impl{RTDBGMODVTIMG,pfnTryOpen} */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncstatic DECLCALLBACK(int) rtDbgModLdr_TryOpen(PRTDBGMODINT pMod)
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync int rc = RTFileOpen(&hFile, pMod->pszImgFile, RTFILE_O_READ | RTFILE_O_DENY_WRITE | RTFILE_O_OPEN);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync rc = RTLdrOpen(pMod->pszImgFile, 0 /*fFlags*/, RTLDRARCH_WHATEVER, &hLdrMod);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PRTDBGMODLDR pThis = (PRTDBGMODLDR)RTMemAllocZ(sizeof(RTDBGMODLDR));
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** Virtual function table for the RTLdr based image reader. */
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncDECL_HIDDEN_CONST(RTDBGMODVTIMG) const g_rtDbgModVtImgLdr =
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync /*.fReserved = */ 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync /*.pfnGetLoadedSize = */ rtDbgModLdr_GetLoadedSize,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync /*.pfnLinkAddressToSegOffset = */ rtDbgModLdr_LinkAddressToSegOffset,