aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorJaya Kumar <jayakumar.lkml@gmail.com>2007-05-08 03:37:37 -0400
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2007-05-08 14:15:26 -0400
commit60b59beafba875aef6d378078bce0baf2287ae14 (patch)
treebb599c0e2ad43ee8f515a9f9af009442931b6a37 /include
parent3a2842480bbef42c3c90e14c1f378360d8c20a0c (diff)
fbdev: mm: Deferred IO support
This implements deferred IO support in fbdev. Deferred IO is a way to delay and repurpose IO. This implementation is done using mm's page_mkwrite and page_mkclean hooks in order to detect, delay and then rewrite IO. This functionality is used by hecubafb. [adaplas] This is useful for graphics hardware with no directly addressable/mappable framebuffer. Implementing this will allow the "framebuffer" to be accesible from user space via mmap(). Signed-off-by: Jaya Kumar <jayakumar.lkml@gmail.com> Signed-off-by: Antonino Daplas <adaplas@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'include')
-rw-r--r--include/linux/fb.h20
1 files changed, 20 insertions, 0 deletions
diff --git a/include/linux/fb.h b/include/linux/fb.h
index be913ec87169..8a8255b94b62 100644
--- a/include/linux/fb.h
+++ b/include/linux/fb.h
@@ -561,6 +561,16 @@ struct fb_pixmap {
561 void (*readio) (struct fb_info *info, void *dst, void __iomem *src, unsigned int size); 561 void (*readio) (struct fb_info *info, void *dst, void __iomem *src, unsigned int size);
562}; 562};
563 563
564#ifdef CONFIG_FB_DEFERRED_IO
565struct fb_deferred_io {
566 /* delay between mkwrite and deferred handler */
567 unsigned long delay;
568 struct mutex lock; /* mutex that protects the page list */
569 struct list_head pagelist; /* list of touched pages */
570 /* callback */
571 void (*deferred_io)(struct fb_info *info, struct list_head *pagelist);
572};
573#endif
564 574
565/* 575/*
566 * Frame buffer operations 576 * Frame buffer operations
@@ -778,6 +788,10 @@ struct fb_info {
778 struct mutex bl_curve_mutex; 788 struct mutex bl_curve_mutex;
779 u8 bl_curve[FB_BACKLIGHT_LEVELS]; 789 u8 bl_curve[FB_BACKLIGHT_LEVELS];
780#endif 790#endif
791#ifdef CONFIG_FB_DEFERRED_IO
792 struct delayed_work deferred_work;
793 struct fb_deferred_io *fbdefio;
794#endif
781 795
782 struct fb_ops *fbops; 796 struct fb_ops *fbops;
783 struct device *device; /* This is the parent */ 797 struct device *device; /* This is the parent */
@@ -913,6 +927,12 @@ static inline void __fb_pad_aligned_buffer(u8 *dst, u32 d_pitch,
913 } 927 }
914} 928}
915 929
930#ifdef CONFIG_FB_DEFERRED_IO
931/* drivers/video/fb_defio.c */
932extern void fb_deferred_io_init(struct fb_info *info);
933extern void fb_deferred_io_cleanup(struct fb_info *info);
934#endif
935
916/* drivers/video/fbsysfs.c */ 936/* drivers/video/fbsysfs.c */
917extern struct fb_info *framebuffer_alloc(size_t size, struct device *dev); 937extern struct fb_info *framebuffer_alloc(size_t size, struct device *dev);
918extern void framebuffer_release(struct fb_info *info); 938extern void framebuffer_release(struct fb_info *info);