summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSander Vrijders <[email protected]>2016-08-29 10:50:43 +0200
committerSander Vrijders <[email protected]>2016-08-29 10:50:43 +0200
commitcaeefb4d96331d24b38e845c99d0517913a71671 (patch)
treea9dbfceba99190181f0d427fb98bb964031d9548
parentda0739d8dea1235a047095c08cfe67871c3c216e (diff)
parentbb2e24baf3f05c03450defd4c22a8a1279698bb1 (diff)
downloadouroboros-caeefb4d96331d24b38e845c99d0517913a71671.tar.gz
ouroboros-caeefb4d96331d24b38e845c99d0517913a71671.zip
Merged in dstaesse/ouroboros/be-bugfixing (pull request #228)
Some fixes
-rw-r--r--src/irmd/api_table.c10
-rw-r--r--src/irmd/api_table.h2
-rw-r--r--src/lib/cdap.c11
3 files changed, 14 insertions, 9 deletions
diff --git a/src/irmd/api_table.c b/src/irmd/api_table.c
index 2747ed1a..519b4efe 100644
--- a/src/irmd/api_table.c
+++ b/src/irmd/api_table.c
@@ -70,6 +70,11 @@ void api_entry_destroy(struct api_entry * e)
pthread_mutex_lock(&e->state_lock);
+ if (e->state == API_DESTROY) {
+ pthread_mutex_unlock(&e->state_lock);
+ return;
+ }
+
if (e->state == API_SLEEP)
e->state = API_DESTROY;
@@ -163,6 +168,9 @@ int api_entry_sleep(struct api_entry * e)
}
}
+ if (e->state == API_DESTROY)
+ ret = -1;
+
e->state = API_INIT;
pthread_cond_broadcast(&e->state_cond);
pthread_mutex_unlock(&e->state_lock);
@@ -177,7 +185,7 @@ void api_entry_wake(struct api_entry * e, struct reg_entry * re)
pthread_mutex_lock(&e->state_lock);
- if (e->state == API_NULL) {
+ if (e->state != API_SLEEP) {
pthread_mutex_unlock(&e->state_lock);
return;
}
diff --git a/src/irmd/api_table.h b/src/irmd/api_table.h
index 0758fdb8..8741a86b 100644
--- a/src/irmd/api_table.h
+++ b/src/irmd/api_table.h
@@ -41,7 +41,7 @@ struct api_entry {
pid_t api;
char * apn; /* application process instantiated */
char * daf_name; /* DAF this AP-I belongs to */
- struct list_head names; /* names for which this api accepts flows */
+ struct list_head names; /* names for which api accepts flows */
struct reg_entry * re; /* reg_entry for which a flow arrived */
diff --git a/src/lib/cdap.c b/src/lib/cdap.c
index 5dc050a4..8b1b3bc6 100644
--- a/src/lib/cdap.c
+++ b/src/lib/cdap.c
@@ -107,7 +107,7 @@ static void * handle_cdap_msg(void * o)
case OPCODE__DELETE:
if (msg->name != NULL &&
msg->has_value)
- instance->ops->cdap_create(instance,
+ instance->ops->cdap_delete(instance,
msg->invoke_id,
msg->name,
msg->value.data,
@@ -230,12 +230,10 @@ struct cdap * cdap_create(struct cdap_ops * ops,
int cdap_destroy(struct cdap * instance)
{
if (instance == NULL)
- return -1;
+ return 0;
pthread_cancel(instance->reader);
-
- if (flow_dealloc(instance->fd))
- return -1;
+ pthread_join(instance->reader, NULL);
pthread_mutex_lock(&instance->ids_lock);
@@ -243,8 +241,7 @@ int cdap_destroy(struct cdap * instance)
pthread_mutex_unlock(&instance->ids_lock);
- pthread_join(instance->reader,
- NULL);
+ flow_dealloc(instance->fd);
free(instance);