From f7820301d583ae190b683bdd1371ee6f7a35ac16 Mon Sep 17 00:00:00 2001 From: Benji Dial Date: Sat, 18 Jan 2020 14:28:53 -0500 Subject: going to try efi again --- src/kernel/ata.asm | 4 ++-- src/kernel/fat12.c | 58 +++++++++++++++++++++++++++++++++++++++++++++++++++ src/kernel/fat12.h | 48 ++++++++++++++++++++++++++++++++++++++++++ src/kernel/floppy.asm | 4 ++-- src/kernel/ide.asm | 4 ++-- 5 files changed, 112 insertions(+), 6 deletions(-) create mode 100644 src/kernel/fat12.c create mode 100644 src/kernel/fat12.h (limited to 'src/kernel') diff --git a/src/kernel/ata.asm b/src/kernel/ata.asm index 40c1cc7..bbd1f47 100644 --- a/src/kernel/ata.asm +++ b/src/kernel/ata.asm @@ -23,7 +23,7 @@ ata_read_sectors:;uint32_t ata_read_sectors(uint8_t number, uint32_t start, uint push ebp mov ebp, esp - ;TODO + xor eax, eax;TODO leave ret @@ -32,7 +32,7 @@ ata_write_sectors:;uint32_t ata_write_sectors(uint8_t number, uint32_t start, ui push ebp mov ebp, esp - ;TODO + xor eax, eax;TODO leave ret \ No newline at end of file diff --git a/src/kernel/fat12.c b/src/kernel/fat12.c new file mode 100644 index 0000000..ef09116 --- /dev/null +++ b/src/kernel/fat12.c @@ -0,0 +1,58 @@ +/* +Copyright 2019 Benji Dial + +Permission to use, copy, modify, and/or distribute this +software for any purpose with or without fee is hereby +granted, provided that the above copyright notice and this +permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS +ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO +EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER +RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, +ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE +OF THIS SOFTWARE. +*/ + +#include "iso9660.h" +#include "diskio.h" +#include "files.h" +#include "mem.h" + +bool iso_9660_parse_ph(uint8_t dn, uint8_t pn, uint32_t sector, uint8_t *buffer) { + uint32_t s = sector + 64; + read_sectors_t rsf = get_read_sectors_function(dn); + do { + rsf(drives[dn].number, s, 4, buffer); + if ((*buffer == 255) || (*(uint32_t *)&buffer[1] != 0x30304443) || + (buffer[5] != (uint8_t)'1')) + return false; + s += 4; + } while (*buffer != PRIM_VOLUME); + part_info[dn].partition_types[pn] = ISO_9660; + part_info[dn].partition_offsets[pn] = sector; + struct iso_9660_cache *cache = allocate_block(sizeof(struct iso_9660_cache), KERNEL); + struct iso_9660_primary_vd *as_vd = (struct iso_9660_primary_vd *)buffer; + part_info[dn].partition_cache[pn] = cache; + if ((cache->block_size = as_vd->block_size) & ~0x01ff) { + part_info[dn].partition_sizes[pn] = + (as_vd->block_size >> 9) * as_vd->size; + cache->path_table_sector = + (as_vd->block_size >> 9) * as_vd->path_table_block; + cache->optional_path_table_sector = + (as_vd->block_size >> 9) * as_vd->optional_path_table_block; + } + else { + part_info[dn].partition_sizes[pn] = + (as_vd->block_size * as_vd->size) >> 9; + cache->path_table_sector = + (as_vd->block_size * as_vd->path_table_block) >> 9; + cache->optional_path_table_sector = + (as_vd->block_size * as_vd->optional_path_table_block) >> 9; + } + cache->path_table_size = as_vd->path_table_size; + return true; +} \ No newline at end of file diff --git a/src/kernel/fat12.h b/src/kernel/fat12.h new file mode 100644 index 0000000..250d877 --- /dev/null +++ b/src/kernel/fat12.h @@ -0,0 +1,48 @@ +/* +Copyright 2019 Benji Dial + +Permission to use, copy, modify, and/or distribute this +software for any purpose with or without fee is hereby +granted, provided that the above copyright notice and this +permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS +ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO +EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER +RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, +ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE +OF THIS SOFTWARE. +*/ + +#include +#include + +#ifndef FAT12_H +#define FAT12_H + +struct bpb { + uint8_t jump[3]; + uint8_t oem[8]; + uint16_t bytes_per_sector; + uint8_t sectors_per_cluster; + uint16_t reserved_sectors; + uint8_t number_of_fats; + uint16_t root_size; + uint16_t short_sectors; + uint8_t media_type; + uint16_t sectors_per_fat; + uint16_t sectors_per_track; + uint16_t number_of_heads; + uint32_t hidden_sectors; + uint32_t long_sectors; +} __attribute__ ((__packed__)); + +struct fat12_cache { +}; + +bool fat12_parse_ph(uint8_t dn, uint8_t pn, uint32_t sector, uint8_t *buffer); + +#endif \ No newline at end of file diff --git a/src/kernel/floppy.asm b/src/kernel/floppy.asm index 3bc02a2..ffe6c99 100644 --- a/src/kernel/floppy.asm +++ b/src/kernel/floppy.asm @@ -23,7 +23,7 @@ floppy_read_sectors:;uint32_t floppy_read_sectors(uint8_t number, uint32_t start push ebp mov ebp, esp - ;TODO + xor eax, eax;TODO leave ret @@ -32,7 +32,7 @@ floppy_write_sectors:;uint32_t floppy_write_sectors(uint8_t number, uint32_t sta push ebp mov ebp, esp - ;TODO + xor eax, eax;TODO leave ret \ No newline at end of file diff --git a/src/kernel/ide.asm b/src/kernel/ide.asm index b888a06..ccac986 100644 --- a/src/kernel/ide.asm +++ b/src/kernel/ide.asm @@ -23,7 +23,7 @@ ide_read_sectors:;uint32_t ide_read_sectors(uint8_t number, uint32_t start, uint push ebp mov ebp, esp - ;TODO + xor eax, eax;TODO leave ret @@ -32,7 +32,7 @@ ide_write_sectors:;uint32_t ide_write_sectors(uint8_t number, uint32_t start, ui push ebp mov ebp, esp - ;TODO + xor eax, eax;TODO leave ret \ No newline at end of file -- cgit v1.2.3