From ce00d1677d7a419b427e7f11963eee982a55a231 Mon Sep 17 00:00:00 2001 From: dzwdz Date: Thu, 4 Aug 2022 23:06:57 +0200 Subject: do some simple TODOs, organize the rest; general code maintainance --- src/kernel/arch/amd64/driver/fsroot.c | 12 +----------- src/kernel/arch/amd64/driver/util.c | 16 ++++++++++++++++ src/kernel/arch/amd64/driver/util.h | 4 ++++ src/kernel/arch/amd64/driver/video.c | 15 ++------------- 4 files changed, 23 insertions(+), 24 deletions(-) create mode 100644 src/kernel/arch/amd64/driver/util.c create mode 100644 src/kernel/arch/amd64/driver/util.h (limited to 'src/kernel/arch/amd64/driver') diff --git a/src/kernel/arch/amd64/driver/fsroot.c b/src/kernel/arch/amd64/driver/fsroot.c index 512b7da..41fe136 100644 --- a/src/kernel/arch/amd64/driver/fsroot.c +++ b/src/kernel/arch/amd64/driver/fsroot.c @@ -2,6 +2,7 @@ #include #include #include +#include #include #include #include @@ -22,17 +23,6 @@ static bool exacteq(struct vfs_request *req, const char *str) { return req->input.len == len && !memcmp(req->input.buf_kern, str, len); } -static int req_readcopy(struct vfs_request *req, const void *buf, size_t len) { - assert(req->type == VFSOP_READ); - fs_normslice(&req->offset, &req->output.len, len, false); - virt_cpy_to( - req->caller->pages, req->output.buf, - buf + req->offset, req->output.len); - /* read errors are ignored. TODO write docs */ - return req->output.len; -} - - static int handle(struct vfs_request *req) { assert(req->caller); int id = (int)(long __force)req->id; diff --git a/src/kernel/arch/amd64/driver/util.c b/src/kernel/arch/amd64/driver/util.c new file mode 100644 index 0000000..b03e582 --- /dev/null +++ b/src/kernel/arch/amd64/driver/util.c @@ -0,0 +1,16 @@ +#include +#include +#include +#include +#include + +int req_readcopy(struct vfs_request *req, const void *buf, size_t len) { + if (!req->caller) return -1; + assert(req->type == VFSOP_READ); + fs_normslice(&req->offset, &req->output.len, len, false); + virt_cpy_to( + req->caller->pages, req->output.buf, + buf + req->offset, req->output.len); + /* read errors are ignored. TODO write a spec */ + return req->output.len; +} diff --git a/src/kernel/arch/amd64/driver/util.h b/src/kernel/arch/amd64/driver/util.h new file mode 100644 index 0000000..fd8d506 --- /dev/null +++ b/src/kernel/arch/amd64/driver/util.h @@ -0,0 +1,4 @@ +#pragma once + +struct vfs_request; +int req_readcopy(struct vfs_request *req, const void *buf, size_t len); diff --git a/src/kernel/arch/amd64/driver/video.c b/src/kernel/arch/amd64/driver/video.c index 8ace3d4..2d1ac03 100644 --- a/src/kernel/arch/amd64/driver/video.c +++ b/src/kernel/arch/amd64/driver/video.c @@ -1,5 +1,6 @@ -#include #include +#include +#include #include #include #include @@ -12,18 +13,6 @@ enum { H_FB, }; -/* stolen from fsroot.c, TODO shared copy? i guess? */ -static int req_readcopy(struct vfs_request *req, const void *buf, size_t len) { - if (!req->caller) return -1; - assert(req->type == VFSOP_READ); - fs_normslice(&req->offset, &req->output.len, len, false); - virt_cpy_to( - req->caller->pages, req->output.buf, - buf + req->offset, req->output.len); - /* read errors are ignored. TODO write docs */ - return req->output.len; -} - static int handle(struct vfs_request *req) { switch (req->type) { case VFSOP_OPEN: -- cgit v1.2.3