aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/video/fb_defio.c12
-rw-r--r--drivers/video/fbmem.c3
2 files changed, 15 insertions, 0 deletions
diff --git a/drivers/video/fb_defio.c b/drivers/video/fb_defio.c
index 65f4e6ee7f94..f963f5f59b73 100644
--- a/drivers/video/fb_defio.c
+++ b/drivers/video/fb_defio.c
@@ -47,6 +47,18 @@ static struct page* fb_deferred_io_nopage(struct vm_area_struct *vma,
47 return page; 47 return page;
48} 48}
49 49
50int fb_deferred_io_fsync(struct file *file, struct dentry *dentry, int datasync)
51{
52 struct fb_info *info = file->private_data;
53
54 /* Kill off the delayed work */
55 cancel_rearming_delayed_work(&info->deferred_work);
56
57 /* Run it immediately */
58 return schedule_delayed_work(&info->deferred_work, 0);
59}
60EXPORT_SYMBOL_GPL(fb_deferred_io_fsync);
61
50/* vm_ops->page_mkwrite handler */ 62/* vm_ops->page_mkwrite handler */
51static int fb_deferred_io_mkwrite(struct vm_area_struct *vma, 63static int fb_deferred_io_mkwrite(struct vm_area_struct *vma,
52 struct page *page) 64 struct page *page)
diff --git a/drivers/video/fbmem.c b/drivers/video/fbmem.c
index 28225265159a..44cf0e4f52e9 100644
--- a/drivers/video/fbmem.c
+++ b/drivers/video/fbmem.c
@@ -1266,6 +1266,9 @@ static const struct file_operations fb_fops = {
1266#ifdef HAVE_ARCH_FB_UNMAPPED_AREA 1266#ifdef HAVE_ARCH_FB_UNMAPPED_AREA
1267 .get_unmapped_area = get_fb_unmapped_area, 1267 .get_unmapped_area = get_fb_unmapped_area,
1268#endif 1268#endif
1269#ifdef CONFIG_FB_DEFERRED_IO
1270 .fsync = fb_deferred_io_fsync,
1271#endif
1269}; 1272};
1270 1273
1271struct class *fb_class; 1274struct class *fb_class;