|
|
|
|
@@ -46,11 +46,11 @@ static GWEN_MSG_REQUEST *_mkRequest_SetData(AQHOME_DATA *aqh,
|
|
|
|
|
GWEN_MSG_ENDPOINT *epDriver,
|
|
|
|
|
const AQH_VALUE *v, const char *data);
|
|
|
|
|
static void _rqSubRequestFinished(GWEN_MSG_REQUEST *rq, GWEN_MSG_REQUEST *subRq, int reason);
|
|
|
|
|
static void _rqAbort(GWEN_MSG_REQUEST *rq);
|
|
|
|
|
static void _rqAbort(GWEN_MSG_REQUEST *rq, int reason);
|
|
|
|
|
|
|
|
|
|
static GWEN_MSG_REQUEST *_mkSubRequest_SetData(AQHOME_DATA *aqh, GWEN_MSG_ENDPOINT *epDriver, const AQH_VALUE *v, const char *data);
|
|
|
|
|
static int _subRqHandleResponse(GWEN_MSG_REQUEST *rq, GWEN_MSG *msg);
|
|
|
|
|
static void _subRqAbort(GWEN_MSG_REQUEST *rq);
|
|
|
|
|
static void _subRqAbort(GWEN_MSG_REQUEST *rq, int reason);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@@ -68,7 +68,7 @@ void AqHomeData_HandleSetData(AQHOME_DATA *aqh, GWEN_MSG_ENDPOINT *epSrc, GWEN_M
|
|
|
|
|
AQH_VALUE *systemValue;
|
|
|
|
|
|
|
|
|
|
msgId=GWEN_IpcMsg_GetMsgId(recvdMsg);
|
|
|
|
|
DBG_ERROR(NULL, "Received IPC SetDataRequest message (msgId=%d)", msgId);
|
|
|
|
|
DBG_INFO(NULL, "Received IPC SetDataRequest message (msgId=%d)", msgId);
|
|
|
|
|
|
|
|
|
|
AQH_SetDataIpcMsg_Parse(recvdMsg, 0);
|
|
|
|
|
recvdValue=AQH_SetDataIpcMsg_ReadValue(recvdMsg);
|
|
|
|
|
@@ -88,7 +88,7 @@ void AqHomeData_HandleSetData(AQHOME_DATA *aqh, GWEN_MSG_ENDPOINT *epSrc, GWEN_M
|
|
|
|
|
if (epDriver) {
|
|
|
|
|
GWEN_MSG_REQUEST *rq;
|
|
|
|
|
|
|
|
|
|
DBG_ERROR(NULL, "Creating SETDATA request for driver endpoint (%s)", GWEN_MsgEndpoint_GetName(epDriver));
|
|
|
|
|
DBG_DEBUG(NULL, "Creating SETDATA request for driver endpoint (%s)", GWEN_MsgEndpoint_GetName(epDriver));
|
|
|
|
|
rq=_mkRequest_SetData(aqh, epSrc, msgId, epDriver, systemValue, valueDataFreeable);
|
|
|
|
|
AqHomeData_AddRequestToTree(aqh, rq);
|
|
|
|
|
}
|
|
|
|
|
@@ -151,7 +151,7 @@ void _rqSubRequestFinished(GWEN_MSG_REQUEST *rq, GWEN_MSG_REQUEST *subRq, int re
|
|
|
|
|
uint32_t refMsgId;
|
|
|
|
|
int result;
|
|
|
|
|
|
|
|
|
|
DBG_ERROR(NULL, "SubRequest finished (reason: %d)", reason);
|
|
|
|
|
DBG_DEBUG(NULL, "SubRequest finished (reason: %d)", reason);
|
|
|
|
|
refMsgId=GWEN_MsgRequest_GetRequestMsgId(rq);
|
|
|
|
|
ep=GWEN_MsgRequest_GetEndpoint(rq);
|
|
|
|
|
result=GWEN_MsgRequest_GetResult(subRq);
|
|
|
|
|
@@ -167,7 +167,7 @@ void _rqSubRequestFinished(GWEN_MSG_REQUEST *rq, GWEN_MSG_REQUEST *subRq, int re
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void _rqAbort(GWEN_MSG_REQUEST *rq)
|
|
|
|
|
void _rqAbort(GWEN_MSG_REQUEST *rq, int reason)
|
|
|
|
|
{
|
|
|
|
|
GWEN_MSG_ENDPOINT *ep;
|
|
|
|
|
uint32_t refMsgId;
|
|
|
|
|
@@ -181,7 +181,7 @@ void _rqAbort(GWEN_MSG_REQUEST *rq)
|
|
|
|
|
|
|
|
|
|
rqParent=GWEN_MsgRequest_Tree2_GetParent(rq);
|
|
|
|
|
if (rqParent)
|
|
|
|
|
GWEN_MsgRequest_SubRequestFinished(rqParent, rq, GWEN_MSG_REQUEST_REASON_ABORTED);
|
|
|
|
|
GWEN_MsgRequest_SubRequestFinished(rqParent, rq, reason);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@@ -218,13 +218,13 @@ GWEN_MSG_REQUEST *_mkSubRequest_SetData(AQHOME_DATA *aqh, GWEN_MSG_ENDPOINT *epD
|
|
|
|
|
|
|
|
|
|
int _subRqHandleResponse(GWEN_MSG_REQUEST *rq, GWEN_MSG *msg)
|
|
|
|
|
{
|
|
|
|
|
DBG_ERROR(NULL, "Checking message from driver");
|
|
|
|
|
DBG_DEBUG(NULL, "Checking message from driver");
|
|
|
|
|
if (GWEN_IpcMsg_GetCode(msg)==AQH_MSGTYPE_IPC_DATA_RESULT) {
|
|
|
|
|
uint32_t result;
|
|
|
|
|
GWEN_MSG_REQUEST *rqParent;
|
|
|
|
|
|
|
|
|
|
result=AQH_ResultIpcMsg_GetResultCode(msg);
|
|
|
|
|
DBG_ERROR(NULL, "Received result for request: %d", result);
|
|
|
|
|
DBG_INFO(NULL, "Received result for request: %d", result);
|
|
|
|
|
GWEN_MsgRequest_SetResult(rq, result);
|
|
|
|
|
GWEN_MsgRequest_SetState(rq, GWEN_MSG_REQUEST_STATE_DONE);
|
|
|
|
|
rqParent=GWEN_MsgRequest_Tree2_GetParent(rq);
|
|
|
|
|
@@ -241,18 +241,18 @@ int _subRqHandleResponse(GWEN_MSG_REQUEST *rq, GWEN_MSG *msg)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void _subRqAbort(GWEN_MSG_REQUEST *rq)
|
|
|
|
|
void _subRqAbort(GWEN_MSG_REQUEST *rq, int reason)
|
|
|
|
|
{
|
|
|
|
|
GWEN_MSG_REQUEST *rqParent;
|
|
|
|
|
|
|
|
|
|
DBG_ERROR(NULL, "Aborting request");
|
|
|
|
|
DBG_INFO(NULL, "Aborting request");
|
|
|
|
|
|
|
|
|
|
GWEN_MsgRequest_SetResult(rq, AQH_MSG_IPC_ERROR_GENERIC);
|
|
|
|
|
GWEN_MsgRequest_SetState(rq, GWEN_MSG_REQUEST_STATE_DONE);
|
|
|
|
|
|
|
|
|
|
rqParent=GWEN_MsgRequest_Tree2_GetParent(rq);
|
|
|
|
|
if (rqParent)
|
|
|
|
|
GWEN_MsgRequest_SubRequestFinished(rqParent, rq, GWEN_MSG_REQUEST_REASON_ABORTED);
|
|
|
|
|
GWEN_MsgRequest_SubRequestFinished(rqParent, rq, reason);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|