Commit f5f2e754 authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] fbdev: Virtual fbdev updates

From: James Simmons <jsimmons@infradead.org>

This is attempt 2 at the virtual framebuffer patch.  It migrates the driver
to the framebuffer_release/framebuffer_alloc api.  It doesn't enable the
driver by default.
parent 3cb52df5
...@@ -37,9 +37,6 @@ static void *videomemory; ...@@ -37,9 +37,6 @@ static void *videomemory;
static u_long videomemorysize = VIDEOMEMSIZE; static u_long videomemorysize = VIDEOMEMSIZE;
MODULE_PARM(videomemorysize, "l"); MODULE_PARM(videomemorysize, "l");
static struct fb_info fb_info;
static u32 vfb_pseudo_palette[17];
static struct fb_var_screeninfo vfb_default __initdata = { static struct fb_var_screeninfo vfb_default __initdata = {
.xres = 640, .xres = 640,
.yres = 480, .yres = 480,
...@@ -404,18 +401,22 @@ int __init vfb_setup(char *options) ...@@ -404,18 +401,22 @@ int __init vfb_setup(char *options)
* Initialisation * Initialisation
*/ */
int __init vfb_init(void) static void vfb_platform_release(struct device *device)
{ {
int retval; // This is called when the reference count goes to zero.
}
if (!vfb_enable) static int __init vfb_probe(struct device *device)
return -ENXIO; {
struct platform_device *dev = to_platform_device(device);
struct fb_info *info;
int retval = -ENOMEM;
/* /*
* For real video cards we use ioremap. * For real video cards we use ioremap.
*/ */
if (!(videomemory = vmalloc(videomemorysize))) if (!(videomemory = vmalloc(videomemorysize)))
return -ENOMEM; return retval;
/* /*
* VFB must clear memory to prevent kernel info * VFB must clear memory to prevent kernel info
...@@ -425,41 +426,98 @@ int __init vfb_init(void) ...@@ -425,41 +426,98 @@ int __init vfb_init(void)
*/ */
memset(videomemory, 0, videomemorysize); memset(videomemory, 0, videomemorysize);
fb_info.screen_base = videomemory; info = framebuffer_alloc(sizeof(u32) * 256, &dev->dev);
fb_info.fbops = &vfb_ops; if (!info)
goto err;
retval = fb_find_mode(&fb_info.var, &fb_info, NULL, info->screen_base = videomemory;
info->fbops = &vfb_ops;
retval = fb_find_mode(&info->var, info, NULL,
NULL, 0, NULL, 8); NULL, 0, NULL, 8);
if (!retval || (retval == 4)) if (!retval || (retval == 4))
fb_info.var = vfb_default; info->var = vfb_default;
fb_info.fix = vfb_fix; info->fix = vfb_fix;
fb_info.pseudo_palette = &vfb_pseudo_palette; info->pseudo_palette = info->par;
fb_info.flags = FBINFO_FLAG_DEFAULT; info->par = NULL;
info->flags = FBINFO_FLAG_DEFAULT;
fb_alloc_cmap(&fb_info.cmap, 256, 0); retval = fb_alloc_cmap(&info->cmap, 256, 0);
if (retval < 0)
goto err1;
if (register_framebuffer(&fb_info) < 0) { retval = register_framebuffer(info);
vfree(videomemory); if (retval < 0)
return -EINVAL; goto err2;
} dev_set_drvdata(&dev->dev, info);
printk(KERN_INFO printk(KERN_INFO
"fb%d: Virtual frame buffer device, using %ldK of video memory\n", "fb%d: Virtual frame buffer device, using %ldK of video memory\n",
fb_info.node, videomemorysize >> 10); info->node, videomemorysize >> 10);
return 0; return 0;
err2:
fb_dealloc_cmap(&info->cmap);
err1:
framebuffer_release(info);
err:
vfree(videomemory);
return retval;
} }
#ifdef MODULE static int vfb_remove(struct device *device)
static void __exit vfb_cleanup(void)
{ {
unregister_framebuffer(&fb_info); struct fb_info *info = dev_get_drvdata(device);
if (info) {
unregister_framebuffer(info);
vfree(videomemory); vfree(videomemory);
framebuffer_release(info);
}
return 0;
}
static struct device_driver vfb_driver = {
.name = "vfb",
.bus = &platform_bus_type,
.probe = vfb_probe,
.remove = vfb_remove,
};
static struct platform_device vfb_device = {
.name = "vfb",
.id = 0,
.dev = {
.release = vfb_platform_release,
}
};
int __init vfb_init(void)
{
int ret = 0;
if (!vfb_enable)
return -ENXIO;
ret = driver_register(&vfb_driver);
if (!ret) {
ret = platform_device_register(&vfb_device);
if (ret)
driver_unregister(&vfb_driver);
}
return ret;
}
#ifdef MODULE
static void __exit vfb_exit(void)
{
platform_device_unregister(&vfb_device);
driver_unregister(&vfb_driver);
} }
module_init(vfb_init); module_init(vfb_init);
module_exit(vfb_cleanup); module_exit(vfb_exit);
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
#endif /* MODULE */ #endif /* MODULE */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment