cookie info iter was uninitialized
leads to crash
This commit is contained in:
parent
262d34174e
commit
d99be25529
@ -32,19 +32,20 @@ DeviceHandlerBase::DeviceHandlerBase(object_id_t setObjectId,
|
|||||||
deviceThermalRequestPoolId(thermalRequestPoolId),
|
deviceThermalRequestPoolId(thermalRequestPoolId),
|
||||||
childTransitionFailure(RETURN_OK), fdirInstance(fdirInstance),
|
childTransitionFailure(RETURN_OK), fdirInstance(fdirInstance),
|
||||||
hkSwitcher(this), defaultFDIRUsed(fdirInstance == nullptr),
|
hkSwitcher(this), defaultFDIRUsed(fdirInstance == nullptr),
|
||||||
switchOffWasReported(false), cookieInfo(),
|
switchOffWasReported(false), childTransitionDelay(5000),
|
||||||
childTransitionDelay(5000),
|
|
||||||
transitionSourceMode(_MODE_POWER_DOWN), transitionSourceSubMode(
|
transitionSourceMode(_MODE_POWER_DOWN), transitionSourceSubMode(
|
||||||
SUBMODE_NONE), deviceSwitch(setDeviceSwitch) {
|
SUBMODE_NONE), deviceSwitch(setDeviceSwitch) {
|
||||||
commandQueue = QueueFactory::instance()->createMessageQueue(cmdQueueSize,
|
commandQueue = QueueFactory::instance()->createMessageQueue(cmdQueueSize,
|
||||||
CommandMessage::MAX_MESSAGE_SIZE);
|
CommandMessage::MAX_MESSAGE_SIZE);
|
||||||
cookieInfo.state = COOKIE_UNUSED;
|
|
||||||
insertInCommandMap(RAW_COMMAND_ID);
|
insertInCommandMap(RAW_COMMAND_ID);
|
||||||
|
cookieInfo.state = COOKIE_UNUSED;
|
||||||
|
cookieInfo.pendingCommand = deviceCommandMap.end();
|
||||||
if (comCookie == nullptr) {
|
if (comCookie == nullptr) {
|
||||||
sif::error << "DeviceHandlerBase: ObjectID 0x" << std::hex <<
|
sif::error << "DeviceHandlerBase: ObjectID 0x" << std::hex <<
|
||||||
std::setw(8) << std::setfill('0') << this->getObjectId() <<
|
std::setw(8) << std::setfill('0') << this->getObjectId() <<
|
||||||
std::dec << ": Do not pass nullptr as a cookie, consider "
|
std::dec << ": Do not pass nullptr as a cookie, consider "
|
||||||
"passing a dummy cookie instead!" << std::endl;
|
<< std::setfill(' ') << "passing a dummy cookie instead!" <<
|
||||||
|
std::endl;
|
||||||
}
|
}
|
||||||
if (this->fdirInstance == nullptr) {
|
if (this->fdirInstance == nullptr) {
|
||||||
this->fdirInstance = new DeviceHandlerFailureIsolation(setObjectId,
|
this->fdirInstance = new DeviceHandlerFailureIsolation(setObjectId,
|
||||||
@ -571,12 +572,12 @@ void DeviceHandlerBase::doSendRead() {
|
|||||||
ReturnValue_t result;
|
ReturnValue_t result;
|
||||||
|
|
||||||
size_t requestLen = 0;
|
size_t requestLen = 0;
|
||||||
DeviceReplyIter iter = deviceReplyMap.find(cookieInfo.pendingCommand->first);
|
if(cookieInfo.pendingCommand != deviceCommandMap.end()) {
|
||||||
if(iter != deviceReplyMap.end()) {
|
DeviceReplyIter iter = deviceReplyMap.find(
|
||||||
requestLen = iter->second.replyLen;
|
cookieInfo.pendingCommand->first);
|
||||||
}
|
if(iter != deviceReplyMap.end()) {
|
||||||
else {
|
requestLen = iter->second.replyLen;
|
||||||
requestLen = 0;
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
result = communicationInterface->requestReceiveMessage(comCookie, requestLen);
|
result = communicationInterface->requestReceiveMessage(comCookie, requestLen);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user