> compile NEMU
221220000 张三 Linux zzy 5.15.146.1-microsoft-standard-WSL2 #1 SMP Thu Jan 11 04:09:03 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux 23:06:41 up 2 days, 13:20, 1 user, load average: 0.64, 0.62, 0.46
This commit is contained in:
@ -2,24 +2,43 @@
|
||||
#include <nemu.h>
|
||||
|
||||
#define SYNC_ADDR (VGACTL_ADDR + 4)
|
||||
#define GET_W(var) uint16_t var = inw(VGACTL_ADDR + 2)
|
||||
#define GET_H(var) uint16_t var = inw(VGACTL_ADDR)
|
||||
|
||||
void __am_gpu_init() {
|
||||
int i;
|
||||
GET_W(w);
|
||||
GET_H(h);
|
||||
// int w = inw(VGACTL_ADDR + 2); // TODO: get the correct width
|
||||
// int h = inw(VGACTL_ADDR); // TODO: get the correct height
|
||||
uint32_t *fb = (uint32_t *)(uintptr_t)FB_ADDR;
|
||||
for (i = 0; i < w * h; i ++) fb[i] = i;
|
||||
outl(SYNC_ADDR, 1);
|
||||
}
|
||||
|
||||
void __am_gpu_config(AM_GPU_CONFIG_T *cfg) {
|
||||
// uint32_t vgactl = inl(VGACTL_ADDR);
|
||||
GET_W(w);
|
||||
GET_H(h);
|
||||
*cfg = (AM_GPU_CONFIG_T) {
|
||||
.present = true, .has_accel = false,
|
||||
.width = 0, .height = 0,
|
||||
.vmemsz = 0
|
||||
.width = w, .height = h,
|
||||
.vmemsz = w*h*32
|
||||
};
|
||||
}
|
||||
|
||||
void __am_gpu_fbdraw(AM_GPU_FBDRAW_T *ctl) {
|
||||
GET_W(w);
|
||||
for (int i = 0; i < ctl->h; i++) {
|
||||
for (int j = 0; j < ctl->w; j++) {
|
||||
outl(FB_ADDR + w * j + i, (uint32_t)ctl->pixels + w * j + i);
|
||||
}
|
||||
}
|
||||
if (ctl->sync) {
|
||||
outl(SYNC_ADDR, 1);
|
||||
}
|
||||
}
|
||||
|
||||
void __am_gpu_status(AM_GPU_STATUS_T *status) {
|
||||
status->ready = true;
|
||||
status->ready = inl(SYNC_ADDR) == 0 ? true : false;
|
||||
}
|
||||
|
Reference in New Issue
Block a user