Major cleanup and use hdb.c abstracted out functions

now instead of internal hacked together stuff that was
there previously.

(Logical change 1.44)


git-svn-id: http://svn.fedorahosted.org/svn/corosync/trunk@130 fd59a12c-fef9-0310-b244-a6a79926bd2f
This commit is contained in:
Steven Dake 2004-07-27 23:30:47 +00:00
parent 21d72de996
commit 71bf042ce9

View File

@ -39,6 +39,8 @@
#include "aispoll.h"
#include "../include/list.h"
#include "hdb.h"
#include "../include/ais_types.h"
#include "tlist.h"
typedef int (*dispatch_fn_t) (poll_handle poll_handle, int fd, int revents, void *data);
@ -49,166 +51,57 @@ struct poll_instance {
dispatch_fn_t *dispatch_fns;
void **data;
struct timerlist timerlist;
pthread_mutex_t mutex;
};
#define POLLINSTANCE_MUTEX_OFFSET offset_of(struct poll_instance, mutex)
struct handle {
int valid;
void *instance;
unsigned int generation;
};
struct handle_database {
unsigned int handle_count;
struct handle *handles;
unsigned int generation;
pthread_mutex_t mutex;
};
#define offset_of(type,member) (int)(&(((type *)0)->member))
#define HANDLECONVERT_NOLOCKING 0x80000000
#define HANDLECONVERT_DONTUNLOCKDB 0x40000000
int handle_create (
struct handle_database *handle_database,
void **instance_out,
int instance_size,
int *handle_out)
{
int handle;
void *new_handles;
int found = 0;
void *instance;
pthread_mutex_lock (&handle_database->mutex);
for (handle = 0; handle < handle_database->handle_count; handle++) {
if (handle_database->handles[handle].valid == 0) {
found = 1;
break;
}
}
if (found == 0) {
handle_database->handle_count += 1;
new_handles = (struct handle *)realloc (handle_database->handles,
sizeof (struct handle) * handle_database->handle_count);
if (new_handles == 0) {
pthread_mutex_unlock (&handle_database->mutex);
errno = ENOMEM;
return (-1);
}
handle_database->handles = new_handles;
}
instance = (void *)malloc (instance_size);
if (instance == 0) {
errno = ENOMEM;
return (-1);
}
memset (instance, 0, instance_size);
handle_database->handles[handle].valid = 1;
handle_database->handles[handle].instance = instance;
handle_database->handles[handle].generation = handle_database->generation++;
*handle_out = handle;
*instance_out = instance;
pthread_mutex_unlock (&handle_database->mutex);
return (0);
}
int handle_convert (
struct handle_database *handle_database,
unsigned int handle,
void **instance,
int offset_to_mutex,
unsigned int *generation_out)
{
int unlock_db;
int locking;
unlock_db = (0 == (offset_to_mutex & HANDLECONVERT_DONTUNLOCKDB));
locking = (0 == (offset_to_mutex & HANDLECONVERT_NOLOCKING));
offset_to_mutex &= 0x00fffff; /* remove 8 bits of flags */
if (locking) {
pthread_mutex_lock (&handle_database->mutex);
}
/* Add this later
res = saHandleVerify (handle_database, handle);
if (res == -1) {
if (locking) {
pthread_mutex_unlock (&handle_database->mutex);
}
errno = ENOENT;
return (-1);
}
*/
*instance = handle_database->handles[handle].instance;
if (generation_out) {
*generation_out = handle_database->handles[handle].generation;
}
/*
* This function exits holding the mutex in the instance instance
* pointed to by offset_to_mutex (if NOLOCKING isn't set)
*/
if (locking) {
pthread_mutex_lock ((pthread_mutex_t *)(*instance + offset_to_mutex));
if (unlock_db) {
pthread_mutex_unlock (&handle_database->mutex);
}
}
return (0);
}
/*
* All instances in one database
*/
static struct handle_database poll_instance_database = {
.handle_count = 0,
.handles = 0,
.generation = 0,
.mutex = PTHREAD_MUTEX_INITIALIZER
static struct saHandleDatabase poll_instance_database = {
.handleCount = 0,
.handles = 0,
.handleInstanceDestructor = 0
};
poll_handle poll_create (void)
{
poll_handle poll_handle;
poll_handle handle;
struct poll_instance *poll_instance;
int res;
SaErrorT error;
res = handle_create (&poll_instance_database, (void *)&poll_instance,
sizeof (struct poll_instance), &poll_handle);
if (res == -1) {
error = saHandleCreate (&poll_instance_database,
sizeof (struct poll_instance), &handle);
if (error != SA_OK) {
goto error_exit;
}
error = saHandleInstanceGet (&poll_instance_database, handle,
(void *)&poll_instance);
if (error != SA_OK) {
goto error_destroy;
}
poll_instance->ufds = 0;
poll_instance->nfds = 0;
poll_instance->dispatch_fns = 0;
poll_instance->data = 0;
timerlist_init (&poll_instance->timerlist);
return (poll_handle);
return (handle);
error_destroy:
saHandleDestroy (&poll_instance_database, handle);
error_exit:
return (-1);
}
int poll_destroy (poll_handle poll_handle)
int poll_destroy (poll_handle handle)
{
struct poll_instance *poll_instance;
int res;
SaErrorT error;
res = handle_convert (&poll_instance_database, poll_handle,
(void *)&poll_instance, POLLINSTANCE_MUTEX_OFFSET, 0);
if (res == -1) {
error = saHandleInstanceGet (&poll_instance_database, handle,
(void *)&poll_instance);
if (error != SA_OK) {
goto error_exit;
}
@ -222,7 +115,10 @@ int poll_destroy (poll_handle poll_handle)
free (poll_instance->data);
}
timerlist_free (&poll_instance->timerlist);
// TODO destroy poll
saHandleDestroy (&poll_instance_database, handle);
saHandleInstancePut (&poll_instance_database, handle);
return (0);
@ -241,14 +137,13 @@ int poll_dispatch_add (
struct pollfd *ufds;
dispatch_fn_t *dispatch_fns;
void **data_list;
int res;
int found = 0;
int install_pos;
SaErrorT error;
res = handle_convert (&poll_instance_database, handle,
(void *)&poll_instance, POLLINSTANCE_MUTEX_OFFSET, 0);
if (res == -1) {
error = saHandleInstanceGet (&poll_instance_database, handle,
(void *)&poll_instance);
if (error != SA_OK) {
goto error_exit;
}
@ -306,6 +201,8 @@ int poll_dispatch_add (
poll_instance->dispatch_fns[install_pos] = dispatch_fn;
poll_instance->data[install_pos] = data;
saHandleInstancePut (&poll_instance_database, handle);
return (0);
error_exit:
@ -320,12 +217,12 @@ int poll_dispatch_modify (
{
struct poll_instance *poll_instance;
int i;
int res;
SaErrorT error;
res = handle_convert (&poll_instance_database, handle,
(void *)&poll_instance, POLLINSTANCE_MUTEX_OFFSET, 0);
if (res == -1) {
return (-1);
error = saHandleInstanceGet (&poll_instance_database, handle,
(void *)&poll_instance);
if (error != SA_OK) {
goto error_exit;
}
/*
@ -340,6 +237,10 @@ int poll_dispatch_modify (
}
errno = EBADF;
saHandleInstancePut (&poll_instance_database, handle);
error_exit:
return (-1);
}
@ -349,12 +250,12 @@ int poll_dispatch_delete (
{
struct poll_instance *poll_instance;
int i;
int res;
SaErrorT error;
int found = 0;
res = handle_convert (&poll_instance_database, handle,
(void *)&poll_instance, POLLINSTANCE_MUTEX_OFFSET, 0);
if (res == -1) {
error = saHandleInstanceGet (&poll_instance_database, handle,
(void *)&poll_instance);
if (error != SA_OK) {
goto error_exit;
}
@ -370,9 +271,12 @@ int poll_dispatch_delete (
if (found) {
poll_instance->ufds[i].fd = -1;
saHandleInstancePut (&poll_instance_database, handle);
return (0);
}
saHandleInstancePut (&poll_instance_database, handle);
error_exit:
errno = EBADF;
return (-1);
@ -386,12 +290,13 @@ int poll_timer_add (
{
struct poll_instance *poll_instance;
poll_timer_handle timer_handle;
int res;
int res = -1;
SaErrorT error;
res = handle_convert (&poll_instance_database, handle,
(void *)&poll_instance, POLLINSTANCE_MUTEX_OFFSET, 0);
if (res == -1) {
return (-1);
error = saHandleInstanceGet (&poll_instance_database, handle,
(void *)&poll_instance);
if (error != SA_OK) {
goto error_exit;
}
timer_handle = (poll_timer_handle)timerlist_add_future (&poll_instance->timerlist,
@ -399,9 +304,12 @@ int poll_timer_add (
if (timer_handle != 0) {
*timer_handle_out = timer_handle;
return (0);
res = 0;
}
return (-1);
saHandleInstancePut (&poll_instance_database, handle);
error_exit:
return (res);
}
int poll_timer_delete (
@ -409,19 +317,25 @@ int poll_timer_delete (
poll_timer_handle timer_handle)
{
struct poll_instance *poll_instance;
int res;
SaErrorT error;
if (timer_handle == 0) {
return (0);
}
res = handle_convert (&poll_instance_database, handle,
(void *)&poll_instance, POLLINSTANCE_MUTEX_OFFSET, 0);
if (res == -1) {
return (-1);
error = saHandleInstanceGet (&poll_instance_database, handle,
(void *)&poll_instance);
if (error != SA_OK) {
goto error_exit;
}
timerlist_del (&poll_instance->timerlist, (void *)timer_handle);
saHandleInstancePut (&poll_instance_database, handle);
return (0);
error_exit:
return (-1);
}
int poll_run (
@ -431,10 +345,11 @@ int poll_run (
int i;
int timeout = -1;
int res;
SaErrorT error;
res = handle_convert (&poll_instance_database, handle,
(void *)&poll_instance, POLLINSTANCE_MUTEX_OFFSET, 0);
if (res == -1) {
error = saHandleInstanceGet (&poll_instance_database, handle,
(void *)&poll_instance);
if (error != SA_OK) {
goto error_exit;
}
@ -469,6 +384,7 @@ retry_poll:
timerlist_expire (&poll_instance->timerlist);
} /* for (;;) */
saHandleInstancePut (&poll_instance_database, handle);
error_exit:
return (-1);
}