本文整理汇总了C++中PVLOGGER_LOGMSG函数的典型用法代码示例。如果您正苦于以下问题:C++ PVLOGGER_LOGMSG函数的具体用法?C++ PVLOGGER_LOGMSG怎么用?C++ PVLOGGER_LOGMSG使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了PVLOGGER_LOGMSG函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: PVLOGGER_LOGMSG
OSCL_EXPORT_REF PVMFStatus PvmfPortBaseImpl::PeerDisconnect()
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_STACK_TRACE,
(0, "0x%x PvmfPortBaseImpl::PeerDisconnect", this));
if (!iConnectedPort)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_REL, iLogger, PVLOGMSG_ERR,
(0, "0x%x PvmfPortBaseImpl::PeerDisconnect: Error - Port not connected", this));
return PVMFFailure;
}
//reset busy flags - this would prevent any queue / port ready
//events from being generated as we clear the message queues
iIncomingQueue.iBusy = false;
iOutgoingQueue.iBusy = false;
ClearMsgQueues();
iConnectedPort = NULL;
#if PVMF_PORT_BASE_IMPL_STATS
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "0x%x PvmfPortBaseImpl::PeerDisconnect: Stats: OutMsgQd=%d, OutMsgSent=%d, OutBusy=%d, ConnectedPortBusy=%d",
this, iStats.iOutgoingMsgQueued, iStats.iOutgoingMsgSent, iStats.iOutgoingQueueBusy,
iStats.iConnectedPortBusy));
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "0x%x PvmfPortBaseImpl::PeerDisconnect: Stats: InMsgRecv=%d, InMsgConsumed=%d, InBusy=%d",
this, iStats.iIncomingMsgRecv, iStats.iIncomingMsgConsumed, iStats.iIncomingQueueBusy));
#endif
PortActivity(PVMF_PORT_ACTIVITY_DISCONNECT);
return PVMFSuccess;
}
示例2: PVLOGGER_LOGMSG
OMX_BOOL OmxDecTestBase::VerifyAllBuffersReturned()
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_STACK_TRACE, (0, "OmxDecTestBase::VerifyAllBuffersReturned() - IN"));
OMX_U32 ii;
OMX_BOOL AllBuffersReturned = OMX_TRUE;
//check here to verify whether all the ip/op buffers are returned back by the component or not
for (ii = 0; ii < iInBufferCount; ii++)
{
if (OMX_FALSE == ipInputAvail[ii])
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "OmxDecTestBase::VerifyAllBuffersReturned() - Not all the input buffers returned by component yet, rescheduling"));
AllBuffersReturned = OMX_FALSE;
break;
}
}
for (ii = 0; ii < iOutBufferCount; ii++)
{
if (OMX_FALSE == ipOutReleased[ii])
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "OmxDecTestBase::VerifyAllBuffersReturned() - Not all the input buffers returned by component yet, rescheduling"));
AllBuffersReturned = OMX_FALSE;
break;
}
}
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_STACK_TRACE, (0, "OmxDecTestBase::VerifyAllBuffersReturned() - OUT"));
return AllBuffersReturned;
}
示例3: PVLOGGER_LOGMSG
uint32 TSC_324m::MiscIndicationRecv(PS_ControlMsgHeader pReceiveInf)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_STACK_TRACE,
(0, "TSC_324m::MiscIndicationRecv"));
PS_MiscellaneousIndication indication = (PS_MiscellaneousIndication)pReceiveInf->pParameter;
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_STACK_TRACE,
(0, "TSC_324m::MiscIndicationRecv lcn(%d),index(%d)",
indication->logicalChannelNumber, indication->miType.index));
switch (indication->miType.index)
{
case 9:
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_STACK_TRACE,
(0, "TSC_324m::MiscIndicationRecv videoSpatialTemporalTradeoff(%d)",
indication->miType.videoTemporalSpatialTradeOff));
if (iTSC_324mObserver)
{
iTSC_324mObserver->VideoSpatialTemporalTradeoffIndicationReceived(indication->logicalChannelNumber,
indication->miType.videoTemporalSpatialTradeOff);
}
break;
default:
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_STACK_TRACE,
(0, "TSC_324m::MiscIndicationRecv Indication not handled"));
break;
}
return iTerminalStatus;
}
示例4: OSCL_UNUSED_ARG
PVMFStatus PVMFSocketPort::getParametersSync(PvmiMIOSession aSession,
PvmiKeyType aIdentifier,
PvmiKvp*& aParameters,
int& num_parameter_elements,
PvmiCapabilityContext aContext)
{
OSCL_UNUSED_ARG(aSession);
OSCL_UNUSED_ARG(aContext);
PVLOGGER_LOGMSG(PVLOGMSG_INST_MLDBG, iLogger, PVLOGMSG_INFO, (0, "PVMFSocketPort::getParametersSync: aSession=0x%x, aIdentifier=%s, aParameters=0x%x, num_parameters_elements=%d, aContext=0x%x",
aSession, aIdentifier, aParameters, num_parameter_elements, aContext));
if (pv_mime_strcmp(aIdentifier, PVMI_PORT_CONFIG_INPLACE_DATA_PROCESSING_KEY) != 0)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_MLDBG, iLogger, PVLOGMSG_ERR, (0, "PVMFSocketPort::getParametersSync: Error - Unsupported PvmiKeyType"));
return PVMFErrNotSupported;
}
num_parameter_elements = 0;
if (!pvmiGetPortInPlaceDataProcessingInfoSync(PVMI_PORT_CONFIG_INPLACE_DATA_PROCESSING_VALUE, aParameters))
{
return PVMFFailure;
}
num_parameter_elements = 1;
return PVMFSuccess;
}
示例5: PVLOGGER_LOGMSG
void CPV2WayRecDatapath::CheckPause()
{
uint32 i;
int32 error;
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_NOTICE, (0, "CPV2WayDatapath::CheckPause state %d\n", iState));
for (i = 0; i < iNodeList.size(); i++)
{
if (!iNodeList[i].iCanNodePause) continue;
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_NOTICE, (0, "CPV2WayDatapath::CheckPause node %d state %d\n", i, iNodeList[i].iNode.node->GetState()));
switch (iNodeList[i].iNode.node->GetState())
{
case EPVMFNodeStarted:
OSCL_TRY(error, i2Way->SendNodeCmdL(PV2WAY_NODE_CMD_PAUSE, iNodeList[i].iNode.node, iNodeList[i].iNode.session, this));
OSCL_FIRST_CATCH_ANY(error,
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_ERR, (0, "CPV2WayDatapath::CheckPause unable to pause node\n"));
DatapathError();
return;);
break;
default:
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_NOTICE, (0, "CPV2WayDatapath::CheckPause transitional node state!\n"));
break;
}
}
示例6: ShowSummaryStats
static void ShowSummaryStats(PVServiStats* aArray)
{
//lump this logging with Oscl scheduler perf logging.
uint32 index = 0;
PVLogger* logger = PVLogger::GetLoggerObject("OsclSchedulerPerfStats");
PVLOGGER_LOGMSG(PVLOGMSG_INST_PROF, logger, PVLOGMSG_INFO, (0, "Session Breakdown:"));
while (index < EServiSession_Last)
{
aArray[index].ShowStats(logger, index, aArray[EServiSession_All]);
index++;
}
PVLOGGER_LOGMSG(PVLOGMSG_INST_PROF, logger, PVLOGMSG_INFO, (0, "Run Breakdown:"));
while (index < EServiRun_Last)
{
aArray[index].ShowStats(logger, index, aArray[EServiSession_All]);
index++;
}
PVLOGGER_LOGMSG(PVLOGMSG_INST_PROF, logger, PVLOGMSG_INFO, (0, "ProcessRequests Breakdown:"));
while (index < EServiProc_Last)
{
aArray[index].ShowStats(logger, index, aArray[EServiSession_All]);
index++;
}
PVLOGGER_LOGMSG(PVLOGMSG_INST_PROF, logger, PVLOGMSG_INFO, (0, "ProcessRequests Loop Breakdown:"));
while (index < EServiProcLoop_Last)
{
aArray[index].ShowStats(logger, index, aArray[EServiSession_All]);
index++;
}
}
示例7: OSCL_ASSERT
int32 OsclFileCache::Open(uint32 mode, uint32 size)
//Called to open the cache for a newly opened file.
//The NativeOpen was just called prior to this and was successful.
{
//should not be called with zero-size cache.
OSCL_ASSERT(size > 0);
//Save the mode
_mode = mode;
//open logger object only if logging is enabled on this
//file
if (iContainer.iLogger)
iLogger = PVLogger::GetLoggerObject("OsclFileCache");
else
iLogger = NULL;
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "OsclFileCache(0x%x)::Open mode %d size %d", this, mode, size));
// Create the movable cache.
// Re-allocate it if the size has changed.
if (_movableCache.pBuffer
&& size != _movableCache.capacity)
{
OSCL_FREE(_movableCache.pBuffer);
_movableCache.pBuffer = NULL;
}
if (!_movableCache.pBuffer
&& size > 0)
{
_movableCache.pBuffer = (uint8*)OSCL_MALLOC(size);
}
if (!_movableCache.pBuffer)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "OsclFileCache(0x%x)::Open ERROR no memory %d", this));
return (-1);//error
}
_movableCache.capacity = _movableCache.usableSize = size;
_movableCache.filePosition = 0;
_movableCache.updateStart = _movableCache.updateEnd = 0;
_movableCache.currentPos = _movableCache.endPos = 0;
//Position the cache at zero.
SetCachePosition(0);
//get initial file size & native position
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "OsclFileCache(0x%x)::Open CallingNativeSize", this));
_fileSize = iContainer.CallNativeSize();
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "OsclFileCache(0x%x)::Open CallingNativeTell", this));
_nativePosition = iContainer.CallNativeTell();
return 0;
}
示例8: if
int32 OsclFileCache::UpdateFixedCaches()
//Process any queued requests to remove or add fixed caches.
{
int32 error = 0;
if (iContainer.iRemoveFixedCache.size())
{
for (uint32 i = 0; i < iContainer.iRemoveFixedCache.size(); i++)
{
for (uint32 j = 0; j < _fixedCaches.size(); j++)
{
if (_fixedCaches[j].filePosition < iContainer.iRemoveFixedCache[i])
{
//fixed cache list is sorted, so we can end search now.
break;
}
else if (_fixedCaches[j].filePosition == iContainer.iRemoveFixedCache[i])
{
//found it
if (_fixedCaches[j].IsUpdated())
{
int32 result = _fixedCaches[j].WriteUpdatesToFile();
if (result != 0)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "OsclFileCache(0x%x)::UpdateFixedCaches ERROR in WriteUpdatesToFile", this));
error = result;
}
}
if (_fixedCaches[j].pBuffer)
{
OSCL_FREE(_fixedCaches[j].pBuffer);
_fixedCaches[j].pBuffer = NULL;
}
_fixedCaches.erase(&_fixedCaches[j]);
break;
}
}
}
iContainer.iRemoveFixedCache.clear();
}
if (iContainer.iAddFixedCache.size())
{
for (uint32 i = 0; i < iContainer.iAddFixedCache.size(); i++)
{
if (!AddFixedCache(iContainer.iAddFixedCache[i]))
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_DEBUG,
(0, "OsclFileCache(0x%x)::UpdateFixedCaches ERROR in AddFixedCache", this));
error = (-1);
}
}
iContainer.iAddFixedCache.clear();
}
return error;
}
示例9: PVLOGGER_LOGMSG
// same as base-class DeQueue method, except no RunIfNotReady/PendForExec is called (since all events are processed in a loop)
// (i.e. PendForExec control is done in the loop in Run)
OsclAny* OmxEventHandlerThreadSafeCallbackAO::DeQueue(OsclReturnCode &stat)
{
OsclAny *pData;
OsclProcStatus::eOsclProcError sema_status;
stat = OsclSuccess;
// Protect the queue while accessing it:
Mutex.Lock();
if (Q->NumElem == 0)
{
// nothing to de-queue
stat = OsclFailure;
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_STACK_TRACE, (0, "OmxEventHandlerThreadSafeCallbackAO::DeQueue() - No events in the queue - return ()"));
Mutex.Unlock();
return NULL;
}
pData = (Q->pFirst[Q->index_out]).pData;
Q->index_out++;
// roll-over the index
if (Q->index_out == Q->MaxNumElements)
Q->index_out = 0;
Q->NumElem--;
// check if there is need to call waitforevent
if ((Q->NumElem) == 0)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_STACK_TRACE, (0, "OmxEventHandlerThreadSafeCallbackAO::Run() - No more events, call PendForExec()"));
PendForExec();
stat = OsclPending; // let the Run know that the last event was pulled out of the queue
// so that it can get out of the loop
}
//release queue access
Mutex.Unlock();
// Signal the semaphore that controls the remote thread.
// The remote thread might be blocked and waiting for an event to be processed in case the event queue is full
sema_status = RemoteThreadCtrlSema.Signal();
if (sema_status != OsclProcStatus::SUCCESS_ERROR)
{
stat = OsclFailure;
return NULL;
}
return pData;
}
示例10: PVLOGGER_LOGMSG
unsigned H223LowerLayer::SetPduSize(unsigned pdu_size)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_STACK_TRACE, (0, "SetPduSize - current(%d), new(%d)!\n", iPduSize, pdu_size));
if (pdu_size < iPduSize)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_STACK_TRACE, (0, "SetPduSize - setting pdu size to (%d)", pdu_size));
iPduSize = pdu_size;
}
else
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_STACK_TRACE, (0, "SetPduSize - not setting pdu size "));
}
return iPduSize;
}
示例11: PVLOGGER_LOGMSG
OSCL_EXPORT_REF PVMFStatus PVMp4FFComposerPort::PeerConnect(PVMFPortInterface* aPort)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_LLDBG, iLogger, PVLOGMSG_STACK_TRACE,
(0, "0x%x PVMp4FFComposerPort::PeerConnect: aPort=0x%x", this, aPort));
if (!aPort)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_REL, iLogger, PVLOGMSG_ERR,
(0, "0x%x PVMp4FFComposerPort::PeerConnect: Error - Connecting to invalid port", this));
return PVMFErrArgument;
}
if (iConnectedPort)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_REL, iLogger, PVLOGMSG_ERR,
(0, "0x%x PVMp4FFComposerPort::PeerConnect: Error - Already connected", this));
return PVMFFailure;
}
// When connection is initiated by peer, this port still needs to query the peer
// for input format configuration data
OsclAny* temp = NULL;
aPort->QueryInterface(PVMI_CAPABILITY_AND_CONFIG_PVUUID, temp);
PvmiCapabilityAndConfig *config = OSCL_STATIC_CAST(PvmiCapabilityAndConfig*, temp);
if (!config)
{
LOG_ERR((0, "PVMp4FFComposerPort::PeerConnect: Error - Peer port does not support capability interface"));
return PVMFFailure;
}
PVMFStatus status = GetInputParametersFromPeer(config);
if (status != PVMFSuccess)
{
LOG_ERR((0, "PVMp4FFComposerPort::PeerConnect: Error - GetVideoInputParametersFromPeer failed. status=%d",
status));
return status;
}
iConnectedPort = aPort;
#if PVMF_PORT_BASE_IMPL_STATS
// Reset statistics
oscl_memset((OsclAny*)&(PvmfPortBaseImpl::iStats), 0, sizeof(PvmfPortBaseImplStats));
#endif
PortActivity(PVMF_PORT_ACTIVITY_CONNECT);
return PVMFSuccess;
}
示例12: PVLOGGER_LOGMSG
PVMFStatus PVMFSocketPort::QueueOutgoingMsg(PVMFSharedMediaMsgPtr aMsg)
//In this node, we skip the outgoing queue and go directly to the connected port's
//incoming queue.
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_MLDBG, iLogger, PVLOGMSG_INFO, (0, "PVMFSocketPort::QueueOutgoingMsg"));
//If port is not connected, don't accept data on the
//outgoing queue.
if (!iConnectedPort)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_MLDBG, iLogger, PVLOGMSG_INFO, (0, "PVMFSocketPort::QueueOutgoingMsg: Error - Port not connected"));
return PVMFFailure;
}
PvmfPortBaseImpl* cpPort = OSCL_STATIC_CAST(PvmfPortBaseImpl*, iConnectedPort);
// Connected Port incoming Queue is in busy / flushing state. Do not accept more outgoing messages
// until the queue is not busy, i.e. queue size drops below specified threshold or FlushComplete
// is called.
if (cpPort->iIncomingQueue.iBusy)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_MLDBG, iLogger, PVLOGMSG_INFO, (0, "PVMFSocketPort::QueueOutgoingMsg: Connected Port Incoming queue in busy / flushing state - Attempting to Q in output port's outgoing msg q"));
return (PvmfPortBaseImpl::QueueOutgoingMsg(aMsg));
}
// Add message to outgoing queue and notify the node of the activity
// There is no need to trap the push_back, since it cannot leave in this usage
// Reason being that we do a reserve in the constructor and we do not let the
// port queues grow indefinitely (we either a connected port busy or outgoing Q busy
// before we reach the reserved limit
PVMFStatus status = cpPort->Receive(aMsg);
if (status != PVMFSuccess)
{
return PVMFFailure;
}
// Outgoing queue size is at capacity and goes into busy state. The owner node is
// notified of this transition into busy state.
if (cpPort->isIncomingFull())
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_MLDBG, iLogger, PVLOGMSG_INFO, (0, "PVMFSocketPort::QueueOutgoingMsg: Connected Port incoming queue is full. Goes into busy state"));
cpPort->iIncomingQueue.iBusy = true;
PvmfPortBaseImpl::PortActivity(PVMF_PORT_ACTIVITY_CONNECTED_PORT_BUSY);
}
return PVMFSuccess;
}
示例13: oscl_strlen
bool
PVMFSocketPort::pvmiGetPortInPlaceDataProcessingInfoSync(const char* aFormatValType,
PvmiKvp*& aKvp)
{
/*
* Create PvmiKvp for capability settings
*/
aKvp = NULL;
OsclMemAllocator alloc;
uint32 strLen = oscl_strlen(aFormatValType) + 1;
uint8* ptr = (uint8*)alloc.allocate(sizeof(PvmiKvp) + strLen);
if (!ptr)
{
PVLOGGER_LOGMSG(PVLOGMSG_INST_MLDBG, iLogger, PVLOGMSG_ERR, (0, "PVMFSocketPort::pvmiGetPortInPlaceDataProcessingInfoSync: Error - No memory. Cannot allocate PvmiKvp"));
return false;
}
aKvp = new(ptr) PvmiKvp;
ptr += sizeof(PvmiKvp);
aKvp->key = (PvmiKeyType)ptr;
oscl_strncpy(aKvp->key, aFormatValType, strLen);
aKvp->length = aKvp->capacity = strLen;
#if SNODE_ENABLE_UDP_MULTI_PACKET
if (iTag == PVMF_SOCKET_NODE_PORT_TYPE_SOURCE)
aKvp->value.bool_value = false;//for the multiple UDP recv feature
else
#endif
aKvp->value.bool_value = true;
return true;
}
示例14: PVLOGGER_LOGMSG
void TSC_blc::BlcEtbRps(TPVChannelId incoming_lcn, TPVChannelId outgoing_lcn)
{
S_ControlMsgHeader infHeader;
S_ReverseData parameter;
PVLOGGER_LOGMSG(PVLOGMSG_INST_HLDBG, iLogger, PVLOGMSG_STACK_TRACE,
(0,
"TSC_blc::BlcEtbRps incoming(%d), outgoing(%d)\n", incoming_lcn, outgoing_lcn));
// Buffer Allocate
oscl_memset(¶meter, 0, sizeof(S_ReverseData));
// ESTABLISH.response primitive - Parameter(REVERSE_DATA)
parameter.option_of_reverseLogicalChannelParameters = true;
parameter.reverseLogicalChannelParameters.reverseLogicalChannelNumber =
(uint16)incoming_lcn; // WWU_BLC: change 0->3
parameter.reverseLogicalChannelParameters.option_of_portNumber = false;
parameter.reverseLogicalChannelParameters.option_of_ackMultiplexParameters = false;
parameter.reverseLogicalChannelParameters.option_of_replacementFor = false;
Tsc_SendDataSet(&infHeader,
H245_PRIMITIVE,
E_PtvId_Blc_Etb_Rps,
incoming_lcn,
outgoing_lcn,
(uint8*)¶meter,
sizeof(S_ReverseData));
// Primitive Send
iH245->DispatchControlMessage(&infHeader);
}
示例15: OSCL_UNUSED_ARG
void pv_mediainput_async_test_delete::HandleErrorEvent(const PVAsyncErrorEvent& aEvent)
{
OSCL_UNUSED_ARG(aEvent);
PVLOGGER_LOGMSG(PVLOGMSG_INST_REL, iLogger, PVLOGMSG_ERR, (0, "pv_mediainput_async_test_delete::HandleErrorEvent"));
iState = PVAE_CMD_RESET;
RunIfNotReady();
}