VirtualBox

Changeset 35663 in vbox for trunk


Ignore:
Timestamp:
Jan 20, 2011 9:00:56 PM (14 years ago)
Author:
vboxsync
Message:

Storage/tstVDIo: Random I/O access mode and dumpfile command

Location:
trunk/src/VBox/Storage/testcase
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Storage/testcase/VDIoBackendMem.cpp

    r35596 r35663  
    149149        return VERR_NO_MEMORY;
    150150
    151     Assert(cbData == sizeof(VDIOBACKENDREQ));
     151    Assert(cbData == (size_t)RT_OFFSETOF(VDIOBACKENDREQ, aSegs[cSegs]));
    152152    pReq->enmTxDir    = enmTxDir;
    153153    pReq->cbTransfer  = cbTransfer;
     
    162162        pReq->aSegs[i].cbSeg = paSegs[i].cbSeg;
    163163    }
    164     RTCircBufReleaseWriteBlock(pIoBackend->pRequestRing, sizeof(VDIOBACKENDREQ));
     164    RTCircBufReleaseWriteBlock(pIoBackend->pRequestRing, RT_OFFSETOF(VDIOBACKENDREQ, aSegs[cSegs]));
    165165    vdIoBackendMemThreadPoke(pIoBackend);
    166166
  • trunk/src/VBox/Storage/testcase/tstVDIo.cpp

    r35597 r35663  
    126126    /** Number of bytes to transfer. */
    127127    size_t      cbIo;
     128    /** Chance in percent to get a write. */
    128129    unsigned    uWriteChance;
     130    /** Pointer to the I/O data generator. */
    129131    PVDIORND    pIoRnd;
    130     uint64_t    offNext;
     132    /** Data dependent on the I/O mode (sequential or random). */
     133    union
     134    {
     135        /** Next offset for seuential access. */
     136        uint64_t    offNext;
     137        /** Data for random acess. */
     138        struct
     139        {
     140            /** Number of valid entries in the bitmap. */
     141            uint32_t cBlocks;
     142            /** Pointer to the bitmap marking accessed blocks. */
     143            uint8_t *pbMapAccessed;
     144        } Rnd;
     145    } u;
    131146} VDIOTEST, *PVDIOTEST;
    132147
     
    230245static DECLCALLBACK(int) vdScriptHandlerIoRngDestroy(PVDTESTGLOB pGlob, PVDSCRIPTARG paScriptArgs, unsigned cScriptArgs);
    231246static DECLCALLBACK(int) vdScriptHandlerSleep(PVDTESTGLOB pGlob, PVDSCRIPTARG paScriptArgs, unsigned cScriptArgs);
     247static DECLCALLBACK(int) vdScriptHandlerDumpFile(PVDTESTGLOB pGlob, PVDSCRIPTARG paScriptArgs, unsigned cScriptArgs);
    232248
    233249/* create action */
     
    300316};
    301317
     318/* Dump memory file */
     319const VDSCRIPTARGDESC g_aArgDumpFile[] =
     320{
     321    /* pcszName  chId enmType                            fFlags */
     322    {"file",     'f', VDSCRIPTARGTYPE_STRING,            VDSCRIPTARGDESC_FLAG_MANDATORY},
     323    {"path",     'p', VDSCRIPTARGTYPE_STRING,            VDSCRIPTARGDESC_FLAG_MANDATORY},
     324};
     325
    302326const VDSCRIPTACTION g_aScriptActions[] =
    303327{
     
    312336    {"iorngdestroy", NULL,                0,                               vdScriptHandlerIoRngDestroy},
    313337    {"sleep",        g_aArgSleep,         RT_ELEMENTS(g_aArgSleep),        vdScriptHandlerSleep},
     338    {"dumpfile",     g_aArgDumpFile,      RT_ELEMENTS(g_aArgDumpFile),     vdScriptHandlerDumpFile}
    314339};
    315340
     
    335360                           unsigned uWriteChance, unsigned uReadChance);
    336361static bool tstVDIoTestRunning(PVDIOTEST pIoTest);
     362static void tstVDIoTestDestroy(PVDIOTEST pIoTest);
    337363static bool tstVDIoTestReqOutstanding(PVDIOREQ pIoReq);
    338364static int  tstVDIoTestReqInit(PVDIOTEST pIoTest, PVDIOREQ pIoReq);
     
    659685            else
    660686                rc = VERR_NO_MEMORY;
     687
     688            tstVDIoTestDestroy(&IoTest);
    661689        }
    662690    }
     
    816844}
    817845
     846static DECLCALLBACK(int) vdScriptHandlerDumpFile(PVDTESTGLOB pGlob, PVDSCRIPTARG paScriptArgs, unsigned cScriptArgs)
     847{
     848    int rc = VINF_SUCCESS;
     849    const char *pcszFile = NULL;
     850    const char *pcszPathToDump = NULL;
     851
     852    for (unsigned i = 0; i < cScriptArgs; i++)
     853    {
     854        switch (paScriptArgs[i].chId)
     855        {
     856            case 'f':
     857            {
     858                pcszFile = paScriptArgs[i].u.pcszString;
     859                break;
     860            }
     861            case 'p':
     862            {
     863                pcszPathToDump = paScriptArgs[i].u.pcszString;
     864                break;
     865            }
     866            default:
     867                AssertMsgFailed(("Invalid argument given!\n"));
     868        }
     869    }
     870
     871    /* Check for the file. */
     872    PVDFILE pIt = NULL;
     873    bool fFound = false;
     874    RTListForEach(&pGlob->ListFiles, pIt, VDFILE, Node)
     875    {
     876        if (!RTStrCmp(pIt->pszName, pcszFile))
     877        {
     878            fFound = true;
     879            break;
     880        }
     881    }
     882
     883    if (fFound)
     884    {
     885        RTPrintf("Dumping memory file %s to %s, this might take some time\n", pcszFile, pcszPathToDump);
     886        rc = VDMemDiskWriteToFile(pIt->pMemDisk, pcszPathToDump);
     887    }
     888    else
     889        rc = VERR_FILE_NOT_FOUND;
     890
     891    return rc;
     892}
     893
    818894static DECLCALLBACK(int) tstVDIoFileOpen(void *pvUser, const char *pszLocation,
    819895                                         uint32_t fOpen,
     
    10911167                           unsigned uWriteChance, unsigned uReadChance)
    10921168{
     1169    int rc = VINF_SUCCESS;
     1170
    10931171    pIoTest->fRandomAccess = fRandomAcc;
    10941172    pIoTest->cbIo          = cbIo;
     
    10981176    pIoTest->uWriteChance  = uWriteChance;
    10991177    pIoTest->pIoRnd        = pGlob->pIoRnd;
    1100     pIoTest->offNext       = pIoTest->offEnd < pIoTest->offStart ? pIoTest->offEnd - cbBlkSize : 0;
    1101     return VINF_SUCCESS;
     1178    if (fRandomAcc)
     1179    {
     1180        pIoTest->u.Rnd.cBlocks = cbIo / cbBlkSize + ((cbIo % cbBlkSize) ? 1 : 0);
     1181        pIoTest->u.Rnd.pbMapAccessed = (uint8_t *)RTMemAllocZ(pIoTest->u.Rnd.cBlocks / 8
     1182                                                              + ((pIoTest->u.Rnd.cBlocks % 8)
     1183                                                                ? 1
     1184                                                                : 0));
     1185        if (!pIoTest->u.Rnd.pbMapAccessed)
     1186            rc = VERR_NO_MEMORY;
     1187    }
     1188    else
     1189        pIoTest->u.offNext = pIoTest->offEnd < pIoTest->offStart ? pIoTest->offEnd - cbBlkSize : 0;
     1190
     1191    return rc;
     1192}
     1193
     1194static void tstVDIoTestDestroy(PVDIOTEST pIoTest)
     1195{
     1196    if (pIoTest->fRandomAccess)
     1197        RTMemFree(pIoTest->u.Rnd.pbMapAccessed);
    11021198}
    11031199
     
    11361232        pIoTest->cbIo -= pIoReq->cbReq;
    11371233        pIoReq->DataSeg.cbSeg = pIoReq->cbReq;
    1138         pIoReq->off           = pIoTest->offNext;
    11391234
    11401235        if (pIoReq->enmTxDir == VDIOREQTXDIR_WRITE)
     
    11571252            if (pIoTest->fRandomAccess)
    11581253            {
    1159                 /** @todo */
     1254                int idx = -1;
     1255
     1256                idx = ASMBitFirstClear(pIoTest->u.Rnd.pbMapAccessed, pIoTest->u.Rnd.cBlocks);
     1257
     1258                /* In case this is the last request we don't need to search further. */
     1259                if (pIoTest->cbIo > 0)
     1260                {
     1261                    int idxIo;
     1262                    idxIo = VDIoRndGetU32Ex(pIoTest->pIoRnd, idx, pIoTest->u.Rnd.cBlocks - 1);
     1263
     1264                    /*
     1265                     * If the bit is marked free use it, otherwise search for the next free bit
     1266                     * and if that doesn't work use the first free bit.
     1267                     */
     1268                    if (ASMBitTest(pIoTest->u.Rnd.pbMapAccessed, idxIo))
     1269                    {
     1270                        idxIo = ASMBitNextClear(pIoTest->u.Rnd.pbMapAccessed, pIoTest->u.Rnd.cBlocks, idxIo);
     1271                        if (idxIo != -1)
     1272                            idx = idxIo;
     1273                    }
     1274                    else
     1275                        idx = idxIo;
     1276                }
     1277
     1278                Assert(idx != -1);
     1279                pIoReq->off = idx * pIoTest->cbBlkIo;
     1280                ASMBitSet(pIoTest->u.Rnd.pbMapAccessed, idx);
    11601281            }
    11611282            else
    11621283            {
    1163                 pIoTest->offNext = pIoTest->offEnd < pIoTest->offStart
    1164                                    ? RT_MAX(pIoTest->offEnd, pIoTest->offNext - pIoTest->cbBlkIo)
    1165                                    : RT_MIN(pIoTest->offEnd, pIoTest->offNext + pIoTest->cbBlkIo);
     1284                pIoReq->off        = pIoTest->u.offNext;
     1285                pIoTest->u.offNext = pIoTest->offEnd < pIoTest->offStart
     1286                                     ? RT_MAX(pIoTest->offEnd, pIoTest->u.offNext - pIoTest->cbBlkIo)
     1287                                     : RT_MIN(pIoTest->offEnd, pIoTest->u.offNext + pIoTest->cbBlkIo);
    11661288            }
    11671289            pIoReq->fOutstanding = true;
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