This patch adds a helper function that should be used by filesystems that need to flush the underlying block device on fsync()/fdatasync(). Signed-off-by: Fernando Luis Vazquez Cao <fernando@xxxxxxxxxxxxx> --- diff -urNp linux-2.6.29-rc4-orig/fs/buffer.c linux-2.6.29-rc4/fs/buffer.c --- linux-2.6.29-rc4-orig/fs/buffer.c 2009-02-16 14:45:11.000000000 +0900 +++ linux-2.6.29-rc4/fs/buffer.c 2009-02-16 14:53:26.000000000 +0900 @@ -165,6 +165,17 @@ void end_buffer_write_sync(struct buffer put_bh(bh); } +/* Issue flush of write caches on the block device */ +int block_flush_device(struct super_block *sb) +{ + int ret = 0; + + ret = blkdev_issue_flush(sb->s_bdev, NULL); + + return (ret == -EOPNOTSUPP) ? 0 : ret; +} +EXPORT_SYMBOL(block_flush_device); + /* * Write out and wait upon all the dirty data associated with a block * device via its mapping. Does not take the superblock lock. diff -urNp linux-2.6.29-rc4-orig/include/linux/buffer_head.h linux-2.6.29-rc4/include/linux/buffer_head.h --- linux-2.6.29-rc4-orig/include/linux/buffer_head.h 2009-02-16 14:45:12.000000000 +0900 +++ linux-2.6.29-rc4/include/linux/buffer_head.h 2009-02-16 14:48:28.000000000 +0900 @@ -238,6 +238,7 @@ int nobh_write_end(struct file *, struct int nobh_truncate_page(struct address_space *, loff_t, get_block_t *); int nobh_writepage(struct page *page, get_block_t *get_block, struct writeback_control *wbc); +int block_flush_device(struct super_block *sb); void buffer_init(void); -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html