Exemplo n.º 1
0
void
UnsupportRsvdFields_r10b::VerifyDataPat(SharedReadPtr readCmd,
    SharedWritePtr writeCmd)
{
    LOG_NRM("Compare read vs written data to verify");
    SharedMemBufferPtr rdPayload = readCmd->GetRWPrpBuffer();
    SharedMemBufferPtr wrPayload = writeCmd->GetRWPrpBuffer();
    if (rdPayload->Compare(wrPayload) == false) {
        readCmd->Dump(
            FileSystem::PrepDumpFile(mGrpName, mTestName, "ReadCmd"),
            "Read command");
        writeCmd->Dump(
            FileSystem::PrepDumpFile(mGrpName, mTestName, "WriteCmd"),
            "Write command");
        throw FrmwkEx(HERE, "Data miscompare");
    }

    // If meta data is allocated then compare meta data.
    if (writeCmd->GetMetaBuffer() != NULL) {
        const uint8_t *metaRdBuff = readCmd->GetMetaBuffer();
        const uint8_t *metaWrBuff = writeCmd->GetMetaBuffer();
        if (memcmp(metaRdBuff, metaWrBuff, writeCmd->GetMetaBufferSize())) {
            readCmd->Dump(
                FileSystem::PrepDumpFile(mGrpName, mTestName, "ReadCmdMeta"),
                "Read command with meta data");
            writeCmd->Dump(
                FileSystem::PrepDumpFile(mGrpName, mTestName, "WriteCmdMeta"),
                "Write command with meta data");
            throw FrmwkEx(HERE, "Meta data miscompare");
        }
    }
}
Exemplo n.º 2
0
void
FunctionalityMeta_r10b::VerifyDataPat(SharedReadPtr readCmd,
    SharedWritePtr writeCmd, uint64_t metaBuffSz)
{
    LOG_NRM("Compare read vs written data to verify");
    SharedMemBufferPtr rdPayload = readCmd->GetRWPrpBuffer();
    SharedMemBufferPtr wrPayload = writeCmd->GetRWPrpBuffer();
    if (rdPayload->Compare(wrPayload) == false) {
        readCmd->Dump(
            FileSystem::PrepDumpFile(mGrpName, mTestName, "ReadCmd"),
            "Read command");
        rdPayload->Dump(
            FileSystem::PrepDumpFile(mGrpName, mTestName, "ReadPayload"),
            "Data read from media miscompared from written");
        wrPayload->Dump(
            FileSystem::PrepDumpFile(mGrpName, mTestName, "WrittenPayload"),
            "Data read from media miscompared from written");
        throw FrmwkEx(HERE, "Data miscompare");
    }

    // If meta data is allocated then compare meta data.
    if (writeCmd->GetMetaBuffer() != NULL) {
        const uint8_t *metaRdBuff = readCmd->GetMetaBuffer();
        const uint8_t *metaWrBuff = writeCmd->GetMetaBuffer();
        if (memcmp(metaRdBuff, metaWrBuff, metaBuffSz)) {
            readCmd->Dump(
                FileSystem::PrepDumpFile(mGrpName, mTestName, "ReadCmdMeta"),
                "Read command with meta data");
            writeCmd->Dump(
                FileSystem::PrepDumpFile(mGrpName, mTestName, "WriteCmdMeta"),
                "Write command with meta data");
            throw FrmwkEx(HERE, "Meta data miscompare, Meta Sz %d", metaBuffSz);
        }
    }
}
void
PRPOffsetDualPgMultiBlk_r10b::VerifyDataPat(SharedReadPtr readCmd,
    DataPattern dataPat, uint64_t wrVal, uint64_t metabufSz)
{
    LOG_NRM("Compare read vs written data to verify");
    SharedMemBufferPtr wrPayload = SharedMemBufferPtr(new MemBuffer());
    wrPayload->Init(readCmd->GetPrpBufferSize());
    wrPayload->SetDataPattern(dataPat, wrVal);

    SharedMemBufferPtr rdPayload = readCmd->GetRWPrpBuffer();
    if (rdPayload->Compare(wrPayload) == false) {
        rdPayload->Dump(
            FileSystem::PrepDumpFile(mGrpName, mTestName, "ReadPayload"),
            "Data read from media miscompared from written");
        wrPayload->Dump(
            FileSystem::PrepDumpFile(mGrpName, mTestName, "WrittenPayload"),
            "Data read from media miscompared from written");
        throw FrmwkEx(HERE, "Data miscompare");
    }

    if (readCmd->GetMetaBuffer() != NULL) {
        SharedMemBufferPtr metaWrPayload = SharedMemBufferPtr(new MemBuffer());
        metaWrPayload->Init(metabufSz);
        metaWrPayload->SetDataPattern(dataPat, wrVal);

        if (readCmd->CompareMetaBuffer(metaWrPayload) == false) {
            readCmd->Dump(
                FileSystem::PrepDumpFile(mGrpName, mTestName, "MetaRdPayload"),
                "Meta Data read from media miscompared from written");
            metaWrPayload->Dump(
                FileSystem::PrepDumpFile(mGrpName, mTestName, "MetaWrPayload"),
                "Meta Data read from media miscompared from written");
            throw FrmwkEx(HERE, "Meta Data miscompare");
        }
    }
}
void
PRPOffsetSinglePgSingleBlk_r10b::VerifyDataPattern(SharedReadPtr readCmd,
    DataPattern dataPattern, uint64_t wrVal)
{
    LOG_NRM("Compare read vs written data to verify");
    uint16_t mWrVal = (uint16_t)wrVal;
    if (dataPattern == DATAPAT_INC_16BIT) {
        const uint16_t *rdBuffPtr = (const uint16_t *)readCmd->GetROPrpBuffer();
        for (uint64_t i = 0; i <
            (readCmd->GetPrpBufferSize() / sizeof(uint16_t)); i++) {
            if (*rdBuffPtr++ != mWrVal++) {
                readCmd->Dump(
                    FileSystem::PrepDumpFile(mGrpName, mTestName,
                    "ReadPayload"),
                    "Data read from media miscompared from written");
                throw FrmwkEx(HERE, "Read data mismatch for 16bit inc prp data "
                    "read ptr: 0x%08X, read value: 0x%02X, write value: 0x%02X",
                    rdBuffPtr, *rdBuffPtr, mWrVal);
            }
        }
        // Check if meta data exists and then compare meta buffer data.
        const uint16_t *rdMetaPtr = (const uint16_t *)readCmd->GetMetaBuffer();
        mWrVal = (uint16_t)wrVal;
        if (rdMetaPtr) {
            LOG_NRM("Compare read vs written meta data to verify");
            for (uint64_t i = 0; i <
                (readCmd->GetMetaBufferSize() / sizeof(uint16_t)); i++) {
                if (*rdMetaPtr++ != mWrVal++) {
                    readCmd->Dump(
                        FileSystem::PrepDumpFile(mGrpName, mTestName,
                        "MetaPayload"),
                        "Meta Data read from media miscompared from written");
                    throw FrmwkEx(HERE,
                        "Read data mismatch for 16bit inc meta data "
                        "read ptr: 0x%08X, read val: 0x%02X, write val: 0x%02X",
                        rdBuffPtr, *rdBuffPtr, mWrVal);
                }
            }
        }
    } else if (dataPattern == DATAPAT_CONST_8BIT) {
        const uint8_t *rdBuffPtr = readCmd->GetROPrpBuffer();
        for (uint64_t i = 0; i <
            (readCmd->GetPrpBufferSize() / sizeof(uint8_t)); i++) {
            if (*rdBuffPtr++ != (uint8_t)wrVal) {
                readCmd->Dump(
                    FileSystem::PrepDumpFile(mGrpName, mTestName,
                    "ReadPayload"),
                    "Data read from media miscompared from written");
                throw FrmwkEx(HERE, "Read data mismatch for 8bit const data "
                    "read ptr: 0x%08X, read value: 0x%02X, write value: 0x%02X",
                    rdBuffPtr, *rdBuffPtr, wrVal);
            }
        }
        // Check if meta data exists and then compare meta buffer data.
        const uint8_t *rdMetaPtr = readCmd->GetMetaBuffer();
        if (rdMetaPtr) {
            LOG_NRM("Compare read vs written meta data to verify");
            for (uint64_t i = 0; i <
                (readCmd->GetMetaBufferSize() / sizeof(uint8_t)); i++) {
                if (*rdMetaPtr++ != (uint8_t)wrVal) {
                    readCmd->Dump(
                        FileSystem::PrepDumpFile(mGrpName, mTestName,
                        "MetaPayload"),
                        "Meta Data read from media miscompared from written");
                    throw FrmwkEx(HERE,
                        "Read data mismatch for 8bit const meta data "
                        "read ptr: 0x%08X, read val: 0x%02X, write val: 0x%02X",
                        rdBuffPtr, *rdBuffPtr, wrVal);
                }
            }
        }
    }
}