going to try efi again

This commit is contained in:
Benji Dial 2020-01-18 14:28:53 -05:00
parent 243e28075e
commit f7820301d5
6 changed files with 115 additions and 9 deletions

View file

@ -18,8 +18,8 @@ kernel: obj out
nasm src/kernel/serial.asm -o obj/kserial.o -f elf32 nasm src/kernel/serial.asm -o obj/kserial.o -f elf32
nasm src/kernel/stub.asm -o obj/kstub.o -f elf32 nasm src/kernel/stub.asm -o obj/kstub.o -f elf32
gcc -c src/kernel/diskio.c -o obj/kdiskio.o -ffreestanding -nostdlib -m32 gcc -c src/kernel/diskio.c -o obj/kdiskio.o -ffreestanding -nostdlib -m32
gcc -c src/kernel/fat12.c -o obj/kfat12.o -ffreestanding -nostdlib -m32
gcc -c src/kernel/files.c -o obj/kfiles.o -ffreestanding -nostdlib -m32 gcc -c src/kernel/files.c -o obj/kfiles.o -ffreestanding -nostdlib -m32
#gcc -c src/kernel/gpt.c -o obj/kgpt.o -ffreestanding -nostdlib -m32
gcc -c src/kernel/iso9660.c -o obj/kiso9660.o -ffreestanding -nostdlib -m32 gcc -c src/kernel/iso9660.c -o obj/kiso9660.o -ffreestanding -nostdlib -m32
gcc -c src/kernel/keyb.c -o obj/kkeybc.o -ffreestanding -nostdlib -m32 gcc -c src/kernel/keyb.c -o obj/kkeybc.o -ffreestanding -nostdlib -m32
gcc -c src/kernel/main.c -o obj/kmain.o -ffreestanding -nostdlib -m32 gcc -c src/kernel/main.c -o obj/kmain.o -ffreestanding -nostdlib -m32
@ -27,8 +27,8 @@ kernel: obj out
gcc -c src/kernel/proc.c -o obj/kproc.o -ffreestanding -nostdlib -m32 gcc -c src/kernel/proc.c -o obj/kproc.o -ffreestanding -nostdlib -m32
gcc -c src/kernel/vga.c -o obj/kvga.o -ffreestanding -nostdlib -m32 gcc -c src/kernel/vga.c -o obj/kvga.o -ffreestanding -nostdlib -m32
ld obj/kata.o obj/kfloppy.o obj/kide.o obj/kkeyba.o obj/kserial.o \ ld obj/kata.o obj/kfloppy.o obj/kide.o obj/kkeyba.o obj/kserial.o \
obj/kstub.o obj/kdiskio.o obj/kfiles.o obj/kiso9660.o obj/kkeybc.o \ obj/kstub.o obj/kdiskio.o obj/kfat12.o obj/kfiles.o obj/kiso9660.o \
obj/kmain.o obj/kmem.o obj/kproc.o obj/kvga.o \ obj/kkeybc.o obj/kmain.o obj/kmem.o obj/kproc.o obj/kvga.o \
-o out/kernel.elf -T src/kernel/link.ld -s --orphan-handling=discard -melf_i386 -o out/kernel.elf -T src/kernel/link.ld -s --orphan-handling=discard -melf_i386
clean: clean:

View file

@ -23,7 +23,7 @@ ata_read_sectors:;uint32_t ata_read_sectors(uint8_t number, uint32_t start, uint
push ebp push ebp
mov ebp, esp mov ebp, esp
;TODO xor eax, eax;TODO
leave leave
ret ret
@ -32,7 +32,7 @@ ata_write_sectors:;uint32_t ata_write_sectors(uint8_t number, uint32_t start, ui
push ebp push ebp
mov ebp, esp mov ebp, esp
;TODO xor eax, eax;TODO
leave leave
ret ret

58
src/kernel/fat12.c Normal file
View file

@ -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;
}

48
src/kernel/fat12.h Normal file
View file

@ -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 <stdint.h>
#include <stdbool.h>
#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

View file

@ -23,7 +23,7 @@ floppy_read_sectors:;uint32_t floppy_read_sectors(uint8_t number, uint32_t start
push ebp push ebp
mov ebp, esp mov ebp, esp
;TODO xor eax, eax;TODO
leave leave
ret ret
@ -32,7 +32,7 @@ floppy_write_sectors:;uint32_t floppy_write_sectors(uint8_t number, uint32_t sta
push ebp push ebp
mov ebp, esp mov ebp, esp
;TODO xor eax, eax;TODO
leave leave
ret ret

View file

@ -23,7 +23,7 @@ ide_read_sectors:;uint32_t ide_read_sectors(uint8_t number, uint32_t start, uint
push ebp push ebp
mov ebp, esp mov ebp, esp
;TODO xor eax, eax;TODO
leave leave
ret ret
@ -32,7 +32,7 @@ ide_write_sectors:;uint32_t ide_write_sectors(uint8_t number, uint32_t start, ui
push ebp push ebp
mov ebp, esp mov ebp, esp
;TODO xor eax, eax;TODO
leave leave
ret ret