anakinfb.c 2.37 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
/*
 *  linux/drivers/video/anakinfb.c
 *
 *  Copyright (C) 2001 Aleph One Ltd. for Acunia N.V.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 *  Changelog:
 *   23-Apr-2001 TTC	Created
 */

#include <linux/types.h>
#include <linux/fb.h>
#include <linux/string.h>
#include <linux/errno.h>
#include <linux/init.h>
#include <linux/module.h>

#include <asm/io.h>

23
static u32 colreg[17];
24 25
static struct fb_info fb_info;

26
static struct fb_var_screeninfo anakinfb_var = {
27 28 29 30 31 32 33 34 35 36 37 38
	.xres 		= 400,
	.yres 		= 234,
	.xres_virtual 	= 400,
	.yres_virtual 	= 234,
	.bits_per_pixel = 16,
	.red 		= { 11, 5, 0 },
	.green 		= {  5, 6, 0 }, 
	.blue 		= {  0, 5, 0 },
	.activate	= FB_ACTIVATE_NOW,
	.height		= -1,
	.width		= -1,
	.vmode		= FB_VMODE_NONINTERLACED,
39
};
40

41
static struct fb_fix_screeninfo anakinfb_fix = {
42 43 44 45 46 47 48
	.id 		= "AnakinFB",
	.smem_start 	= VGA_START,
	.smem_len 	= VGA_SIZE,
	.type 		= FB_TYPE_PACKED_PIXELS,
	.visual 	= FB_VISUAL_TRUECOLOR,
	.line_length 	= 400*2,
	.accel 		= FB_ACCEL_NONE,
49
};
50 51 52 53 54 55 56 57

static int
anakinfb_setcolreg(u_int regno, u_int red, u_int green, u_int blue,
			u_int transp, struct fb_info *info)
{
	if (regno > 15)
		return 1;

58
	((u16 *)(info->pseudo_palette))[regno] = (red & 0xf800) | (green & 0xfc00 >> 5) | (blue & 0xf800 >> 11);
59 60 61 62
	return 0;
}

static struct fb_ops anakinfb_ops = {
63 64 65 66 67
	.owner		= THIS_MODULE,
	.fb_setcolreg	= anakinfb_setcolreg,
	.fb_fillrect	= cfb_fillrect,
	.fb_copyarea	= cfb_copyarea,
	.fb_imageblit	= cfb_imageblit,
68
	.fb_cursor	= soft_cursor,
69 70 71 72 73 74
};

int __init
anakinfb_init(void)
{
	memset(&fb_info, 0, sizeof(struct fb_info));
75

76
	fb_info.node = NODEV;
77 78
	fb_info.flags = FBINFO_FLAG_DEFAULT;
	fb_info.fbops = &anakinfb_ops;
79 80
	fb_info.var = anakinfb_var;
	fb_info.fix = anakinfb_fix;
81
	fb_info.psuedo_palette = colreg;
82 83
	if (!(request_mem_region(VGA_START, VGA_SIZE, "vga")))
		return -ENOMEM;
84
	if (fb_info.screen_base = ioremap(VGA_START, VGA_SIZE)) {
85 86 87
		release_mem_region(VGA_START, VGA_SIZE);
		return -EIO;
	}
88

89
	fb_alloc_cmap(&fb_info.cmap, 16, 0);
90

91
	if (register_framebuffer(&fb_info) < 0) {
92
		iounmap(fb_info.screen_base);
93
		release_mem_region(VGA_START, VGA_SIZE);
94
		return -EINVAL;
95
	}
96 97 98 99 100 101 102 103

	MOD_INC_USE_COUNT;
	return 0;
}

MODULE_AUTHOR("Tak-Shing Chan <chan@aleph1.co.uk>");
MODULE_DESCRIPTION("Anakin framebuffer driver");
MODULE_SUPPORTED_DEVICE("fb");