2014-01-04 18:04:25 +01:00
/* Copyright (C) 2006-2014 B.A.T.M.A.N. contributors:
2010-12-13 11:19:28 +00:00
*
* Simon Wunderlich , Marek Lindner
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of version 2 of the GNU General Public
* License 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
2013-11-03 20:40:48 +01:00
* along with this program ; if not , see < http : //www.gnu.org/licenses/>.
2010-12-13 11:19:28 +00:00
*/
# include "main.h"
# include "hash.h"
/* clears the hash */
2012-06-05 22:31:28 +02:00
static void batadv_hash_init ( struct batadv_hashtable * hash )
2010-12-13 11:19:28 +00:00
{
2011-10-05 17:05:25 +02:00
uint32_t i ;
2010-12-13 11:19:28 +00:00
2012-06-17 16:27:22 +02:00
for ( i = 0 ; i < hash - > size ; i + + ) {
2010-12-13 11:19:28 +00:00
INIT_HLIST_HEAD ( & hash - > table [ i ] ) ;
2011-01-19 20:01:40 +00:00
spin_lock_init ( & hash - > list_locks [ i ] ) ;
}
2010-12-13 11:19:28 +00:00
}
/* free only the hashtable and the hash itself. */
2012-06-05 22:31:28 +02:00
void batadv_hash_destroy ( struct batadv_hashtable * hash )
2010-12-13 11:19:28 +00:00
{
2011-01-19 20:01:40 +00:00
kfree ( hash - > list_locks ) ;
2010-12-13 11:19:28 +00:00
kfree ( hash - > table ) ;
kfree ( hash ) ;
}
/* allocates and clears the hash */
2012-06-05 22:31:28 +02:00
struct batadv_hashtable * batadv_hash_new ( uint32_t size )
2010-12-13 11:19:28 +00:00
{
2012-06-05 22:31:28 +02:00
struct batadv_hashtable * hash ;
2010-12-13 11:19:28 +00:00
2011-05-14 23:14:54 +02:00
hash = kmalloc ( sizeof ( * hash ) , GFP_ATOMIC ) ;
2010-12-13 11:19:28 +00:00
if ( ! hash )
return NULL ;
2011-05-14 23:14:54 +02:00
hash - > table = kmalloc ( sizeof ( * hash - > table ) * size , GFP_ATOMIC ) ;
2011-01-19 20:01:40 +00:00
if ( ! hash - > table )
goto free_hash ;
2010-12-13 11:19:28 +00:00
2011-05-14 23:14:54 +02:00
hash - > list_locks = kmalloc ( sizeof ( * hash - > list_locks ) * size ,
GFP_ATOMIC ) ;
2011-01-19 20:01:40 +00:00
if ( ! hash - > list_locks )
goto free_table ;
2010-12-13 11:19:28 +00:00
2011-01-19 20:01:40 +00:00
hash - > size = size ;
2012-05-12 18:33:58 +02:00
batadv_hash_init ( hash ) ;
2010-12-13 11:19:28 +00:00
return hash ;
2011-01-19 20:01:40 +00:00
free_table :
kfree ( hash - > table ) ;
free_hash :
kfree ( hash ) ;
return NULL ;
}
2012-03-29 12:38:20 +02:00
2012-06-05 22:31:28 +02:00
void batadv_hash_set_lock_class ( struct batadv_hashtable * hash ,
2012-03-29 12:38:20 +02:00
struct lock_class_key * key )
{
uint32_t i ;
for ( i = 0 ; i < hash - > size ; i + + )
lockdep_set_class ( & hash - > list_locks [ i ] , key ) ;
}