summaryrefslogtreecommitdiff
path: root/src/kernel/vfs/request.c
diff options
context:
space:
mode:
authordzwdz2022-07-17 20:28:53 +0200
committerdzwdz2022-07-17 20:28:53 +0200
commitc6bbf615e5c77ec273b954c11cef95df3d6f7286 (patch)
tree7b4539c9c5089a8b563d90444c388169fd093cf0 /src/kernel/vfs/request.c
parent51cbabd0f40b041fa00203266afa046d14e88b22 (diff)
kernel/virt_cpy: error struct, better error handling
Diffstat (limited to 'src/kernel/vfs/request.c')
-rw-r--r--src/kernel/vfs/request.c20
1 files changed, 14 insertions, 6 deletions
diff --git a/src/kernel/vfs/request.c b/src/kernel/vfs/request.c
index 87d6208..b056a31 100644
--- a/src/kernel/vfs/request.c
+++ b/src/kernel/vfs/request.c
@@ -4,6 +4,7 @@
#include <kernel/panic.h>
#include <kernel/proc.h>
#include <kernel/vfs/request.h>
+#include <shared/errno.h>
#include <shared/mem.h>
void vfsreq_create(struct vfs_request req_) {
@@ -102,6 +103,7 @@ void vfs_backend_tryaccept(struct vfs_backend *backend) {
void vfs_backend_user_accept(struct vfs_request *req) {
struct process *handler;
struct fs_wait_response res = {0};
+ struct virt_cpy_error cpyerr;
int len = 0;
assert(req && req->backend && req->backend->user.handler);
@@ -115,9 +117,15 @@ void vfs_backend_user_accept(struct vfs_request *req) {
if (req->input.buf) {
len = min(req->input.len, handler->awaited_req.max_len);
- if (!virt_cpy(handler->pages, handler->awaited_req.buf,
- req->input.kern ? NULL : req->caller->pages, req->input.buf, len))
- goto fail; // can't copy buffer
+ virt_cpy(handler->pages, handler->awaited_req.buf,
+ req->input.kern ? NULL : req->caller->pages, req->input.buf,
+ len, &cpyerr);
+ if (cpyerr.write_fail)
+ panic_unimplemented();
+ if (cpyerr.read_fail) {
+ vfsreq_finish_short(req, -EFAULT);
+ return;
+ }
}
res.len = len;
@@ -129,15 +137,15 @@ void vfs_backend_user_accept(struct vfs_request *req) {
if (!virt_cpy_to(handler->pages,
handler->awaited_req.res, &res, sizeof res))
- goto fail; // can't copy response struct
+ {
+ panic_unimplemented();
+ }
process_transition(handler, PS_RUNNING);
handler->handled_req = req;
req->backend->user.handler = NULL;
regs_savereturn(&handler->regs, 0);
return;
-fail:
- panic_unimplemented(); // TODO
}
void vfs_backend_refdown(struct vfs_backend *b) {