summaryrefslogtreecommitdiffstats
path: root/drivers/video/vfb.c
diff options
context:
space:
mode:
authorRalf Baechle <ralf@linux-mips.org>1999-10-09 00:00:47 +0000
committerRalf Baechle <ralf@linux-mips.org>1999-10-09 00:00:47 +0000
commitd6434e1042f3b0a6dfe1b1f615af369486f9b1fa (patch)
treee2be02f33984c48ec019c654051d27964e42c441 /drivers/video/vfb.c
parent609d1e803baf519487233b765eb487f9ec227a18 (diff)
Merge with 2.3.19.
Diffstat (limited to 'drivers/video/vfb.c')
-rw-r--r--drivers/video/vfb.c25
1 files changed, 13 insertions, 12 deletions
diff --git a/drivers/video/vfb.c b/drivers/video/vfb.c
index ccc5e2a27..165b03077 100644
--- a/drivers/video/vfb.c
+++ b/drivers/video/vfb.c
@@ -78,7 +78,7 @@ static int vfb_enable = 0; /* disabled by default */
* Interface used by the world
*/
-void vfb_setup(char *options, int *ints);
+int vfb_setup(char*);
static int vfb_open(struct fb_info *info, int user);
static int vfb_release(struct fb_info *info, int user);
@@ -102,7 +102,7 @@ static int vfb_ioctl(struct inode *inode, struct file *file, u_int cmd,
* Interface to the low level console driver
*/
-void vfb_init(void);
+int vfb_init(void);
static int vfbcon_switch(int con, struct fb_info *info);
static int vfbcon_updatevar(int con, struct fb_info *info);
static void vfbcon_blank(int blank, struct fb_info *info);
@@ -406,7 +406,7 @@ static int vfb_ioctl(struct inode *inode, struct file *file, u_int cmd,
}
-__initfunc(void vfb_setup(char *options, int *ints))
+int __init vfb_setup(char *options)
{
char *this_opt;
@@ -415,13 +415,14 @@ __initfunc(void vfb_setup(char *options, int *ints))
vfb_enable = 1;
if (!options || !*options)
- return;
+ return 0;
for (this_opt = strtok(options, ","); this_opt;
this_opt = strtok(NULL, ",")) {
if (!strncmp(this_opt, "font:", 5))
strcpy(fb_info.fontname, this_opt+5);
}
+ return 0;
}
@@ -429,13 +430,13 @@ __initfunc(void vfb_setup(char *options, int *ints))
* Initialisation
*/
-__initfunc(void vfb_init(void))
+int __init vfb_init(void)
{
if (!vfb_enable)
- return;
+ return -ENXIO;
if (!(videomemory = (u_long)vmalloc(videomemorysize)))
- return;
+ return -ENOMEM;
strcpy(fb_info.modename, vfb_name);
fb_info.changevar = NULL;
@@ -451,11 +452,12 @@ __initfunc(void vfb_init(void))
if (register_framebuffer(&fb_info) < 0) {
vfree((void *)videomemory);
- return;
+ return -EINVAL;
}
- printk("fb%d: Virtual frame buffer device, using %ldK of video memory\n",
+ printk(KERN_INFO "fb%d: Virtual frame buffer device, using %ldK of video memory\n",
GET_FB_IDX(fb_info.node), videomemorysize>>10);
+ return 0;
}
@@ -505,7 +507,7 @@ static void vfb_encode_fix(struct fb_fix_screeninfo *fix,
{
memset(fix, 0, sizeof(struct fb_fix_screeninfo));
strcpy(fix->id, vfb_name);
- fix->smem_start = (char *)videomemory;
+ fix->smem_start = videomemory;
fix->smem_len = videomemorysize;
fix->type = FB_TYPE_PACKED_PIXELS;
fix->type_aux = 0;
@@ -636,8 +638,7 @@ static void do_install_cmap(int con, struct fb_info *info)
#ifdef MODULE
int init_module(void)
{
- vfb_init();
- return 0;
+ return vfb_init();
}
void cleanup_module(void)