aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul Mundt <lethal@linux-sh.org>2007-05-08 03:37:41 -0400
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2007-05-08 14:15:27 -0400
commit5e841b88d23d0ea0a6ee4e76c489899d4d23ce25 (patch)
tree7268b4bbb85aa7b1c72f54f7f8cd309b34cfecce
parent7bf1ea33ad70cf49638092367d52859fbbc44fee (diff)
fb: fsync() method for deferred I/O flush.
There are cases when we do not want to wait on the delay for automatically updating the "real" framebuffer, this implements a simple ->fsync() hook for explicitly flushing the deferred I/O work. The ->page_mkwrite() handler will rearm the work queue normally. (akpm: nuke unneeded ifdefs, forward-delcare struct dentry) Signed-off-by: Paul Mundt <lethal@linux-sh.org> Cc: Jaya Kumar <jayakumar.lkml@gmail.com> Acked-by: Antonino Daplas <adaplas@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--drivers/video/fb_defio.c12
-rw-r--r--drivers/video/fbmem.c3
-rw-r--r--include/linux/fb.h6
3 files changed, 19 insertions, 2 deletions
diff --git a/drivers/video/fb_defio.c b/drivers/video/fb_defio.c
index 65f4e6ee7f9..f963f5f59b7 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 28225265159..44cf0e4f52e 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;
diff --git a/include/linux/fb.h b/include/linux/fb.h
index 8a8255b94b6..0de426026f4 100644
--- a/include/linux/fb.h
+++ b/include/linux/fb.h
@@ -4,6 +4,8 @@
4#include <asm/types.h> 4#include <asm/types.h>
5#include <linux/i2c.h> 5#include <linux/i2c.h>
6 6
7struct dentry;
8
7/* Definitions of frame buffers */ 9/* Definitions of frame buffers */
8 10
9#define FB_MAJOR 29 11#define FB_MAJOR 29
@@ -927,11 +929,11 @@ static inline void __fb_pad_aligned_buffer(u8 *dst, u32 d_pitch,
927 } 929 }
928} 930}
929 931
930#ifdef CONFIG_FB_DEFERRED_IO
931/* drivers/video/fb_defio.c */ 932/* drivers/video/fb_defio.c */
932extern void fb_deferred_io_init(struct fb_info *info); 933extern void fb_deferred_io_init(struct fb_info *info);
933extern void fb_deferred_io_cleanup(struct fb_info *info); 934extern void fb_deferred_io_cleanup(struct fb_info *info);
934#endif 935extern int fb_deferred_io_fsync(struct file *file, struct dentry *dentry,
936 int datasync);
935 937
936/* drivers/video/fbsysfs.c */ 938/* drivers/video/fbsysfs.c */
937extern struct fb_info *framebuffer_alloc(size_t size, struct device *dev); 939extern struct fb_info *framebuffer_alloc(size_t size, struct device *dev);