diff options
author | dzwdz | 2021-09-09 21:14:26 +0200 |
---|---|---|
committer | dzwdz | 2021-09-09 21:14:26 +0200 |
commit | 80b2c1c2ab36b4ddb030e135bcacf1f30db362d2 (patch) | |
tree | 50eaf0a30fb296a21f24254575b4d6bbb52c95f1 /src/kernel/vfs/backend.c | |
parent | 7192887ee27487d209b98b7192cb6798b036b824 (diff) |
basic _syscall_fs_wait() impl, doesn't pass the req yet
Diffstat (limited to 'src/kernel/vfs/backend.c')
-rw-r--r-- | src/kernel/vfs/backend.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/src/kernel/vfs/backend.c b/src/kernel/vfs/backend.c index 7e53e51..4b22104 100644 --- a/src/kernel/vfs/backend.c +++ b/src/kernel/vfs/backend.c @@ -27,14 +27,22 @@ _Noreturn void vfs_backend_dispatch(struct vfs_backend *backend, struct vfs_op o process_current->pending_req = req; process_switch_any(); } else { - assert(backend->handler->state == PS_WAITS4REQUEST); - panic(); // TODO + vfs_request_pass2handler(req); } default: panic(); } } +_Noreturn void vfs_request_pass2handler(struct vfs_op_request *req) { + assert(req->backend->handler); + assert(req->backend->handler->state == PS_WAITS4REQUEST); + + req->backend->handler->state = PS_RUNNING; + // TODO pass the request to the process + process_switch(req->backend->handler); +} + // returns from a VFS operation to the calling process _Noreturn void vfs_backend_finish(struct vfs_op_request *req, int ret) { struct process *caller = req->caller; |