#define UP_LOAD (2*LH_LOAD_MULT) /* load times 256 (default 2) */
#define DOWN_LOAD (LH_LOAD_MULT) /* load times 256 (default 1) */
-static void expand(OPENSSL_LHASH *lh);
+static int expand(OPENSSL_LHASH *lh);
static void contract(OPENSSL_LHASH *lh);
static OPENSSL_LH_NODE **getrn(OPENSSL_LHASH *lh, const void *data, unsigned long *rhash);
unsigned long hash;
OPENSSL_LH_NODE *nn, **rn;
void *ret;
-
+ int val = 0;
+
lh->error = 0;
if (lh->up_load <= (lh->num_items * LH_LOAD_MULT / lh->num_nodes))
- expand(lh);
-
+ val = expand(lh);
+
+ if(val){
+ lh->error++;
+ return (NULL);
+ }
+
rn = getrn(lh, data, &hash);
if (*rn == NULL) {
doall_util_fn(lh, 1, (OPENSSL_LH_DOALL_FUNC)0, func, arg);
}
-static void expand(OPENSSL_LHASH *lh)
+static int expand(OPENSSL_LHASH *lh)
{
OPENSSL_LH_NODE **n, **n1, **n2, *np;
unsigned int p, i, j;
/* fputs("realloc error in lhash",stderr); */
lh->error++;
lh->p = 0;
- return;
+ return -1;
}
for (i = (int)lh->num_alloc_nodes; i < j; i++) /* 26/02/92 eay */
n[i] = NULL; /* 02/03/92 eay */
lh->p = 0;
lh->b = n;
}
+ return 0;
}
static void contract(OPENSSL_LHASH *lh)