VirtualBox

Changeset 82902 in vbox for trunk/src/VBox/Devices/testcase


Ignore:
Timestamp:
Jan 29, 2020 10:03:17 AM (5 years ago)
Author:
vboxsync
Message:

Devices/tstDevice: Working on restoring the old state of the device testbench

Location:
trunk/src/VBox/Devices/testcase
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Devices/testcase/tstDevice.cpp

    r82883 r82902  
    815815    "test",
    816816    "Testcase during implementation",
    817     "nvme",
     817    "serial",
    818818    0,
    819819    &s_aTestcaseCfg[0],
     
    849849        AssertRC(rc);
    850850
    851         PPDMDEVINS pDevIns = (PPDMDEVINS)RTMemAllocZ(RT_UOFFSETOF_DYN(PDMDEVINS, achInstanceData[pPdmDev->pReg->cbInstanceCC]));
     851        PPDMCRITSECT pCritSect;
     852        /* Figure out how much we need. */
     853        uint32_t cb = RT_UOFFSETOF_DYN(PDMDEVINS, achInstanceData[pPdmDev->pReg->cbInstanceCC]);
     854        cb  = RT_ALIGN_32(cb, 64);
     855        uint32_t const offShared   = cb;
     856        cb += RT_ALIGN_32(pPdmDev->pReg->cbInstanceShared, 64);
     857        uint32_t const cbCritSect  = RT_ALIGN_32(sizeof(*pCritSect), 64);
     858        cb += cbCritSect;
     859        uint32_t const cbMsixState = RT_ALIGN_32(pPdmDev->pReg->cMaxMsixVectors * 16 + (pPdmDev->pReg->cMaxMsixVectors + 7) / 8, _4K);
     860        uint32_t const cbPciDev    = RT_ALIGN_32(RT_UOFFSETOF_DYN(PDMPCIDEV, abMsixState[cbMsixState]), 64);
     861        uint32_t const cPciDevs    = RT_MIN(pPdmDev->pReg->cMaxPciDevices, 1024);
     862        uint32_t const cbPciDevs   = cbPciDev * cPciDevs;
     863        cb += cbPciDevs;
     864
     865        PPDMDEVINS pDevIns = (PPDMDEVINS)RTMemAllocZ(cb);
    852866        pDevIns->u32Version               = PDM_DEVINS_VERSION;
    853867        pDevIns->iInstance                = 0;
     
    857871        pDevIns->pCfg                     = &Cfg;
    858872        pDevIns->Internal.s.pDut          = &Dut;
     873        pDevIns->cbRing3                  = cb;
     874        //pDevIns->fR0Enabled             = false;
     875        //pDevIns->fRCEnabled             = false;
     876        pDevIns->pvInstanceDataR3         = (uint8_t *)pDevIns + offShared;
     877        pDevIns->pvInstanceDataForR3      = &pDevIns->achInstanceData[0];
     878        pCritSect = (PPDMCRITSECT)((uint8_t *)pDevIns + offShared + RT_ALIGN_32(pPdmDev->pReg->cbInstanceShared, 64));
     879        pDevIns->pCritSectRoR3            = pCritSect;
     880        pDevIns->cbPciDev                 = cbPciDev;
     881        pDevIns->cPciDevs                 = cPciDevs;
     882        for (uint32_t iPciDev = 0; iPciDev < cPciDevs; iPciDev++)
     883        {
     884            PPDMPCIDEV pPciDev = (PPDMPCIDEV)((uint8_t *)pDevIns->pCritSectRoR3 + cbCritSect + cbPciDev * iPciDev);
     885            if (iPciDev < RT_ELEMENTS(pDevIns->apPciDevs))
     886                pDevIns->apPciDevs[iPciDev] = pPciDev;
     887            pPciDev->cbConfig           = _4K;
     888            pPciDev->cbMsixState        = cbMsixState;
     889            pPciDev->idxSubDev          = (uint16_t)iPciDev;
     890            pPciDev->u32Magic           = PDMPCIDEV_MAGIC;
     891        }
     892
    859893        rc = pPdmDev->pReg->pfnConstruct(pDevIns, 0, &Cfg);
    860894        if (RT_SUCCESS(rc))
     
    892926            rc = tstDevPdmLoadMod(argv[1], TSTDEVPDMMODTYPE_R3);
    893927            if (RT_SUCCESS(rc))
    894                 rc = tstDevPdmDevCreate("nvme");
     928                rc = tstDevPdmDevCreate("serial");
    895929            else
    896930                rcExit = RTEXITCODE_FAILURE;
  • trunk/src/VBox/Devices/testcase/tstDeviceInternal.h

    r82883 r82902  
    2626#include <iprt/list.h>
    2727#include <iprt/semaphore.h>
     28#include <iprt/critsect.h>
    2829
    2930#include "tstDevicePlugin.h"
     
    8586} PDMPCIDEVINT;
    8687
     88
     89/**
     90 * Internal PDM critical section structure.
     91 */
     92typedef struct PDMCRITSECTINT
     93{
     94    /** The actual critical section used for emulation. */
     95    RTCRITSECT           CritSect;
     96} PDMCRITSECTINT;
     97AssertCompile(sizeof(PDMCRITSECTINT) <= (HC_ARCH_BITS == 32 ? 0x80 : 0xc0));
     98
     99
     100/**
     101 * MM Heap allocation.
     102 */
     103typedef struct TSTDEVMMHEAPALLOC
     104{
     105    /** Node for the list of allocations. */
     106    RTLISTNODE                      NdMmHeap;
     107    /** Pointer to the device under test the allocation was made for. */
     108    PTSTDEVDUTINT                   pDut;
     109    /** Size of the allocation. */
     110    size_t                          cbAlloc;
     111    /** Start of the real allocation. */
     112    uint8_t                         abAlloc[RT_FLEXIBLE_ARRAY];
     113} TSTDEVMMHEAPALLOC;
     114/** Pointer to a MM Heap allocation. */
     115typedef TSTDEVMMHEAPALLOC *PTSTDEVMMHEAPALLOC;
     116/** Pointer to a const MM Heap allocation. */
     117typedef const TSTDEVMMHEAPALLOC *PCTSTDEVMMHEAPALLOC;
     118
     119AssertCompileMemberAlignment(TSTDEVMMHEAPALLOC, abAlloc, HC_ARCH_BITS == 64 ? 16 : 8);
     120
     121
     122#define PDMCRITSECTINT_DECLARED
    87123#define PDMDEVINSINT_DECLARED
    88124#define PDMPCIDEVINT_DECLARED
     
    90126#define VMM_INCLUDED_SRC_include_VMMInternal_h
    91127RT_C_DECLS_END
     128#include <VBox/vmm/pdmcritsect.h>
    92129#include <VBox/vmm/pdmdev.h>
    93130#include <VBox/vmm/pdmpci.h>
    94131#include <VBox/vmm/pdmdrv.h>
     132#include <VBox/vmm/tm.h>
    95133RT_C_DECLS_BEGIN
     134
     135
     136/**
     137 * TM timer structure.
     138 */
     139typedef struct TMTIMER
     140{
     141    /** List of timers created by the device. */
     142    RTLISTNODE           NdDevTimers;
     143    /** Clock this timer belongs to. */
     144    TMCLOCK              enmClock;
     145    /** Callback to call when the timer expires. */
     146    PFNTMTIMERDEV        pfnCallbackDev;
     147    /** Opaque user data to pass to the callback. */
     148    void                 *pvUser;
     149    /** Flags. */
     150    uint32_t             fFlags;
     151    /** @todo: */
     152} TMTIMER;
    96153
    97154
  • trunk/src/VBox/Devices/testcase/tstDevicePdmDevHlp.cpp

    r82883 r82902  
    4343        AssertPtr(pDevIns); \
    4444        Assert(pDevIns->u32Version == PDM_DEVINS_VERSION); \
    45         Assert(pDevIns->CTX_SUFF(pvInstanceData) == (void *)&pDevIns->achInstanceData[0]); \
     45        Assert(pDevIns->CTX_SUFF(pvInstanceDataFor) == (void *)&pDevIns->achInstanceData[0]); \
    4646    } while (0)
    4747#else
     
    5050
    5151
     52/** Frequency of the real clock. */
     53#define TMCLOCK_FREQ_REAL       UINT32_C(1000)
     54/** Frequency of the virtual clock. */
     55#define TMCLOCK_FREQ_VIRTUAL    UINT32_C(1000000000)
     56
    5257/*********************************************************************************************************************************
    5358*   Structures and Typedefs                                                                                                      *
     
    6671*********************************************************************************************************************************/
    6772
     73
     74/**
     75 * Resolves a path reference to a configuration item.
     76 *
     77 * @returns VBox status code.
     78 * @param   paDevCfg        The array of config items.
     79 * @param   pszName         Name of a byte string value.
     80 * @param   ppItem          Where to store the pointer to the item.
     81 */
     82static int tstDev_CfgmR3ResolveItem(PCTSTDEVCFGITEM paDevCfg, const char *pszName, PCTSTDEVCFGITEM *ppItem)
     83{
     84    *ppItem = NULL;
     85    if (!paDevCfg)
     86        return VERR_CFGM_VALUE_NOT_FOUND;
     87
     88    size_t          cchName = strlen(pszName);
     89    PCTSTDEVCFGITEM pDevCfgItem = paDevCfg;
     90    while (pDevCfgItem->pszKey != NULL)
     91    {
     92        size_t cchKey = strlen(pDevCfgItem->pszKey);
     93        if (cchName == cchKey)
     94        {
     95            int iDiff = memcmp(pszName, pDevCfgItem->pszKey, cchName);
     96            if (iDiff <= 0)
     97            {
     98                if (iDiff != 0)
     99                    break;
     100                *ppItem = pDevCfgItem;
     101                return VINF_SUCCESS;
     102            }
     103        }
     104
     105        /* next */
     106        pDevCfgItem++;
     107    }
     108    return VERR_CFGM_VALUE_NOT_FOUND;
     109}
    68110
    69111
     
    11051147static DECLCALLBACK(uint64_t) pdmR3DevHlp_TimerGetFreq(PPDMDEVINS pDevIns, TMTIMERHANDLE hTimer)
    11061148{
    1107     RT_NOREF(pDevIns, hTimer);
    1108     AssertFailed();
    1109     return 0;
     1149    PDMDEV_ASSERT_DEVINS(pDevIns);
     1150
     1151    PTMTIMERR3 pTimer = (PTMTIMERR3)hTimer;
     1152    switch (pTimer->enmClock)
     1153    {
     1154        case TMCLOCK_VIRTUAL:
     1155        case TMCLOCK_VIRTUAL_SYNC:
     1156            return TMCLOCK_FREQ_VIRTUAL;
     1157
     1158        case TMCLOCK_REAL:
     1159            return TMCLOCK_FREQ_REAL;
     1160
     1161        default:
     1162            AssertMsgFailed(("Invalid enmClock=%d\n", pTimer->enmClock));
     1163            return 0;
     1164    }
    11101165}
    11111166
     
    13271382static DECLCALLBACK(int) pdmR3DevHlp_CFGMQuerySize(PCFGMNODE pNode, const char *pszName, size_t *pcb)
    13281383{
    1329     RT_NOREF(pNode, pszName, pcb);
    1330     AssertFailed();
    1331     return VERR_NOT_IMPLEMENTED;
     1384    if (!pNode)
     1385        return VERR_CFGM_NO_PARENT;
     1386
     1387    PCTSTDEVCFGITEM pCfgItem;
     1388    int rc = tstDev_CfgmR3ResolveItem(pNode->pDut->pTestcaseReg->paDevCfg, pszName, &pCfgItem);
     1389    if (RT_SUCCESS(rc))
     1390    {
     1391        switch (pCfgItem->enmType)
     1392        {
     1393            case TSTDEVCFGITEMTYPE_INTEGER:
     1394                *pcb = sizeof(uint64_t);
     1395                break;
     1396
     1397            case TSTDEVCFGITEMTYPE_STRING:
     1398                *pcb = strlen(pCfgItem->pszVal) + 1;
     1399                break;
     1400
     1401            case TSTDEVCFGITEMTYPE_BYTES:
     1402                AssertFailed();
     1403                break;
     1404
     1405            default:
     1406                rc = VERR_CFGM_IPE_1;
     1407                AssertMsgFailed(("Invalid value type %d\n", pCfgItem->enmType));
     1408                break;
     1409        }
     1410    }
     1411    return rc;
    13321412}
    13331413
     
    13351415static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryInteger(PCFGMNODE pNode, const char *pszName, uint64_t *pu64)
    13361416{
    1337     RT_NOREF(pNode, pszName, pu64);
    1338     AssertFailed();
    1339     return VERR_NOT_IMPLEMENTED;
     1417    if (!pNode)
     1418        return VERR_CFGM_NO_PARENT;
     1419
     1420    PCTSTDEVCFGITEM pCfgItem;
     1421    int rc = tstDev_CfgmR3ResolveItem(pNode->pDut->pTestcaseReg->paDevCfg, pszName, &pCfgItem);
     1422    if (RT_SUCCESS(rc))
     1423    {
     1424        if (pCfgItem->enmType == TSTDEVCFGITEMTYPE_INTEGER)
     1425            *pu64 = RTStrToUInt64(pCfgItem->pszVal);
     1426        else
     1427            rc = VERR_CFGM_NOT_INTEGER;
     1428    }
     1429
     1430    return rc;
    13401431}
    13411432
     
    13431434static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryIntegerDef(PCFGMNODE pNode, const char *pszName, uint64_t *pu64, uint64_t u64Def)
    13441435{
    1345     RT_NOREF(pNode, pszName, pu64, u64Def);
    1346     AssertFailed();
    1347     return VERR_NOT_IMPLEMENTED;
     1436    int rc = pdmR3DevHlp_CFGMQueryInteger(pNode, pszName, pu64);
     1437    if (RT_FAILURE(rc))
     1438    {
     1439        *pu64 = u64Def;
     1440        if (rc == VERR_CFGM_VALUE_NOT_FOUND || rc == VERR_CFGM_NO_PARENT)
     1441            rc = VINF_SUCCESS;
     1442    }
     1443
     1444    return rc;
    13481445}
    13491446
     
    13511448static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryString(PCFGMNODE pNode, const char *pszName, char *pszString, size_t cchString)
    13521449{
    1353     RT_NOREF(pNode, pszName, pszString, cchString);
    1354     AssertFailed();
    1355     return VERR_NOT_IMPLEMENTED;
     1450    if (!pNode)
     1451        return VERR_CFGM_NO_PARENT;
     1452
     1453    PCTSTDEVCFGITEM pCfgItem;
     1454    int rc = tstDev_CfgmR3ResolveItem(pNode->pDut->pTestcaseReg->paDevCfg, pszName, &pCfgItem);
     1455    if (RT_SUCCESS(rc))
     1456    {
     1457        switch (pCfgItem->enmType)
     1458        {
     1459            case TSTDEVCFGITEMTYPE_STRING:
     1460            {
     1461                size_t cchVal = strlen(pCfgItem->pszVal);
     1462                if (cchString <= cchVal + 1)
     1463                    memcpy(pszString, pCfgItem->pszVal, cchVal);
     1464                else
     1465                    rc = VERR_CFGM_NOT_ENOUGH_SPACE;
     1466                break;
     1467            }
     1468            case TSTDEVCFGITEMTYPE_INTEGER:
     1469            case TSTDEVCFGITEMTYPE_BYTES:
     1470            default:
     1471                rc = VERR_CFGM_IPE_1;
     1472                AssertMsgFailed(("Invalid value type %d\n", pCfgItem->enmType));
     1473                break;
     1474        }
     1475    }
     1476    else
     1477        rc = VERR_CFGM_VALUE_NOT_FOUND;
     1478
     1479    return rc;
    13561480}
    13571481
     
    13591483static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryStringDef(PCFGMNODE pNode, const char *pszName, char *pszString, size_t cchString, const char *pszDef)
    13601484{
    1361     RT_NOREF(pNode, pszName, pszString, cchString, pszDef);
    1362     AssertFailed();
    1363     return VERR_NOT_IMPLEMENTED;
     1485    int rc = pdmR3DevHlp_CFGMQueryString(pNode, pszName, pszString, cchString);
     1486    if (RT_FAILURE(rc) && rc != VERR_CFGM_NOT_ENOUGH_SPACE)
     1487    {
     1488        size_t cchDef = strlen(pszDef);
     1489        if (cchString > cchDef)
     1490        {
     1491            memcpy(pszString, pszDef, cchDef);
     1492            memset(pszString + cchDef, 0, cchString - cchDef);
     1493            if (rc == VERR_CFGM_VALUE_NOT_FOUND || rc == VERR_CFGM_NO_PARENT)
     1494                rc = VINF_SUCCESS;
     1495        }
     1496        else if (rc == VERR_CFGM_VALUE_NOT_FOUND || rc == VERR_CFGM_NO_PARENT)
     1497            rc = VERR_CFGM_NOT_ENOUGH_SPACE;
     1498    }
     1499
     1500    return rc;
    13641501}
    13651502
     
    13751512static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryU64(PCFGMNODE pNode, const char *pszName, uint64_t *pu64)
    13761513{
    1377     RT_NOREF(pNode, pszName, pu64);
    1378     AssertFailed();
    1379     return VERR_NOT_IMPLEMENTED;
     1514    return pdmR3DevHlp_CFGMQueryInteger(pNode, pszName, pu64);
    13801515}
    13811516
     
    13831518static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryU64Def(PCFGMNODE pNode, const char *pszName, uint64_t *pu64, uint64_t u64Def)
    13841519{
    1385     RT_NOREF(pNode, pszName, pu64, u64Def);
    1386     AssertFailed();
    1387     return VERR_NOT_IMPLEMENTED;
     1520    return pdmR3DevHlp_CFGMQueryIntegerDef(pNode, pszName, pu64, u64Def);
    13881521}
    13891522
     
    14071540static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryU32(PCFGMNODE pNode, const char *pszName, uint32_t *pu32)
    14081541{
    1409     RT_NOREF(pNode, pszName, pu32);
    1410     AssertFailed();
    1411     return VERR_NOT_IMPLEMENTED;
     1542    uint64_t u64;
     1543    int rc = pdmR3DevHlp_CFGMQueryInteger(pNode, pszName, &u64);
     1544    if (RT_SUCCESS(rc))
     1545    {
     1546        if (!(u64 & UINT64_C(0xffffffff00000000)))
     1547            *pu32 = (uint32_t)u64;
     1548        else
     1549            rc = VERR_CFGM_INTEGER_TOO_BIG;
     1550    }
     1551    return rc;
    14121552}
    14131553
     
    14151555static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryU32Def(PCFGMNODE pNode, const char *pszName, uint32_t *pu32, uint32_t u32Def)
    14161556{
    1417     RT_NOREF(pNode, pszName, pu32, u32Def);
    1418     AssertFailed();
    1419     return VERR_NOT_IMPLEMENTED;
     1557    uint64_t u64;
     1558    int rc = pdmR3DevHlp_CFGMQueryIntegerDef(pNode, pszName, &u64, u32Def);
     1559    if (RT_SUCCESS(rc))
     1560    {
     1561        if (!(u64 & UINT64_C(0xffffffff00000000)))
     1562            *pu32 = (uint32_t)u64;
     1563        else
     1564            rc = VERR_CFGM_INTEGER_TOO_BIG;
     1565    }
     1566    if (RT_FAILURE(rc))
     1567        *pu32 = u32Def;
     1568    return rc;
    14201569}
    14211570
     
    14231572static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryS32(PCFGMNODE pNode, const char *pszName, int32_t *pi32)
    14241573{
    1425     RT_NOREF(pNode, pszName, pi32);
    1426     AssertFailed();
    1427     return VERR_NOT_IMPLEMENTED;
     1574    uint64_t u64;
     1575    int rc = pdmR3DevHlp_CFGMQueryInteger(pNode, pszName, &u64);
     1576    if (RT_SUCCESS(rc))
     1577    {
     1578        if (   !(u64 & UINT64_C(0xffffffff80000000))
     1579            ||  (u64 & UINT64_C(0xffffffff80000000)) == UINT64_C(0xffffffff80000000))
     1580            *pi32 = (int32_t)u64;
     1581        else
     1582            rc = VERR_CFGM_INTEGER_TOO_BIG;
     1583    }
     1584    return rc;
    14281585}
    14291586
     
    14311588static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryS32Def(PCFGMNODE pNode, const char *pszName, int32_t *pi32, int32_t i32Def)
    14321589{
    1433     RT_NOREF(pNode, pszName, pi32, i32Def);
    1434     AssertFailed();
    1435     return VERR_NOT_IMPLEMENTED;
     1590    uint64_t u64;
     1591    int rc = pdmR3DevHlp_CFGMQueryIntegerDef(pNode, pszName, &u64, i32Def);
     1592    if (RT_SUCCESS(rc))
     1593    {
     1594        if (   !(u64 & UINT64_C(0xffffffff80000000))
     1595            ||  (u64 & UINT64_C(0xffffffff80000000)) == UINT64_C(0xffffffff80000000))
     1596            *pi32 = (int32_t)u64;
     1597        else
     1598            rc = VERR_CFGM_INTEGER_TOO_BIG;
     1599    }
     1600    if (RT_FAILURE(rc))
     1601        *pi32 = i32Def;
     1602    return rc;
    14361603}
    14371604
     
    14391606static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryU16(PCFGMNODE pNode, const char *pszName, uint16_t *pu16)
    14401607{
    1441     RT_NOREF(pNode, pszName, pu16);
    1442     AssertFailed();
    1443     return VERR_NOT_IMPLEMENTED;
     1608    uint64_t u64;
     1609    int rc = pdmR3DevHlp_CFGMQueryInteger(pNode, pszName, &u64);
     1610    if (RT_SUCCESS(rc))
     1611    {
     1612        if (!(u64 & UINT64_C(0xffffffffffff0000)))
     1613            *pu16 = (int16_t)u64;
     1614        else
     1615            rc = VERR_CFGM_INTEGER_TOO_BIG;
     1616    }
     1617    return rc;
    14441618}
    14451619
     
    14471621static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryU16Def(PCFGMNODE pNode, const char *pszName, uint16_t *pu16, uint16_t u16Def)
    14481622{
    1449     RT_NOREF(pNode, pszName, pu16, u16Def);
    1450     AssertFailed();
    1451     return VERR_NOT_IMPLEMENTED;
     1623    uint64_t u64;
     1624    int rc = pdmR3DevHlp_CFGMQueryIntegerDef(pNode, pszName, &u64, u16Def);
     1625    if (RT_SUCCESS(rc))
     1626    {
     1627        if (!(u64 & UINT64_C(0xffffffffffff0000)))
     1628            *pu16 = (int16_t)u64;
     1629        else
     1630            rc = VERR_CFGM_INTEGER_TOO_BIG;
     1631    }
     1632    if (RT_FAILURE(rc))
     1633        *pu16 = u16Def;
     1634    return rc;
    14521635}
    14531636
     
    14711654static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryU8(PCFGMNODE pNode, const char *pszName, uint8_t *pu8)
    14721655{
    1473     RT_NOREF(pNode, pszName, pu8);
    1474     AssertFailed();
    1475     return VERR_NOT_IMPLEMENTED;
     1656    uint64_t u64;
     1657    int rc = pdmR3DevHlp_CFGMQueryInteger(pNode, pszName, &u64);
     1658    if (RT_SUCCESS(rc))
     1659    {
     1660        if (!(u64 & UINT64_C(0xffffffffffffff00)))
     1661            *pu8 = (uint8_t)u64;
     1662        else
     1663            rc = VERR_CFGM_INTEGER_TOO_BIG;
     1664    }
     1665    return rc;
    14761666}
    14771667
     
    14791669static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryU8Def(PCFGMNODE pNode, const char *pszName, uint8_t *pu8, uint8_t u8Def)
    14801670{
    1481     RT_NOREF(pNode, pszName, pu8, u8Def);
    1482     AssertFailed();
    1483     return VERR_NOT_IMPLEMENTED;
     1671    uint64_t u64;
     1672    int rc = pdmR3DevHlp_CFGMQueryIntegerDef(pNode, pszName, &u64, u8Def);
     1673    if (RT_SUCCESS(rc))
     1674    {
     1675        if (!(u64 & UINT64_C(0xffffffffffffff00)))
     1676            *pu8 = (uint8_t)u64;
     1677        else
     1678            rc = VERR_CFGM_INTEGER_TOO_BIG;
     1679    }
     1680    if (RT_FAILURE(rc))
     1681        *pu8 = u8Def;
     1682    return rc;
    14841683}
    14851684
     
    15031702static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryBool(PCFGMNODE pNode, const char *pszName, bool *pf)
    15041703{
    1505     RT_NOREF(pNode, pszName, pf);
    1506     AssertFailed();
    1507     return VERR_NOT_IMPLEMENTED;
     1704    uint64_t u64;
     1705    int rc = pdmR3DevHlp_CFGMQueryInteger(pNode, pszName, &u64);
     1706    if (RT_SUCCESS(rc))
     1707        *pf = u64 ? true : false;
     1708    return rc;
    15081709}
    15091710
     
    15111712static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryBoolDef(PCFGMNODE pNode, const char *pszName, bool *pf, bool fDef)
    15121713{
    1513     RT_NOREF(pNode, pszName, pf, fDef);
    1514     AssertFailed();
    1515     return VERR_NOT_IMPLEMENTED;
     1714    uint64_t u64;
     1715    int rc = pdmR3DevHlp_CFGMQueryIntegerDef(pNode, pszName, &u64, fDef);
     1716    *pf = u64 ? true : false;
     1717    return rc;
    15161718}
    15171719
     
    15271729static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryPortDef(PCFGMNODE pNode, const char *pszName, PRTIOPORT pPort, RTIOPORT PortDef)
    15281730{
    1529     RT_NOREF(pNode, pszName, pPort, PortDef);
    1530     AssertFailed();
    1531     return VERR_NOT_IMPLEMENTED;
     1731    AssertCompileSize(RTIOPORT, 2);
     1732    return pdmR3DevHlp_CFGMQueryU16Def(pNode, pszName, pPort, PortDef);
    15321733}
    15331734
     
    15671768static DECLCALLBACK(int) pdmR3DevHlp_CFGMQueryPtr(PCFGMNODE pNode, const char *pszName, void **ppv)
    15681769{
    1569     RT_NOREF(pNode, pszName, ppv);
    1570     AssertFailed();
    1571     return VERR_NOT_IMPLEMENTED;
     1770    uint64_t u64;
     1771    int rc = pdmR3DevHlp_CFGMQueryInteger(pNode, pszName, &u64);
     1772    if (RT_SUCCESS(rc))
     1773    {
     1774        uintptr_t u = (uintptr_t)u64;
     1775        if (u64 == u)
     1776            *ppv = (void *)u;
     1777        else
     1778            rc = VERR_CFGM_INTEGER_TOO_BIG;
     1779    }
     1780    return rc;
    15721781}
    15731782
     
    17591968static DECLCALLBACK(bool) pdmR3DevHlp_CFGMAreValuesValid(PCFGMNODE pNode, const char *pszzValid)
    17601969{
    1761     RT_NOREF(pNode, pszzValid);
    1762     AssertFailed();
    1763     return false;
     1970    if (pNode && pNode->pDut->pTestcaseReg->paDevCfg)
     1971    {
     1972        PCTSTDEVCFGITEM pDevCfgItem = pNode->pDut->pTestcaseReg->paDevCfg;
     1973        while (pDevCfgItem->pszKey != NULL)
     1974        {
     1975            size_t cchKey = strlen(pDevCfgItem->pszKey);
     1976
     1977            /* search pszzValid for the name */
     1978            const char *psz = pszzValid;
     1979            while (*psz)
     1980            {
     1981                size_t cch = strlen(psz);
     1982                if (    cch == cchKey
     1983                    &&  !memcmp(psz, pDevCfgItem->pszKey, cch))
     1984                    break;
     1985
     1986                /* next */
     1987                psz += cch + 1;
     1988            }
     1989
     1990            /* if at end of pszzValid we didn't find it => failure */
     1991            if (!*psz)
     1992                return false;
     1993
     1994            pDevCfgItem++;
     1995        }
     1996    }
     1997
     1998    return true;
    17641999}
    17652000
     
    17702005{
    17712006    RT_NOREF(pNode, pszNode, pszValidValues, pszValidNodes, pszWho, uInstance);
    1772     AssertFailed();
    1773     return VERR_NOT_IMPLEMENTED;
     2007#if 1
     2008    return VINF_SUCCESS;
     2009#else
     2010    AssertFailed();
     2011    return VERR_NOT_IMPLEMENTED;
     2012#endif
    17742013}
    17752014
     
    20622301    LogFlow(("pdmR3DevHlp_MMHeapFree: caller='%s'/%d: pv=%p\n", pDevIns->pReg->szName, pDevIns->iInstance, pv));
    20632302
    2064     AssertFailed();
     2303    PTSTDEVMMHEAPALLOC pHeapAlloc = (PTSTDEVMMHEAPALLOC)((uint8_t *)pv - RT_UOFFSETOF(TSTDEVMMHEAPALLOC, abAlloc[0]));
     2304    PTSTDEVDUTINT pThis = pHeapAlloc->pDut;
     2305
     2306    tstDevDutLockExcl(pThis);
     2307    RTListNodeRemove(&pHeapAlloc->NdMmHeap);
     2308    tstDevDutUnlockExcl(pThis);
     2309
     2310    /* Poison */
     2311    memset(&pHeapAlloc->abAlloc[0], 0xfc, pHeapAlloc->cbAlloc);
     2312    RTMemFree(pHeapAlloc);
    20652313
    20662314    LogFlow(("pdmR3DevHlp_MMHeapAlloc: caller='%s'/%d: returns void\n", pDevIns->pReg->szName, pDevIns->iInstance));
     
    31023350    PDMDEV_ASSERT_DEVINS(pDevIns);
    31033351
    3104     RT_NOREF(pDevIns, pCritSect, rcBusy, uId, RT_SRC_POS_ARGS);
    3105     int rc = VERR_NOT_IMPLEMENTED;
    3106     AssertFailed();
    3107     return rc;
     3352    RT_NOREF(pDevIns, rcBusy, uId, RT_SRC_POS_ARGS);
     3353    return RTCritSectEnter(&pCritSect->s.CritSect);
    31083354}
    31093355
     
    31383384    PDMDEV_ASSERT_DEVINS(pDevIns);
    31393385
    3140     RT_NOREF(pDevIns, pCritSect);
    3141     int rc = VERR_NOT_IMPLEMENTED;
    3142     AssertFailed();
    3143     return rc;
     3386    return RTCritSectLeave(&pCritSect->s.CritSect);
    31443387}
    31453388
     
    31503393    PDMDEV_ASSERT_DEVINS(pDevIns);
    31513394
    3152     RT_NOREF(pDevIns, pCritSect);
    3153     AssertFailed();
    3154     return false;
     3395    return RTCritSectIsOwner(&pCritSect->s.CritSect);
    31553396}
    31563397
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