Rewrite PS2KB using the new devctl interface

This commit is contained in:
2025-09-28 23:25:43 +02:00
parent f5f44da5f6
commit d7562b98c1
10 changed files with 64 additions and 75 deletions

View File

@ -54,7 +54,6 @@ SRCFILES += $(call GRABSRC, \
baseimg \ baseimg \
proc \ proc \
proc/kproc \ proc/kproc \
proc/ps2kbproc \
proc/serialproc \ proc/serialproc \
hal \ hal \
hal/$(ARCH) \ hal/$(ARCH) \

35
kernel/dev/ps2kbdev.c Normal file
View File

@ -0,0 +1,35 @@
#include <stdint.h>
#include <stddef.h>
#include "kprintf.h"
#include "hal/hal.h"
#include "ps2kbdev.h"
#include "dev.h"
#include "errors.h"
#include "dlmalloc/malloc.h"
Dev PS2KBDEV;
Ps2KbFastBuf PS2KB_BUF;
int32_t ps2kbdev_readch(uint8_t *buffer, size_t len, void *extra) {
(void)buffer; (void)len; (void)extra;
uint8_t b = 0;
spinlock_acquire(&PS2KB_BUF.spinlock);
int32_t r = rbuf_pop(&PS2KB_BUF.rbuf, &b);
spinlock_release(&PS2KB_BUF.spinlock);
if (r == 0) {
return b;
} else {
return E_NOTYET;
}
}
void ps2kbdev_init(void) {
hal_memset(&PS2KBDEV, 0, sizeof(PS2KBDEV));
PS2KBDEV.fns[0] = &ps2kbdev_readch;
const int bufsz = 0x1000;
uint8_t *buf = dlmalloc(bufsz);
rbuf_init(&PS2KB_BUF.rbuf, buf, bufsz);
PS2KB_BUF.init = true;
}

22
kernel/dev/ps2kbdev.h Normal file
View File

@ -0,0 +1,22 @@
#ifndef DEV_PS2KBDEV_H_
#define DEV_PS2KBDEV_H_
#include <stdint.h>
#include <stddef.h>
#include "dev.h"
#include "rbuf/rbuf.h"
#include "spinlock/spinlock.h"
typedef struct {
RBuf rbuf;
SpinLock spinlock;
bool init;
} Ps2KbFastBuf;
void ps2kbdev_init(void);
extern Dev PS2KBDEV;
extern Ps2KbFastBuf PS2KB_BUF;
#endif // DEV_PS2KBDEV_H_

View File

@ -14,8 +14,8 @@
#include "errors.h" #include "errors.h"
#include "drivers/ps2kb/ps2kb.h" #include "drivers/ps2kb/ps2kb.h"
#include "ipc/pipe/pipe.h" #include "ipc/pipe/pipe.h"
#include "proc/ps2kbproc/ps2kbproc.h"
#include "rbuf/rbuf.h" #include "rbuf/rbuf.h"
#include "dev/ps2kbdev.h"
typedef struct BackTraceFrame { typedef struct BackTraceFrame {
struct BackTraceFrame *rbp; struct BackTraceFrame *rbp;

View File

@ -12,6 +12,7 @@
#include "util/util.h" #include "util/util.h"
#include "proc/proc.h" #include "proc/proc.h"
#include "dev/termdev.h" #include "dev/termdev.h"
#include "dev/ps2kbdev.h"
const char *human_size(uint64_t bytes, char *buf, size_t bufsize) { const char *human_size(uint64_t bytes, char *buf, size_t bufsize) {
static const char *units[] = { "B", "KiB", "MiB", "GiB", "TiB", "PiB" }; static const char *units[] = { "B", "KiB", "MiB", "GiB", "TiB", "PiB" };
@ -66,6 +67,7 @@ void kmain(void) {
baseimg_init(); baseimg_init();
vfs_init(); vfs_init();
termdev_init(); termdev_init();
ps2kbdev_init();
proc_init(); proc_init();
for(;;); for(;;);

View File

@ -14,7 +14,6 @@
#include "bootinfo/bootinfo.h" #include "bootinfo/bootinfo.h"
#include "ipc/pipe/pipe.h" #include "ipc/pipe/pipe.h"
#include "kproc/kproc.h" #include "kproc/kproc.h"
#include "ps2kbproc/ps2kbproc.h"
#include "serialproc/serialproc.h" #include "serialproc/serialproc.h"
#include "sysdefs/processctl.h" #include "sysdefs/processctl.h"
@ -308,18 +307,6 @@ void proc_init(void) {
spinlock_init(&PROCS.spinlock); spinlock_init(&PROCS.spinlock);
PROCS.procs = NULL; PROCS.procs = NULL;
/* kproc_init(proc_spawnkern(&kproc_fn, "kproc")); */
/* proc_register(KPROC); */
/* PROCS.current = KPROC; */
/* KPROC->state = PROC_READY; */
/* ps2kbproc_init(proc_spawnkern(&ps2kbproc_fn, "ps2kbproc")); */
/* proc_register(PS2KBPROC); */
/* PS2KBPROC->state = PROC_READY; */
/* serialproc_init(proc_spawnkern(&serialproc_fn, "serialproc")); */
/* proc_register(SERIALPROC); */
Proc *init = proc_spawnuser("base", "/bin/init"); Proc *init = proc_spawnuser("base", "/bin/init");
PROCS.current = init; PROCS.current = init;
proc_register(init); proc_register(init);

View File

@ -1,39 +0,0 @@
#include <stdint.h>
#include "proc/proc.h"
#include "dlmalloc/malloc.h"
#include "ipc/pipe/pipe.h"
#include "kprintf.h"
#include "rbuf/rbuf.h"
#include "ps2kbproc.h"
Proc *PS2KBPROC = NULL;
Ps2KbFastBuf PS2KB_BUF = {0};
void ps2kbproc_init(Proc *proc) {
PS2KBPROC = proc;
PS2KBPROC->bcast_pipes.list = NULL;
uint8_t *buf = dlmalloc(IPC_PIPE_MAX);
rbuf_init(&PS2KB_BUF.rbuf, buf, IPC_PIPE_MAX);
spinlock_init(&PS2KB_BUF.spinlock);
PS2KB_BUF.init = true;
}
void ps2kbproc_fn(void) {
for (;;) {
/* uint8_t b = 0; */
/* spinlock_acquire(&PS2KB_BUF.spinlock); */
/* if (rbuf_pop(&PS2KB_BUF.rbuf, &b) == 0) { */
/* spinlock_acquire(&PS2KBPROC->bcast_pipes.spinlock); */
/* IpcPipe *head = PS2KBPROC->bcast_pipes.list; */
/* while (head != NULL) { */
/* ipc_pipewrite(head, &b, 1); */
/* head = head->next; */
/* } */
/* spinlock_release(&PS2KBPROC->bcast_pipes.spinlock); */
/* } */
/* spinlock_release(&PS2KB_BUF.spinlock); */
}
}

View File

@ -1,21 +0,0 @@
#ifndef PROC_PS2KB_PS2KBPROC_H_
#define PROC_PS2KB_PS2KBPROC_H_
#include <stdbool.h>
#include "proc/proc.h"
#include "rbuf/rbuf.h"
#include "spinlock/spinlock.h"
typedef struct {
RBuf rbuf;
SpinLock spinlock;
bool init;
} Ps2KbFastBuf;
extern Proc *PS2KBPROC;
extern Ps2KbFastBuf PS2KB_BUF;
void ps2kbproc_fn(void);
void ps2kbproc_init(Proc *proc);
#endif // PROC_PS2KB_PS2KBPROC_H_

View File

@ -7,10 +7,12 @@
#include "proc/proc.h" #include "proc/proc.h"
#include "sysdefs/devctl.h" #include "sysdefs/devctl.h"
#include "dev/termdev.h" #include "dev/termdev.h"
#include "dev/ps2kbdev.h"
#include "util/util.h" #include "util/util.h"
Dev *DEVS[] = { Dev *DEVS[] = {
[0x10] = &TERMDEV, [0x10] = &TERMDEV,
[0x11] = &PS2KBDEV,
}; };
int32_t SYSCALL5(sys_devctl, devh1, cmd1, buffer1, len1, extra1) { int32_t SYSCALL5(sys_devctl, devh1, cmd1, buffer1, len1, extra1) {
@ -35,6 +37,7 @@ int32_t SYSCALL5(sys_devctl, devh1, cmd1, buffer1, len1, extra1) {
if (proc->devs[i] == NULL) { if (proc->devs[i] == NULL) {
found = true; found = true;
proc->devs[i] = DEVS[devid]; proc->devs[i] = DEVS[devid];
*devh = i;
break; break;
} }
} }

View File

@ -16,6 +16,7 @@ enum {
E_INVALIDOPER = -11, E_INVALIDOPER = -11,
E_RESOURCEAVAIL = -12, E_RESOURCEAVAIL = -12,
E_SPAWNERROR = -13, E_SPAWNERROR = -13,
E_NOTYET = -14,
}; };
static const char *_ERROR_STRINGS[] = { static const char *_ERROR_STRINGS[] = {