summaryrefslogtreecommitdiff
path: root/src/kernel/arch/amd64/driver
diff options
context:
space:
mode:
authordzwdz2022-07-29 16:16:24 +0200
committerdzwdz2022-07-29 16:16:24 +0200
commitc6424fbc55298399f133ca1ede11e1f0b4a5c824 (patch)
treed8dd1c160a7184a99ea3c72779dce95b4bbee692 /src/kernel/arch/amd64/driver
parenta0b16620e1699504e8d21a481e019dec40d7ee1b (diff)
use a shared fs_normslice() function to handle offsets
Diffstat (limited to 'src/kernel/arch/amd64/driver')
-rw-r--r--src/kernel/arch/amd64/driver/fsroot.c28
1 files changed, 4 insertions, 24 deletions
diff --git a/src/kernel/arch/amd64/driver/fsroot.c b/src/kernel/arch/amd64/driver/fsroot.c
index 1e3dc1f..c4c3de4 100644
--- a/src/kernel/arch/amd64/driver/fsroot.c
+++ b/src/kernel/arch/amd64/driver/fsroot.c
@@ -1,4 +1,5 @@
#include <camellia/errno.h>
+#include <camellia/fsutil.h>
#include <kernel/arch/amd64/ata.h>
#include <kernel/arch/amd64/driver/fsroot.h>
#include <kernel/mem/virt.h>
@@ -22,30 +23,9 @@ static bool exacteq(struct vfs_request *req, const char *str) {
return req->input.len == len && !memcmp(req->input.buf_kern, str, len);
}
-/* truncates the length */
-static void req_preprocess(struct vfs_request *req, size_t max_len) {
- if (req->offset < 0) {
- // TODO negative offsets
- req->offset = 0;
- }
-
- if (req->offset >= capped_cast32(max_len)) {
- req->input.len = 0;
- req->output.len = 0;
- req->offset = max_len;
- return;
- }
-
- req->input.len = min(req->input.len, max_len - req->offset);
- req->output.len = min(req->output.len, max_len - req->offset);
-
- assert(req->input.len + req->offset <= max_len);
- assert(req->input.len + req->offset <= max_len);
-}
-
static int req_readcopy(struct vfs_request *req, const void *buf, size_t len) {
assert(req->type == VFSOP_READ);
- req_preprocess(req, len);
+ fs_normslice(&req->offset, &req->output.len, len, false);
virt_cpy_to(
req->caller->pages, req->output.buf,
buf + req->offset, req->output.len);
@@ -100,7 +80,7 @@ static int handle(struct vfs_request *req) {
}
case HANDLE_ATA: case HANDLE_ATA+1:
case HANDLE_ATA+2: case HANDLE_ATA+3:
- if (req->offset < 0) return 0;
+ if (req->offset < 0) return -1;
char buf[512];
uint32_t sector = req->offset / 512;
size_t len = min(req->output.len, 512 - ((size_t)req->offset & 511));
@@ -114,7 +94,7 @@ static int handle(struct vfs_request *req) {
switch (id) {
case HANDLE_VGA: {
void *vga = (void*)0xB8000;
- req_preprocess(req, 80*25*2);
+ fs_normslice(&req->offset, &req->input.len, 80*25*2, false);
if (!virt_cpy_from(req->caller->pages, vga + req->offset,
req->input.buf, req->input.len))
{