aboutsummaryrefslogtreecommitdiff
path: root/kernel/drivers/fb.c
blob: 8e73f5b11d446e7b499db029f790b329ade75bcd (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
// MIT License, Copyright (c) 2021 Marvin Borner

#include <assert.h>
#include <def.h>
#include <fb.h>
#include <fs.h>
#include <ioctl.h>
#include <mem.h>
#include <mm.h>
#include <str.h>
#include <sys.h>

struct vbe_basic {
	u8 stuff1[16];
	u16 pitch;
	u16 width;
	u16 height;
	u8 stuff2[18];
	u8 *fb;
	u8 stuff3[212];
};

static u32 dev_id = 0;
static struct vid_info *info = NULL;

static s32 fb_ioctl(u32 request, void *arg1, void *arg2, void *arg3, struct device *dev)
{
	UNUSED(arg2);
	UNUSED(arg3);
	UNUSED(dev);

	switch (request) {
	case IO_FB_GET: {
		if (!info)
			return -1;
		struct vbe_basic *vbe = (struct vbe_basic *)info->vbe;
		memcpy(arg1, info->vbe, sizeof(struct vbe_basic));
		u32 size = vbe->height * vbe->pitch;
		memory_map_identity(proc_current()->page_dir,
				    memory_range_around((u32)vbe->fb, size), MEMORY_USER);
		return 0;
	}
	default:
		return -1;
	}
}

static u8 fb_ready(void)
{
	return 1;
}

void fb_install(struct vid_info *boot)
{
	info = boot;

	struct device *dev = zalloc(sizeof(*dev));
	dev->name = strdup("fb");
	dev->type = DEV_CHAR;
	dev->ioctl = fb_ioctl;
	dev->ready = fb_ready;
	device_add(dev);
	dev_id = dev->id;
}