New tool lfbviewx, new shell commands, fix bug in process_info(-1).
* lfbviewx: LFB viewer for X. Reads framebuffer of umka_os and displays the picture in X window. * New shell commands: dump_appdata, dump_taskdata, mouse_move. * Bug with process_info is because SLOT_BASE in umka_os is not aligned on 0x10000. Mitigated with a macro.
This commit is contained in:
parent
477978175d
commit
f7942d2eb3
1
.gitignore
vendored
1
.gitignore
vendored
@ -8,6 +8,7 @@ umka_os
|
|||||||
umka_ping
|
umka_ping
|
||||||
mkdirrange
|
mkdirrange
|
||||||
mkfilepattern
|
mkfilepattern
|
||||||
|
lfbviewx
|
||||||
*.img
|
*.img
|
||||||
*.img.xz
|
*.img.xz
|
||||||
*.img.gz
|
*.img.gz
|
||||||
|
47
README
47
README
@ -2,26 +2,52 @@ UMKa -- User-Mode KolibriOS developer tools
|
|||||||
===========================================
|
===========================================
|
||||||
|
|
||||||
This is a common project for a set of KolibriOS developer tools which are based
|
This is a common project for a set of KolibriOS developer tools which are based
|
||||||
on original KolibriOS code wrapped and hacked as to run in the UNIX programming
|
on original KolibriOS kernel code wrapped and hacked as to run in the UNIX
|
||||||
environment. The idea is to make userspace UNIX tools that use as much unchanged
|
programming environment. The idea is to make userspace UNIX tools that use as
|
||||||
KolibriOS source as possible to test architecture-independent parts of the
|
much unchanged KolibriOS kernel source as possible to test
|
||||||
kernel in your favorite developer environment.
|
architecture-independent parts of the kernel in your favorite developer
|
||||||
|
environment.
|
||||||
|
|
||||||
|
|
||||||
umka_shell
|
umka_shell
|
||||||
----------
|
----------
|
||||||
|
|
||||||
is an interactive shell with commands that are wrappers around KolibriOS kernel
|
is an interactive shell with commands that are wrappers around KolibriOS kernel
|
||||||
block, FS, UI and other functions. Can read input from the keyboard, stdin and a
|
syscalls and other internal functions. What works now: block layer including
|
||||||
file, i.e. can be used for automated testing.
|
disk cache, FS, UI and graphics, scheduler, ACPI/AML interpreter,
|
||||||
|
synchronization primitives, strings, slab allocator, events, unpacker, other
|
||||||
|
minor functions.
|
||||||
|
|
||||||
|
It can also be used for automated testing by feeding it a file of commands
|
||||||
|
instead of typing them.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
$ umka_shell < mytest.t > mytest.out.log
|
||||||
|
|
||||||
|
|
||||||
umka_fuse
|
umka_fuse
|
||||||
---------
|
---------
|
||||||
|
|
||||||
is like umka_shell above but commands are translated from FUSE calls, not
|
is like umka_shell above but commands are translated from FUSE calls, not
|
||||||
entered manually. Can *potentially* be used to run xfstests (cross-fs-tests) and
|
entered manually or read from a file. Can *potentially* be used to run xfstests
|
||||||
automatestrcatd tests against reference FS implementations.
|
(cross-fs-tests) and automated tests against reference FS implementation.
|
||||||
|
|
||||||
|
|
||||||
|
umka_os
|
||||||
|
-------
|
||||||
|
|
||||||
|
is KolibriOS kernel running main loop (osloop), scheduler and all the threads
|
||||||
|
including network stack.
|
||||||
|
|
||||||
|
|
||||||
|
tools
|
||||||
|
-----
|
||||||
|
|
||||||
|
mkdirrange
|
||||||
|
|
||||||
|
mkfilepattern
|
||||||
|
|
||||||
|
lfbviewx
|
||||||
|
|
||||||
|
|
||||||
BUILD
|
BUILD
|
||||||
@ -43,13 +69,14 @@ Framebuffer can be dumped to disk as image file.
|
|||||||
Testing
|
Testing
|
||||||
-------
|
-------
|
||||||
|
|
||||||
sudo cp --parents --no-preserve=mode /sys/firmware/acpi/tables/?SDT* /sys/bus/pci/devices/*/config .
|
sudo cp --parents /sys/firmware/acpi/tables/?SDT* /sys/bus/pci/devices/*/config .
|
||||||
|
|
||||||
|
|
||||||
Troubleshooting
|
Troubleshooting
|
||||||
---------------
|
---------------
|
||||||
|
|
||||||
No troubles -- no shooting.
|
# sysctl -w kernel.yama.ptrace_scope=0
|
||||||
|
# sysctl -w vm.mmap_min_addr=0
|
||||||
|
|
||||||
|
|
||||||
Links & Acknowledgements
|
Links & Acknowledgements
|
||||||
|
13
makefile
13
makefile
@ -12,7 +12,7 @@ LDFLAGS=-no-pie
|
|||||||
LDFLAGS_32=$(LDFLAGS) -m32
|
LDFLAGS_32=$(LDFLAGS) -m32
|
||||||
|
|
||||||
all: umka_shell umka_fuse umka_os umka_ping umka.sym umka.prp umka.lst tags \
|
all: umka_shell umka_fuse umka_os umka_ping umka.sym umka.prp umka.lst tags \
|
||||||
tools/mkdirrange tools/mkfilepattern covpreproc default.skn skin.skn
|
covpreproc default.skn skin.skn
|
||||||
|
|
||||||
covpreproc: covpreproc.c
|
covpreproc: covpreproc.c
|
||||||
$(CC) $(CFLAGS) $(LDFLAGS) $^ -o $@
|
$(CC) $(CFLAGS) $(LDFLAGS) $^ -o $@
|
||||||
@ -85,20 +85,13 @@ umka_fuse.o: umka_fuse.c umka.h
|
|||||||
$(CC) $(CFLAGS_32) `pkg-config fuse3 --cflags` -c $<
|
$(CC) $(CFLAGS_32) `pkg-config fuse3 --cflags` -c $<
|
||||||
|
|
||||||
umka_os.o: umka_os.c umka.h
|
umka_os.o: umka_os.c umka.h
|
||||||
$(CC) $(CFLAGS_32) -c $<
|
$(CC) $(CFLAGS_32) -c $< -D_DEFAULT_SOURCE
|
||||||
|
|
||||||
umka_ping.o: umka_ping.c umka.h
|
umka_ping.o: umka_ping.c umka.h
|
||||||
$(CC) $(CFLAGS_32) -D_DEFAULT_SOURCE -c $<
|
$(CC) $(CFLAGS_32) -D_DEFAULT_SOURCE -c $<
|
||||||
|
|
||||||
tools/mkdirrange: tools/mkdirrange.c
|
|
||||||
$(CC) $(CFLAGS) $(LDFLAGS) $< -o $@
|
|
||||||
|
|
||||||
tools/mkfilepattern: tools/mkfilepattern.c
|
|
||||||
$(CC) $(CFLAGS) $(LDFLAGS) $< -o $@
|
|
||||||
|
|
||||||
.PHONY: all clean
|
.PHONY: all clean
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f *.o umka_shell umka_fuse umka_os umka.fas umka.sym umka.lst umka.prp \
|
rm -f *.o umka_shell umka_fuse umka_os umka.fas umka.sym umka.lst umka.prp \
|
||||||
coverage tools/mkdirrange tools/mkfilepattern
|
coverage
|
||||||
|
|
||||||
|
141
shell.c
141
shell.c
@ -443,6 +443,144 @@ void shell_dump_win_pos(int argc, char **argv) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void shell_dump_appdata(int argc, char **argv) {
|
||||||
|
// TODO: usage
|
||||||
|
int idx;
|
||||||
|
int show_pointers = 0;
|
||||||
|
if (argc > 1) {
|
||||||
|
idx = strtol(argv[1], NULL, 0);
|
||||||
|
}
|
||||||
|
if (argc > 2 && !strcmp(argv[2], "-p")) {
|
||||||
|
show_pointers = 1;
|
||||||
|
}
|
||||||
|
appdata_t *a = kos_slot_base + idx;
|
||||||
|
fprintf(fout, "app_name: %s\n", a->app_name);
|
||||||
|
if (show_pointers) {
|
||||||
|
fprintf(fout, "process: %p\n", (void*)a->process);
|
||||||
|
fprintf(fout, "fpu_state: %p\n", (void*)a->fpu_state);
|
||||||
|
fprintf(fout, "exc_handler: %p\n", (void*)a->exc_handler);
|
||||||
|
}
|
||||||
|
fprintf(fout, "except_mask: %" PRIx32 "\n", a->except_mask);
|
||||||
|
if (show_pointers) {
|
||||||
|
fprintf(fout, "pl0_stack: %p\n", (void*)a->pl0_stack);
|
||||||
|
fprintf(fout, "cursor: %p\n", (void*)a->cursor);
|
||||||
|
fprintf(fout, "fd_ev: %p\n", (void*)a->fd_ev);
|
||||||
|
fprintf(fout, "bk_ev: %p\n", (void*)a->bk_ev);
|
||||||
|
fprintf(fout, "fd_obj: %p\n", (void*)a->fd_obj);
|
||||||
|
fprintf(fout, "bk_obj: %p\n", (void*)a->bk_obj);
|
||||||
|
fprintf(fout, "saved_esp: %p\n", (void*)a->saved_esp);
|
||||||
|
}
|
||||||
|
fprintf(fout, "dbg_state: %u\n", a->dbg_state);
|
||||||
|
fprintf(fout, "cur_dir: %s\n", a->cur_dir);
|
||||||
|
fprintf(fout, "event_filter: %" PRIx32 "\n", a->event_filter);
|
||||||
|
fprintf(fout, "draw_bgr_x: %u\n", a->draw_bgr_x);
|
||||||
|
fprintf(fout, "draw_bgr_y: %u\n", a->draw_bgr_y);
|
||||||
|
fprintf(fout, "event_mask: %" PRIx32 "\n", a->event_mask);
|
||||||
|
fprintf(fout, "terminate_protection: %u\n", a->terminate_protection);
|
||||||
|
fprintf(fout, "keyboard_mode: %u\n", a->keyboard_mode);
|
||||||
|
fprintf(fout, "captionEncoding: %u\n", a->captionEncoding);
|
||||||
|
fprintf(fout, "exec_params: %s\n", a->exec_params);
|
||||||
|
fprintf(fout, "wnd_caption: %s\n", a->wnd_caption);
|
||||||
|
fprintf(fout, "wnd_clientbox (ltwh): %u %u %u %u\n", a->wnd_clientbox.left,
|
||||||
|
a->wnd_clientbox.top, a->wnd_clientbox.width,
|
||||||
|
a->wnd_clientbox.height);
|
||||||
|
fprintf(fout, "priority: %u\n", a->priority);
|
||||||
|
}
|
||||||
|
|
||||||
|
void shell_dump_taskdata(int argc, char **argv) {
|
||||||
|
// TODO: usage
|
||||||
|
int idx;
|
||||||
|
if (argc > 1) {
|
||||||
|
idx = strtol(argv[1], NULL, 0);
|
||||||
|
}
|
||||||
|
taskdata_t *t = kos_task_base + idx;
|
||||||
|
fprintf(fout, "event_mask: %" PRIx32 "\n", t->event_mask);
|
||||||
|
}
|
||||||
|
|
||||||
|
void shell_mouse_move(int argc, char **argv) {
|
||||||
|
const char *usage = \
|
||||||
|
"usage: mouse_move [-l] [-m] [-r] [-x {+|-|=}<value>]"
|
||||||
|
"[-y {+|-|=}<value>] [-h {+|-}<value>] [-v {+|-}<value>]\n"
|
||||||
|
" -l left button is held\n"
|
||||||
|
" -m middle button is held\n"
|
||||||
|
" -r right button is held\n"
|
||||||
|
" -x increase, decrease or set x coordinate\n"
|
||||||
|
" -y increase, decrease or set y coordinate\n"
|
||||||
|
" -h scroll horizontally\n"
|
||||||
|
" -v scroll vertically\n";
|
||||||
|
|
||||||
|
int lbheld = 0, mbheld = 0, rbheld = 0, xabs = 0, yabs = 0;
|
||||||
|
int32_t xmoving = 0, ymoving = 0, hscroll = 0, vscroll = 0;
|
||||||
|
int opt;
|
||||||
|
optind = 1;
|
||||||
|
while ((opt = getopt(argc, argv, "lmrx:y:h:v:")) != -1) {
|
||||||
|
switch (opt) {
|
||||||
|
case 'l':
|
||||||
|
lbheld = 1;
|
||||||
|
break;
|
||||||
|
case 'm':
|
||||||
|
mbheld = 1;
|
||||||
|
break;
|
||||||
|
case 'r':
|
||||||
|
rbheld = 1;
|
||||||
|
break;
|
||||||
|
case 'x':
|
||||||
|
switch (*optarg++) {
|
||||||
|
case '=':
|
||||||
|
xabs = 1;
|
||||||
|
__attribute__ ((fallthrough));
|
||||||
|
case '+':
|
||||||
|
xmoving = strtol(optarg, NULL, 0);
|
||||||
|
break;
|
||||||
|
case '-':
|
||||||
|
xmoving = -strtol(optarg, NULL, 0);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
fputs(usage, fout);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'y':
|
||||||
|
switch (*optarg++) {
|
||||||
|
case '=':
|
||||||
|
yabs = 1;
|
||||||
|
__attribute__ ((fallthrough));
|
||||||
|
case '+':
|
||||||
|
ymoving = strtol(optarg, NULL, 0);
|
||||||
|
break;
|
||||||
|
case '-':
|
||||||
|
ymoving = -strtol(optarg, NULL, 0);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
fputs(usage, fout);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'h':
|
||||||
|
if ((optarg[0] != '+') && (optarg[0] != '-')) {
|
||||||
|
fputs(usage, fout);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
hscroll = strtol(optarg, NULL, 0);
|
||||||
|
break;
|
||||||
|
case 'v':
|
||||||
|
if ((optarg[0] != '+') && (optarg[0] != '-')) {
|
||||||
|
fputs(usage, fout);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
vscroll = strtol(optarg, NULL, 0);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
fputs(usage, fout);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
COVERAGE_ON();
|
||||||
|
umka_mouse_move(lbheld, mbheld, rbheld, xabs, xmoving, yabs, ymoving,
|
||||||
|
hscroll, vscroll);
|
||||||
|
COVERAGE_OFF();
|
||||||
|
}
|
||||||
|
|
||||||
void shell_process_info(int argc, char **argv) {
|
void shell_process_info(int argc, char **argv) {
|
||||||
(void)argc;
|
(void)argc;
|
||||||
process_information_t info;
|
process_information_t info;
|
||||||
@ -1941,6 +2079,8 @@ func_table_t funcs[] = {
|
|||||||
{ "scrot", shell_scrot },
|
{ "scrot", shell_scrot },
|
||||||
{ "dump_win_stack", shell_dump_win_stack },
|
{ "dump_win_stack", shell_dump_win_stack },
|
||||||
{ "dump_win_pos", shell_dump_win_pos },
|
{ "dump_win_pos", shell_dump_win_pos },
|
||||||
|
{ "dump_appdata", shell_dump_appdata },
|
||||||
|
{ "dump_taskdata", shell_dump_taskdata },
|
||||||
{ "acpi_set_usage", shell_acpi_set_usage },
|
{ "acpi_set_usage", shell_acpi_set_usage },
|
||||||
{ "acpi_get_usage", shell_acpi_get_usage },
|
{ "acpi_get_usage", shell_acpi_get_usage },
|
||||||
{ "acpi_enable", shell_acpi_enable },
|
{ "acpi_enable", shell_acpi_enable },
|
||||||
@ -1987,6 +2127,7 @@ func_table_t funcs[] = {
|
|||||||
{ "bg_unmap", shell_bg_unmap },
|
{ "bg_unmap", shell_bg_unmap },
|
||||||
{ "pci_set_path", shell_pci_set_path },
|
{ "pci_set_path", shell_pci_set_path },
|
||||||
{ "pci_get_path", shell_pci_get_path },
|
{ "pci_get_path", shell_pci_get_path },
|
||||||
|
{ "mouse_move", shell_mouse_move },
|
||||||
{ NULL, NULL },
|
{ NULL, NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
81
tools/lfbviewx.c
Normal file
81
tools/lfbviewx.c
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
#include <inttypes.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/uio.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <X11/Xlib.h>
|
||||||
|
#include <X11/Xutil.h>
|
||||||
|
#include <X11/XKBlib.h>
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
if (argc != 5) {
|
||||||
|
printf("usage: lfbviewx <pid> <address> <width> <height>\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
int depth = 32;
|
||||||
|
int umka_pid = strtol(argv[1], NULL, 0);
|
||||||
|
uintptr_t umka_lfb_addr = strtol(argv[2], NULL, 0);
|
||||||
|
size_t lfb_width = strtoul(argv[3], NULL, 0);
|
||||||
|
size_t lfb_height = strtoul(argv[4], NULL, 0);
|
||||||
|
|
||||||
|
Display *display = XOpenDisplay(NULL);
|
||||||
|
int screen_num = XDefaultScreen(display);
|
||||||
|
Window root = XDefaultRootWindow(display);
|
||||||
|
|
||||||
|
XVisualInfo vis_info;
|
||||||
|
if(!XMatchVisualInfo(display, screen_num, depth, TrueColor, &vis_info)) {
|
||||||
|
fprintf(stderr, "ERR: %d-bit depth is not supported\n", depth);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
Visual *visual = vis_info.visual;
|
||||||
|
XSetWindowAttributes win_attr = {
|
||||||
|
.colormap = XCreateColormap(display, root, visual, AllocNone),
|
||||||
|
.background_pixel = 0,
|
||||||
|
.border_pixel = 0};
|
||||||
|
unsigned long win_mask = CWBackPixel | CWColormap | CWBorderPixel;
|
||||||
|
Window window = XCreateWindow(display, root, 0, 0, lfb_width, lfb_height, 0, depth, InputOutput, visual, win_mask, &win_attr);
|
||||||
|
GC gc = XCreateGC(display, window, 0, 0);
|
||||||
|
|
||||||
|
uint32_t *lfb = (uint32_t*)malloc(lfb_width*lfb_height*sizeof(uint32_t));
|
||||||
|
XImage *image = XCreateImage(display, visual, depth, ZPixmap, 0, (char*)lfb, lfb_width, lfb_height, 32, 0);
|
||||||
|
|
||||||
|
XSelectInput(display, window, ExposureMask | KeyPressMask);
|
||||||
|
XStoreName(display, window, "KolibriOS LFB Viewer for X");
|
||||||
|
XMapWindow(display, window);
|
||||||
|
|
||||||
|
|
||||||
|
struct iovec remote = {.iov_base = (void*)umka_lfb_addr,
|
||||||
|
.iov_len = lfb_width*lfb_height*4};
|
||||||
|
struct iovec local = {.iov_base = lfb,
|
||||||
|
.iov_len = lfb_width*lfb_height*4};
|
||||||
|
/*
|
||||||
|
XEvent event;
|
||||||
|
while (true) {
|
||||||
|
XNextEvent(display, &event);
|
||||||
|
if (event.type == Expose) {
|
||||||
|
process_vm_readv(umka_pid, &local, 1, &remote, 1, 0);
|
||||||
|
XPutImage(display, window, gc, image, 0, 0, 0, 0, lfb_width, lfb_height);
|
||||||
|
} else if (event.type == KeyPress) {
|
||||||
|
int keysym = XkbKeycodeToKeysym(display, event. xkey.keycode, 0, 0);
|
||||||
|
|
||||||
|
if (keysym == XK_Escape) break;
|
||||||
|
switch (keysym) {
|
||||||
|
case XK_Left: {break;}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
XEvent event;
|
||||||
|
while (true) {
|
||||||
|
while (XCheckMaskEvent(display, (long)-1, &event)) { /* skip */ }
|
||||||
|
process_vm_readv(umka_pid, &local, 1, &remote, 1, 0);
|
||||||
|
XPutImage(display, window, gc, image, 0, 0, 0, 0, lfb_width, lfb_height);
|
||||||
|
sleep(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
XCloseDisplay(display);
|
||||||
|
return 0;
|
||||||
|
}
|
24
tools/makefile
Normal file
24
tools/makefile
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
CC=gcc
|
||||||
|
WARNINGS=-Wall -Wextra -Wduplicated-cond -Wduplicated-branches -Wlogical-op \
|
||||||
|
-Wrestrict -Wnull-dereference -Wjump-misses-init -Wshadow -Wformat=2 \
|
||||||
|
-Wswitch -Wswitch-enum -Wpedantic
|
||||||
|
NOWARNINGS=-Wno-address-of-packed-member
|
||||||
|
CFLAGS=$(WARNINGS) $(NOWARNINGS) -std=c11 -O2 \
|
||||||
|
-DNDEBUG -D_POSIX_C_SOURCE=200809L -fno-pie
|
||||||
|
LDFLAGS=-no-pie
|
||||||
|
|
||||||
|
all: mkdirrange mkfilepattern lfbviewx
|
||||||
|
|
||||||
|
mkdirrange: mkdirrange.c
|
||||||
|
$(CC) $(CFLAGS) $(LDFLAGS) $< -o $@
|
||||||
|
|
||||||
|
mkfilepattern: mkfilepattern.c
|
||||||
|
$(CC) $(CFLAGS) $(LDFLAGS) $< -o $@
|
||||||
|
|
||||||
|
lfbviewx: lfbviewx.c
|
||||||
|
$(CC) $(CFLAGS) $(LDFLAGS) $< -o $@ -lX11 -lXext -D_GNU_SOURCE
|
||||||
|
|
||||||
|
.PHONY: all clean
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f *.o mkdirrange mkfilepattern lfbviewx
|
32
umka.asm
32
umka.asm
@ -30,7 +30,6 @@ public sha3_256_oneshot as 'hash_oneshot'
|
|||||||
public kos_time_to_epoch
|
public kos_time_to_epoch
|
||||||
public kos_init
|
public kos_init
|
||||||
|
|
||||||
public monitor_thread
|
|
||||||
public CURRENT_TASK as 'kos_current_task'
|
public CURRENT_TASK as 'kos_current_task'
|
||||||
public current_slot as 'kos_current_slot'
|
public current_slot as 'kos_current_slot'
|
||||||
public TASK_COUNT as 'kos_task_count'
|
public TASK_COUNT as 'kos_task_count'
|
||||||
@ -64,6 +63,7 @@ public REDRAW_BACKGROUND
|
|||||||
public scheduler_add_thread
|
public scheduler_add_thread
|
||||||
public new_sys_threads
|
public new_sys_threads
|
||||||
public osloop
|
public osloop
|
||||||
|
public set_mouse_data as 'kos_set_mouse_data'
|
||||||
|
|
||||||
macro cli {
|
macro cli {
|
||||||
pushfd
|
pushfd
|
||||||
@ -193,8 +193,19 @@ macro call target {
|
|||||||
}
|
}
|
||||||
do_change_task equ hjk
|
do_change_task equ hjk
|
||||||
irq0 equ jhg
|
irq0 equ jhg
|
||||||
|
macro mov r, v {
|
||||||
|
if r eq [CURRENT_TASK] & v eq bh
|
||||||
|
push ebx
|
||||||
|
sub ebx, SLOT_BASE
|
||||||
|
mov [CURRENT_TASK], bh
|
||||||
|
pop ebx
|
||||||
|
else
|
||||||
|
mov r, v
|
||||||
|
end if
|
||||||
|
}
|
||||||
include 'core/sched.inc'
|
include 'core/sched.inc'
|
||||||
restore do_change_task
|
purge mov
|
||||||
|
purge call
|
||||||
restore irq0
|
restore irq0
|
||||||
include 'core/syscall.inc'
|
include 'core/syscall.inc'
|
||||||
;include 'core/fpu.inc'
|
;include 'core/fpu.inc'
|
||||||
@ -423,7 +434,7 @@ proc kos_init c uses ebx esi edi ebp
|
|||||||
mov dword[CURRENT_TASK], 2
|
mov dword[CURRENT_TASK], 2
|
||||||
mov dword[TASK_COUNT], 2
|
mov dword[TASK_COUNT], 2
|
||||||
mov dword[TASK_BASE], CURRENT_TASK + 2*sizeof.TASKDATA
|
mov dword[TASK_BASE], CURRENT_TASK + 2*sizeof.TASKDATA
|
||||||
mov [current_slot], SLOT_BASE+256*2
|
mov [current_slot], SLOT_BASE+2*sizeof.APPDATA
|
||||||
mov [CURRENT_TASK + 2*sizeof.TASKDATA + TASKDATA.pid], 2
|
mov [CURRENT_TASK + 2*sizeof.TASKDATA + TASKDATA.pid], 2
|
||||||
|
|
||||||
call set_window_defaults
|
call set_window_defaults
|
||||||
@ -431,8 +442,8 @@ proc kos_init c uses ebx esi edi ebp
|
|||||||
call calculatebackground
|
call calculatebackground
|
||||||
call init_display
|
call init_display
|
||||||
mov eax, [def_cursor]
|
mov eax, [def_cursor]
|
||||||
mov [SLOT_BASE+APPDATA.cursor+256], eax
|
mov [SLOT_BASE+APPDATA.cursor+sizeof.APPDATA], eax
|
||||||
mov [SLOT_BASE+APPDATA.cursor+256*2], eax
|
mov [SLOT_BASE+APPDATA.cursor+sizeof.APPDATA*2], eax
|
||||||
|
|
||||||
; from set_variables
|
; from set_variables
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
@ -440,7 +451,7 @@ proc kos_init c uses ebx esi edi ebp
|
|||||||
mov byte [KEY_COUNT], al ; keyboard buffer
|
mov byte [KEY_COUNT], al ; keyboard buffer
|
||||||
mov byte [BTN_COUNT], al ; button buffer
|
mov byte [BTN_COUNT], al ; button buffer
|
||||||
|
|
||||||
mov ebx, SLOT_BASE + 2*256
|
mov ebx, SLOT_BASE + 2*sizeof.APPDATA
|
||||||
mov word[cur_dir.path], '/'
|
mov word[cur_dir.path], '/'
|
||||||
mov [ebx+APPDATA.cur_dir], cur_dir
|
mov [ebx+APPDATA.cur_dir], cur_dir
|
||||||
|
|
||||||
@ -501,7 +512,6 @@ proc delay_ms
|
|||||||
ret
|
ret
|
||||||
endp
|
endp
|
||||||
|
|
||||||
|
|
||||||
extrn reset_procmask
|
extrn reset_procmask
|
||||||
extrn get_fake_if
|
extrn get_fake_if
|
||||||
extrn restart_timer
|
extrn restart_timer
|
||||||
@ -518,7 +528,7 @@ proc irq0 c, _signo, _info, _context
|
|||||||
mov bl, SCHEDULE_ANY_PRIORITY
|
mov bl, SCHEDULE_ANY_PRIORITY
|
||||||
call find_next_task
|
call find_next_task
|
||||||
jz .done ; if there is only one running process
|
jz .done ; if there is only one running process
|
||||||
call do_change_task
|
call _do_change_task
|
||||||
.done:
|
.done:
|
||||||
ccall restart_timer
|
ccall restart_timer
|
||||||
popad
|
popad
|
||||||
@ -644,13 +654,11 @@ purge sys_msg_board,HEAP_BASE,__pew8
|
|||||||
coverage_end:
|
coverage_end:
|
||||||
|
|
||||||
|
|
||||||
section '.data' writeable align 64
|
section '.data' writeable align 4096
|
||||||
public umka_tool
|
public umka_tool
|
||||||
umka_tool dd ?
|
umka_tool dd ?
|
||||||
fpu_owner dd ?
|
fpu_owner dd ?
|
||||||
|
|
||||||
monitor_thread dd ?
|
|
||||||
|
|
||||||
uglobal
|
uglobal
|
||||||
v86_irqhooks rd IRQ_RESERVED*2
|
v86_irqhooks rd IRQ_RESERVED*2
|
||||||
cache_ide0 IDE_CACHE
|
cache_ide0 IDE_CACHE
|
||||||
@ -685,7 +693,9 @@ WIN_POS rw 0x600
|
|||||||
rb 0x1000000
|
rb 0x1000000
|
||||||
BOOT_LO boot_data
|
BOOT_LO boot_data
|
||||||
BOOT boot_data
|
BOOT boot_data
|
||||||
|
align 4096
|
||||||
lfb_base rd MAX_SCREEN_WIDTH*MAX_SCREEN_HEIGHT
|
lfb_base rd MAX_SCREEN_WIDTH*MAX_SCREEN_HEIGHT
|
||||||
|
align 4096
|
||||||
cur_dir:
|
cur_dir:
|
||||||
.encoding rb 1
|
.encoding rb 1
|
||||||
.path rb maxPathLength
|
.path rb maxPathLength
|
||||||
|
42
umka.h
42
umka.h
@ -348,6 +348,19 @@ extern uint8_t ntfs_user_functions[];
|
|||||||
extern uint8_t kos_ramdisk[2880*512];
|
extern uint8_t kos_ramdisk[2880*512];
|
||||||
disk_t *kos_ramdisk_init(void);
|
disk_t *kos_ramdisk_init(void);
|
||||||
|
|
||||||
|
void kos_set_mouse_data(uint32_t btn_state, int32_t xmoving, int32_t ymoving,
|
||||||
|
int32_t vscroll, int32_t hscroll)
|
||||||
|
__attribute__((__stdcall__));
|
||||||
|
|
||||||
|
static inline void umka_mouse_move(int lbheld, int mbheld, int rbheld,
|
||||||
|
int xabs, int32_t xmoving,
|
||||||
|
int yabs, int32_t ymoving,
|
||||||
|
int32_t hscroll, int32_t vscroll) {
|
||||||
|
uint32_t btn_state = lbheld + (rbheld << 1) + (mbheld << 2) +
|
||||||
|
(yabs << 30) + (xabs << 31);
|
||||||
|
kos_set_mouse_data(btn_state, xmoving, ymoving, vscroll, hscroll);
|
||||||
|
}
|
||||||
|
|
||||||
static inline void umka_new_sys_threads(uint32_t flags, void (*entry)(), void *stack) {
|
static inline void umka_new_sys_threads(uint32_t flags, void (*entry)(), void *stack) {
|
||||||
__asm__ __inline__ __volatile__ (
|
__asm__ __inline__ __volatile__ (
|
||||||
"pushad;"
|
"pushad;"
|
||||||
@ -438,13 +451,35 @@ typedef struct {
|
|||||||
uint32_t pad[5];
|
uint32_t pad[5];
|
||||||
} event_t;
|
} event_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
lhead_t list;
|
||||||
|
lhead_t thr_list;
|
||||||
|
mutex_t heap_lock;
|
||||||
|
void *heap_base;
|
||||||
|
void *heap_top;
|
||||||
|
uint32_t mem_used;
|
||||||
|
void *dlls_list_ptr;
|
||||||
|
void *pdt_0_phys;
|
||||||
|
void *pdt_1_phys;
|
||||||
|
void *io_map_0;
|
||||||
|
void *io_map_1;
|
||||||
|
|
||||||
|
void *ht_lock;
|
||||||
|
void *ht_free;
|
||||||
|
void *ht_next;
|
||||||
|
void *htab[(1024-18*4)/4];
|
||||||
|
void *pdt_0[1024];
|
||||||
|
} proc_t;
|
||||||
|
|
||||||
|
_Static_assert(sizeof(proc_t) == 0x1400, "must be 0x1400 bytes long");
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
char app_name[11];
|
char app_name[11];
|
||||||
uint8_t pad1[5];
|
uint8_t pad1[5];
|
||||||
|
|
||||||
lhead_t list; // +16
|
lhead_t list; // +16
|
||||||
uint32_t process; // +24
|
proc_t *process; // +24
|
||||||
sigjmp_buf *fpu_state; // +28
|
void *fpu_state; // +28
|
||||||
void *exc_handler; // +32
|
void *exc_handler; // +32
|
||||||
uint32_t except_mask; // +36
|
uint32_t except_mask; // +36
|
||||||
void *pl0_stack; // +40
|
void *pl0_stack; // +40
|
||||||
@ -453,7 +488,7 @@ typedef struct {
|
|||||||
event_t *bk_ev; // +52
|
event_t *bk_ev; // +52
|
||||||
appobj_t *fd_obj; // +56
|
appobj_t *fd_obj; // +56
|
||||||
appobj_t *bk_obj; // +60
|
appobj_t *bk_obj; // +60
|
||||||
uint32_t saved_esp; // +64
|
void *saved_esp; // +64
|
||||||
uint32_t io_map[2]; // +68
|
uint32_t io_map[2]; // +68
|
||||||
uint32_t dbg_state; // +76
|
uint32_t dbg_state; // +76
|
||||||
char *cur_dir; // +80
|
char *cur_dir; // +80
|
||||||
@ -521,7 +556,6 @@ extern size_t kos_task_count;
|
|||||||
extern taskdata_t *kos_task_base;
|
extern taskdata_t *kos_task_base;
|
||||||
extern taskdata_t kos_task_data[];
|
extern taskdata_t kos_task_data[];
|
||||||
extern appdata_t kos_slot_base[];
|
extern appdata_t kos_slot_base[];
|
||||||
extern void (*monitor_thread)(void);
|
|
||||||
extern void umka_do_change_task(appdata_t *new);
|
extern void umka_do_change_task(appdata_t *new);
|
||||||
extern void scheduler_add_thread(void);
|
extern void scheduler_add_thread(void);
|
||||||
extern void find_next_task(void);
|
extern void find_next_task(void);
|
||||||
|
11
umka_os.c
11
umka_os.c
@ -2,6 +2,7 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <sys/mman.h>
|
||||||
#include <sys/select.h>
|
#include <sys/select.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
@ -37,7 +38,15 @@ int main() {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
monitor_thread = monitor;
|
|
||||||
|
/*
|
||||||
|
void *app_base = mmap((void*)0x000000, 16*0x100000, PROT_READ | PROT_WRITE | PROT_EXEC, MAP_FIXED | MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
|
||||||
|
if (app_base == MAP_FAILED) {
|
||||||
|
perror("mmap failed");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
printf("pid=%d, kos_lfb_base=%p\n", getpid(), (void*)kos_lfb_base);
|
||||||
|
|
||||||
kos_init();
|
kos_init();
|
||||||
kos_stack_init();
|
kos_stack_init();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user