Fixing returned error codes in OCProcessPresence.
authorYamin S Al-mousa <yamin.s.al-mousa@intel.com>
Mon, 6 Oct 2014 23:52:15 +0000 (16:52 -0700)
committerYamin S Al-mousa <yamin.s.al-mousa@intel.com>
Mon, 6 Oct 2014 23:52:15 +0000 (16:52 -0700)
Change-Id: I1976a240bdd440708acfc4e10bfc0bc06437c35a

csdk/stack/src/ocstack.c

index 78aa0d0e8d2672242066d68088c888629a995af0..ebaae392d3ea1eacac4f21919a611b639184c6d3 100644 (file)
@@ -527,7 +527,7 @@ OCStackResult OCCancel(OCDoHandle handle, OCQualityOfService qos, OCHeaderOption
 #ifdef WITH_PRESENCE
 OCStackResult OCProcessPresence()
 {
-    OCStackResult result = OC_STACK_ERROR;
+    OCStackResult result = OC_STACK_OK;
     uint8_t ipAddr[4] = { 0 };
     uint16_t port = 0;
 
@@ -570,6 +570,7 @@ OCStackResult OCProcessPresence()
                     }
                     else
                     {
+                        result = OC_STACK_INVALID_IP;
                         goto exit;
                     }
                     HandleStackResponses(response);
@@ -581,6 +582,10 @@ OCStackResult OCProcessPresence()
                     OCGenerateCoAPToken(&token);
                     result = OCDoCoAPResource(OC_REST_GET, OC_NON_CONFIRMABLE,
                             &token, (const char *)cbNode->requestUri, NULL, NULL, 0);
+                    if(result != OC_STACK_OK)
+                    {
+                        goto exit;
+                    }
                     cbNode->presence->TTLlevel++;
                     OC_LOG_V(DEBUG, TAG, "----------------moving to TTL level %d", cbNode->presence->TTLlevel);
                 }