From 5942ad15bea544cb1f1e603691010ab5b18ebd67 Mon Sep 17 00:00:00 2001 From: Erayd Date: Fri, 22 May 2015 09:19:41 +1200 Subject: [PATCH] Add some sanity checks to skiplist functions --- src/libec/include/ec.h | 1 + src/libec/misc/skiplist.c | 10 +++++++++- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/src/libec/include/ec.h b/src/libec/include/ec.h index cba0396..66d6bf4 100644 --- a/src/libec/include/ec.h +++ b/src/libec/include/ec.h @@ -54,6 +54,7 @@ char *ec_errstr(ec_err_t error); #define EC_ENOCTX 26 /*no context*/ #define EC_ENOVALIDATOR 27 /*no validator*/ #define EC_EREQUIRED 28 /*required record does not validate*/ +#define EC_EUNDEFINED 29 /*undefined data*/ //flags #define EC_CERT_TRUSTED (1 << 0) /*cert is a trust anchor*/ diff --git a/src/libec/misc/skiplist.c b/src/libec/misc/skiplist.c index 6112cc5..d21d5e7 100644 --- a/src/libec/misc/skiplist.c +++ b/src/libec/misc/skiplist.c @@ -69,6 +69,8 @@ ec_sl_cursor_t *ec_sl_cursor(ec_sl_t *l, ec_sl_cursor_t *c, void *key) { * Sets & returns errno on failure, otherwise returns zero */ int ec_sl_insert(ec_sl_t *l, ec_sl_cursor_t *c, void *data) { + if(!data) + return EC_EUNDEFINED; //set element level int level = 1; while(level < EC_SL_MAXLEVEL && rand() % 2) @@ -94,12 +96,14 @@ int ec_sl_insert(ec_sl_t *l, ec_sl_cursor_t *c, void *data) { * Get the element data for a given key. Returns NULL if not found. */ void *ec_sl_get(ec_sl_t *l, void *key) { + if(!key) + return NULL; ec_sl_node_t *n = l->start; for(int level = l->level; level; level--) { while(n[level].next && (!key || l->compfn(key, n[level].next->data) >= 0)) n = n[level].next; } - return (n->data && !l->compfn(key, n->data)) ?n->data : NULL; + return (n->data && !l->compfn(key, n->data)) ? n->data : NULL; } /** @@ -108,6 +112,8 @@ void *ec_sl_get(ec_sl_t *l, void *key) { * Sets & returns errno on failure, otherwise returns zero. */ int ec_sl_set(ec_sl_t *l, void *key, void *data, ec_sl_freefn_t freefn) { + if(!key || !data) + return EC_EUNDEFINED; ec_sl_cursor_t c; ec_sl_cursor(l, &c, key); if(c[1]->next && !l->compfn(key, c[1]->next->data)) { @@ -124,6 +130,8 @@ int ec_sl_set(ec_sl_t *l, void *key, void *data, ec_sl_freefn_t freefn) { * Remove the element for a given key, if it exists */ void ec_sl_remove(ec_sl_t *l, void *key, ec_sl_freefn_t freefn) { + if(!key) + return NULL; ec_sl_cursor_t c; ec_sl_cursor(l, &c, key); ec_sl_node_t *n = c[1]->next;