aboutsummaryrefslogtreecommitdiffstats
path: root/framework/src/suricata/src/util-hashlist.c
diff options
context:
space:
mode:
Diffstat (limited to 'framework/src/suricata/src/util-hashlist.c')
-rw-r--r--framework/src/suricata/src/util-hashlist.c518
1 files changed, 0 insertions, 518 deletions
diff --git a/framework/src/suricata/src/util-hashlist.c b/framework/src/suricata/src/util-hashlist.c
deleted file mode 100644
index db8ba905..00000000
--- a/framework/src/suricata/src/util-hashlist.c
+++ /dev/null
@@ -1,518 +0,0 @@
-/* Copyright (C) 2007-2010 Open Information Security Foundation
- *
- * You can copy, redistribute or modify this Program under the terms of
- * the GNU General Public License version 2 as published by the Free
- * Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * version 2 along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
- * 02110-1301, USA.
- */
-
-/**
- * \file
- *
- * \author Victor Julien <victor@inliniac.net>
- *
- * Chained hash table implementation
- *
- * The 'Free' pointer can be used to have the API free your
- * hashed data. If it's NULL it's the callers responsebility
- */
-
-#include "suricata-common.h"
-#include "util-hashlist.h"
-#include "util-unittest.h"
-#include "util-debug.h"
-#include "util-memcmp.h"
-
-HashListTable* HashListTableInit(uint32_t size, uint32_t (*Hash)(struct HashListTable_ *, void *, uint16_t), char (*Compare)(void *, uint16_t, void *, uint16_t), void (*Free)(void *)) {
-
- HashListTable *ht = NULL;
-
- if (size == 0) {
- goto error;
- }
-
- if (Hash == NULL) {
- //printf("ERROR: HashListTableInit no Hash function\n");
- goto error;
- }
-
- /* setup the filter */
- ht = SCMalloc(sizeof(HashListTable));
- if (unlikely(ht == NULL))
- goto error;
- memset(ht,0,sizeof(HashListTable));
- ht->array_size = size;
- ht->Hash = Hash;
- ht->Free = Free;
-
- if (Compare != NULL)
- ht->Compare = Compare;
- else
- ht->Compare = HashListTableDefaultCompare;
-
- /* setup the bitarray */
- ht->array = SCMalloc(ht->array_size * sizeof(HashListTableBucket *));
- if (ht->array == NULL)
- goto error;
- memset(ht->array,0,ht->array_size * sizeof(HashListTableBucket *));
-
- ht->listhead = NULL;
- ht->listtail = NULL;
- return ht;
-
-error:
- if (ht != NULL) {
- if (ht->array != NULL)
- SCFree(ht->array);
-
- SCFree(ht);
- }
- return NULL;
-}
-
-void HashListTableFree(HashListTable *ht)
-{
- uint32_t i = 0;
-
- if (ht == NULL)
- return;
-
- /* free the buckets */
- for (i = 0; i < ht->array_size; i++) {
- HashListTableBucket *hashbucket = ht->array[i];
- while (hashbucket != NULL) {
- HashListTableBucket *next_hashbucket = hashbucket->bucknext;
- if (ht->Free != NULL)
- ht->Free(hashbucket->data);
- SCFree(hashbucket);
- hashbucket = next_hashbucket;
- }
- }
-
- /* free the array */
- if (ht->array != NULL)
- SCFree(ht->array);
-
- SCFree(ht);
-}
-
-void HashListTablePrint(HashListTable *ht)
-{
- printf("\n----------- Hash Table Stats ------------\n");
- printf("Buckets: %" PRIu32 "\n", ht->array_size);
- printf("Hash function pointer: %p\n", ht->Hash);
- printf("-----------------------------------------\n");
-}
-
-int HashListTableAdd(HashListTable *ht, void *data, uint16_t datalen)
-{
- if (ht == NULL || data == NULL)
- return -1;
-
- uint32_t hash = ht->Hash(ht, data, datalen);
-
- SCLogDebug("ht %p hash %"PRIu32"", ht, hash);
-
- HashListTableBucket *hb = SCMalloc(sizeof(HashListTableBucket));
- if (unlikely(hb == NULL))
- goto error;
- memset(hb, 0, sizeof(HashListTableBucket));
- hb->data = data;
- hb->size = datalen;
- hb->bucknext = NULL;
- hb->listnext = NULL;
- hb->listprev = NULL;
-
- if (ht->array[hash] == NULL) {
- ht->array[hash] = hb;
- } else {
- hb->bucknext = ht->array[hash];
- ht->array[hash] = hb;
- }
-
- if (ht->listtail == NULL) {
- ht->listhead = hb;
- ht->listtail = hb;
- } else {
- hb->listprev = ht->listtail;
- ht->listtail->listnext = hb;
- ht->listtail = hb;
- }
-
- return 0;
-
-error:
- return -1;
-}
-
-int HashListTableRemove(HashListTable *ht, void *data, uint16_t datalen)
-{
- uint32_t hash = ht->Hash(ht, data, datalen);
-
- SCLogDebug("ht %p hash %"PRIu32"", ht, hash);
-
- if (ht->array[hash] == NULL) {
- SCLogDebug("ht->array[hash] NULL");
- return -1;
- }
-
- /* fast track for just one data part */
- if (ht->array[hash]->bucknext == NULL) {
- HashListTableBucket *hb = ht->array[hash];
-
- if (ht->Compare(hb->data,hb->size,data,datalen) == 1) {
- /* remove from the list */
- if (hb->listprev == NULL) {
- ht->listhead = hb->listnext;
- } else {
- hb->listprev->listnext = hb->listnext;
- }
- if (hb->listnext == NULL) {
- ht->listtail = hb->listprev;
- } else {
- hb->listnext->listprev = hb->listprev;
- }
-
- if (ht->Free != NULL)
- ht->Free(hb->data);
-
- SCFree(ht->array[hash]);
- ht->array[hash] = NULL;
- return 0;
- }
-
- SCLogDebug("fast track default case");
- return -1;
- }
-
- /* more data in this bucket */
- HashListTableBucket *hashbucket = ht->array[hash], *prev_hashbucket = NULL;
- do {
- if (ht->Compare(hashbucket->data,hashbucket->size,data,datalen) == 1) {
-
- /* remove from the list */
- if (hashbucket->listprev == NULL) {
- ht->listhead = hashbucket->listnext;
- } else {
- hashbucket->listprev->listnext = hashbucket->listnext;
- }
- if (hashbucket->listnext == NULL) {
- ht->listtail = hashbucket->listprev;
- } else {
- hashbucket->listnext->listprev = hashbucket->listprev;
- }
-
- if (prev_hashbucket == NULL) {
- /* root bucket */
- ht->array[hash] = hashbucket->bucknext;
- } else {
- /* child bucket */
- prev_hashbucket->bucknext = hashbucket->bucknext;
- }
-
- /* remove this */
- if (ht->Free != NULL)
- ht->Free(hashbucket->data);
- SCFree(hashbucket);
- return 0;
- }
-
- prev_hashbucket = hashbucket;
- hashbucket = hashbucket->bucknext;
- } while (hashbucket != NULL);
-
- SCLogDebug("slow track default case");
- return -1;
-}
-
-char HashListTableDefaultCompare(void *data1, uint16_t len1, void *data2, uint16_t len2)
-{
- if (len1 != len2)
- return 0;
-
- if (SCMemcmp(data1,data2,len1) != 0)
- return 0;
-
- return 1;
-}
-
-void *HashListTableLookup(HashListTable *ht, void *data, uint16_t datalen)
-{
-
- if (ht == NULL) {
- SCLogDebug("Hash List table is NULL");
- return NULL;
- }
-
- uint32_t hash = ht->Hash(ht, data, datalen);
-
- if (ht->array[hash] == NULL) {
- return NULL;
- }
-
- HashListTableBucket *hashbucket = ht->array[hash];
- do {
- if (ht->Compare(hashbucket->data,hashbucket->size,data,datalen) == 1)
- return hashbucket->data;
-
- hashbucket = hashbucket->bucknext;
- } while (hashbucket != NULL);
-
- return NULL;
-}
-
-uint32_t HashListTableGenericHash(HashListTable *ht, void *data, uint16_t datalen)
-{
- uint8_t *d = (uint8_t *)data;
- uint32_t i;
- uint32_t hash = 0;
-
- for (i = 0; i < datalen; i++) {
- if (i == 0) hash += (((uint32_t)*d++));
- else if (i == 1) hash += (((uint32_t)*d++) * datalen);
- else hash *= (((uint32_t)*d++) * i) + datalen + i;
- }
-
- hash *= datalen;
- hash %= ht->array_size;
- return hash;
-}
-
-HashListTableBucket *HashListTableGetListHead(HashListTable *ht)
-{
- return ht->listhead;
-}
-
-/*
- * ONLY TESTS BELOW THIS COMMENT
- */
-
-#ifdef UNITTESTS
-static int HashListTableTestInit01 (void)
-{
- HashListTable *ht = HashListTableInit(1024, HashListTableGenericHash, NULL, NULL);
- if (ht == NULL)
- return 0;
-
- HashListTableFree(ht);
- return 1;
-}
-
-/* no hash function, so it should fail */
-static int HashListTableTestInit02 (void)
-{
- HashListTable *ht = HashListTableInit(1024, NULL, NULL, NULL);
- if (ht == NULL)
- return 1;
-
- HashListTableFree(ht);
- return 0;
-}
-
-static int HashListTableTestInit03 (void)
-{
- int result = 0;
- HashListTable *ht = HashListTableInit(1024, HashListTableGenericHash, NULL, NULL);
- if (ht == NULL)
- return 0;
-
- if (ht->Hash == HashListTableGenericHash)
- result = 1;
-
- HashListTableFree(ht);
- return result;
-}
-
-static int HashListTableTestInit04 (void)
-{
- HashListTable *ht = HashListTableInit(0, HashListTableGenericHash, NULL, NULL);
- if (ht == NULL)
- return 1;
-
- HashListTableFree(ht);
- return 0;
-}
-
-static int HashListTableTestAdd01 (void)
-{
- int result = 0;
- HashListTable *ht = HashListTableInit(32, HashListTableGenericHash, NULL, NULL);
- if (ht == NULL)
- goto end;
-
- int r = HashListTableAdd(ht, "test", 0);
- if (r != 0)
- goto end;
-
- /* all is good! */
- result = 1;
-end:
- if (ht != NULL) HashListTableFree(ht);
- return result;
-}
-
-static int HashListTableTestAdd02 (void)
-{
- int result = 0;
- HashListTable *ht = HashListTableInit(32, HashListTableGenericHash, NULL, NULL);
- if (ht == NULL)
- goto end;
-
- int r = HashListTableAdd(ht, NULL, 4);
- if (r == 0)
- goto end;
-
- /* all is good! */
- result = 1;
-end:
- if (ht != NULL) HashListTableFree(ht);
- return result;
-}
-
-static int HashListTableTestAdd03 (void)
-{
- int result = 0;
- HashListTable *ht = HashListTableInit(32, HashListTableGenericHash, NULL, NULL);
- if (ht == NULL)
- goto end;
-
- int r = HashListTableAdd(ht, "test", 0);
- if (r != 0)
- goto end;
-
- if (ht->listhead == NULL) {
- printf("ht->listhead == NULL: ");
- goto end;
- }
-
- if (ht->listtail == NULL) {
- printf("ht->listtail == NULL: ");
- goto end;
- }
-
- /* all is good! */
- result = 1;
-end:
- if (ht != NULL) HashListTableFree(ht);
- return result;
-}
-
-static int HashListTableTestAdd04 (void)
-{
- int result = 0;
- HashListTable *ht = HashListTableInit(32, HashListTableGenericHash, NULL, NULL);
- if (ht == NULL)
- goto end;
-
- int r = HashListTableAdd(ht, "test", 4);
- if (r != 0)
- goto end;
-
- char *rp = HashListTableLookup(ht, "test", 4);
- if (rp == NULL)
- goto end;
-
- HashListTableBucket *htb = HashListTableGetListHead(ht);
- if (htb == NULL) {
- printf("htb == NULL: ");
- goto end;
- }
-
- char *rp2 = HashListTableGetListData(htb);
- if (rp2 == NULL) {
- printf("rp2 == NULL: ");
- goto end;
- }
-
- if (rp != rp2) {
- printf("rp != rp2: ");
- goto end;
- }
-
- /* all is good! */
- result = 1;
-end:
- if (ht != NULL) HashListTableFree(ht);
- return result;
-}
-
-static int HashListTableTestFull01 (void)
-{
- int result = 0;
- HashListTable *ht = HashListTableInit(32, HashListTableGenericHash, NULL, NULL);
- if (ht == NULL)
- goto end;
-
- int r = HashListTableAdd(ht, "test", 4);
- if (r != 0)
- goto end;
-
- char *rp = HashListTableLookup(ht, "test", 4);
- if (rp == NULL)
- goto end;
-
- r = HashListTableRemove(ht, "test", 4);
- if (r != 0)
- goto end;
-
- /* all is good! */
- result = 1;
-end:
- if (ht != NULL) HashListTableFree(ht);
- return result;
-}
-
-static int HashListTableTestFull02 (void)
-{
- int result = 0;
- HashListTable *ht = HashListTableInit(32, HashListTableGenericHash, NULL, NULL);
- if (ht == NULL)
- goto end;
-
- int r = HashListTableAdd(ht, "test", 4);
- if (r != 0)
- goto end;
-
- char *rp = HashListTableLookup(ht, "test", 4);
- if (rp == NULL)
- goto end;
-
- r = HashListTableRemove(ht, "test2", 5);
- if (r == 0)
- goto end;
-
- /* all is good! */
- result = 1;
-end:
- if (ht != NULL) HashListTableFree(ht);
- return result;
-}
-#endif /* UNITTESTS */
-
-void HashListTableRegisterTests(void)
-{
-#ifdef UNITTESTS
- UtRegisterTest("HashListTableTestInit01", HashListTableTestInit01, 1);
- UtRegisterTest("HashListTableTestInit02", HashListTableTestInit02, 1);
- UtRegisterTest("HashListTableTestInit03", HashListTableTestInit03, 1);
- UtRegisterTest("HashListTableTestInit04", HashListTableTestInit04, 1);
-
- UtRegisterTest("HashListTableTestAdd01", HashListTableTestAdd01, 1);
- UtRegisterTest("HashListTableTestAdd02", HashListTableTestAdd02, 1);
- UtRegisterTest("HashListTableTestAdd03", HashListTableTestAdd03, 1);
- UtRegisterTest("HashListTableTestAdd04", HashListTableTestAdd04, 1);
-
- UtRegisterTest("HashListTableTestFull01", HashListTableTestFull01, 1);
- UtRegisterTest("HashListTableTestFull02", HashListTableTestFull02, 1);
-#endif /* UNITTESTS */
-}
-