From: Maneesh Soni <maneesh@in.ibm.com>
To: Al Viro <viro@parcelfarce.linux.theplanet.co.uk>
Cc: LKML <linux-kernel@vger.kernel.org>, Greg KH <greg@kroah.com>,
Dipankar Sarma <dipankar@in.ibm.com>,
Carsten Otte <COTTE@de.ibm.com>,
Christian Borntraeger <CBORNTRA@de.ibm.com>,
"Martin J. Bligh" <mjbligh@us.ibm.com>,
Matt Mackall <mpm@selenic.com>
Subject: [RFC 3/6] sysfs backing store v0.3
Date: Thu, 18 Mar 2004 12:04:55 +0530 [thread overview]
Message-ID: <20040318063455.GD27107@in.ibm.com> (raw)
In-Reply-To: <20040318063424.GC27107@in.ibm.com>
=> changes in version 0.3
o Nil, just re-diffed
=> changes in version 0.2
o Nil, just re-diffed
=> Changes:
o Removed the extra kobject_get from sysfs_release()
=======================================================
o sysfs_create_file() will just link a new sysfs_dirent() structure representing
the attribute file to the kobject's s_children list.
o in sysfs_create() we take extra ref. only for dentries corresponding to
non-regular files or in other words pin only non-leaf dentries.
fs/sysfs/file.c | 63 +++++++++++++++++++++++++------------------------------
fs/sysfs/inode.c | 14 +++++++++---
2 files changed, 40 insertions(+), 37 deletions(-)
diff -puN fs/sysfs/file.c~sysfs-leaves-file fs/sysfs/file.c
--- linux-2.6.5-rc1/fs/sysfs/file.c~sysfs-leaves-file 2004-03-18 11:36:30.000000000 +0530
+++ linux-2.6.5-rc1-maneesh/fs/sysfs/file.c 2004-03-18 11:36:30.000000000 +0530
@@ -9,14 +9,6 @@
#include "sysfs.h"
-static struct file_operations sysfs_file_operations;
-
-static int init_file(struct inode * inode)
-{
- inode->i_size = PAGE_SIZE;
- inode->i_fop = &sysfs_file_operations;
- return 0;
-}
#define to_subsys(k) container_of(k,struct subsystem,kset.kobj)
#define to_sattr(a) container_of(a,struct subsys_attribute,attr)
@@ -77,8 +69,10 @@ struct sysfs_buffer {
*/
static int fill_read_buffer(struct file * file, struct sysfs_buffer * buffer)
{
- struct attribute * attr = file->f_dentry->d_fsdata;
- struct kobject * kobj = file->f_dentry->d_parent->d_fsdata;
+ struct sysfs_dirent * sd_attr = file->f_dentry->d_fsdata;
+ struct attribute * attr = sd_attr->s_element;
+ struct sysfs_dirent * sd_kobj = file->f_dentry->d_parent->d_fsdata;
+ struct kobject * kobj = sd_kobj->s_element;
struct sysfs_ops * ops = buffer->ops;
int ret = 0;
ssize_t count;
@@ -198,8 +192,10 @@ fill_write_buffer(struct sysfs_buffer *
static int
flush_write_buffer(struct file * file, struct sysfs_buffer * buffer, size_t count)
{
- struct attribute * attr = file->f_dentry->d_fsdata;
- struct kobject * kobj = file->f_dentry->d_parent->d_fsdata;
+ struct sysfs_dirent * sd_attr = file->f_dentry->d_fsdata;
+ struct attribute * attr = sd_attr->s_element;
+ struct sysfs_dirent * sd_kobj = file->f_dentry->d_parent->d_fsdata;
+ struct kobject * kobj = sd_kobj->s_element;
struct sysfs_ops * ops = buffer->ops;
return ops->store(kobj,attr,buffer->page,count);
@@ -238,8 +234,10 @@ sysfs_write_file(struct file *file, cons
static int check_perm(struct inode * inode, struct file * file)
{
- struct kobject * kobj = kobject_get(file->f_dentry->d_parent->d_fsdata);
- struct attribute * attr = file->f_dentry->d_fsdata;
+ struct sysfs_dirent * sd_attr = file->f_dentry->d_fsdata;
+ struct attribute * attr = sd_attr->s_element;
+ struct sysfs_dirent * sd_kobj = file->f_dentry->d_parent->d_fsdata;
+ struct kobject * kobj = kobject_get(sd_kobj->s_element);
struct sysfs_buffer * buffer;
struct sysfs_ops * ops = NULL;
int error = 0;
@@ -320,8 +318,10 @@ static int sysfs_open_file(struct inode
static int sysfs_release(struct inode * inode, struct file * filp)
{
- struct kobject * kobj = filp->f_dentry->d_parent->d_fsdata;
- struct attribute * attr = filp->f_dentry->d_fsdata;
+ struct sysfs_dirent * sd_attr = filp->f_dentry->d_fsdata;
+ struct attribute * attr = sd_attr->s_element;
+ struct sysfs_dirent * sd_kobj = filp->f_dentry->d_parent->d_fsdata;
+ struct kobject * kobj = sd_kobj->s_element;
struct sysfs_buffer * buffer = filp->private_data;
if (kobj)
@@ -336,7 +336,7 @@ static int sysfs_release(struct inode *
return 0;
}
-static struct file_operations sysfs_file_operations = {
+struct file_operations sysfs_file_operations = {
.read = sysfs_read_file,
.write = sysfs_write_file,
.llseek = generic_file_llseek,
@@ -345,23 +345,18 @@ static struct file_operations sysfs_file
};
-int sysfs_add_file(struct dentry * dir, const struct attribute * attr)
+int sysfs_add_file(struct dentry * parent, const struct attribute * attr, int t)
{
- struct dentry * dentry;
- int error;
+ struct sysfs_dirent * sd;
+ struct sysfs_dirent * parent_sd = parent->d_fsdata;
+ int error = 0;
- down(&dir->d_inode->i_sem);
- dentry = sysfs_get_dentry(dir,attr->name);
- if (!IS_ERR(dentry)) {
- error = sysfs_create(dentry,
- (attr->mode & S_IALLUGO) | S_IFREG,
- init_file);
- if (!error)
- dentry->d_fsdata = (void *)attr;
- dput(dentry);
- } else
- error = PTR_ERR(dentry);
- up(&dir->d_inode->i_sem);
+ down(&parent->d_inode->i_sem);
+ sd = sysfs_new_dirent(parent_sd, (void *) attr, t);
+ if (!sd)
+ error = -ENOMEM;
+ up(&parent->d_inode->i_sem);
+
return error;
}
@@ -374,8 +369,8 @@ int sysfs_add_file(struct dentry * dir,
int sysfs_create_file(struct kobject * kobj, const struct attribute * attr)
{
- if (kobj && attr)
- return sysfs_add_file(kobj->dentry,attr);
+ if (kobj && kobj->dentry && attr)
+ return sysfs_add_file(kobj->dentry, attr, SYSFS_KOBJ_ATTR);
return -EINVAL;
}
diff -puN fs/sysfs/inode.c~sysfs-leaves-file fs/sysfs/inode.c
--- linux-2.6.5-rc1/fs/sysfs/inode.c~sysfs-leaves-file 2004-03-18 11:36:30.000000000 +0530
+++ linux-2.6.5-rc1-maneesh/fs/sysfs/inode.c 2004-03-18 11:36:30.000000000 +0530
@@ -11,6 +11,8 @@
#include <linux/pagemap.h>
#include <linux/namei.h>
#include <linux/backing-dev.h>
+#include "sysfs.h"
+
extern struct super_block * sysfs_sb;
static struct address_space_operations sysfs_aops = {
@@ -61,7 +63,8 @@ int sysfs_create(struct dentry * dentry,
error = init(inode);
if (!error) {
d_instantiate(dentry, inode);
- dget(dentry); /* Extra count - pin the dentry in core */
+ if (S_ISDIR(mode))
+ dget(dentry); /* pin only directory dentry in core */
} else
iput(inode);
Done:
@@ -96,14 +99,19 @@ void sysfs_hash_and_remove(struct dentry
pr_debug("sysfs: Removing %s (%d)\n", victim->d_name.name,
atomic_read(&victim->d_count));
- d_delete(victim);
- simple_unlink(dir->d_inode,victim);
+ if (S_ISDIR(victim->d_inode->i_mode)) {
+ d_delete(victim);
+ simple_unlink(dir->d_inode,victim);
+ }
+ else
+ d_drop(victim);
}
/*
* Drop reference from sysfs_get_dentry() above.
*/
dput(victim);
}
+ sysfs_remove_dirent(dir->d_fsdata, name);
up(&dir->d_inode->i_sem);
}
_
--
Maneesh Soni
Linux Technology Center,
IBM Software Lab, Bangalore, India
email: maneesh@in.ibm.com
Phone: 91-80-25044999 Fax: 91-80-25268553
T/L : 9243696
next prev parent reply other threads:[~2004-03-18 6:32 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-03-18 6:33 [RFC 0/6] sysfs backing store v0.3 Maneesh Soni
2004-03-18 6:33 ` [RFC 1/6] " Maneesh Soni
2004-03-18 6:34 ` [RFC 2/6] " Maneesh Soni
2004-03-18 6:34 ` Maneesh Soni [this message]
2004-03-18 6:35 ` [RFC 4/6] " Maneesh Soni
2004-03-18 6:35 ` [RFC 5/6] " Maneesh Soni
2004-03-18 6:36 ` [RFC 6/6] " Maneesh Soni
2004-03-20 17:57 ` [RFC 0/6] " Matt Mackall
2004-03-22 6:28 ` Maneesh Soni
2004-03-22 6:30 ` [RFC 1/6] " Maneesh Soni
2004-03-22 6:30 ` [RFC 2/6] " Maneesh Soni
2004-03-22 6:30 ` [RFC 3/6] " Maneesh Soni
2004-03-22 6:31 ` [RFC 4/6] " Maneesh Soni
2004-03-22 6:31 ` [RFC 5/6] " Maneesh Soni
2004-03-22 6:32 ` [RFC 6/6] " Maneesh Soni
2004-03-24 10:45 ` [RFC 2/6] sysfs backing store v0.3a Maneesh Soni
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20040318063455.GD27107@in.ibm.com \
--to=maneesh@in.ibm.com \
--cc=CBORNTRA@de.ibm.com \
--cc=COTTE@de.ibm.com \
--cc=dipankar@in.ibm.com \
--cc=greg@kroah.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mjbligh@us.ibm.com \
--cc=mpm@selenic.com \
--cc=viro@parcelfarce.linux.theplanet.co.uk \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.