2005-12-16 01:29:43 +03:00
/* -*- mode: c; c-basic-offset: 8; -*-
* vim : noexpandtab sw = 8 ts = 8 sts = 0 :
*
* item . c - library routines for handling generic config items
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public
* License as published by the Free Software Foundation ; either
* version 2 of the License , or ( at your option ) any later version .
*
* 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 along with this program ; if not , write to the
* Free Software Foundation , Inc . , 59 Temple Place - Suite 330 ,
* Boston , MA 021110 - 1307 , USA .
*
* Based on kobject :
2014-06-05 03:05:57 +04:00
* kobject is Copyright ( c ) 2002 - 2003 Patrick Mochel
2005-12-16 01:29:43 +03:00
*
* configfs Copyright ( C ) 2005 Oracle . All rights reserved .
*
2011-08-15 04:02:26 +04:00
* Please see the file Documentation / filesystems / configfs / configfs . txt for
2005-12-16 01:29:43 +03:00
* critical information about using the config_item interface .
*/
# include <linux/string.h>
# include <linux/module.h>
# include <linux/stat.h>
# include <linux/slab.h>
# include <linux/configfs.h>
2014-06-05 03:05:57 +04:00
static inline struct config_item * to_item ( struct list_head * entry )
2005-12-16 01:29:43 +03:00
{
2014-06-05 03:05:57 +04:00
return container_of ( entry , struct config_item , ci_entry ) ;
2005-12-16 01:29:43 +03:00
}
/* Evil kernel */
static void config_item_release ( struct kref * kref ) ;
/**
* config_item_init - initialize item .
* @ item : item in question .
*/
2014-06-05 03:05:57 +04:00
void config_item_init ( struct config_item * item )
2005-12-16 01:29:43 +03:00
{
kref_init ( & item - > ci_kref ) ;
INIT_LIST_HEAD ( & item - > ci_entry ) ;
}
2014-06-05 03:05:57 +04:00
EXPORT_SYMBOL ( config_item_init ) ;
2005-12-16 01:29:43 +03:00
/**
* config_item_set_name - Set the name of an item
* @ item : item .
2014-06-05 03:05:57 +04:00
* @ fmt : The vsnprintf ( ) ' s format string .
2005-12-16 01:29:43 +03:00
*
* If strlen ( name ) > = CONFIGFS_ITEM_NAME_LEN , then use a
* dynamically allocated string that @ item - > ci_name points to .
* Otherwise , use the static @ item - > ci_namebuf array .
*/
2014-06-05 03:05:57 +04:00
int config_item_set_name ( struct config_item * item , const char * fmt , . . . )
2005-12-16 01:29:43 +03:00
{
int error = 0 ;
int limit = CONFIGFS_ITEM_NAME_LEN ;
int need ;
va_list args ;
2014-06-05 03:05:57 +04:00
char * name ;
2005-12-16 01:29:43 +03:00
/*
* First , try the static array
*/
2014-06-05 03:05:57 +04:00
va_start ( args , fmt ) ;
need = vsnprintf ( item - > ci_namebuf , limit , fmt , args ) ;
2005-12-16 01:29:43 +03:00
va_end ( args ) ;
if ( need < limit )
name = item - > ci_namebuf ;
else {
/*
* Need more space ? Allocate it and try again
*/
limit = need + 1 ;
2014-06-05 03:05:57 +04:00
name = kmalloc ( limit , GFP_KERNEL ) ;
2005-12-16 01:29:43 +03:00
if ( ! name ) {
error = - ENOMEM ;
goto Done ;
}
2014-06-05 03:05:57 +04:00
va_start ( args , fmt ) ;
need = vsnprintf ( name , limit , fmt , args ) ;
2005-12-16 01:29:43 +03:00
va_end ( args ) ;
/* Still? Give up. */
if ( need > = limit ) {
kfree ( name ) ;
error = - EFAULT ;
goto Done ;
}
}
/* Free the old name, if necessary. */
if ( item - > ci_name & & item - > ci_name ! = item - > ci_namebuf )
kfree ( item - > ci_name ) ;
/* Now, set the new name */
item - > ci_name = name ;
Done :
return error ;
}
EXPORT_SYMBOL ( config_item_set_name ) ;
void config_item_init_type_name ( struct config_item * item ,
const char * name ,
struct config_item_type * type )
{
config_item_set_name ( item , name ) ;
item - > ci_type = type ;
config_item_init ( item ) ;
}
EXPORT_SYMBOL ( config_item_init_type_name ) ;
void config_group_init_type_name ( struct config_group * group , const char * name ,
struct config_item_type * type )
{
config_item_set_name ( & group - > cg_item , name ) ;
group - > cg_item . ci_type = type ;
config_group_init ( group ) ;
}
EXPORT_SYMBOL ( config_group_init_type_name ) ;
2014-06-05 03:05:57 +04:00
struct config_item * config_item_get ( struct config_item * item )
2005-12-16 01:29:43 +03:00
{
if ( item )
kref_get ( & item - > ci_kref ) ;
return item ;
}
2014-06-05 03:05:57 +04:00
EXPORT_SYMBOL ( config_item_get ) ;
2005-12-16 01:29:43 +03:00
2014-06-05 03:05:57 +04:00
static void config_item_cleanup ( struct config_item * item )
2005-12-16 01:29:43 +03:00
{
2014-06-05 03:05:57 +04:00
struct config_item_type * t = item - > ci_type ;
struct config_group * s = item - > ci_group ;
struct config_item * parent = item - > ci_parent ;
2005-12-16 01:29:43 +03:00
2014-06-05 03:05:57 +04:00
pr_debug ( " config_item %s: cleaning up \n " , config_item_name ( item ) ) ;
2005-12-16 01:29:43 +03:00
if ( item - > ci_name ! = item - > ci_namebuf )
kfree ( item - > ci_name ) ;
item - > ci_name = NULL ;
if ( t & & t - > ct_item_ops & & t - > ct_item_ops - > release )
t - > ct_item_ops - > release ( item ) ;
if ( s )
config_group_put ( s ) ;
if ( parent )
config_item_put ( parent ) ;
}
static void config_item_release ( struct kref * kref )
{
config_item_cleanup ( container_of ( kref , struct config_item , ci_kref ) ) ;
}
/**
* config_item_put - decrement refcount for item .
* @ item : item .
*
* Decrement the refcount , and if 0 , call config_item_cleanup ( ) .
*/
2014-06-05 03:05:57 +04:00
void config_item_put ( struct config_item * item )
2005-12-16 01:29:43 +03:00
{
if ( item )
kref_put ( & item - > ci_kref , config_item_release ) ;
}
2014-06-05 03:05:57 +04:00
EXPORT_SYMBOL ( config_item_put ) ;
2005-12-16 01:29:43 +03:00
/**
* config_group_init - initialize a group for use
2014-06-05 03:05:57 +04:00
* @ group : config_group
2005-12-16 01:29:43 +03:00
*/
void config_group_init ( struct config_group * group )
{
config_item_init ( & group - > cg_item ) ;
INIT_LIST_HEAD ( & group - > cg_children ) ;
}
2014-06-05 03:05:57 +04:00
EXPORT_SYMBOL ( config_group_init ) ;
2005-12-16 01:29:43 +03:00
/**
[PATCH] configfs+dlm: Rename config_group_find_obj and state semantics clearly
Configfs being based upon sysfs code, config_group_find_obj() is probably
so named because of the similar kset_find_obj() in sysfs. However,
"kobject"s in sysfs become "config_item"s in configfs, so let's call it
config_group_find_item() instead, for sake of uniformity, and make
corresponding change in the users of this function.
BTW a crucial difference between kset_find_obj and config_group_find_item
is in locking expectations. kset_find_obj does its locking by itself, but
config_group_find_item expects the *caller* to do the locking. The reason
for this: kset's have their own locks, config_group's don't but instead
rely on the subsystem mutex. And, subsystem needn't necessarily be around
when config_group_find_item() is called.
So let's state these locking semantics explicitly, and rectify the comment,
otherwise bugs could continue to occur in future, as they did in the past
(refer commit d82b8191e238 in gfs2-2.6-fixes.git).
[ I also took the opportunity to fix some bad whitespace and
double-empty lines. --Joel ]
[ Conflict in fs/dlm/config.c with commit
3168b0780d06ace875696f8a648d04d6089654e5 manually resolved. --Mark ]
Signed-off-by: Satyam Sharma <ssatyam@cse.iitk.ac.in>
Cc: David Teigland <teigland@redhat.com>
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Signed-off-by: Mark Fasheh <mark.fasheh@oracle.com>
2007-07-04 15:07:16 +04:00
* config_group_find_item - search for item in group .
2005-12-16 01:29:43 +03:00
* @ group : group we ' re looking in .
* @ name : item ' s name .
*
[PATCH] configfs+dlm: Rename config_group_find_obj and state semantics clearly
Configfs being based upon sysfs code, config_group_find_obj() is probably
so named because of the similar kset_find_obj() in sysfs. However,
"kobject"s in sysfs become "config_item"s in configfs, so let's call it
config_group_find_item() instead, for sake of uniformity, and make
corresponding change in the users of this function.
BTW a crucial difference between kset_find_obj and config_group_find_item
is in locking expectations. kset_find_obj does its locking by itself, but
config_group_find_item expects the *caller* to do the locking. The reason
for this: kset's have their own locks, config_group's don't but instead
rely on the subsystem mutex. And, subsystem needn't necessarily be around
when config_group_find_item() is called.
So let's state these locking semantics explicitly, and rectify the comment,
otherwise bugs could continue to occur in future, as they did in the past
(refer commit d82b8191e238 in gfs2-2.6-fixes.git).
[ I also took the opportunity to fix some bad whitespace and
double-empty lines. --Joel ]
[ Conflict in fs/dlm/config.c with commit
3168b0780d06ace875696f8a648d04d6089654e5 manually resolved. --Mark ]
Signed-off-by: Satyam Sharma <ssatyam@cse.iitk.ac.in>
Cc: David Teigland <teigland@redhat.com>
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Signed-off-by: Mark Fasheh <mark.fasheh@oracle.com>
2007-07-04 15:07:16 +04:00
* Iterate over @ group - > cg_list , looking for a matching config_item .
* If matching item is found take a reference and return the item .
* Caller must have locked group via @ group - > cg_subsys - > su_mtx .
2005-12-16 01:29:43 +03:00
*/
[PATCH] configfs+dlm: Rename config_group_find_obj and state semantics clearly
Configfs being based upon sysfs code, config_group_find_obj() is probably
so named because of the similar kset_find_obj() in sysfs. However,
"kobject"s in sysfs become "config_item"s in configfs, so let's call it
config_group_find_item() instead, for sake of uniformity, and make
corresponding change in the users of this function.
BTW a crucial difference between kset_find_obj and config_group_find_item
is in locking expectations. kset_find_obj does its locking by itself, but
config_group_find_item expects the *caller* to do the locking. The reason
for this: kset's have their own locks, config_group's don't but instead
rely on the subsystem mutex. And, subsystem needn't necessarily be around
when config_group_find_item() is called.
So let's state these locking semantics explicitly, and rectify the comment,
otherwise bugs could continue to occur in future, as they did in the past
(refer commit d82b8191e238 in gfs2-2.6-fixes.git).
[ I also took the opportunity to fix some bad whitespace and
double-empty lines. --Joel ]
[ Conflict in fs/dlm/config.c with commit
3168b0780d06ace875696f8a648d04d6089654e5 manually resolved. --Mark ]
Signed-off-by: Satyam Sharma <ssatyam@cse.iitk.ac.in>
Cc: David Teigland <teigland@redhat.com>
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Signed-off-by: Mark Fasheh <mark.fasheh@oracle.com>
2007-07-04 15:07:16 +04:00
struct config_item * config_group_find_item ( struct config_group * group ,
const char * name )
2005-12-16 01:29:43 +03:00
{
2014-06-05 03:05:57 +04:00
struct list_head * entry ;
struct config_item * ret = NULL ;
2005-12-16 01:29:43 +03:00
2014-06-05 03:05:57 +04:00
list_for_each ( entry , & group - > cg_children ) {
struct config_item * item = to_item ( entry ) ;
2005-12-16 01:29:43 +03:00
if ( config_item_name ( item ) & &
[PATCH] configfs+dlm: Rename config_group_find_obj and state semantics clearly
Configfs being based upon sysfs code, config_group_find_obj() is probably
so named because of the similar kset_find_obj() in sysfs. However,
"kobject"s in sysfs become "config_item"s in configfs, so let's call it
config_group_find_item() instead, for sake of uniformity, and make
corresponding change in the users of this function.
BTW a crucial difference between kset_find_obj and config_group_find_item
is in locking expectations. kset_find_obj does its locking by itself, but
config_group_find_item expects the *caller* to do the locking. The reason
for this: kset's have their own locks, config_group's don't but instead
rely on the subsystem mutex. And, subsystem needn't necessarily be around
when config_group_find_item() is called.
So let's state these locking semantics explicitly, and rectify the comment,
otherwise bugs could continue to occur in future, as they did in the past
(refer commit d82b8191e238 in gfs2-2.6-fixes.git).
[ I also took the opportunity to fix some bad whitespace and
double-empty lines. --Joel ]
[ Conflict in fs/dlm/config.c with commit
3168b0780d06ace875696f8a648d04d6089654e5 manually resolved. --Mark ]
Signed-off-by: Satyam Sharma <ssatyam@cse.iitk.ac.in>
Cc: David Teigland <teigland@redhat.com>
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Signed-off-by: Mark Fasheh <mark.fasheh@oracle.com>
2007-07-04 15:07:16 +04:00
! strcmp ( config_item_name ( item ) , name ) ) {
2005-12-16 01:29:43 +03:00
ret = config_item_get ( item ) ;
break ;
}
}
return ret ;
}
[PATCH] configfs+dlm: Rename config_group_find_obj and state semantics clearly
Configfs being based upon sysfs code, config_group_find_obj() is probably
so named because of the similar kset_find_obj() in sysfs. However,
"kobject"s in sysfs become "config_item"s in configfs, so let's call it
config_group_find_item() instead, for sake of uniformity, and make
corresponding change in the users of this function.
BTW a crucial difference between kset_find_obj and config_group_find_item
is in locking expectations. kset_find_obj does its locking by itself, but
config_group_find_item expects the *caller* to do the locking. The reason
for this: kset's have their own locks, config_group's don't but instead
rely on the subsystem mutex. And, subsystem needn't necessarily be around
when config_group_find_item() is called.
So let's state these locking semantics explicitly, and rectify the comment,
otherwise bugs could continue to occur in future, as they did in the past
(refer commit d82b8191e238 in gfs2-2.6-fixes.git).
[ I also took the opportunity to fix some bad whitespace and
double-empty lines. --Joel ]
[ Conflict in fs/dlm/config.c with commit
3168b0780d06ace875696f8a648d04d6089654e5 manually resolved. --Mark ]
Signed-off-by: Satyam Sharma <ssatyam@cse.iitk.ac.in>
Cc: David Teigland <teigland@redhat.com>
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Signed-off-by: Mark Fasheh <mark.fasheh@oracle.com>
2007-07-04 15:07:16 +04:00
EXPORT_SYMBOL ( config_group_find_item ) ;