umka_shell: add i40 command to call arbitrary sysfn.

This commit is contained in:
Ivan Baravy 2020-05-06 17:53:15 +03:00
parent 00fc0da12d
commit 2bd42fd701
4 changed files with 65 additions and 9 deletions

View File

@ -228,6 +228,17 @@ typedef struct {
uint8_t opaque[1024-HASH_SIZE]; uint8_t opaque[1024-HASH_SIZE];
} hash_context; } hash_context;
typedef struct {
uint32_t edi;
uint32_t esi;
uint32_t ebp;
uint32_t esp;
uint32_t ebx;
uint32_t edx;
uint32_t ecx;
uint32_t eax;
} pushad_t;
void kos_init(void); void kos_init(void);
void i40(void); void i40(void);
uint32_t kos_time_to_epoch(uint32_t *time); uint32_t kos_time_to_epoch(uint32_t *time);

View File

@ -4,6 +4,25 @@
#include <inttypes.h> #include <inttypes.h>
#include "kolibri.h" #include "kolibri.h"
static inline void umka_i40(pushad_t *regs) {
__asm__ __inline__ __volatile__ (
"push ebp;"
"mov ebp, %[ebp];"
"call i40;"
"pop ebp"
: "=a"(regs->eax),
"=b"(regs->ebx)
: "a"(regs->eax),
"b"(regs->ebx),
"c"(regs->ecx),
"d"(regs->edx),
"S"(regs->esi),
"D"(regs->edi),
[ebp] "Rm"(regs->ebp)
: "memory");
}
static inline void umka_sys_draw_window(size_t x, size_t xsize, static inline void umka_sys_draw_window(size_t x, size_t xsize,
size_t y, size_t ysize, size_t y, size_t ysize,
uint32_t color, int has_caption, uint32_t color, int has_caption,
@ -278,7 +297,7 @@ static inline int32_t umka_sys_set_skin(const char *path) {
int32_t status; int32_t status;
__asm__ __inline__ __volatile__ ( __asm__ __inline__ __volatile__ (
"call i40" "call i40"
: "=a" (status) : "=a"(status)
: "a"(48), : "a"(48),
"b"(8), "b"(8),
"c"(path) "c"(path)
@ -290,7 +309,7 @@ static inline int umka_sys_get_font_smoothing() {
int type; int type;
__asm__ __inline__ __volatile__ ( __asm__ __inline__ __volatile__ (
"call i40" "call i40"
: "=a" (type) : "=a"(type)
: "a"(48), : "a"(48),
"b"(9) "b"(9)
: "memory"); : "memory");
@ -311,7 +330,7 @@ static inline int umka_sys_get_font_size() {
uint32_t size; uint32_t size;
__asm__ __inline__ __volatile__ ( __asm__ __inline__ __volatile__ (
"call i40" "call i40"
: "=a" (size) : "=a"(size)
: "a"(48), : "a"(48),
"b"(11) "b"(11)
: "memory"); : "memory");
@ -366,7 +385,7 @@ static inline void umka_sys_lfn(void *f7080sXarg, f7080ret_t *r,
f70or80_t f70or80) { f70or80_t f70or80) {
__asm__ __inline__ __volatile__ ( __asm__ __inline__ __volatile__ (
"call i40" "call i40"
: "=a" (r->status), : "=a"(r->status),
"=b" (r->count) "=b" (r->count)
: "a"(f70or80), : "a"(f70or80),
"b"(f7080sXarg) "b"(f7080sXarg)

View File

@ -199,6 +199,31 @@ int split_args(char *s, char **argv) {
return argc; return argc;
} }
void shell_i40(int argc, char **argv) {
const char *usage = \
"usage: i40 <eax> [ebx [ecx [edx [esi [edi [ebp]]]]]]...\n"
" see '/kernel/docs/sysfuncs.txt' for details";
if (argc == 1 || argc > 8) {
puts(usage);
return;
}
pushad_t regs = {0, 0, 0, 0, 0, 0, 0, 0};
if (argv[1]) regs.eax = strtoul(argv[1], NULL, 0);
if (argv[2]) regs.ebx = strtoul(argv[2], NULL, 0);
if (argv[3]) regs.ecx = strtoul(argv[3], NULL, 0);
if (argv[4]) regs.edx = strtoul(argv[4], NULL, 0);
if (argv[5]) regs.esi = strtoul(argv[5], NULL, 0);
if (argv[6]) regs.edi = strtoul(argv[6], NULL, 0);
if (argv[7]) regs.ebp = strtoul(argv[7], NULL, 0);
COVERAGE_ON();
umka_i40(&regs);
COVERAGE_OFF();
printf("eax = %8.8x %" PRIu32 " %" PRIi32 "\n"
"ebx = %8.8x %" PRIu32 " %" PRIi32 "\n",
regs.eax, regs.eax, (int32_t)regs.eax,
regs.ebx, regs.ebx, (int32_t)regs.ebx);
}
void shell_disk_list_partitions(disk_t *d) { void shell_disk_list_partitions(disk_t *d) {
for (size_t i = 0; i < d->num_partitions; i++) { for (size_t i = 0; i < d->num_partitions; i++) {
printf("/%s/%d: ", d->name, i+1); printf("/%s/%d: ", d->name, i+1);
@ -1023,6 +1048,7 @@ typedef struct {
} func_table_t; } func_table_t;
func_table_t funcs[] = { func_table_t funcs[] = {
{ "i40", shell_i40 },
{ "disk_add", shell_disk_add }, { "disk_add", shell_disk_add },
{ "disk_del", shell_disk_del }, { "disk_del", shell_disk_del },
{ "ls70", shell_ls70 }, { "ls70", shell_ls70 },