diff options
Diffstat (limited to 'src/kernel/arch/amd64/driver')
-rw-r--r-- | src/kernel/arch/amd64/driver/fsroot.c | 12 | ||||
-rw-r--r-- | src/kernel/arch/amd64/driver/util.c | 16 | ||||
-rw-r--r-- | src/kernel/arch/amd64/driver/util.h | 4 | ||||
-rw-r--r-- | src/kernel/arch/amd64/driver/video.c | 15 |
4 files changed, 23 insertions, 24 deletions
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 <camellia/fsutil.h> #include <kernel/arch/amd64/ata.h> #include <kernel/arch/amd64/driver/fsroot.h> +#include <kernel/arch/amd64/driver/util.h> #include <kernel/mem/virt.h> #include <kernel/panic.h> #include <kernel/proc.h> @@ -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 <camellia/fsutil.h> +#include <kernel/arch/amd64/driver/util.h> +#include <kernel/mem/virt.h> +#include <kernel/panic.h> +#include <kernel/vfs/request.h> + +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 <camellia/fsutil.h> #include <camellia/errno.h> +#include <camellia/fsutil.h> +#include <kernel/arch/amd64/driver/util.h> #include <kernel/arch/amd64/driver/video.h> #include <kernel/mem/virt.h> #include <kernel/panic.h> @@ -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: |