diff options
author | dzwdz | 2022-08-14 21:18:01 +0200 |
---|---|---|
committer | dzwdz | 2022-08-14 21:18:01 +0200 |
commit | fa082df2da6b3be52c66ce0d48c209a3df38115d (patch) | |
tree | 1c51b4d084d966fddfbc91afb33469e4582cde84 /src/kernel/arch/amd64/driver/pata.c | |
parent | b58a95e1a529db1f640eb9ac3ca6e0244790e0ca (diff) |
kernel/ata: "proper" read support
Diffstat (limited to 'src/kernel/arch/amd64/driver/pata.c')
-rw-r--r-- | src/kernel/arch/amd64/driver/pata.c | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/src/kernel/arch/amd64/driver/pata.c b/src/kernel/arch/amd64/driver/pata.c index b4ec46c..1193add 100644 --- a/src/kernel/arch/amd64/driver/pata.c +++ b/src/kernel/arch/amd64/driver/pata.c @@ -1,4 +1,5 @@ #include <camellia/errno.h> +#include <camellia/fsutil.h> #include <kernel/arch/amd64/ata.h> #include <kernel/arch/amd64/driver/pata.h> #include <kernel/arch/amd64/driver/util.h> @@ -53,22 +54,26 @@ static void accept(struct vfs_request *req) { vfsreq_finish_short(req, req_readcopy(req, list, len)); break; } - // TODO ata size get - if (req->offset < 0) { - vfsreq_finish_short(req, -ENOSYS); - break; - } + fs_normslice(&req->offset, &req->output.len, ata_size(id), false); + char buf[512]; /* stupid */ - uint32_t sector = req->offset / 512; - size_t len = min(req->output.len, 512 - ((size_t)req->offset & 511)); + uint32_t sector = req->offset / ATA_SECTOR; + size_t skip = (size_t)req->offset & (ATA_SECTOR - 1); + size_t len = min(req->output.len, ATA_SECTOR - skip); ata_read(id, sector, buf); - virt_cpy_to(req->caller->pages, req->output.buf, buf, len); + virt_cpy_to(req->caller->pages, req->output.buf, buf + skip, len); vfsreq_finish_short(req, len); break; case VFSOP_WRITE: panic_unimplemented(); + case VFSOP_GETSIZE: + if (id == root_id) + panic_unimplemented(); + vfsreq_finish_short(req, ata_size(id)); + break; + default: vfsreq_finish_short(req, -ENOSYS); break; |