VirtualBox

Ignore:
Timestamp:
Mar 23, 2012 10:09:54 PM (13 years ago)
Author:
vboxsync
Message:

coding in progress... -> laptop.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/HostDrivers/Support/SUPDrv-dtrace.cpp

    r40599 r40600  
    3333
    3434#include <VBox/err.h>
     35#include <VBox/VBoxTpG.h>
    3536#include <iprt/assert.h>
    3637
    3738#include <sys/dtrace.h>
    3839
     40
     41/*******************************************************************************
     42*   Structures and Typedefs                                                    *
     43*******************************************************************************/
     44/**
     45 * Data for a provider.
     46 */
     47typedef struct SUPDRVDTPROVIDER
     48{
     49    /** The entry in the provider list for this image. */
     50    RTLISTNODE          ListEntry;
     51
     52    /** The provider descriptor. */
     53    PVTGDESCPROVIDER    pDesc;
     54    /** The VTG header. */
     55    PVTGOBJHDR          pHdr;
     56
     57    /** Pointer to the image this provider resides in.  NULL if it's a
     58     * driver. */
     59    PSUPDRVLDRIMAGE     pImage;
     60    /** The session this provider is associated with if registered via
     61     * SUPR0VtgRegisterDrv.  NULL if pImage is set. */
     62    PSUPDRVSESSION      pSession;
     63    /** The module name. */
     64    const char         *pszModName;
     65} SUPDRVDTPROVIDER;
     66/** Pointer to the data for a provider. */
     67typedef SUPDRVDTPROVIDER *PSUPDRVDTPROVIDER;
    3968
    4069
     
    4574static int      supdrvDTracePOps_Enable(void *pvProv, dtrace_id_t idProbe, void *pvProbe);
    4675static void     supdrvDTracePOps_Disable(void *pvProv, dtrace_id_t idProbe, void *pvProbe);
    47 static void     supdrvDTracePOps_GetArgDesc(void *pvProv, dtrace_id_t idProbe, void *pvProbe, 
     76static void     supdrvDTracePOps_GetArgDesc(void *pvProv, dtrace_id_t idProbe, void *pvProbe,
    4877                                            dtrace_argdesc_t *pArgDesc);
    4978/*static uint64_t supdrvDTracePOps_GetArgVal(void *pvProv, dtrace_id_t idProbe, void *pvProbe,
     
    5786*******************************************************************************/
    5887/** The default provider attributes. */
    59 static dtrace_pattr_t g_DefProvAttrs = 
     88static dtrace_pattr_t g_DefProvAttrs =
    6089{   /*                       .dtat_name,                .dtat_data,                .dtat_class */
    6190    /* .dtpa_provider = */ { DTRACE_STABILITY_UNSTABLE, DTRACE_STABILITY_UNSTABLE, DTRACE_CLASS_ISA },
     
    6695};
    6796
    68 /** 
    69  * DTrace provider method table. 
    70  */ 
    71 static const dtrace_pops_t g_SupDrvDTraceProvOps = 
     97/**
     98 * DTrace provider method table.
     99 */
     100static const dtrace_pops_t g_SupDrvDTraceProvOps =
    72101{
    73102    /* .dtps_provide         = */ NULL,
     
    84113
    85114
     115#define VERR_SUPDRV_VTG_MAGIC           (-3704)
     116#define VERR_SUPDRV_VTG_BITS            (-3705)
     117#define VERR_SUPDRV_VTG_RESERVED        (-3705)
     118#define VERR_SUPDRV_VTG_BAD_PTR         (-3706)
     119#define VERR_SUPDRV_VTG_TOO_FEW         (-3707)
     120#define VERR_SUPDRV_VTG_TOO_MUCH        (-3708)
     121#define VERR_SUPDRV_VTG_NOT_MULTIPLE    (-3709)
     122
     123
     124/**
     125 * Validates the VTG data.
     126 * 
     127 * @returns VBox status code.
     128 * @param   pVtgHdr             The VTG object header of the data to validate.
     129 * @param   cbVtgObj            The size of the VTG object.
     130 * @param   pbImage             The image base. For validating the probe
     131 *                              locations.
     132 * @param   cbImage             The image size to go with @a pbImage.
     133 */
     134static int supdrvVtgValidate(PVTGOBJHDR pVtgHdr, size_t cbVtgObj, uint8_t *pbImage, size_t cbImage)
     135{
     136    /*
     137     * The header.
     138     */
     139    if (!memcmp(pVtgHdr->szMagic, VTGOBJHDR_MAGIC, sizeof(pVtgHdr->szMagic)))
     140        return VERR_SUPDRV_VTG_MAGIC;
     141    if (pVtgHdr->cBits != ARCH_BITS)
     142        return VERR_SUPDRV_VTG_BITS;
     143    if (pVtgHdr->u32Reserved0)
     144        return VERR_SUPDRV_VTG_RESERVED;
     145
     146#define MY_VALIDATE_PTR(p, cb, cMin, cMax, cbUnit) \
     147    do { \
     148        if (   (cb) >= cbVtgObj \
     149            || (uintptr_t)(p) - (uintptr_t)pVtgHdr < cbVtgObj - (cb) ) \
     150            return VERR_SUPDRV_VTG_BAD_PTR; \
     151        if ((cb) <  (cMin) * (cbUnit)) \
     152            return VERR_SUPDRV_VTG_TOO_FEW; \
     153        if ((cb) >= (cMax) * (cbUnit)) \
     154            return VERR_SUPDRV_VTG_TOO_MUCH; \
     155        if ((cb) / (cbUnit) * (cbUnit) != (cb)) \
     156            return VERR_SUPDRV_VTG_NOT_MULTIPLE; \
     157    } while (0)
     158
     159    MY_VALIDATE_PTR(pVtgHdr->paProviders,       pVtgHdr->cbProviders,    1,   16, sizeof(VTGDESCPROVIDER));
     160    MY_VALIDATE_PTR(pVtgHdr->paProbes,          pVtgHdr->cbProbes,       1, _32K, sizeof(VTGDESCPROBE));
     161    MY_VALIDATE_PTR(pVtgHdr->pafProbeEnabled,   pVtgHdr->cbProbeEnabled, 1, _32K, sizeof(bool));
     162    MY_VALIDATE_PTR(pVtgHdr->pachStrTab,        pVtgHdr->cbStrTab,       4,  _1M,  sizeof(char));
     163    MY_VALIDATE_PTR(pVtgHdr->paArgLists,        pVtgHdr->cbArgLists,     0, _32K, sizeof(uint32_t));
     164#undef MY_VALIDATE_PTR
     165
     166    if (!RT_VALID_PTR(pVtgHdr->paProbLocs))
     167        return VERR_SUPDRV_VTG_BAD_PTR;
     168    if (!RT_VALID_PTR(pVtgHdr->paProbLocsEnd))
     169        return VERR_SUPDRV_VTG_BAD_PTR;
     170    if ((uintptr_t)pVtgHdr->paProbLocsEnd - (uintptr_t)pVtgHdr->paProbLocs < sizeof(VTGPROBELOC))
     171        return VERR_SUPDRV_VTG_TOO_FEW;
     172    if ((uintptr_t)pVtgHdr->paProbLocsEnd - (uintptr_t)pVtgHdr->paProbLocs > sizeof(VTGPROBELOC) * _128K)
     173        return VERR_SUPDRV_VTG_TOO_MUCH;
     174    if (   ((uintptr_t)pVtgHdr->paProbLocsEnd - (uintptr_t)pVtgHdr->paProbLocs)
     175           / sizeof(VTGPROBELOC) * sizeof(VTGPROBELOC)
     176        != (uintptr_t)pVtgHdr->paProbLocsEnd - (uintptr_t)pVtgHdr->paProbLocs)
     177        return VERR_SUPDRV_VTG_NOT_MULTIPLE;
     178    if (pbImage && cbImage)
     179    {
     180        if ((uintptr_t)pVtgHdr->paProbLocs - (uintptr_t)pbImage >= cbImage)
     181            return VERR_SUPDRV_VTG_BAD_PTR;
     182        if ((uintptr_t)pVtgHdr->paProbLocsEnd - (uintptr_t)pbImage > cbImage)
     183            return VERR_SUPDRV_VTG_BAD_PTR;
     184    }
     185
     186    /*
     187     * Validate the providers.
     188     */
     189
     190
     191    return VINF_SUCCESS;
     192}
     193
     194
     195/**
     196 * Registers the VTG tracepoint providers of a driver.
     197 * 
     198 * @returns VBox status code.
     199 * @param   pszName             The driver name.
     200 * @param   pVtgHdr             The VTG header.
     201 * @param   pImage              The image if applicable.
     202 * @param   pSession            The session if applicable.
     203 * @param   pszModName          The module name.
     204 */
     205static int supdrvVtgRegister(PSUPDRVDEVEXT pDevExt, PVTGOBJHDR pVtgHdr, PSUPDRVLDRIMAGE pImage, PSUPDRVSESSION pSession,
     206                             const char *pszModName)
     207{
     208    /*
     209     * Validate input.
     210     */
     211    AssertPtrReturn(pDevExt, VERR_INVALID_POINTER);
     212    AssertPtrReturn(pVtgHdr, VERR_INVALID_POINTER);
     213    AssertPtrNullReturn(pImage, VERR_INVALID_POINTER);
     214    AssertPtrNullReturn(pSession, VERR_INVALID_POINTER);
     215    AssertPtrReturn(pszModName, VERR_INVALID_POINTER);
     216    AssertReturn((pImage == NULL) != (pSession != NULL), VERR_INVALID_PARAMETER);
     217
     218
     219
     220    /*
     221     *
     222     */
     223
     224}
     225
     226
     227
     228/**
     229 * Registers the VTG tracepoint providers of a driver.
     230 * 
     231 * @returns VBox status code.
     232 * @param   pSession            The support driver session handle.
     233 * @param   pVtgHdr             The VTG header.
     234 * @param   pszName             The driver name.
     235 */
     236SUPR0DECL(int) SUPR0VtgRegisterDrv(PSUPDRVSESSION pSession, PVTGOBJHDR pVtgHdr, const char *pszName)
     237{
     238    AssertReturn(SUP_IS_SESSION_VALID(pSession), NULL);
     239    AssertPtrReturn(pszName, VERR_INVALID_POINTER);
     240    AssertPtrReturn(pVtgHdr, VERR_INVALID_POINTER);
     241
     242    return supdrvVtgRegister(pSession->pDevExt, pVtgHdr, NULL, pSession, pszName);
     243}
     244
     245
     246
     247/**
     248 * Deregister the VTG tracepoint providers of a driver.
     249 * 
     250 * @param   pSession            The support driver session handle.
     251 * @param   pVtgHdr             The VTG header.
     252 */
     253SUPR0DECL(void) SUPR0VtgDeregisterDrv(PSUPDRVSESSION pSession, PVTGOBJHDR pVtgHdr)
     254{
     255}
     256
     257
    86258
    87259/**
    88260 * Early module initialization hook.
    89  * 
     261 *
    90262 * @returns VBox status code.
    91263 * @param   pDevExt             The device extension structure.
     
    103275/**
    104276 * Late module termination hook.
    105  * 
     277 *
    106278 * @returns VBox status code.
    107279 * @param   pDevExt             The device extension structure.
     
    119291/**
    120292 * Module loading hook, called before calling into the module.
    121  * 
     293 *
    122294 * @returns VBox status code.
    123295 * @param   pDevExt             The device extension structure.
     
    126298{
    127299    /*
    128      * Check for DTrace probes in the module, register a new provider for them 
     300     * Check for DTrace probes in the module, register a new provider for them
    129301     * if found.
    130302     */
     
    135307
    136308/**
    137  * Module unloading hook, called after execution in the module 
     309 * Module unloading hook, called after execution in the module
    138310 * have ceased.
    139  * 
     311 *
    140312 * @returns VBox status code.
    141313 * @param   pDevExt             The device extension structure.
     
    143315int supdrvDTraceModuleUnloading(PSUPDRVDEVEXT pDevExt, PSUPDRVLDRIMAGE pImage)
    144316{
    145     /* 
     317    /*
    146318     * Undo what we did in supdrvDTraceModuleLoading.
    147319     */
     
    182354 * @callback_method_impl{dtrace_pops_t,dtps_getargdesc}
    183355 */
    184 static void     supdrvDTracePOps_GetArgDesc(void *pvProv, dtrace_id_t idProbe, void *pvProbe, 
     356static void     supdrvDTracePOps_GetArgDesc(void *pvProv, dtrace_id_t idProbe, void *pvProbe,
    185357                                            dtrace_argdesc_t *pArgDesc)
    186358{
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