diff options
| author | dimitri staessens <dimitri.staessens@intec.ugent.be> | 2016-06-30 23:14:14 +0200 | 
|---|---|---|
| committer | dimitri staessens <dimitri.staessens@intec.ugent.be> | 2016-07-02 19:11:12 +0200 | 
| commit | 79475a4742bc28e1737044f2300bcb601e6e10bf (patch) | |
| tree | cd79dba391c0ded80125836069d8187a22f7e5f5 /src/irmd | |
| parent | d85f211d53a0cb35a756d0c44a2b28807eff4e5d (diff) | |
| download | ouroboros-79475a4742bc28e1737044f2300bcb601e6e10bf.tar.gz ouroboros-79475a4742bc28e1737044f2300bcb601e6e10bf.zip | |
lib: robust locking in shared memory and crash recovery
This PR enhances the shared memory providing recovery if a process
crashes. It adds a SHM_DU_TIMEOUT_MICROS variable, setting an
expiration time for SDU's when shared memory is full. If an
application doesn't read a blocking SDU within this time, the shared
memory will be cleansed of all SDU's for this application and the
application's rbuff will be cleared.
Some refactoring of the API's. Fixed wrong pthread checks in IRMd.
Fixes #13
Fixes #14
Diffstat (limited to 'src/irmd')
| -rw-r--r-- | src/irmd/main.c | 18 | 
1 files changed, 14 insertions, 4 deletions
| diff --git a/src/irmd/main.c b/src/irmd/main.c index 5ff84da1..b4771b89 100644 --- a/src/irmd/main.c +++ b/src/irmd/main.c @@ -30,6 +30,7 @@  #include <ouroboros/list.h>  #include <ouroboros/utils.h>  #include <ouroboros/irm_config.h> +#include <ouroboros/shm_ap_rbuff.h>  #include <ouroboros/shm_du_map.h>  #include <ouroboros/bitmap.h>  #include <ouroboros/flow.h> @@ -163,7 +164,7 @@ static void reg_instance_destroy(struct reg_instance * i)          while (wait) {                  pthread_mutex_lock(&i->mutex); -                if (pthread_cond_destroy(&i->wakeup) < 0) +                if (pthread_cond_destroy(&i->wakeup))                          pthread_cond_broadcast(&i->wakeup);                  else                          wait = false; @@ -291,7 +292,7 @@ static void port_map_entry_destroy(struct port_map_entry * e)          while (wait) {                  pthread_mutex_lock(&e->res_lock); -                if (pthread_cond_destroy(&e->res_signal) < 0) +                if (pthread_cond_destroy(&e->res_signal))                          pthread_cond_broadcast(&e->res_signal);                  else                          wait = false; @@ -477,7 +478,7 @@ static void reg_entry_destroy(struct reg_entry * e)          while (wait) {                  pthread_mutex_lock(&e->state_lock); -                if (pthread_cond_destroy(&e->acc_signal) < 0) +                if (pthread_cond_destroy(&e->acc_signal))                          pthread_cond_broadcast(&e->acc_signal);                  else                          wait = false; @@ -1942,18 +1943,26 @@ void * irm_flow_cleaner()                          pthread_mutex_unlock(&e->res_lock);                          if (kill(e->n_api, 0) < 0) { +                                struct shm_ap_rbuff * n_rb = +                                        shm_ap_rbuff_open(e->n_api);                                  bmp_release(instance->port_ids, e->port_id);                                  list_del(&e->next);                                  LOG_INFO("Process %d gone, %d deallocated.",                                           e->n_api, e->port_id);                                  ipcp_flow_dealloc(e->n_1_api, e->port_id); +                                if (n_rb != NULL) +                                        shm_ap_rbuff_destroy(n_rb);                                  port_map_entry_destroy(e);                          }                          if (kill(e->n_1_api, 0) < 0) { +                                struct shm_ap_rbuff * n_1_rb = +                                        shm_ap_rbuff_open(e->n_1_api);                                  list_del(&e->next);                                  LOG_ERR("IPCP %d gone, flow %d removed.",                                          e->n_1_api, e->port_id); +                                if (n_1_rb != NULL) +                                        shm_ap_rbuff_destroy(n_1_rb);                                  port_map_entry_destroy(e);                          }                  } @@ -2205,7 +2214,8 @@ static struct irm * irm_create()                          shm_du_map_destroy(dum);                          LOG_INFO("Stale shm file removed.");                  } else { -                        LOG_INFO("IRMd already running, exiting."); +                        LOG_INFO("IRMd already running (%d), exiting.", +                                 shm_du_map_owner(dum));                          free(instance);                          exit(EXIT_SUCCESS);                  } | 
