Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 70731
b: refs/heads/master
c: 0e0f4fc
h: refs/heads/master
i:
  70729: fab56a9
  70727: 170ee72
v: v3
  • Loading branch information
Ken Chen authored and Linus Torvalds committed Oct 17, 2007
1 parent c2a7ba7 commit de7dab7
Show file tree
Hide file tree
Showing 4 changed files with 17 additions and 23 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 670e4def6ef5f44315d62748134e535b479c784f
refs/heads/master: 0e0f4fc22ece8e593167eccbb1a4154565c11faa
36 changes: 14 additions & 22 deletions trunk/fs/fs-writeback.c
Original file line number Diff line number Diff line change
Expand Up @@ -165,25 +165,11 @@ static void redirty_tail(struct inode *inode)
}

/*
* Redirty an inode, but mark it as the very next-to-be-written inode on its
* superblock's dirty-inode list.
* We need to preserve s_dirty's reverse-time-orderedness, so we cheat by
* setting this inode's dirtied_when to the same value as that of the inode
* which is presently head-of-list, if present head-of-list is newer than this
* inode. (head-of-list is the least-recently-dirtied inode: the oldest one).
* requeue inode for re-scanning after sb->s_io list is exhausted.
*/
static void redirty_head(struct inode *inode)
static void requeue_io(struct inode *inode)
{
struct super_block *sb = inode->i_sb;

if (!list_empty(&sb->s_dirty)) {
struct inode *head_inode;

head_inode = list_entry(sb->s_dirty.prev, struct inode, i_list);
if (time_after(inode->dirtied_when, head_inode->dirtied_when))
inode->dirtied_when = head_inode->dirtied_when;
}
list_move_tail(&inode->i_list, &sb->s_dirty);
list_move(&inode->i_list, &inode->i_sb->s_more_io);
}

/*
Expand Down Expand Up @@ -255,7 +241,7 @@ __sync_single_inode(struct inode *inode, struct writeback_control *wbc)
* uncongested.
*/
inode->i_state |= I_DIRTY_PAGES;
redirty_head(inode);
requeue_io(inode);
} else {
/*
* Otherwise fully redirty the inode so that
Expand Down Expand Up @@ -315,7 +301,7 @@ __writeback_single_inode(struct inode *inode, struct writeback_control *wbc)
* on s_io. We'll have another go at writing back this inode
* when the s_dirty iodes get moved back onto s_io.
*/
redirty_head(inode);
requeue_io(inode);

/*
* Even if we don't actually write the inode itself here,
Expand Down Expand Up @@ -410,14 +396,14 @@ sync_sb_inodes(struct super_block *sb, struct writeback_control *wbc)
wbc->encountered_congestion = 1;
if (!sb_is_blkdev_sb(sb))
break; /* Skip a congested fs */
redirty_head(inode);
requeue_io(inode);
continue; /* Skip a congested blockdev */
}

if (wbc->bdi && bdi != wbc->bdi) {
if (!sb_is_blkdev_sb(sb))
break; /* fs has the wrong queue */
redirty_head(inode);
requeue_io(inode);
continue; /* blockdev has wrong queue */
}

Expand All @@ -427,8 +413,10 @@ sync_sb_inodes(struct super_block *sb, struct writeback_control *wbc)

/* Was this inode dirtied too recently? */
if (wbc->older_than_this && time_after(inode->dirtied_when,
*wbc->older_than_this))
*wbc->older_than_this)) {
list_splice_init(&sb->s_io, sb->s_dirty.prev);
break;
}

/* Is another pdflush already flushing this queue? */
if (current_is_pdflush() && !writeback_acquire(bdi))
Expand Down Expand Up @@ -458,6 +446,10 @@ sync_sb_inodes(struct super_block *sb, struct writeback_control *wbc)
if (wbc->nr_to_write <= 0)
break;
}

if (list_empty(&sb->s_io))
list_splice_init(&sb->s_more_io, &sb->s_io);

return; /* Leave any unwritten inodes on s_io */
}

Expand Down
1 change: 1 addition & 0 deletions trunk/fs/super.c
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@ static struct super_block *alloc_super(struct file_system_type *type)
}
INIT_LIST_HEAD(&s->s_dirty);
INIT_LIST_HEAD(&s->s_io);
INIT_LIST_HEAD(&s->s_more_io);
INIT_LIST_HEAD(&s->s_files);
INIT_LIST_HEAD(&s->s_instances);
INIT_HLIST_HEAD(&s->s_anon);
Expand Down
1 change: 1 addition & 0 deletions trunk/include/linux/fs.h
Original file line number Diff line number Diff line change
Expand Up @@ -1002,6 +1002,7 @@ struct super_block {
struct list_head s_inodes; /* all inodes */
struct list_head s_dirty; /* dirty inodes */
struct list_head s_io; /* parked for writeback */
struct list_head s_more_io; /* parked for more writeback */
struct hlist_head s_anon; /* anonymous dentries for (nfs) exporting */
struct list_head s_files;

Expand Down

0 comments on commit de7dab7

Please sign in to comment.