rulimine/stage23/fs/file.s2.c

124 lines
2.9 KiB
C
Raw Normal View History

2020-04-14 06:20:55 +03:00
#include <stddef.h>
#include <stdint.h>
#include <fs/file.h>
#include <fs/echfs.h>
#include <fs/ext2.h>
2020-05-01 18:19:29 +03:00
#include <fs/fat32.h>
2021-02-21 05:45:24 +03:00
#include <fs/iso9660.h>
2021-03-04 00:38:28 +03:00
#include <lib/print.h>
2020-04-14 06:20:55 +03:00
#include <lib/blib.h>
2020-09-20 13:03:44 +03:00
#include <mm/pmm.h>
2020-11-01 23:25:35 +03:00
#include <lib/part.h>
#include <lib/libc.h>
2021-03-13 11:08:01 +03:00
#include <pxe/tftp.h>
2020-11-01 23:25:35 +03:00
bool fs_get_guid(struct guid *guid, struct volume *part) {
2020-11-01 23:25:35 +03:00
if (echfs_check_signature(part)) {
return echfs_get_guid(guid, part);
}
if (ext2_check_signature(part)) {
return ext2_get_guid(guid, part);
}
return false;
}
2020-04-14 06:20:55 +03:00
int fopen(struct file_handle *ret, struct volume *part, const char *filename) {
ret->is_memfile = false;
#if bios == 1
2021-03-13 11:08:01 +03:00
if (part->pxe) {
2021-08-12 08:40:29 +03:00
int r = tftp_open(ret, 0, 69, filename);
2021-03-13 11:08:01 +03:00
if (r)
return r;
return 0;
}
2021-03-13 11:45:17 +03:00
#endif
2021-03-13 11:08:01 +03:00
#if uefi == 1
ret->efi_part_handle = part->efi_part_handle;
#endif
2021-02-25 03:40:02 +03:00
if (iso9660_check_signature(part)) {
2021-02-21 05:45:24 +03:00
struct iso9660_file_handle *fd = ext_mem_alloc(sizeof(struct iso9660_file_handle));
int r = iso9660_open(fd, part, filename);
if (r)
return r;
ret->fd = (void *)fd;
ret->read = (void *)iso9660_read;
ret->size = fd->size;
return 0;
}
2020-11-02 12:17:20 +03:00
if (echfs_check_signature(part)) {
struct echfs_file_handle *fd = ext_mem_alloc(sizeof(struct echfs_file_handle));
2020-04-14 06:20:55 +03:00
2020-11-02 12:17:20 +03:00
int r = echfs_open(fd, part, filename);
2020-04-14 06:20:55 +03:00
if (r)
return r;
2020-11-02 12:17:20 +03:00
ret->fd = (void *)fd;
ret->read = (void *)echfs_read;
ret->size = fd->dir_entry.size;
2020-04-14 06:20:55 +03:00
return 0;
}
2020-11-02 12:17:20 +03:00
if (ext2_check_signature(part)) {
struct ext2_file_handle *fd = ext_mem_alloc(sizeof(struct ext2_file_handle));
2020-11-02 12:17:20 +03:00
int r = ext2_open(fd, part, filename);
2020-04-15 23:34:09 +03:00
if (r)
return r;
2020-11-02 12:17:20 +03:00
ret->fd = (void *)fd;
ret->read = (void *)ext2_read;
ret->size = fd->size;
return 0;
}
2020-04-14 06:20:55 +03:00
2020-11-02 12:17:20 +03:00
if (fat32_check_signature(part)) {
struct fat32_file_handle *fd = ext_mem_alloc(sizeof(struct fat32_file_handle));
2020-05-01 18:19:29 +03:00
2020-11-02 12:17:20 +03:00
int r = fat32_open(fd, part, filename);
2020-05-01 18:19:29 +03:00
if (r)
return r;
2020-11-02 12:17:20 +03:00
ret->fd = (void *)fd;
ret->read = (void *)fat32_read;
ret->size = fd->size_bytes;
2020-05-01 18:19:29 +03:00
return 0;
}
2020-04-14 06:20:55 +03:00
return -1;
}
int fread(struct file_handle *fd, void *buf, uint64_t loc, uint64_t count) {
if (fd->is_memfile) {
memcpy(buf, fd->fd + loc, count);
return 0;
} else {
return fd->read(fd->fd, buf, loc, count);
}
}
void *freadall(struct file_handle *fd, uint32_t type) {
if (fd->is_memfile) {
2021-05-06 05:31:05 +03:00
memmap_alloc_range((uint64_t)(size_t)fd->fd, ALIGN_UP(fd->size, 4096), type, false, true, false, false);
return fd->fd;
} else {
void *ret = ext_mem_alloc_type(fd->size, type);
if (fd->read(fd->fd, ret, 0, fd->size)) {
panic("freadall error");
}
return ret;
}
2020-04-14 06:20:55 +03:00
}