lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1237439565-25039-3-git-send-email-hooanon05@yahoo.co.jp>
Date:	Thu, 19 Mar 2009 14:12:45 +0900
From:	"J. R. Okajima" <hooanon05@...oo.co.jp>
To:	greg@...ah.com
Cc:	linux-kernel@...r.kernel.org, linux-fsdevel@...r.kernel.org,
	"J. R. Okajima" <hooanon05@...oo.co.jp>
Subject: [RFC Aufs2 #3 2/2] split 'xino' entry under sysfs

Follow the comments from Greg KH on LKML.
- make all entries "one value per file".
- split 'xino' into 'xi_path', 'xib' and 'xi0'...'xiN'.
- new members in struct au_xino_file for xi[0-9]* entry.
- remove sysaufs_si_attr_xino.
- sysaufs_si_xino() shows only a size info of one xino file.
- new variables sysaufs_si_attr_xi_path and sysaufs_si_attr_xib.
- new functions sysaufs_si_xi_path() and sysaufs_si_xib().
- rename sysaufs_sbi_xi() to sysaufs_xi_attr().
- sysaufs_si_show() supports xiN.
- sysaufs_br_init() initializes br->br_xino.xi_attr too.
- sysaufs_brs_del() and sysaufs_brs_add() always handle
  br->br_xino.xi_attr.
- new static function sysaufs_brs_do_add() to generate brN and xiN
  names.

Signed-off-by: J. R. Okajima <hooanon05@...oo.co.jp>
---
 Documentation/ABI/testing/sysfs-aufs |   62 +++++++++++
 fs/aufs/branch.h                     |    6 +
 fs/aufs/sysaufs.c                    |    6 +-
 fs/aufs/sysaufs.h                    |   11 ++-
 fs/aufs/sysfs.c                      |  195 +++++++++++++++++++++++-----------
 5 files changed, 212 insertions(+), 68 deletions(-)
 create mode 100644 Documentation/ABI/testing/sysfs-aufs

diff --git a/Documentation/ABI/testing/sysfs-aufs b/Documentation/ABI/testing/sysfs-aufs
new file mode 100644
index 0000000..1552d3e
--- /dev/null
+++ b/Documentation/ABI/testing/sysfs-aufs
@@ -0,0 +1,62 @@
+What:		/sys/fs/aufs/si_<id>/
+Date:		March 2009
+Contact:	J. R. Okajima <hooanon05@...oo.co.jp>
+Description:
+		Under /sys/fs/aufs, a directory named si_<id> is created
+		per aufs mount, where <id> is a unique id generated
+		internally.
+
+What:		/sys/fs/aufs/si_<id>/br0, br1 ... brN
+Date:		March 2009
+Contact:	J. R. Okajima <hooanon05@...oo.co.jp>
+Description:
+		It shows the abolute path of a member directory (which
+		is called branch) in aufs, and its permission.
+
+What:		/sys/fs/aufs/si_<id>/xi_path
+Date:		March 2009
+Contact:	J. R. Okajima <hooanon05@...oo.co.jp>
+Description:
+		It shows the abolute path of XINO (External Inode Number
+		Bitmap, Translation Table and Generation Table) file
+		even if it is the default path.
+		When the aufs mount option 'noxino' is specified, it
+		will be empty. About XINO files, see
+		Documentation/filesystems/aufs/aufs.5 in detail.
+
+What:		/sys/fs/aufs/si_<id>/xib
+Date:		March 2009
+Contact:	J. R. Okajima <hooanon05@...oo.co.jp>
+Description:
+		It shows the consumed blocks by xib (External Inode Number
+		Bitmap), its block size and file size.
+		When the aufs mount option 'noxino' is specified, it
+		will be empty. About XINO files, see
+		Documentation/filesystems/aufs/aufs.5 in detail.
+
+What:		/sys/fs/aufs/si_<id>/xino0, xino1 ... xinoN
+Date:		March 2009
+Contact:	J. R. Okajima <hooanon05@...oo.co.jp>
+Description:
+		It shows the consumed blocks by xino (External Inode Number
+		Translation Table), its link count, block size and file
+		size.
+		When the aufs mount option 'noxino' is specified, it
+		will be empty. About XINO files, see
+		Documentation/filesystems/aufs/aufs.5 in detail.
+
+What:		/sys/fs/aufs/si_<id>/xigen
+Date:		March 2009
+Contact:	J. R. Okajima <hooanon05@...oo.co.jp>
+Description:
+		It shows the consumed blocks by xigen (External Inode
+		Generation Table), its block size and file size.
+		If CONFIG_AUFS_EXPORT is disabled, this entry will not
+		be created.
+		When the aufs mount option 'noxino' is specified, it
+		will be empty. About XINO files, see
+		Documentation/filesystems/aufs/aufs.5 in detail.
+
+# Local variables: ;
+# mode: text;
+# End: ;
diff --git a/fs/aufs/branch.h b/fs/aufs/branch.h
index 5a7fed4..838648f 100644
--- a/fs/aufs/branch.h
+++ b/fs/aufs/branch.h
@@ -31,6 +31,12 @@ struct au_xino_file {
 	struct mutex		xi_nondir_mtx;
 
 	/* todo: make xino files an array to support huge inode number */
+
+#ifdef CONFIG_SYSFS
+	/* an entry under sysfs per mount-point */
+	char			xi_name[8];
+	struct attribute	xi_attr;
+#endif
 };
 
 /* members for writable branch only */
diff --git a/fs/aufs/sysaufs.c b/fs/aufs/sysaufs.c
index 47ffbfd..c6fde2c 100644
--- a/fs/aufs/sysaufs.c
+++ b/fs/aufs/sysaufs.c
@@ -25,9 +25,11 @@ struct kset *sysaufs_ket;
 	.show   = sysaufs_si_##_name,				\
 }
 
-static struct sysaufs_si_attr sysaufs_si_attr_xino = AuSiAttr(xino);
+static struct sysaufs_si_attr sysaufs_si_attr_xi_path = AuSiAttr(xi_path),
+	sysaufs_si_attr_xib = AuSiAttr(xib);
 struct attribute *sysaufs_si_attrs[] = {
-	&sysaufs_si_attr_xino.attr,
+	&sysaufs_si_attr_xi_path.attr,
+	&sysaufs_si_attr_xib.attr,
 	NULL,
 };
 
diff --git a/fs/aufs/sysaufs.h b/fs/aufs/sysaufs.h
index 60b18a8..71a0bba 100644
--- a/fs/aufs/sysaufs.h
+++ b/fs/aufs/sysaufs.h
@@ -48,7 +48,8 @@ struct au_branch;
 /* sysfs.c */
 extern struct attribute_group *sysaufs_attr_group;
 
-int sysaufs_si_xino(struct seq_file *seq, struct super_block *sb);
+int sysaufs_si_xi_path(struct seq_file *seq, struct super_block *sb);
+int sysaufs_si_xib(struct seq_file *seq, struct super_block *sb);
 ssize_t sysaufs_si_show(struct kobject *kobj, struct attribute *attr,
 			 char *buf);
 
@@ -62,7 +63,13 @@ void sysaufs_brs_del(struct super_block *sb, aufs_bindex_t bindex);
 #define sysaufs_attr_group	NULL
 
 static inline
-int sysaufs_si_xino(struct seq_file *seq, struct super_block *sb)
+int sysaufs_si_xi_path(struct seq_file *seq, struct super_block *sb)
+{
+	return 0;
+}
+
+static inline
+int sysaufs_si_xib(struct seq_file *seq, struct super_block *sb)
 {
 	return 0;
 }
diff --git a/fs/aufs/sysfs.c b/fs/aufs/sysfs.c
index 2112f3b..9bcdce2 100644
--- a/fs/aufs/sysfs.c
+++ b/fs/aufs/sysfs.c
@@ -28,55 +28,65 @@ struct attribute_group *sysaufs_attr_group = &sysaufs_attr_group_body;
 
 /* ---------------------------------------------------------------------- */
 
-static int sysaufs_sbi_xi(struct seq_file *seq, struct file *xf,
-			  struct kstat *st)
+int sysaufs_si_xi_path(struct seq_file *seq, struct super_block *sb)
+{
+	int err;
+
+	err = 0;
+	if (au_opt_test(au_mntflags(sb), XINO)) {
+		err = au_xino_path(seq, au_sbi(sb)->si_xib);
+		seq_putc(seq, '\n');
+	}
+	return err;
+}
+
+static int sysaufs_xi_attr(struct seq_file *seq, struct file *xf,
+			   struct kstat *st)
 {
 	int err;
 
 	err = vfs_getattr(xf->f_vfsmnt, xf->f_dentry, st);
-	if (!err) {
-		seq_printf(seq, "%llux%lu %lld",
+	if (!err)
+		seq_printf(seq, "%llux%lu %lld\n",
 			   st->blocks, st->blksize, (long long)st->size);
-		seq_putc(seq, '\n');
-	} else
+	else
 		seq_printf(seq, "err %d\n", err);
 
 	return err;
 }
 
-int sysaufs_si_xino(struct seq_file *seq, struct super_block *sb)
+int sysaufs_si_xib(struct seq_file *seq, struct super_block *sb)
+{
+	int err;
+	struct kstat st;
+
+	err = 0;
+	if (au_opt_test(au_mntflags(sb), XINO))
+		err = sysaufs_xi_attr(seq, au_sbi(sb)->si_xib, &st);
+	return err;
+}
+
+static int sysaufs_si_xino(struct seq_file *seq, struct super_block *sb,
+			   aufs_bindex_t bindex)
 {
 	int err;
-	aufs_bindex_t bend, bindex;
 	struct kstat st;
-	struct au_sbinfo *sbinfo;
 	struct file *xf;
 
 	err = 0;
-	sbinfo = au_sbi(sb);
 	if (!au_opt_test(au_mntflags(sb), XINO))
 		goto out; /* success */
 
-	xf = sbinfo->si_xib;
-	err = au_xino_path(seq, xf);
-	seq_putc(seq, '\n');
-	if (!err)
-		err = sysaufs_sbi_xi(seq, xf, &st);
-
-	bend = au_sbend(sb);
-	for (bindex = 0; !err && bindex <= bend; bindex++) {
-		xf = au_sbr(sb, bindex)->br_xino.xi_file;
-		if (!xf)
-			continue;
+	AuDbg("b%d\n", bindex);
 
-		seq_printf(seq, "%d: ", bindex);
+	xf = au_sbr(sb, bindex)->br_xino.xi_file;
+	if (xf) {
 		err = vfs_getattr(xf->f_vfsmnt, xf->f_dentry, &st);
-		if (!err) {
-			seq_printf(seq, "%ld, %llux%lu %lld",
+		if (!err)
+			seq_printf(seq, "%ld, %llux%lu %lld\n",
 				   (long)file_count(xf), st.blocks, st.blksize,
 				   (long long)st.size);
-			seq_putc(seq, '\n');
-		} else
+		else
 			seq_printf(seq, "err %d\n", err);
 	}
 
@@ -89,20 +99,15 @@ int sysaufs_si_xino(struct seq_file *seq, struct super_block *sb)
  * sysfs handles the lifetime of the entry, and never call ->show() after it is
  * unlinked.
  */
-#define SysaufsBr_PREFIX "br"
-static int sysaufs_sbi_br(struct seq_file *seq, struct super_block *sb,
-			  aufs_bindex_t bindex)
+static int sysaufs_si_br(struct seq_file *seq, struct super_block *sb,
+			 aufs_bindex_t bindex)
 {
-	int err;
 	struct path path;
 	struct dentry *root;
 	struct au_branch *br;
 
-	err = -ENOENT;
-	if (unlikely(au_sbend(sb) < bindex))
-		goto out;
+	AuDbg("b%d\n", bindex);
 
-	err = 0;
 	root = sb->s_root;
 	di_read_lock_parent(root, !AuLock_IR);
 	br = au_sbr(sb, bindex);
@@ -111,9 +116,7 @@ static int sysaufs_sbi_br(struct seq_file *seq, struct super_block *sb,
 	au_seq_path(seq, &path);
 	di_read_unlock(root, !AuLock_IR);
 	seq_printf(seq, "=%s\n", au_optstr_br_perm(br->br_perm));
-
- out:
-	return err;
+	return 0;
 }
 
 /* ---------------------------------------------------------------------- */
@@ -134,17 +137,41 @@ static struct seq_file *au_seq(char *p, ssize_t len)
 	return seq;
 }
 
+#define SysaufsBr_PREFIX "br"
+#define SysaufsXi_PREFIX "xi"
+
 /* todo: file size may exceed PAGE_SIZE */
 ssize_t sysaufs_si_show(struct kobject *kobj, struct attribute *attr,
 			 char *buf)
 {
 	ssize_t err;
 	long l;
+	aufs_bindex_t bend;
 	struct au_sbinfo *sbinfo;
 	struct super_block *sb;
 	struct seq_file *seq;
 	char *name;
 	struct attribute **cattr;
+	static struct {
+		const int prefix_len;
+		char *prefix;
+		int (*func)(struct seq_file *seq, struct super_block *sb,
+			    aufs_bindex_t bindex);
+	} a[] = {
+		{
+			.prefix_len	= sizeof(SysaufsBr_PREFIX) - 1,
+			.prefix		= SysaufsBr_PREFIX,
+			.func		= sysaufs_si_br
+		},
+		{
+			.prefix_len	= sizeof(SysaufsXi_PREFIX) - 1,
+			.prefix		= SysaufsXi_PREFIX,
+			.func		= sysaufs_si_xino
+		},
+		{
+			.prefix_len	= 0
+		}
+	}, *p;
 
 	sbinfo = container_of(kobj, struct au_sbinfo, si_kobj);
 	sb = sbinfo->si_sb;
@@ -166,12 +193,22 @@ ssize_t sysaufs_si_show(struct kobject *kobj, struct attribute *attr,
 		cattr++;
 	}
 
-	if (!strncmp(name, SysaufsBr_PREFIX, sizeof(SysaufsBr_PREFIX) - 1)) {
-		name += sizeof(SysaufsBr_PREFIX) - 1;
-		err = strict_strtol(name, 10, &l);
-		if (!err)
-			err = sysaufs_sbi_br(seq, sb, (aufs_bindex_t)l);
-		goto out_seq;
+	p = a;
+	bend = au_sbend(sb);
+	while (p->prefix_len) {
+		if (!strncmp(name, p->prefix, p->prefix_len)) {
+			name += p->prefix_len;
+			err = strict_strtol(name, 10, &l);
+			if (!err) {
+				if (l <= bend)
+					err = p->func(seq, sb,
+						      (aufs_bindex_t)l);
+				else
+					err = -ENOENT;
+			}
+			goto out_seq;
+		}
+		p++;
 	}
 	BUG();
 
@@ -192,44 +229,74 @@ ssize_t sysaufs_si_show(struct kobject *kobj, struct attribute *attr,
 
 void sysaufs_br_init(struct au_branch *br)
 {
+	struct au_xino_file *xi;
+
 	br->br_attr.name = br->br_name;
 	br->br_attr.mode = S_IRUGO;
 	br->br_attr.owner = THIS_MODULE;
+
+	xi = &br->br_xino;
+	xi->xi_attr.name = xi->xi_name;
+	xi->xi_attr.mode = S_IRUGO;
+	xi->xi_attr.owner = THIS_MODULE;
 }
 
 void sysaufs_brs_del(struct super_block *sb, aufs_bindex_t bindex)
 {
-	struct au_sbinfo *sbinfo;
-	aufs_bindex_t bend;
-
-	if (!sysaufs_brs)
-		return;
+	struct au_branch *br;
+	struct au_xino_file *xi;
+	struct kobject *kobj;
+	aufs_bindex_t bend, bi;
 
-	sbinfo = au_sbi(sb);
+	kobj = &au_sbi(sb)->si_kobj;
 	bend = au_sbend(sb);
-	for (; bindex <= bend; bindex++)
-		sysfs_remove_file(&sbinfo->si_kobj,
-				  &au_sbr(sb, bindex)->br_attr);
+	for (bi = bindex; bi <= bend; bi++) {
+		br = au_sbr(sb, bi);
+		xi = &br->br_xino;
+		sysfs_remove_file(kobj, &xi->xi_attr);
+	}
+
+	if (sysaufs_brs)
+		for (; bindex <= bend; bindex++) {
+			br = au_sbr(sb, bindex);
+			sysfs_remove_file(kobj, &br->br_attr);
+		}
 }
 
-void sysaufs_brs_add(struct super_block *sb, aufs_bindex_t bindex)
+static void sysaufs_brs_do_add(struct kobject *kobj, struct attribute *attr,
+			       char name[], int nlen, char prefix[],
+			       aufs_bindex_t bindex)
 {
 	int err;
-	aufs_bindex_t bend;
+
+	snprintf(name, nlen, "%s%d", prefix, bindex);
+	err = sysfs_create_file(kobj, attr);
+	if (unlikely(err))
+		AuWarn("failed %s under sysfs(%d)\n", name, err);
+}
+
+void sysaufs_brs_add(struct super_block *sb, aufs_bindex_t bindex)
+{
+	aufs_bindex_t bend, bi;
 	struct kobject *kobj;
 	struct au_branch *br;
-
-	if (!sysaufs_brs)
-		return;
+	struct au_xino_file *xi;
 
 	kobj = &au_sbi(sb)->si_kobj;
 	bend = au_sbend(sb);
-	for (; bindex <= bend; bindex++) {
-		br = au_sbr(sb, bindex);
-		snprintf(br->br_name, sizeof(br->br_name),
-			 SysaufsBr_PREFIX "%d", bindex);
-		err = sysfs_create_file(kobj, &br->br_attr);
-		if (unlikely(err))
-			AuWarn("failed %s under sysfs(%d)\n", br->br_name, err);
+	for (bi = bindex; bi <= bend; bi++) {
+		br = au_sbr(sb, bi);
+		xi = &br->br_xino;
+		/* todo: create link for shared xino */
+		sysaufs_brs_do_add(kobj, &xi->xi_attr, xi->xi_name,
+				   sizeof(xi->xi_name), SysaufsXi_PREFIX, bi);
 	}
+
+	if (sysaufs_brs)
+		for (; bindex <= bend; bindex++) {
+			br = au_sbr(sb, bindex);
+			sysaufs_brs_do_add(kobj, &br->br_attr, br->br_name,
+					   sizeof(br->br_name),
+					   SysaufsBr_PREFIX, bindex);
+		}
 }
-- 
1.6.1.284.g5dc13

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ