2009-04-03 19:42:38 +04:00
/* FS-Cache netfs (client) registration
*
* Copyright ( C ) 2008 Red Hat , Inc . All Rights Reserved .
* Written by David Howells ( dhowells @ redhat . com )
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public Licence
* as published by the Free Software Foundation ; either version
* 2 of the Licence , or ( at your option ) any later version .
*/
# define FSCACHE_DEBUG_LEVEL COOKIE
# include <linux/module.h>
# include <linux/slab.h>
# include "internal.h"
static LIST_HEAD ( fscache_netfs_list ) ;
/*
* register a network filesystem for caching
*/
int __fscache_register_netfs ( struct fscache_netfs * netfs )
{
struct fscache_netfs * ptr ;
2015-11-04 18:20:24 +03:00
struct fscache_cookie * cookie ;
2009-04-03 19:42:38 +04:00
int ret ;
_enter ( " {%s} " , netfs - > name ) ;
INIT_LIST_HEAD ( & netfs - > link ) ;
/* allocate a cookie for the primary index */
2015-11-04 18:20:24 +03:00
cookie = kmem_cache_zalloc ( fscache_cookie_jar , GFP_KERNEL ) ;
2009-04-03 19:42:38 +04:00
2015-11-04 18:20:24 +03:00
if ( ! cookie ) {
2009-04-03 19:42:38 +04:00
_leave ( " = -ENOMEM " ) ;
return - ENOMEM ;
}
/* initialise the primary index cookie */
2015-11-04 18:20:24 +03:00
atomic_set ( & cookie - > usage , 1 ) ;
atomic_set ( & cookie - > n_children , 0 ) ;
atomic_set ( & cookie - > n_active , 1 ) ;
2009-04-03 19:42:38 +04:00
2015-11-04 18:20:24 +03:00
cookie - > def = & fscache_fsdef_netfs_def ;
cookie - > parent = & fscache_fsdef_index ;
cookie - > netfs_data = netfs ;
cookie - > flags = 1 < < FSCACHE_COOKIE_ENABLED ;
2009-04-03 19:42:38 +04:00
2015-11-04 18:20:24 +03:00
spin_lock_init ( & cookie - > lock ) ;
2017-01-18 17:29:17 +03:00
spin_lock_init ( & cookie - > stores_lock ) ;
2015-11-04 18:20:24 +03:00
INIT_HLIST_HEAD ( & cookie - > backing_objects ) ;
2009-04-03 19:42:38 +04:00
/* check the netfs type is not already present */
down_write ( & fscache_addremove_sem ) ;
ret = - EEXIST ;
list_for_each_entry ( ptr , & fscache_netfs_list , link ) {
if ( strcmp ( ptr - > name , netfs - > name ) = = 0 )
goto already_registered ;
}
2018-04-04 15:41:27 +03:00
fscache_cookie_get ( cookie - > parent , fscache_cookie_get_register_netfs ) ;
2015-11-04 18:20:24 +03:00
atomic_inc ( & cookie - > parent - > n_children ) ;
2015-11-04 18:20:15 +03:00
2015-11-04 18:20:24 +03:00
netfs - > primary_index = cookie ;
2009-04-03 19:42:38 +04:00
list_add ( & netfs - > link , & fscache_netfs_list ) ;
ret = 0 ;
2014-06-05 03:05:38 +04:00
pr_notice ( " Netfs '%s' registered for caching \n " , netfs - > name ) ;
2018-04-04 15:41:27 +03:00
trace_fscache_netfs ( netfs ) ;
2009-04-03 19:42:38 +04:00
already_registered :
up_write ( & fscache_addremove_sem ) ;
2015-11-04 18:20:24 +03:00
if ( ret < 0 )
kmem_cache_free ( fscache_cookie_jar , cookie ) ;
2009-04-03 19:42:38 +04:00
_leave ( " = %d " , ret ) ;
return ret ;
}
EXPORT_SYMBOL ( __fscache_register_netfs ) ;
/*
* unregister a network filesystem from the cache
* - all cookies must have been released first
*/
void __fscache_unregister_netfs ( struct fscache_netfs * netfs )
{
_enter ( " {%s.%u} " , netfs - > name , netfs - > version ) ;
down_write ( & fscache_addremove_sem ) ;
list_del ( & netfs - > link ) ;
fscache_relinquish_cookie ( netfs - > primary_index , 0 ) ;
up_write ( & fscache_addremove_sem ) ;
2014-06-05 03:05:38 +04:00
pr_notice ( " Netfs '%s' unregistered from caching \n " ,
netfs - > name ) ;
2009-04-03 19:42:38 +04:00
_leave ( " " ) ;
}
EXPORT_SYMBOL ( __fscache_unregister_netfs ) ;