Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 274367
b: refs/heads/master
c: ad4e38d
h: refs/heads/master
i:
  274365: 8a0c5f4
  274363: 6867abf
  274359: fcd09d5
  274351: 163ace8
  274335: 374cf7f
  274303: 4a74109
v: v3
  • Loading branch information
Curt Wohlgemuth authored and Wu Fengguang committed Oct 30, 2011
1 parent fcb0618 commit 7d5162e
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 11 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: ece13ac31bbe492d940ba0bc4ade2ae1521f46a5
refs/heads/master: ad4e38dd6a33bb3a4882c487d7abe621e583b982
16 changes: 8 additions & 8 deletions trunk/fs/fs-writeback.c
Original file line number Diff line number Diff line change
Expand Up @@ -251,7 +251,7 @@ static bool inode_dirtied_after(struct inode *inode, unsigned long t)
*/
static int move_expired_inodes(struct list_head *delaying_queue,
struct list_head *dispatch_queue,
unsigned long *older_than_this)
struct wb_writeback_work *work)
{
LIST_HEAD(tmp);
struct list_head *pos, *node;
Expand All @@ -262,8 +262,8 @@ static int move_expired_inodes(struct list_head *delaying_queue,

while (!list_empty(delaying_queue)) {
inode = wb_inode(delaying_queue->prev);
if (older_than_this &&
inode_dirtied_after(inode, *older_than_this))
if (work->older_than_this &&
inode_dirtied_after(inode, *work->older_than_this))
break;
if (sb && sb != inode->i_sb)
do_sb_sort = 1;
Expand Down Expand Up @@ -302,13 +302,13 @@ static int move_expired_inodes(struct list_head *delaying_queue,
* |
* +--> dequeue for IO
*/
static void queue_io(struct bdi_writeback *wb, unsigned long *older_than_this)
static void queue_io(struct bdi_writeback *wb, struct wb_writeback_work *work)
{
int moved;
assert_spin_locked(&wb->list_lock);
list_splice_init(&wb->b_more_io, &wb->b_io);
moved = move_expired_inodes(&wb->b_dirty, &wb->b_io, older_than_this);
trace_writeback_queue_io(wb, older_than_this, moved);
moved = move_expired_inodes(&wb->b_dirty, &wb->b_io, work);
trace_writeback_queue_io(wb, work, moved);
}

static int write_inode(struct inode *inode, struct writeback_control *wbc)
Expand Down Expand Up @@ -651,7 +651,7 @@ long writeback_inodes_wb(struct bdi_writeback *wb, long nr_pages)

spin_lock(&wb->list_lock);
if (list_empty(&wb->b_io))
queue_io(wb, NULL);
queue_io(wb, &work);
__writeback_inodes_wb(wb, &work);
spin_unlock(&wb->list_lock);

Expand Down Expand Up @@ -745,7 +745,7 @@ static long wb_writeback(struct bdi_writeback *wb,

trace_writeback_start(wb->bdi, work);
if (list_empty(&wb->b_io))
queue_io(wb, work->older_than_this);
queue_io(wb, work);
if (work->sb)
progress = writeback_sb_inodes(work->sb, wb, work);
else
Expand Down
5 changes: 3 additions & 2 deletions trunk/include/trace/events/writeback.h
Original file line number Diff line number Diff line change
Expand Up @@ -157,16 +157,17 @@ DEFINE_WBC_EVENT(wbc_writepage);

TRACE_EVENT(writeback_queue_io,
TP_PROTO(struct bdi_writeback *wb,
unsigned long *older_than_this,
struct wb_writeback_work *work,
int moved),
TP_ARGS(wb, older_than_this, moved),
TP_ARGS(wb, work, moved),
TP_STRUCT__entry(
__array(char, name, 32)
__field(unsigned long, older)
__field(long, age)
__field(int, moved)
),
TP_fast_assign(
unsigned long *older_than_this = work->older_than_this;
strncpy(__entry->name, dev_name(wb->bdi->dev), 32);
__entry->older = older_than_this ? *older_than_this : 0;
__entry->age = older_than_this ?
Expand Down

0 comments on commit 7d5162e

Please sign in to comment.