forked from Minki/linux
[readdir] convert romfs
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
5f6039ce69
commit
3903b38ce7
@ -145,19 +145,18 @@ static const struct address_space_operations romfs_aops = {
|
||||
/*
|
||||
* read the entries from a directory
|
||||
*/
|
||||
static int romfs_readdir(struct file *filp, void *dirent, filldir_t filldir)
|
||||
static int romfs_readdir(struct file *file, struct dir_context *ctx)
|
||||
{
|
||||
struct inode *i = file_inode(filp);
|
||||
struct inode *i = file_inode(file);
|
||||
struct romfs_inode ri;
|
||||
unsigned long offset, maxoff;
|
||||
int j, ino, nextfh;
|
||||
int stored = 0;
|
||||
char fsname[ROMFS_MAXFN]; /* XXX dynamic? */
|
||||
int ret;
|
||||
|
||||
maxoff = romfs_maxsize(i->i_sb);
|
||||
|
||||
offset = filp->f_pos;
|
||||
offset = ctx->pos;
|
||||
if (!offset) {
|
||||
offset = i->i_ino & ROMFH_MASK;
|
||||
ret = romfs_dev_read(i->i_sb, offset, &ri, ROMFH_SIZE);
|
||||
@ -170,10 +169,10 @@ static int romfs_readdir(struct file *filp, void *dirent, filldir_t filldir)
|
||||
for (;;) {
|
||||
if (!offset || offset >= maxoff) {
|
||||
offset = maxoff;
|
||||
filp->f_pos = offset;
|
||||
ctx->pos = offset;
|
||||
goto out;
|
||||
}
|
||||
filp->f_pos = offset;
|
||||
ctx->pos = offset;
|
||||
|
||||
/* Fetch inode info */
|
||||
ret = romfs_dev_read(i->i_sb, offset, &ri, ROMFH_SIZE);
|
||||
@ -194,16 +193,14 @@ static int romfs_readdir(struct file *filp, void *dirent, filldir_t filldir)
|
||||
nextfh = be32_to_cpu(ri.next);
|
||||
if ((nextfh & ROMFH_TYPE) == ROMFH_HRD)
|
||||
ino = be32_to_cpu(ri.spec);
|
||||
if (filldir(dirent, fsname, j, offset, ino,
|
||||
romfs_dtype_table[nextfh & ROMFH_TYPE]) < 0)
|
||||
if (!dir_emit(ctx, fsname, j, ino,
|
||||
romfs_dtype_table[nextfh & ROMFH_TYPE]))
|
||||
goto out;
|
||||
|
||||
stored++;
|
||||
offset = nextfh & ROMFH_MASK;
|
||||
}
|
||||
|
||||
out:
|
||||
return stored;
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -281,7 +278,7 @@ error:
|
||||
|
||||
static const struct file_operations romfs_dir_operations = {
|
||||
.read = generic_read_dir,
|
||||
.readdir = romfs_readdir,
|
||||
.iterate = romfs_readdir,
|
||||
.llseek = default_llseek,
|
||||
};
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user