summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSander Vrijders <sander.vrijders@intec.ugent.be>2016-09-03 21:08:23 +0200
committerSander Vrijders <sander.vrijders@intec.ugent.be>2016-09-03 21:08:23 +0200
commitd35685c537e7809d5c4a213fcfa553d8a522bc51 (patch)
treefcaf558cf7cb7153ccde33c3fa387741b89f781d
parent19045fa2bb08e598ec5e6f95c1b5e7e9bbb284bc (diff)
parentc7a43ef51e332bcb8c6a97f9a660ed52a912c1be (diff)
downloadouroboros-d35685c537e7809d5c4a213fcfa553d8a522bc51.tar.gz
ouroboros-d35685c537e7809d5c4a213fcfa553d8a522bc51.zip
Merged in dstaesse/ouroboros/be-dev-refactor (pull request #241)
lib: dev: Add fd lookup table
-rw-r--r--src/lib/dev.c48
1 files changed, 25 insertions, 23 deletions
diff --git a/src/lib/dev.c b/src/lib/dev.c
index ee1e7656..b7de921d 100644
--- a/src/lib/dev.c
+++ b/src/lib/dev.c
@@ -53,6 +53,8 @@ struct ap_instance {
pthread_rwlock_t data_lock;
struct flow flows[AP_MAX_FLOWS];
+ int ports[AP_MAX_FLOWS];
+
pthread_rwlock_t flows_lock;
} * ai;
@@ -129,6 +131,7 @@ int ap_init(char * ap_name)
ai->flows[i].oflags = 0;
ai->flows[i].api = -1;
ai->flows[i].timeout = NULL;
+ ai->ports[i] = -1;
}
pthread_rwlock_init(&ai->flows_lock, NULL);
@@ -165,9 +168,11 @@ void ap_fini(void)
pthread_rwlock_rdlock(&ai->flows_lock);
- for (i = 0; i < AP_MAX_FLOWS; ++i)
+ for (i = 0; i < AP_MAX_FLOWS; ++i) {
if (ai->flows[i].rb != NULL)
shm_ap_rbuff_close(ai->flows[i].rb);
+ ai->ports[ai->flows[i].port_id] = -1;
+ }
pthread_rwlock_unlock(&ai->flows_lock);
pthread_rwlock_unlock(&ai->data_lock);
@@ -178,20 +183,11 @@ void ap_fini(void)
free(ai);
}
-static int port_id_to_fd(int port_id)
-{
- int i;
- for (i = 0; i < AP_MAX_FLOWS; ++i)
- if (ai->flows[i].port_id == port_id)
- return i;
- return -1;
-}
-
int flow_accept(char ** ae_name)
{
irm_msg_t msg = IRM_MSG__INIT;
irm_msg_t * recv_msg = NULL;
- int cfd = -1;
+ int fd = -1;
msg.code = IRM_MSG_CODE__IRM_FLOW_ACCEPT;
msg.has_api = true;
@@ -214,17 +210,17 @@ int flow_accept(char ** ae_name)
pthread_rwlock_rdlock(&ai->data_lock);
pthread_rwlock_wrlock(&ai->flows_lock);
- cfd = bmp_allocate(ai->fds);
- if (!bmp_is_id_valid(ai->fds, cfd)) {
+ fd = bmp_allocate(ai->fds);
+ if (!bmp_is_id_valid(ai->fds, fd)) {
pthread_rwlock_unlock(&ai->flows_lock);
pthread_rwlock_unlock(&ai->data_lock);
irm_msg__free_unpacked(recv_msg, NULL);
return -1;
}
- ai->flows[cfd].rb = shm_ap_rbuff_open_n(recv_msg->api);
- if (ai->flows[cfd].rb == NULL) {
- bmp_release(ai->fds, cfd);
+ ai->flows[fd].rb = shm_ap_rbuff_open_n(recv_msg->api);
+ if (ai->flows[fd].rb == NULL) {
+ bmp_release(ai->fds, fd);
pthread_rwlock_unlock(&ai->flows_lock);
pthread_rwlock_unlock(&ai->data_lock);
irm_msg__free_unpacked(recv_msg, NULL);
@@ -234,8 +230,8 @@ int flow_accept(char ** ae_name)
if (ae_name != NULL) {
*ae_name = strdup(recv_msg->ae_name);
if (*ae_name == NULL) {
- shm_ap_rbuff_close(ai->flows[cfd].rb);
- bmp_release(ai->fds, cfd);
+ shm_ap_rbuff_close(ai->flows[fd].rb);
+ bmp_release(ai->fds, fd);
pthread_rwlock_unlock(&ai->flows_lock);
pthread_rwlock_unlock(&ai->data_lock);
irm_msg__free_unpacked(recv_msg, NULL);
@@ -243,16 +239,18 @@ int flow_accept(char ** ae_name)
}
}
- ai->flows[cfd].port_id = recv_msg->port_id;
- ai->flows[cfd].oflags = FLOW_O_DEFAULT;
- ai->flows[cfd].api = recv_msg->api;
+ ai->flows[fd].port_id = recv_msg->port_id;
+ ai->flows[fd].oflags = FLOW_O_DEFAULT;
+ ai->flows[fd].api = recv_msg->api;
+
+ ai->ports[recv_msg->port_id] = fd;
pthread_rwlock_unlock(&ai->flows_lock);
pthread_rwlock_unlock(&ai->data_lock);
irm_msg__free_unpacked(recv_msg, NULL);
- return cfd;
+ return fd;
}
int flow_alloc_resp(int fd,
@@ -366,6 +364,8 @@ int flow_alloc(char * dst_name,
ai->flows[fd].oflags = FLOW_O_DEFAULT;
ai->flows[fd].api = recv_msg->api;
+ ai->ports[recv_msg->port_id] = fd;
+
pthread_rwlock_unlock(&ai->flows_lock);
pthread_rwlock_unlock(&ai->data_lock);
@@ -439,6 +439,8 @@ int flow_dealloc(int fd)
msg.port_id = ai->flows[fd].port_id;
+ ai->ports[msg.port_id] = -1;
+
ai->flows[fd].port_id = -1;
shm_ap_rbuff_close(ai->flows[fd].rb);
ai->flows[fd].rb = NULL;
@@ -580,7 +582,7 @@ int flow_select(const struct timespec * timeout)
int port_id = shm_ap_rbuff_peek_b(ai->rb, timeout);
if (port_id < 0)
return port_id;
- return port_id_to_fd(port_id);
+ return ai->ports[port_id];
}
ssize_t flow_read(int fd, void * buf, size_t count)