Commit 95cc44a0 authored by Vladimir Murzin's avatar Vladimir Murzin Committed by Tomi Valkeinen

fbdev: vfb: add option for video mode

Make vfb a bit more flexible in sense what it can represent and allow
the end user to specify video mode parameters via newly introduced module
option "mode". Since it is test module it is still up to the end user
to make sure there is enough memory to satisfy video mode settings.
Signed-off-by: default avatarVladimir Murzin <vladimir.murzin@arm.com>
[tomi.valkeinen@ti.com: constified vfb_default]
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent cf957ccc
...@@ -37,6 +37,10 @@ static u_long videomemorysize = VIDEOMEMSIZE; ...@@ -37,6 +37,10 @@ static u_long videomemorysize = VIDEOMEMSIZE;
module_param(videomemorysize, ulong, 0); module_param(videomemorysize, ulong, 0);
MODULE_PARM_DESC(videomemorysize, "RAM available to frame buffer (in bytes)"); MODULE_PARM_DESC(videomemorysize, "RAM available to frame buffer (in bytes)");
static char *mode_option = NULL;
module_param(mode_option, charp, 0);
MODULE_PARM_DESC(mode_option, "Preferred video mode (e.g. 640x480-8@60)");
/********************************************************************** /**********************************************************************
* *
* Memory management * Memory management
...@@ -86,26 +90,17 @@ static void rvfree(void *mem, unsigned long size) ...@@ -86,26 +90,17 @@ static void rvfree(void *mem, unsigned long size)
vfree(mem); vfree(mem);
} }
static struct fb_var_screeninfo vfb_default = { static const struct fb_videomode vfb_default = {
.xres = 640, .xres = 640,
.yres = 480, .yres = 480,
.xres_virtual = 640, .pixclock = 20000,
.yres_virtual = 480, .left_margin = 64,
.bits_per_pixel = 8, .right_margin = 64,
.red = { 0, 8, 0 }, .upper_margin = 32,
.green = { 0, 8, 0 }, .lower_margin = 32,
.blue = { 0, 8, 0 }, .hsync_len = 64,
.activate = FB_ACTIVATE_TEST, .vsync_len = 2,
.height = -1, .vmode = FB_VMODE_NONINTERLACED,
.width = -1,
.pixclock = 20000,
.left_margin = 64,
.right_margin = 64,
.upper_margin = 32,
.lower_margin = 32,
.hsync_len = 64,
.vsync_len = 2,
.vmode = FB_VMODE_NONINTERLACED,
}; };
static struct fb_fix_screeninfo vfb_fix = { static struct fb_fix_screeninfo vfb_fix = {
...@@ -479,6 +474,8 @@ static int __init vfb_setup(char *options) ...@@ -479,6 +474,8 @@ static int __init vfb_setup(char *options)
/* Test disable for backwards compatibility */ /* Test disable for backwards compatibility */
if (!strcmp(this_opt, "disable")) if (!strcmp(this_opt, "disable"))
vfb_enable = 0; vfb_enable = 0;
else
mode_option = this_opt;
} }
return 1; return 1;
} }
...@@ -506,11 +503,13 @@ static int vfb_probe(struct platform_device *dev) ...@@ -506,11 +503,13 @@ static int vfb_probe(struct platform_device *dev)
info->screen_base = (char __iomem *)videomemory; info->screen_base = (char __iomem *)videomemory;
info->fbops = &vfb_ops; info->fbops = &vfb_ops;
retval = fb_find_mode(&info->var, info, NULL, if (!fb_find_mode(&info->var, info, mode_option,
NULL, 0, NULL, 8); NULL, 0, &vfb_default, 8)){
fb_err(info, "Unable to find usable video mode.\n");
retval = -EINVAL;
goto err1;
}
if (!retval || (retval == 4))
info->var = vfb_default;
vfb_fix.smem_start = (unsigned long) videomemory; vfb_fix.smem_start = (unsigned long) videomemory;
vfb_fix.smem_len = videomemorysize; vfb_fix.smem_len = videomemorysize;
info->fix = vfb_fix; info->fix = vfb_fix;
......
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