* [patch 18/21] vfs: seq_file: add helpers for data filling
@ 2009-09-18 20:06 akpm
2009-09-21 10:03 ` Al Viro
0 siblings, 1 reply; 3+ messages in thread
From: akpm @ 2009-09-18 20:06 UTC (permalink / raw)
To: viro
Cc: linux-fsdevel, akpm, mszeredi, Valdis.Kletnieks, agruen, hch,
hugh.dickins, matthew
From: Miklos Szeredi <mszeredi@suse.cz>
Add two helpers that allow access to the seq_file's own buffer, but
hides the internal details of seq_files.
This allows easier implementation of special purpose filling
functions. It also cleans up some existing functions which duplicated
the seq_file logic.
Signed-off-by: Miklos Szeredi <mszeredi@suse.cz>
Cc: Valdis Kletnieks <Valdis.Kletnieks@vt.edu>
Acked-by: Hugh Dickins <hugh.dickins@tiscali.co.uk>
Cc: Matthew Wilcox <matthew@wil.cx>
Cc: Andreas Gruenbacher <agruen@suse.de>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: Christoph Hellwig <hch@lst.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
---
fs/seq_file.c | 113 +++++++++++++++++++++++++------------
include/linux/seq_file.h | 3
2 files changed, 80 insertions(+), 36 deletions(-)
diff -puN fs/seq_file.c~vfs-seq_file-add-helpers-for-data-filling fs/seq_file.c
--- a/fs/seq_file.c~vfs-seq_file-add-helpers-for-data-filling
+++ a/fs/seq_file.c
@@ -419,6 +419,44 @@ char *mangle_path(char *s, char *p, char
EXPORT_SYMBOL(mangle_path);
/**
+ * seq_get_buf - get buffer to write arbitrary data to
+ * @m: the seq_file handle
+ * @bufp: the beginning of the buffer is stored here
+ *
+ * Return the number of bytes available in the buffer, or zero if
+ * there's no space.
+ */
+size_t seq_get_buf(struct seq_file *m, char **bufp)
+{
+ BUG_ON(m->count > m->size);
+ if (m->count < m->size)
+ *bufp = m->buf + m->count;
+ else
+ *bufp = NULL;
+
+ return m->size - m->count;
+}
+
+/**
+ * seq_commit - commit data to the buffer
+ * @m: the seq_file handle
+ * @num: the number of bytes to commit
+ *
+ * Commit @num bytes of data written to a buffer previously acquired
+ * by seq_buf_get. To signal an error condition, or that the data
+ * didn't fit in the available space, pass a negative @num value.
+ */
+void seq_commit(struct seq_file *m, int num)
+{
+ if (num < 0) {
+ m->count = m->size;
+ } else {
+ BUG_ON(m->count + num > m->size);
+ m->count += num;
+ }
+}
+
+/**
* seq_path - seq_file interface to print a pathname
* @m: the seq_file handle
* @path: the struct path to print
@@ -429,20 +467,21 @@ EXPORT_SYMBOL(mangle_path);
*/
int seq_path(struct seq_file *m, struct path *path, char *esc)
{
- if (m->count < m->size) {
- char *s = m->buf + m->count;
- char *p = d_path(path, s, m->size - m->count);
+ char *buf;
+ size_t size = seq_get_buf(m, &buf);
+ int res = -1;
+
+ if (size) {
+ char *p = d_path(path, buf, size);
if (!IS_ERR(p)) {
- s = mangle_path(s, p, esc);
- if (s) {
- p = m->buf + m->count;
- m->count = s - m->buf;
- return s - p;
- }
+ char *end = mangle_path(buf, p, esc);
+ if (end)
+ res = end - buf;
}
}
- m->count = m->size;
- return -1;
+ seq_commit(m, res);
+
+ return res;
}
EXPORT_SYMBOL(seq_path);
@@ -454,27 +493,28 @@ EXPORT_SYMBOL(seq_path);
int seq_path_root(struct seq_file *m, struct path *path, struct path *root,
char *esc)
{
- int err = -ENAMETOOLONG;
- if (m->count < m->size) {
- char *s = m->buf + m->count;
+ char *buf;
+ size_t size = seq_get_buf(m, &buf);
+ int res = -ENAMETOOLONG;
+
+ if (size) {
char *p;
spin_lock(&dcache_lock);
- p = __d_path(path, root, s, m->size - m->count);
+ p = __d_path(path, root, buf, size);
spin_unlock(&dcache_lock);
- err = PTR_ERR(p);
+ res = PTR_ERR(p);
if (!IS_ERR(p)) {
- s = mangle_path(s, p, esc);
- if (s) {
- p = m->buf + m->count;
- m->count = s - m->buf;
- return 0;
- }
- err = -ENAMETOOLONG;
+ char *end = mangle_path(buf, p, esc);
+ if (end)
+ res = end - buf;
+ else
+ res = -ENAMETOOLONG;
}
}
- m->count = m->size;
- return err;
+ seq_commit(m, res);
+
+ return res < 0 ? res : 0;
}
/*
@@ -482,20 +522,21 @@ int seq_path_root(struct seq_file *m, st
*/
int seq_dentry(struct seq_file *m, struct dentry *dentry, char *esc)
{
- if (m->count < m->size) {
- char *s = m->buf + m->count;
- char *p = dentry_path(dentry, s, m->size - m->count);
+ char *buf;
+ size_t size = seq_get_buf(m, &buf);
+ int res = -1;
+
+ if (size) {
+ char *p = dentry_path(dentry, buf, size);
if (!IS_ERR(p)) {
- s = mangle_path(s, p, esc);
- if (s) {
- p = m->buf + m->count;
- m->count = s - m->buf;
- return s - p;
- }
+ char *end = mangle_path(buf, p, esc);
+ if (end)
+ res = end - buf;
}
}
- m->count = m->size;
- return -1;
+ seq_commit(m, res);
+
+ return res;
}
int seq_bitmap(struct seq_file *m, const unsigned long *bits,
diff -puN include/linux/seq_file.h~vfs-seq_file-add-helpers-for-data-filling include/linux/seq_file.h
--- a/include/linux/seq_file.h~vfs-seq_file-add-helpers-for-data-filling
+++ a/include/linux/seq_file.h
@@ -48,6 +48,9 @@ int seq_write(struct seq_file *seq, cons
int seq_printf(struct seq_file *, const char *, ...)
__attribute__ ((format (printf,2,3)));
+size_t seq_get_buf(struct seq_file *m, char **bufp);
+void seq_commit(struct seq_file *m, int num);
+
int seq_path(struct seq_file *, struct path *, char *);
int seq_dentry(struct seq_file *, struct dentry *, char *);
int seq_path_root(struct seq_file *m, struct path *path, struct path *root,
_
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [patch 18/21] vfs: seq_file: add helpers for data filling
2009-09-18 20:06 [patch 18/21] vfs: seq_file: add helpers for data filling akpm
@ 2009-09-21 10:03 ` Al Viro
2009-09-21 12:43 ` Miklos Szeredi
0 siblings, 1 reply; 3+ messages in thread
From: Al Viro @ 2009-09-21 10:03 UTC (permalink / raw)
To: akpm
Cc: linux-fsdevel, mszeredi, Valdis.Kletnieks, agruen, hch,
hugh.dickins, matthew
On Fri, Sep 18, 2009 at 01:06:00PM -0700, akpm@linux-foundation.org wrote:
> From: Miklos Szeredi <mszeredi@suse.cz>
>
> Add two helpers that allow access to the seq_file's own buffer, but
> hides the internal details of seq_files.
>
> This allows easier implementation of special purpose filling
> functions. It also cleans up some existing functions which duplicated
> the seq_file logic.
Nice, but I suspect that exporting those two would be the right thing.
That, or inlining them - we are not actually hiding anything here, seeing
that struct seq_file is declared right there in the seq_file.h.
I'm certainly fine with these helpers and associated cleanup. Unless
somebody has realistic plans of actually hiding the seq_file implementation[1],
I'd simply inline those two in seq_file.h. Miklos?
[1] one obvious obstacle is that callers of seq_open() may want at least to
set seq_file->private; that can be solved, of course, but I won't swear that
we have nothing beyond that
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [patch 18/21] vfs: seq_file: add helpers for data filling
2009-09-21 10:03 ` Al Viro
@ 2009-09-21 12:43 ` Miklos Szeredi
0 siblings, 0 replies; 3+ messages in thread
From: Miklos Szeredi @ 2009-09-21 12:43 UTC (permalink / raw)
To: Al Viro
Cc: akpm, linux-fsdevel, Valdis.Kletnieks, agruen, hch, hugh.dickins,
matthew
On Mon, 2009-09-21 at 11:03 +0100, Al Viro wrote:
> On Fri, Sep 18, 2009 at 01:06:00PM -0700, akpm@linux-foundation.org wrote:
> > From: Miklos Szeredi <mszeredi@suse.cz>
> >
> > Add two helpers that allow access to the seq_file's own buffer, but
> > hides the internal details of seq_files.
> >
> > This allows easier implementation of special purpose filling
> > functions. It also cleans up some existing functions which duplicated
> > the seq_file logic.
>
> Nice, but I suspect that exporting those two would be the right thing.
> That, or inlining them - we are not actually hiding anything here, seeing
> that struct seq_file is declared right there in the seq_file.h.
>
> I'm certainly fine with these helpers and associated cleanup. Unless
> somebody has realistic plans of actually hiding the seq_file implementation[1],
> I'd simply inline those two in seq_file.h. Miklos?
Updated patches coming up.
Thanks,
Miklos
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2009-09-21 12:43 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-09-18 20:06 [patch 18/21] vfs: seq_file: add helpers for data filling akpm
2009-09-21 10:03 ` Al Viro
2009-09-21 12:43 ` Miklos Szeredi
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).