void UnsupportRsvdFields_r11b::TestAsyncEvents(SharedACQPtr &acq, SharedASQPtr &asq, bool rsvd) { uint32_t isrCount; uint32_t ceRemain; uint32_t numReaped; uint32_t numCE; SendAsyncEventRequests(asq, 1, rsvd); sleep(5); if (acq->ReapInquiryWaitSpecify(CALC_TIMEOUT_ms(1), 1, numCE, isrCount) == true) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail1"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "0 CE's expected in ACQ but found %d CE's", numCE); } InvalidSQWriteDoorbell(); sleep(1); if (acq->ReapInquiryWaitSpecify(CALC_TIMEOUT_ms(1), 1, numCE, isrCount) == false) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail2"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "1 CE expected in ACQ but found %d CE's", numCE); } SharedMemBufferPtr ceMem = SharedMemBufferPtr(new MemBuffer()); if ((numReaped = acq->Reap(ceRemain, ceMem, isrCount, numCE, true)) != 1) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail3"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "Unable to reap on ACQ"); } union CE *ce = (union CE *)ceMem->GetBuffer(); if (ce->n.async.asyncEventType != EVENT_TYPE_ERROR_STS) { throw FrmwkEx(HERE, "Invalid async event error status, " "(Expected : Received) :: (%d : %d)", EVENT_TYPE_ERROR_STS, ce->n.async.asyncEventType); } else if (ce->n.async.asyncEventInfo != ERR_STS_INVALID_SQ) { throw FrmwkEx(HERE, "Invalid async event info, " "(Expected : Received) :: (%d : %d)", ERR_STS_INVALID_SQ, ce->n.async.asyncEventInfo); } LOG_NRM("Associated Log page = %d", ce->n.async.assocLogPage); ReadLogPage(acq, asq, ce->n.async.assocLogPage); }
void VerifyMasking_r10b::RunCoreTest() { /** \verbatim * Assumptions: * 1) none * \endverbatim */ uint32_t isrCount; uint32_t ceRemain; uint32_t numReaped; uint32_t numCE; LOG_NRM("Issue Identify.AERL to get Async Event Req Limit (AERL)"); uint8_t nAerlimit = gInformative->GetIdentifyCmdCtrlr()-> GetValue(IDCTRLRCAP_AERL) + 1; // Convert to 1-based. if (gCtrlrConfig->SetState(ST_DISABLE_COMPLETELY) == false) throw FrmwkEx(HERE); LOG_NRM("Create admin queues ACQ and ASQ for test lifetime"); SharedACQPtr acq = SharedACQPtr(new ACQ(gDutFd)); acq->Init(nAerlimit + 1); // one extra space than Q full condition SharedASQPtr asq = SharedASQPtr(new ASQ(gDutFd)); asq->Init(nAerlimit + 1); // one extra space than Q full condition // All queues will use identical IRQ vector IRQ::SetAnySchemeSpecifyNum(1); gCtrlrConfig->SetCSS(CtrlrConfig::CSS_NVM_CMDSET); if (gCtrlrConfig->SetState(ST_ENABLE) == false) throw FrmwkEx(HERE); LOG_NRM("Issue %d async event requests", nAerlimit); SendAsyncEventRequests(asq, nAerlimit); for (uint8_t nAer = 1; nAer <= nAerlimit; nAer++) { LOG_NRM("Ring doorbell for IOSQ #1"); InvalidSQWriteDoorbell(); sleep(5); if (nAer == 1) { LOG_NRM("Verify only 1 CE exists for invalid SQID doorbell write"); if (acq->ReapInquiryWaitSpecify(CALC_TIMEOUT_ms(1), 1, numCE, isrCount) == false) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail.reapinq1"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "1 CE expected in but found %d CEs", numCE); } SharedMemBufferPtr ceMem = SharedMemBufferPtr(new MemBuffer()); if ((numReaped = acq->Reap(ceRemain, ceMem, isrCount, numCE, true)) != 1) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail.reap1"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "Unable to reap on ACQ"); } union CE *ce = (union CE *)ceMem->GetBuffer(); if (ce->n.async.asyncEventType != EVENT_TYPE_ERROR_STS) { throw FrmwkEx(HERE, "Invalid async event error status, " "(Expected : Received) :: (%d : %d)", EVENT_TYPE_ERROR_STS, ce->n.async.asyncEventType); } else if (ce->n.async.asyncEventInfo != ERR_STS_INVALID_SQ) { throw FrmwkEx(HERE, "Invalid async event info, " "(Expected : Received) :: (%d : %d)", ERR_STS_INVALID_SQ, ce->n.async.asyncEventInfo); } } else { LOG_NRM("Verify only 1 CE exists for %d cmds as " "async events are masked (GetLogPage not called)", nAer); if (acq->ReapInquiryWaitSpecify(CALC_TIMEOUT_ms(1), 2, numCE, isrCount) == true) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail.reapinq2"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "1 CE expected but found %d CEs", numCE); } } } }
void VerifyMaxEvents_r10b::RunCoreTest() { /** \verbatim * Assumptions: * 1) none * \endverbatim */ uint32_t isrCount; uint32_t ceRemain; uint32_t numReaped; uint32_t numCE; LOG_NRM("Issue Identify.AERL to get Async Event Req Limit (AERL)"); uint8_t nAerlimit = gInformative->GetIdentifyCmdCtrlr()-> GetValue(IDCTRLRCAP_AERL) + 1; // Convert to 1-based. if (gCtrlrConfig->SetState(ST_DISABLE_COMPLETELY) == false) throw FrmwkEx(HERE); LOG_NRM("Create admin queues ACQ and ASQ for test lifetime"); SharedACQPtr acq = SharedACQPtr(new ACQ(gDutFd)); acq->Init(nAerlimit + 2); // one extra space than Q full condition SharedASQPtr asq = SharedASQPtr(new ASQ(gDutFd)); asq->Init(nAerlimit + 2); // one extra space than Q full condition // All queues will use identical IRQ vector IRQ::SetAnySchemeSpecifyNum(1); gCtrlrConfig->SetCSS(CtrlrConfig::CSS_NVM_CMDSET); if (gCtrlrConfig->SetState(ST_ENABLE) == false) throw FrmwkEx(HERE); LOG_NRM("Issue one more than %d (async event req limit)", nAerlimit); SendAsyncEventRequests(asq, (nAerlimit + 1)); LOG_NRM("Delay 5 sec"); sleep(5); if (acq->ReapInquiryWaitSpecify(CALC_TIMEOUT_ms(1), 1, numCE, isrCount) == false) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail1"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "1 CE's expected in ACQ but found %d CE's", numCE); } SharedMemBufferPtr ceMem = SharedMemBufferPtr(new MemBuffer()); if ((numReaped = acq->Reap(ceRemain, ceMem, isrCount, numCE, true)) != 1) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail2"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "Unable to reap on ACQ"); } LOG_NRM("verify SC = Async Event Limit Exceeded"); union CE *ce = (union CE *)ceMem->GetBuffer(); ProcessCE::Validate(*ce, CESTAT_ASYNC_REQ_EXCEED); for (uint8_t nAer = 0; nAer < nAerlimit; nAer++) { LOG_NRM("Ring doorbell for IOSQ #1"); InvalidSQWriteDoorbell(); sleep(1); LOG_NRM("verify CE exists in ACQ for invalid SQID doorbell write"); if (acq->ReapInquiryWaitSpecify(CALC_TIMEOUT_ms(1), 1, numCE, isrCount) == false) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail4"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "1 CE expected in ACQ but found %d CEs", numCE); } SharedMemBufferPtr ceMem = SharedMemBufferPtr(new MemBuffer()); if ((numReaped = acq->Reap(ceRemain, ceMem, isrCount, numCE, true)) != 1) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail5"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "Unable to reap on ACQ"); } union CE *ce = (union CE *)ceMem->GetBuffer(); if (ce->n.async.asyncEventType != EVENT_TYPE_ERROR_STS) { throw FrmwkEx(HERE, "Invalid async event error status, " "(Expected : Received) :: (%d : %d)", EVENT_TYPE_ERROR_STS, ce->n.async.asyncEventType); } else if (ce->n.async.asyncEventInfo != ERR_STS_INVALID_SQ) { throw FrmwkEx(HERE, "Invalid async event info, " "(Expected : Received) :: (%d : %d)", ERR_STS_INVALID_SQ, ce->n.async.asyncEventInfo); } LOG_NRM("Associated Log page = %d", ce->n.async.assocLogPage); ReadLogPage(acq, asq, ce->n.async.assocLogPage); } }
void VerifyEventQueueing_r10b::RunCoreTest() { /** \verbatim * Assumptions: * 1) none * \endverbatim */ uint32_t isrCount; uint32_t ceRemain; uint32_t numReaped; uint32_t numCE; if (gCtrlrConfig->SetState(ST_DISABLE_COMPLETELY) == false) throw FrmwkEx(HERE); LOG_NRM("Create admin queues ACQ and ASQ for test lifetime"); SharedACQPtr acq = SharedACQPtr(new ACQ(gDutFd)); acq->Init(5); SharedASQPtr asq = SharedASQPtr(new ASQ(gDutFd)); asq->Init(5); // All queues will use identical IRQ vector IRQ::SetAnySchemeSpecifyNum(1); gCtrlrConfig->SetCSS(CtrlrConfig::CSS_NVM_CMDSET); if (gCtrlrConfig->SetState(ST_ENABLE) == false) throw FrmwkEx(HERE); LOG_NRM("Ring doorbell for IOSQ #1"); InvalidSQWriteDoorbell(); LOG_NRM("Delay 5 sec"); sleep(5); LOG_NRM("Verify no CE's exist in ACQ"); if (acq->ReapInquiryWaitSpecify(CALC_TIMEOUT_ms(1), 1, numCE, isrCount) == true) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail.0rinq"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "0 CE's expected in ACQ but found %d CE's", numCE); } LOG_NRM("Issue one async event "); SendAsyncEventRequests(asq, 1); LOG_NRM("verify CE exists in ACQ for invalid SQID doorbell write"); if (acq->ReapInquiryWaitSpecify(CALC_TIMEOUT_ms(1), 1, numCE, isrCount) == false) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail.1rinq"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "1 CE expected in ACQ but found %d CEs", numCE); } SharedMemBufferPtr ceMem = SharedMemBufferPtr(new MemBuffer()); if ((numReaped = acq->Reap(ceRemain, ceMem, isrCount, numCE, true)) != 1) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail.1reap"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "Unable to reap on ACQ"); } union CE *ce = (union CE *)ceMem->GetBuffer(); if (ce->n.async.asyncEventType != EVENT_TYPE_ERROR_STS) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail.sts"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "Invalid async event error status, " "(Expected : Received) :: (%d : %d)", EVENT_TYPE_ERROR_STS, ce->n.async.asyncEventType); } else if (ce->n.async.asyncEventInfo != ERR_STS_INVALID_SQ) { acq->Dump(FileSystem::PrepDumpFile(mGrpName, mTestName, "acq.fail.sc"), "Dump Entire ACQ"); throw FrmwkEx(HERE, "Invalid async event info, " "(Expected : Received) :: (%d : %d)", ERR_STS_INVALID_SQ, ce->n.async.asyncEventInfo); } }