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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
#include "devfs.h"
#include "device.h"
#include "common.h"
#include "gfx.h"
#include "framebuffer.h"
#include "vmm.h"
#include "process.h"
static BOOL fb_open(File *file, uint32 flags);
static int32 fb_read(File *file, uint32 size, uint8 *buffer);
static int32 fb_write(File *file, uint32 size, uint8 *buffer);
static int32 fb_ioctl(File *node, int32 request, void * argp);
static void* fb_mmap(File* file, uint32 size, uint32 offset, uint32 flags);
static BOOL fb_munmap(File* file, void* address, uint32 size);
static uint8* gFrameBufferPhysical = 0;
static uint8* gFrameBufferVirtual = 0;
void initializeFrameBuffer(uint8* p_address, uint8* v_address) {
gFrameBufferPhysical = p_address;
gFrameBufferVirtual = v_address;
Device device;
memset((uint8*)&device, 0, sizeof(Device));
strcpy(device.name, "fb0");
device.deviceType = FT_CharacterDevice;
device.open = fb_open;
device.read = fb_read;
device.write = fb_write;
device.ioctl = fb_ioctl;
device.mmap = fb_mmap;
device.munmap = fb_munmap;
registerDevice(&device);
}
static BOOL fb_open(File *file, uint32 flags) {
return TRUE;
}
static int32 fb_read(File *file, uint32 size, uint8 *buffer) {
if (size == 0) {
return 0;
}
return -1;
}
static int32 fb_write(File *file, uint32 size, uint8 *buffer) {
if (size == 0) {
return 0;
}
int32 requestedSize = size;
int32 length = Gfx_GetWidth() * Gfx_GetHeight() * 4;
int32 availableSize = length - file->offset;
if (availableSize <= 0) {
return -1;
}
int32 targetSize = MIN(requestedSize, availableSize);
memcpy(gFrameBufferVirtual + file->offset, buffer, targetSize);
file->offset += targetSize;
return targetSize;
}
static int32 fb_ioctl(File *node, int32 request, void * argp) {
int32 result = -1;
switch (request) {
case FB_GET_WIDTH:
result = Gfx_GetWidth();
break;
case FB_GET_HEIGHT:
result = Gfx_GetHeight();
break;
case FB_GET_BITSPERPIXEL:
result = 32;
break;
}
return result;
}
static void* fb_mmap(File* file, uint32 size, uint32 offset, uint32 flags) {
return mapMemory(file->thread->owner, size, (uint32)(gFrameBufferPhysical + offset), NULL);
}
static BOOL fb_munmap(File* file, void* address, uint32 size) {
return unmapMemory(file->thread->owner, size, (uint32)address);
}
|