Skip to content

Commit 4287e4d

Browse files
Russell KingAl Viro
authored andcommitted
fs/adfs: dir: add more efficient iterate() per-format method
Rather than using setpos + getnext to iterate through the directory entries, pass iterate() down to the dir format code to populate the dirents. Signed-off-by: Russell King <[email protected]> Signed-off-by: Al Viro <[email protected]>
1 parent cdc46e9 commit 4287e4d

File tree

4 files changed

+42
-14
lines changed

4 files changed

+42
-14
lines changed

fs/adfs/adfs.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -120,6 +120,7 @@ struct object_info {
120120
struct adfs_dir_ops {
121121
int (*read)(struct super_block *sb, unsigned int indaddr,
122122
unsigned int size, struct adfs_dir *dir);
123+
int (*iterate)(struct adfs_dir *dir, struct dir_context *ctx);
123124
int (*setpos)(struct adfs_dir *dir, unsigned int fpos);
124125
int (*getnext)(struct adfs_dir *dir, struct object_info *obj);
125126
int (*update)(struct adfs_dir *dir, struct object_info *obj);

fs/adfs/dir.c

Lines changed: 2 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -240,12 +240,8 @@ static int adfs_iterate(struct file *file, struct dir_context *ctx)
240240
struct inode *inode = file_inode(file);
241241
struct super_block *sb = inode->i_sb;
242242
const struct adfs_dir_ops *ops = ADFS_SB(sb)->s_dir;
243-
struct object_info obj;
244243
struct adfs_dir dir;
245-
int ret = 0;
246-
247-
if (ctx->pos >> 32)
248-
return 0;
244+
int ret;
249245

250246
down_read(&adfs_dir_rwsem);
251247
ret = adfs_dir_read_inode(sb, inode, &dir);
@@ -263,15 +259,7 @@ static int adfs_iterate(struct file *file, struct dir_context *ctx)
263259
ctx->pos = 2;
264260
}
265261

266-
ret = ops->setpos(&dir, ctx->pos - 2);
267-
if (ret)
268-
goto unlock_relse;
269-
while (ops->getnext(&dir, &obj) == 0) {
270-
if (!dir_emit(ctx, obj.name, obj.name_len,
271-
obj.indaddr, DT_UNKNOWN))
272-
break;
273-
ctx->pos++;
274-
}
262+
ret = ops->iterate(&dir, ctx);
275263

276264
unlock_relse:
277265
up_read(&adfs_dir_rwsem);

fs/adfs/dir_f.c

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -302,6 +302,23 @@ adfs_f_getnext(struct adfs_dir *dir, struct object_info *obj)
302302
return ret;
303303
}
304304

305+
static int adfs_f_iterate(struct adfs_dir *dir, struct dir_context *ctx)
306+
{
307+
struct object_info obj;
308+
int pos = 5 + (ctx->pos - 2) * 26;
309+
310+
while (ctx->pos < 2 + ADFS_NUM_DIR_ENTRIES) {
311+
if (__adfs_dir_get(dir, pos, &obj))
312+
break;
313+
if (!dir_emit(ctx, obj.name, obj.name_len,
314+
obj.indaddr, DT_UNKNOWN))
315+
break;
316+
pos += 26;
317+
ctx->pos++;
318+
}
319+
return 0;
320+
}
321+
305322
static int
306323
adfs_f_update(struct adfs_dir *dir, struct object_info *obj)
307324
{
@@ -359,6 +376,7 @@ adfs_f_update(struct adfs_dir *dir, struct object_info *obj)
359376

360377
const struct adfs_dir_ops adfs_f_dir_ops = {
361378
.read = adfs_f_read,
379+
.iterate = adfs_f_iterate,
362380
.setpos = adfs_f_setpos,
363381
.getnext = adfs_f_getnext,
364382
.update = adfs_f_update,

fs/adfs/dir_fplus.c

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -118,8 +118,29 @@ adfs_fplus_getnext(struct adfs_dir *dir, struct object_info *obj)
118118
return 0;
119119
}
120120

121+
static int adfs_fplus_iterate(struct adfs_dir *dir, struct dir_context *ctx)
122+
{
123+
struct object_info obj;
124+
125+
if ((ctx->pos - 2) >> 32)
126+
return 0;
127+
128+
if (adfs_fplus_setpos(dir, ctx->pos - 2))
129+
return 0;
130+
131+
while (!adfs_fplus_getnext(dir, &obj)) {
132+
if (!dir_emit(ctx, obj.name, obj.name_len,
133+
obj.indaddr, DT_UNKNOWN))
134+
break;
135+
ctx->pos++;
136+
}
137+
138+
return 0;
139+
}
140+
121141
const struct adfs_dir_ops adfs_fplus_dir_ops = {
122142
.read = adfs_fplus_read,
143+
.iterate = adfs_fplus_iterate,
123144
.setpos = adfs_fplus_setpos,
124145
.getnext = adfs_fplus_getnext,
125146
};

0 commit comments

Comments
 (0)