Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 312974
b: refs/heads/master
c: a8c7176
h: refs/heads/master
v: v3
  • Loading branch information
Jan Kara authored and Al Viro committed Jul 22, 2012
1 parent a58a399 commit c32f295
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 8 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: 5c0d6b60a0ba46d45020547eacf7199171920935
refs/heads/master: a8c7176b6ded413d5044a00f1d05477b95a6d7ad
18 changes: 11 additions & 7 deletions trunk/fs/sync.c
Original file line number Diff line number Diff line change
Expand Up @@ -85,10 +85,14 @@ static void sync_fs_one_sb(struct super_block *sb, void *arg)
sb->s_op->sync_fs(sb, *(int *)arg);
}

static void sync_blkdev_one_sb(struct super_block *sb, void *arg)
static void flush_one_bdev(struct block_device *bdev, void *arg)
{
if (!(sb->s_flags & MS_RDONLY))
__sync_blockdev(sb->s_bdev, *(int *)arg);
__sync_blockdev(bdev, 0);
}

static void sync_one_bdev(struct block_device *bdev, void *arg)
{
sync_blockdev(bdev);
}

/*
Expand All @@ -102,10 +106,10 @@ SYSCALL_DEFINE0(sync)
wakeup_flusher_threads(0, WB_REASON_SYNC);
iterate_supers(writeback_inodes_one_sb, NULL);
iterate_supers(sync_fs_one_sb, &nowait);
iterate_supers(sync_blkdev_one_sb, &nowait);
iterate_bdevs(flush_one_bdev, NULL);
iterate_supers(sync_inodes_one_sb, NULL);
iterate_supers(sync_fs_one_sb, &wait);
iterate_supers(sync_blkdev_one_sb, &wait);
iterate_bdevs(sync_one_bdev, NULL);
if (unlikely(laptop_mode))
laptop_sync_completion();
return 0;
Expand All @@ -121,10 +125,10 @@ static void do_sync_work(struct work_struct *work)
*/
iterate_supers(sync_inodes_one_sb, &nowait);
iterate_supers(sync_fs_one_sb, &nowait);
iterate_supers(sync_blkdev_one_sb, &nowait);
iterate_bdevs(flush_one_bdev, NULL);
iterate_supers(sync_inodes_one_sb, &nowait);
iterate_supers(sync_fs_one_sb, &nowait);
iterate_supers(sync_blkdev_one_sb, &nowait);
iterate_bdevs(flush_one_bdev, NULL);
printk("Emergency Sync complete\n");
kfree(work);
}
Expand Down

0 comments on commit c32f295

Please sign in to comment.