diff options
| author | dimitri staessens <dimitri.staessens@ugent.be> | 2017-03-31 20:36:45 +0200 | 
|---|---|---|
| committer | dimitri staessens <dimitri.staessens@ugent.be> | 2017-03-31 20:52:05 +0200 | 
| commit | 6a2115d05668e8c426d849bd75ef6bec8fa3db2f (patch) | |
| tree | fd900147474bbd67c6dd9fb0868c2b2564e7f83b /src/lib | |
| parent | 2410108f3226f08e0ee0ec1040e0a71e37452b8c (diff) | |
| download | ouroboros-6a2115d05668e8c426d849bd75ef6bec8fa3db2f.tar.gz ouroboros-6a2115d05668e8c426d849bd75ef6bec8fa3db2f.zip | |
lib: Some fixes in CDAP
Diffstat (limited to 'src/lib')
| -rw-r--r-- | src/lib/cdap.c | 11 | 
1 files changed, 10 insertions, 1 deletions
| diff --git a/src/lib/cdap.c b/src/lib/cdap.c index 824f2c5d..f0db2419 100644 --- a/src/lib/cdap.c +++ b/src/lib/cdap.c @@ -183,8 +183,8 @@ static struct cdap_rcvd * cdap_rcvd_get_by_key(struct cdap * instance,          list_for_each_safe(p, h, &instance->rcvd) {                  rcvd = list_entry(p, struct cdap_rcvd, next);                  if (rcvd->key == key) { -                        pthread_mutex_unlock(&instance->rcvd_lock);                          list_del(&rcvd->next); +                        pthread_mutex_unlock(&instance->rcvd_lock);                          return rcvd;                  }          } @@ -669,6 +669,7 @@ cdap_key_t * cdap_request_send(struct cdap *    instance,                          pthread_rwlock_unlock(&instance->flows_lock);                          release_id(instance, *key);                          release_id(instance, iid); +                        *key = INVALID_CDAP_KEY;                          return keys;                  } @@ -678,13 +679,17 @@ cdap_key_t * cdap_request_send(struct cdap *    instance,                          cdap_sent_del(instance, req);                          release_id(instance, *key);                          release_id(instance, iid); +                        *key = INVALID_CDAP_KEY;                          return keys;                  }                  if (ret < 0) { +                        pthread_rwlock_unlock(&instance->flows_lock);                          cdap_sent_del(instance, req);                          release_id(instance, *key);                          release_id(instance, iid); +                        *key = INVALID_CDAP_KEY; +                        return keys;                  }                  ++key; @@ -717,6 +722,7 @@ int cdap_reply_wait(struct cdap * instance,          if (ret < 0) {                  cdap_sent_del(instance, r);                  release_id(instance, iid); +                release_id(instance, key);                  return ret;          } @@ -731,6 +737,7 @@ int cdap_reply_wait(struct cdap * instance,          cdap_sent_del(instance, r);          release_id(instance, iid); +        release_id(instance, key);          return ret;  } @@ -766,6 +773,8 @@ cdap_key_t cdap_request_wait(struct cdap *      instance,                  }          } +        assert(rcv->proc == false); +          rcv->proc = true;          list_del(&rcv->next);          list_add_tail(&rcv->next, &instance->rcvd); | 
