Next step in tidying up the LHASH code.

DECLARE/IMPLEMENT macros now exist to create type (and prototype) safe
wrapper functions that avoid the use of function pointer casting yet retain
type-safety for type-specific callbacks. However, most of the usage within
OpenSSL itself doesn't really require the extra function because the hash
and compare callbacks are internal functions declared only for use by the
hash table. So this change catches all those cases and reimplements the
functions using the base-level LHASH prototypes and does per-variable
casting inside those functions to convert to the appropriate item type.

The exception so far is in ssl_lib.c where the hash and compare callbacks
are not static - they're exposed in ssl.h so their prototypes should not be
changed. In this last case, the IMPLEMENT_LHASH_*** macros have been left
intact.
This commit is contained in:
Geoff Thorpe 2000-12-08 20:02:01 +00:00
parent 15156cce0e
commit d0fa136ce2
7 changed files with 96 additions and 73 deletions

View File

@ -73,8 +73,15 @@
#include "s_apps.h" #include "s_apps.h"
#include <openssl/err.h> #include <openssl/err.h>
static unsigned long MS_CALLBACK hash(FUNCTION *a); /* The LHASH callbacks ("hash" & "cmp") have been replaced by functions with the
static int MS_CALLBACK cmp(FUNCTION *a,FUNCTION *b); * base prototypes (we cast each variable inside the function to the required
* type of "FUNCTION*"). This removes the necessity for macro-generated wrapper
* functions. */
/* static unsigned long MS_CALLBACK hash(FUNCTION *a); */
static unsigned long MS_CALLBACK hash(void *a_void);
/* static int MS_CALLBACK cmp(FUNCTION *a,FUNCTION *b); */
static int MS_CALLBACK cmp(void *a_void,void *b_void);
static LHASH *prog_init(void ); static LHASH *prog_init(void );
static int do_cmd(LHASH *prog,int argc,char *argv[]); static int do_cmd(LHASH *prog,int argc,char *argv[]);
LHASH *config=NULL; LHASH *config=NULL;
@ -85,9 +92,6 @@ char *default_config_file=NULL;
BIO *bio_err=NULL; BIO *bio_err=NULL;
#endif #endif
static IMPLEMENT_LHASH_HASH_FN(hash,FUNCTION *)
static IMPLEMENT_LHASH_COMP_FN(cmp,FUNCTION *)
int main(int Argc, char *Argv[]) int main(int Argc, char *Argv[])
{ {
ARGS arg; ARGS arg;
@ -354,8 +358,7 @@ static LHASH *prog_init(void)
; ;
qsort(functions,i,sizeof *functions,SortFnByName); qsort(functions,i,sizeof *functions,SortFnByName);
if ((ret=lh_new(LHASH_HASH_FN(hash), if ((ret=lh_new(hash, cmp)) == NULL)
LHASH_COMP_FN(cmp))) == NULL)
return(NULL); return(NULL);
for (f=functions; f->name != NULL; f++) for (f=functions; f->name != NULL; f++)
@ -363,12 +366,15 @@ static LHASH *prog_init(void)
return(ret); return(ret);
} }
static int MS_CALLBACK cmp(FUNCTION *a, FUNCTION *b) /* static int MS_CALLBACK cmp(FUNCTION *a, FUNCTION *b) */
static int MS_CALLBACK cmp(void *a_void, void *b_void)
{ {
return(strncmp(a->name,b->name,8)); return(strncmp(((FUNCTION *)a_void)->name,
((FUNCTION *)b_void)->name,8));
} }
static unsigned long MS_CALLBACK hash(FUNCTION *a) /* static unsigned long MS_CALLBACK hash(FUNCTION *a) */
static unsigned long MS_CALLBACK hash(void *a_void)
{ {
return(lh_strhash(a->name)); return(lh_strhash(((FUNCTION *)a_void)->name));
} }

View File

@ -70,11 +70,12 @@
static void value_free_hash(CONF_VALUE *a, LHASH *conf); static void value_free_hash(CONF_VALUE *a, LHASH *conf);
static void value_free_stack(CONF_VALUE *a,LHASH *conf); static void value_free_stack(CONF_VALUE *a,LHASH *conf);
static unsigned long hash(CONF_VALUE *v); /* We don't use function pointer casting or wrapper functions - but cast each
static int cmp_conf(CONF_VALUE *a,CONF_VALUE *b); * callback parameter inside the callback functions. */
/* static unsigned long hash(CONF_VALUE *v); */
static IMPLEMENT_LHASH_HASH_FN(hash, CONF_VALUE *) static unsigned long hash(void *v_void);
static IMPLEMENT_LHASH_COMP_FN(cmp_conf, CONF_VALUE *) /* static int cmp_conf(CONF_VALUE *a,CONF_VALUE *b); */
static int cmp_conf(void *a_void,void *b_void);
/* Up until OpenSSL 0.9.5a, this was get_section */ /* Up until OpenSSL 0.9.5a, this was get_section */
CONF_VALUE *_CONF_get_section(CONF *conf, char *section) CONF_VALUE *_CONF_get_section(CONF *conf, char *section)
@ -184,8 +185,7 @@ int _CONF_new_data(CONF *conf)
return 0; return 0;
} }
if (conf->data == NULL) if (conf->data == NULL)
if ((conf->data = lh_new(LHASH_HASH_FN(hash), if ((conf->data = lh_new(hash, cmp_conf)) == NULL)
LHASH_COMP_FN(cmp_conf))) == NULL)
{ {
return 0; return 0;
} }
@ -238,14 +238,19 @@ static void value_free_stack(CONF_VALUE *a, LHASH *conf)
OPENSSL_free(a); OPENSSL_free(a);
} }
static unsigned long hash(CONF_VALUE *v) /* static unsigned long hash(CONF_VALUE *v) */
static unsigned long hash(void *v_void)
{ {
CONF_VALUE *v = (CONF_VALUE *)v_void;
return((lh_strhash(v->section)<<2)^lh_strhash(v->name)); return((lh_strhash(v->section)<<2)^lh_strhash(v->name));
} }
static int cmp_conf(CONF_VALUE *a, CONF_VALUE *b) /* static int cmp_conf(CONF_VALUE *a, CONF_VALUE *b) */
static int cmp_conf(void *a_void, void *b_void)
{ {
int i; int i;
CONF_VALUE *a = (CONF_VALUE *)a_void;
CONF_VALUE *b = (CONF_VALUE *)b_void;
if (a->section != b->section) if (a->section != b->section)
{ {

View File

@ -123,18 +123,17 @@
static LHASH *error_hash=NULL; static LHASH *error_hash=NULL;
static LHASH *thread_hash=NULL; static LHASH *thread_hash=NULL;
static unsigned long err_hash(ERR_STRING_DATA *a); /* static unsigned long err_hash(ERR_STRING_DATA *a); */
static int err_cmp(ERR_STRING_DATA *a, ERR_STRING_DATA *b); static unsigned long err_hash(void *a_void);
static unsigned long pid_hash(ERR_STATE *pid); /* static int err_cmp(ERR_STRING_DATA *a, ERR_STRING_DATA *b); */
static int pid_cmp(ERR_STATE *a,ERR_STATE *pid); static int err_cmp(void *a_void, void *b_void);
/* static unsigned long pid_hash(ERR_STATE *pid); */
static unsigned long pid_hash(void *pid_void);
/* static int pid_cmp(ERR_STATE *a,ERR_STATE *pid); */
static int pid_cmp(void *a_void,void *pid_void);
static unsigned long get_error_values(int inc,const char **file,int *line, static unsigned long get_error_values(int inc,const char **file,int *line,
const char **data,int *flags); const char **data,int *flags);
static IMPLEMENT_LHASH_HASH_FN(err_hash, ERR_STRING_DATA *)
static IMPLEMENT_LHASH_COMP_FN(err_cmp, ERR_STRING_DATA *)
static IMPLEMENT_LHASH_HASH_FN(pid_hash, ERR_STATE *)
static IMPLEMENT_LHASH_COMP_FN(pid_cmp, ERR_STATE *)
static void ERR_STATE_free(ERR_STATE *s); static void ERR_STATE_free(ERR_STATE *s);
#ifndef NO_ERR #ifndef NO_ERR
static ERR_STRING_DATA ERR_str_libraries[]= static ERR_STRING_DATA ERR_str_libraries[]=
@ -322,8 +321,7 @@ void ERR_load_strings(int lib, ERR_STRING_DATA *str)
if (error_hash == NULL) if (error_hash == NULL)
{ {
CRYPTO_w_lock(CRYPTO_LOCK_ERR_HASH); CRYPTO_w_lock(CRYPTO_LOCK_ERR_HASH);
error_hash=lh_new(LHASH_HASH_FN(err_hash), error_hash=lh_new(err_hash, err_cmp);
LHASH_COMP_FN(err_cmp));
if (error_hash == NULL) if (error_hash == NULL)
{ {
CRYPTO_w_unlock(CRYPTO_LOCK_ERR_HASH); CRYPTO_w_unlock(CRYPTO_LOCK_ERR_HASH);
@ -627,28 +625,34 @@ const char *ERR_reason_error_string(unsigned long e)
return((p == NULL)?NULL:p->string); return((p == NULL)?NULL:p->string);
} }
static unsigned long err_hash(ERR_STRING_DATA *a) /* static unsigned long err_hash(ERR_STRING_DATA *a) */
static unsigned long err_hash(void *a_void)
{ {
unsigned long ret,l; unsigned long ret,l;
l=a->error; l=((ERR_STRING_DATA *)a_void)->error;
ret=l^ERR_GET_LIB(l)^ERR_GET_FUNC(l); ret=l^ERR_GET_LIB(l)^ERR_GET_FUNC(l);
return(ret^ret%19*13); return(ret^ret%19*13);
} }
static int err_cmp(ERR_STRING_DATA *a, ERR_STRING_DATA *b) /* static int err_cmp(ERR_STRING_DATA *a, ERR_STRING_DATA *b) */
static int err_cmp(void *a_void, void *b_void)
{ {
return((int)(a->error-b->error)); return((int)(((ERR_STRING_DATA *)a_void)->error -
((ERR_STRING_DATA *)b_void)->error));
} }
static unsigned long pid_hash(ERR_STATE *a) /* static unsigned long pid_hash(ERR_STATE *a) */
static unsigned long pid_hash(void *a_void)
{ {
return(a->pid*13); return(((ERR_STATE *)a_void)->pid*13);
} }
static int pid_cmp(ERR_STATE *a, ERR_STATE *b) /* static int pid_cmp(ERR_STATE *a, ERR_STATE *b) */
static int pid_cmp(void *a_void, void *b_void)
{ {
return((int)((long)a->pid - (long)b->pid)); return((int)((long)((ERR_STATE *)a_void)->pid -
(long)((ERR_STATE *)b_void)->pid));
} }
void ERR_remove_state(unsigned long pid) void ERR_remove_state(unsigned long pid)
@ -713,8 +717,7 @@ ERR_STATE *ERR_get_state(void)
/* no entry yet in thread_hash for current thread - /* no entry yet in thread_hash for current thread -
* thus, it may have changed since we last looked at it */ * thus, it may have changed since we last looked at it */
if (thread_hash == NULL) if (thread_hash == NULL)
thread_hash = lh_new(LHASH_HASH_FN(pid_hash), thread_hash = lh_new(pid_hash, pid_cmp);
LHASH_COMP_FN(pid_cmp));
if (thread_hash == NULL) if (thread_hash == NULL)
thread_state_exists = 0; /* allocation error */ thread_state_exists = 0; /* allocation error */
else else

View File

@ -219,42 +219,40 @@ long CRYPTO_dbg_get_options(void)
return options; return options;
} }
static int mem_cmp(MEM *a, MEM *b) /* static int mem_cmp(MEM *a, MEM *b) */
static int mem_cmp(void *a_void, void *b_void)
{ {
return((char *)a->addr - (char *)b->addr); return((char *)((MEM *)a_void)->addr - (char *)((MEM *)b_void)->addr);
} }
static unsigned long mem_hash(MEM *a) /* static unsigned long mem_hash(MEM *a) */
static unsigned long mem_hash(void *a_void)
{ {
unsigned long ret; unsigned long ret;
ret=(unsigned long)a->addr; ret=(unsigned long)((MEM *)a_void)->addr;
ret=ret*17851+(ret>>14)*7+(ret>>4)*251; ret=ret*17851+(ret>>14)*7+(ret>>4)*251;
return(ret); return(ret);
} }
static IMPLEMENT_LHASH_HASH_FN(mem_hash, MEM *) /* static int app_info_cmp(APP_INFO *a, APP_INFO *b) */
static IMPLEMENT_LHASH_COMP_FN(mem_cmp, MEM *) static int app_info_cmp(void *a_void, void *b_void)
static int app_info_cmp(APP_INFO *a, APP_INFO *b)
{ {
return(a->thread != b->thread); return(((APP_INFO *)a_void)->thread != ((APP_INFO *)b_void)->thread);
} }
static unsigned long app_info_hash(APP_INFO *a) /* static unsigned long app_info_hash(APP_INFO *a) */
static unsigned long app_info_hash(void *a_void)
{ {
unsigned long ret; unsigned long ret;
ret=(unsigned long)a->thread; ret=(unsigned long)((APP_INFO *)a_void)->thread;
ret=ret*17851+(ret>>14)*7+(ret>>4)*251; ret=ret*17851+(ret>>14)*7+(ret>>4)*251;
return(ret); return(ret);
} }
static IMPLEMENT_LHASH_HASH_FN(app_info_hash, APP_INFO *)
static IMPLEMENT_LHASH_COMP_FN(app_info_cmp, APP_INFO *)
static APP_INFO *pop_info(void) static APP_INFO *pop_info(void)
{ {
APP_INFO tmp; APP_INFO tmp;
@ -308,8 +306,7 @@ int CRYPTO_push_info_(const char *info, const char *file, int line)
} }
if (amih == NULL) if (amih == NULL)
{ {
if ((amih=lh_new(LHASH_HASH_FN(app_info_hash), if ((amih=lh_new(app_info_hash, app_info_cmp)) == NULL)
LHASH_COMP_FN(app_info_cmp))) == NULL)
{ {
OPENSSL_free(ami); OPENSSL_free(ami);
ret=0; ret=0;
@ -401,8 +398,7 @@ void CRYPTO_dbg_malloc(void *addr, int num, const char *file, int line,
} }
if (mh == NULL) if (mh == NULL)
{ {
if ((mh=lh_new(LHASH_HASH_FN(mem_hash), if ((mh=lh_new(mem_hash, mem_cmp)) == NULL)
LHASH_COMP_FN(mem_cmp))) == NULL)
{ {
OPENSSL_free(addr); OPENSSL_free(addr);
OPENSSL_free(m); OPENSSL_free(m);

View File

@ -24,18 +24,20 @@ IMPLEMENT_STACK_OF(NAME_FUNCS)
static STACK_OF(NAME_FUNCS) *name_funcs_stack; static STACK_OF(NAME_FUNCS) *name_funcs_stack;
static unsigned long obj_name_hash(OBJ_NAME *a); /* The LHASH callbacks now use the raw "void *" prototypes and do per-variable
static int obj_name_cmp(OBJ_NAME *a,OBJ_NAME *b); * casting in the functions. This prevents function pointer casting without the
* need for macro-generated wrapper functions. */
static IMPLEMENT_LHASH_HASH_FN(obj_name_hash, OBJ_NAME *) /* static unsigned long obj_name_hash(OBJ_NAME *a); */
static IMPLEMENT_LHASH_COMP_FN(obj_name_cmp, OBJ_NAME *) static unsigned long obj_name_hash(void *a_void);
/* static int obj_name_cmp(OBJ_NAME *a,OBJ_NAME *b); */
static int obj_name_cmp(void *a_void,void *b_void);
int OBJ_NAME_init(void) int OBJ_NAME_init(void)
{ {
if (names_lh != NULL) return(1); if (names_lh != NULL) return(1);
MemCheck_off(); MemCheck_off();
names_lh=lh_new(LHASH_HASH_FN(obj_name_hash), names_lh=lh_new(obj_name_hash, obj_name_cmp);
LHASH_COMP_FN(obj_name_cmp));
MemCheck_on(); MemCheck_on();
return(names_lh != NULL); return(names_lh != NULL);
} }
@ -85,9 +87,12 @@ int OBJ_NAME_new_index(unsigned long (*hash_func)(const char *),
return(ret); return(ret);
} }
static int obj_name_cmp(OBJ_NAME *a, OBJ_NAME *b) /* static int obj_name_cmp(OBJ_NAME *a, OBJ_NAME *b) */
static int obj_name_cmp(void *a_void, void *b_void)
{ {
int ret; int ret;
OBJ_NAME *a = (OBJ_NAME *)a_void;
OBJ_NAME *b = (OBJ_NAME *)b_void;
ret=a->type-b->type; ret=a->type-b->type;
if (ret == 0) if (ret == 0)
@ -104,9 +109,11 @@ static int obj_name_cmp(OBJ_NAME *a, OBJ_NAME *b)
return(ret); return(ret);
} }
static unsigned long obj_name_hash(OBJ_NAME *a) /* static unsigned long obj_name_hash(OBJ_NAME *a) */
static unsigned long obj_name_hash(void *a_void)
{ {
unsigned long ret; unsigned long ret;
OBJ_NAME *a = (OBJ_NAME *)a_void;
if ((name_funcs_stack != NULL) && (sk_NAME_FUNCS_num(name_funcs_stack) > a->type)) if ((name_funcs_stack != NULL) && (sk_NAME_FUNCS_num(name_funcs_stack) > a->type))
{ {

View File

@ -108,12 +108,14 @@ static int ln_cmp(const void *a, const void *b)
return(strcmp((*ap)->ln,(*bp)->ln)); return(strcmp((*ap)->ln,(*bp)->ln));
} }
static unsigned long add_hash(ADDED_OBJ *ca) /* static unsigned long add_hash(ADDED_OBJ *ca) */
static unsigned long add_hash(void *ca_void)
{ {
ASN1_OBJECT *a; ASN1_OBJECT *a;
int i; int i;
unsigned long ret=0; unsigned long ret=0;
unsigned char *p; unsigned char *p;
ADDED_OBJ *ca = (ADDED_OBJ *)ca_void;
a=ca->obj; a=ca->obj;
switch (ca->type) switch (ca->type)
@ -142,10 +144,13 @@ static unsigned long add_hash(ADDED_OBJ *ca)
return(ret); return(ret);
} }
static int add_cmp(ADDED_OBJ *ca, ADDED_OBJ *cb) /* static int add_cmp(ADDED_OBJ *ca, ADDED_OBJ *cb) */
static int add_cmp(void *ca_void, void *cb_void)
{ {
ASN1_OBJECT *a,*b; ASN1_OBJECT *a,*b;
int i; int i;
ADDED_OBJ *ca = (ADDED_OBJ *)ca_void;
ADDED_OBJ *cb = (ADDED_OBJ *)cb_void;
i=ca->type-cb->type; i=ca->type-cb->type;
if (i) return(i); if (i) return(i);
@ -174,13 +179,10 @@ static int add_cmp(ADDED_OBJ *ca, ADDED_OBJ *cb)
return(1); /* should not get here */ return(1); /* should not get here */
} }
static IMPLEMENT_LHASH_HASH_FN(add_hash, ADDED_OBJ *)
static IMPLEMENT_LHASH_COMP_FN(add_cmp, ADDED_OBJ *)
static int init_added(void) static int init_added(void)
{ {
if (added != NULL) return(1); if (added != NULL) return(1);
added=lh_new(LHASH_HASH_FN(add_hash),LHASH_COMP_FN(add_cmp)); added=lh_new(add_hash,add_cmp);
return(added != NULL); return(added != NULL);
} }

View File

@ -1101,6 +1101,10 @@ int SSL_SESSION_cmp(SSL_SESSION *a,SSL_SESSION *b)
return(memcmp(a->session_id,b->session_id,a->session_id_length)); return(memcmp(a->session_id,b->session_id,a->session_id_length));
} }
/* These wrapper functions should remain rather than redeclaring
* SSL_SESSION_hash and SSL_SESSION_cmp for void* types and casting each
* variable. The reason is that the functions aren't static, they're exposed via
* ssl.h. */
static IMPLEMENT_LHASH_HASH_FN(SSL_SESSION_hash, SSL_SESSION *) static IMPLEMENT_LHASH_HASH_FN(SSL_SESSION_hash, SSL_SESSION *)
static IMPLEMENT_LHASH_COMP_FN(SSL_SESSION_cmp, SSL_SESSION *) static IMPLEMENT_LHASH_COMP_FN(SSL_SESSION_cmp, SSL_SESSION *)