diff options
author | dimitri staessens <[email protected]> | 2016-06-16 12:43:39 +0200 |
---|---|---|
committer | dimitri staessens <[email protected]> | 2016-06-16 12:47:55 +0200 |
commit | e7d7632549947fa867d6bec504442647862ad9b8 (patch) | |
tree | 75158ce721b25b838b129faedb5490590a2392cb /src | |
parent | 18318ecbd33544438f7ec870437ff93f6d286c07 (diff) | |
download | ouroboros-e7d7632549947fa867d6bec504442647862ad9b8.tar.gz ouroboros-e7d7632549947fa867d6bec504442647862ad9b8.zip |
ipcpd: fixed locking and cleanup
The ipcpds didn't unlock the flows lock when the dst_name is
unbeknownst to the IRMd.
Diffstat (limited to 'src')
-rw-r--r-- | src/ipcpd/local/main.c | 5 | ||||
-rw-r--r-- | src/ipcpd/shim-udp/main.c | 1 |
2 files changed, 5 insertions, 1 deletions
diff --git a/src/ipcpd/local/main.c b/src/ipcpd/local/main.c index 6357487f..43ca14da 100644 --- a/src/ipcpd/local/main.c +++ b/src/ipcpd/local/main.c @@ -365,8 +365,10 @@ static int ipcp_local_flow_alloc(pid_t n_pid, } rb = shm_ap_rbuff_open(n_pid); - if (rb == NULL) + if (rb == NULL) { + rw_lock_unlock(&_ipcp->state_lock); return -1; /* -ENORBUFF */ + } rw_lock_wrlock(&_ap_instance->flows_lock); @@ -389,6 +391,7 @@ static int ipcp_local_flow_alloc(pid_t n_pid, src_ae_name); if (port_id < 0) { + rw_lock_unlock(&_ap_instance->flows_lock); rw_lock_unlock(&_ipcp->state_lock); LOG_ERR("Could not get port id from IRMd"); /* shm_ap_rbuff_close(n_pid); */ diff --git a/src/ipcpd/shim-udp/main.c b/src/ipcpd/shim-udp/main.c index 99fb134d..f583a998 100644 --- a/src/ipcpd/shim-udp/main.c +++ b/src/ipcpd/shim-udp/main.c @@ -486,6 +486,7 @@ static int ipcp_udp_port_req(struct sockaddr_in * c_saddr, src_ae_name); if (port_id < 0) { + rw_lock_unlock(&_ap_instance->flows_lock); rw_lock_unlock(&_ipcp->state_lock); LOG_ERR("Could not get port id from IRMd"); close(fd); |