public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] sysfs: add filter function to groups
@ 2007-10-29 15:16 James Bottomley
  2007-10-29 16:54 ` Kay Sievers
  0 siblings, 1 reply; 30+ messages in thread
From: James Bottomley @ 2007-10-29 15:16 UTC (permalink / raw)
  To: Kay Sievers, Greg KH; +Cc: linux-scsi, linux-kernel

In the SCSI transport classes (and soon to be in the AEN event
subsystem) we have a lot of need for a grouping that doesn't include all
files in the group.  We basically want to show capability by which file
is present.  A classic example of this is the SPI transport class
connected to the 53c700 card.  It's incapable of doing all of the modern
LVD functions, so we don't show any of those capabilities in its sysfs
directory.  However, we have a lot of horrible logic to generate
separate per host groupings of attributes for this.  We would be able to
use the standard sysfs group attributes *if* there were a way of
filtering them so that certain attributes didn't appear.

This patch is a first pass at adding a filter function to the group
attributes, just to see how the idea flies.  If everyone's OK with this,
I think the next thing that we might do is add bitmap functions (so
every bit in the bitmap has a name, but also might not appear) to
groups.

The kzalloc in kernel/params.c is to stop the system crashing on boot
with a bogus filter function pointer.

Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>

----

There's one final thing; if you're OK with this, can you ack it and let
me take it through the SCSI tree?  we're building functionality that
will depend on this.

Thanks,

James

Index: BUILD-2.6/fs/sysfs/group.c
===================================================================
--- BUILD-2.6.orig/fs/sysfs/group.c	2007-10-28 17:27:04.000000000 -0500
+++ BUILD-2.6/fs/sysfs/group.c	2007-10-29 00:55:49.000000000 -0500
@@ -16,25 +16,31 @@
 #include "sysfs.h"
 
 
-static void remove_files(struct sysfs_dirent *dir_sd,
+static void remove_files(struct sysfs_dirent *dir_sd, struct kobject *kobj,
 			 const struct attribute_group *grp)
 {
 	struct attribute *const* attr;
+	int i;
 
-	for (attr = grp->attrs; *attr; attr++)
-		sysfs_hash_and_remove(dir_sd, (*attr)->name);
+	for (i = 0, attr = grp->attrs; *attr; i++, attr++)
+		if (grp->filter_show &&
+		    grp->filter_show(kobj, i))
+			sysfs_hash_and_remove(dir_sd, (*attr)->name);
 }
 
-static int create_files(struct sysfs_dirent *dir_sd,
+static int create_files(struct sysfs_dirent *dir_sd, struct kobject *kobj,
 			const struct attribute_group *grp)
 {
 	struct attribute *const* attr;
-	int error = 0;
+	int error = 0, i;
 
-	for (attr = grp->attrs; *attr && !error; attr++)
-		error = sysfs_add_file(dir_sd, *attr, SYSFS_KOBJ_ATTR);
+	for (i = 0, attr = grp->attrs; *attr && !error; i++, attr++)
+		if (grp->filter_show &&
+		    grp->filter_show(kobj, i))
+			error |=
+				sysfs_add_file(dir_sd, *attr, SYSFS_KOBJ_ATTR);
 	if (error)
-		remove_files(dir_sd, grp);
+		remove_files(dir_sd, kobj, grp);
 	return error;
 }
 
@@ -54,7 +60,7 @@ int sysfs_create_group(struct kobject * 
 	} else
 		sd = kobj->sd;
 	sysfs_get(sd);
-	error = create_files(sd, grp);
+	error = create_files(sd, kobj, grp);
 	if (error) {
 		if (grp->name)
 			sysfs_remove_subdir(sd);
@@ -75,7 +81,7 @@ void sysfs_remove_group(struct kobject *
 	} else
 		sd = sysfs_get(dir_sd);
 
-	remove_files(sd, grp);
+	remove_files(sd, kobj, grp);
 	if (grp->name)
 		sysfs_remove_subdir(sd);
 
Index: BUILD-2.6/include/linux/sysfs.h
===================================================================
--- BUILD-2.6.orig/include/linux/sysfs.h	2007-10-28 17:20:06.000000000 -0500
+++ BUILD-2.6/include/linux/sysfs.h	2007-10-29 00:37:18.000000000 -0500
@@ -32,6 +32,7 @@ struct attribute {
 
 struct attribute_group {
 	const char		*name;
+	int			(*filter_show)(struct kobject *, int);
 	struct attribute	**attrs;
 };
 
Index: BUILD-2.6/kernel/params.c
===================================================================
--- BUILD-2.6.orig/kernel/params.c	2007-10-29 01:18:43.000000000 -0500
+++ BUILD-2.6/kernel/params.c	2007-10-29 01:18:49.000000000 -0500
@@ -472,7 +472,7 @@ param_sysfs_setup(struct module_kobject 
 			sizeof(mp->grp.attrs[0]));
 	size[1] = (valid_attrs + 1) * sizeof(mp->grp.attrs[0]);
 
-	mp = kmalloc(size[0] + size[1], GFP_KERNEL);
+	mp = kzalloc(size[0] + size[1], GFP_KERNEL);
 	if (!mp)
 		return ERR_PTR(-ENOMEM);
 



^ permalink raw reply	[flat|nested] 30+ messages in thread

end of thread, other threads:[~2007-11-04 19:01 UTC | newest]

Thread overview: 30+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-10-29 15:16 [PATCH] sysfs: add filter function to groups James Bottomley
2007-10-29 16:54 ` Kay Sievers
2007-10-29 16:57   ` James Bottomley
2007-10-29 17:18     ` Cornelia Huck
2007-10-29 17:24       ` James Bottomley
2007-10-29 17:27         ` Jeff Garzik
2007-10-29 17:29           ` James Bottomley
2007-10-30  9:00             ` Cornelia Huck
2007-10-30  8:55         ` Cornelia Huck
2007-10-29 17:27     ` Kay Sievers
2007-10-29 17:28       ` James Bottomley
2007-10-29 17:43         ` Kay Sievers
2007-10-29 17:58     ` Stefan Richter
2007-10-29 18:12       ` James Bottomley
2007-10-30 18:25       ` James Bottomley
2007-10-30 19:31         ` Stefan Richter
2007-10-30 19:47         ` Kay Sievers
2007-10-31  0:40         ` Mark M. Hoffman
2007-10-31  2:01           ` Kay Sievers
2007-10-31 11:28             ` Mark M. Hoffman
2007-10-31  3:55         ` Greg KH
2007-10-31  9:41           ` Cornelia Huck
2007-10-31  9:52             ` Stefan Richter
2007-10-31 10:20               ` Cornelia Huck
2007-10-31 10:37                 ` Stefan Richter
2007-10-31 12:19                   ` Cornelia Huck
2007-10-31 14:38           ` James Bottomley
2007-10-31 17:29             ` Greg KH
2007-11-04 14:12               ` James Bottomley
2007-11-04 19:06                 ` Greg KH

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox