mirror of
https://github.com/limine-bootloader/limine
synced 2025-01-11 15:19:29 +03:00
BIOS disk driver: do not make assumptions about sector size being 512 bytes
This commit is contained in:
parent
a82dc582c7
commit
0e09a8924b
BIN
limine.bin
BIN
limine.bin
Binary file not shown.
@ -8,9 +8,8 @@
|
||||
#include <lib/print.h>
|
||||
#include <mm/pmm.h>
|
||||
|
||||
#define SECTOR_SIZE 512
|
||||
#define BLOCK_SIZE_IN_SECTORS 16
|
||||
#define BLOCK_SIZE (SECTOR_SIZE * BLOCK_SIZE_IN_SECTORS)
|
||||
#define BLOCK_SIZE (sector_size * BLOCK_SIZE_IN_SECTORS)
|
||||
|
||||
#define CACHE_INVALID (~((uint64_t)0))
|
||||
|
||||
@ -27,7 +26,7 @@ struct dap {
|
||||
|
||||
static struct dap *dap = NULL;
|
||||
|
||||
static int cache_block(int drive, uint64_t block) {
|
||||
static int cache_block(int drive, uint64_t block, int sector_size) {
|
||||
if (block == cached_block)
|
||||
return 0;
|
||||
|
||||
@ -55,8 +54,6 @@ static int cache_block(int drive, uint64_t block) {
|
||||
if (r.eflags & EFLAGS_CF) {
|
||||
int ah = (r.eax >> 8) & 0xff;
|
||||
panic("Disk error %x. Drive %x, LBA %x.\n", ah, drive, dap->lba);
|
||||
cached_block = CACHE_INVALID;
|
||||
return ah;
|
||||
}
|
||||
|
||||
cached_block = block;
|
||||
@ -65,12 +62,31 @@ static int cache_block(int drive, uint64_t block) {
|
||||
}
|
||||
|
||||
int read(int drive, void *buffer, uint64_t loc, uint64_t count) {
|
||||
struct rm_regs r = {0};
|
||||
struct bios_drive_params drive_params;
|
||||
|
||||
r.eax = 0x4800;
|
||||
r.edx = drive;
|
||||
r.ds = rm_seg(&drive_params);
|
||||
r.esi = rm_off(&drive_params);
|
||||
|
||||
drive_params.buf_size = sizeof(struct bios_drive_params);
|
||||
|
||||
rm_int(0x13, &r, &r);
|
||||
|
||||
if (r.eflags & EFLAGS_CF) {
|
||||
int ah = (r.eax >> 8) & 0xff;
|
||||
panic("Disk error %x. Drive %x.\n", ah, drive);
|
||||
}
|
||||
|
||||
int sector_size = drive_params.bytes_per_sect;
|
||||
|
||||
uint64_t progress = 0;
|
||||
while (progress < count) {
|
||||
uint64_t block = (loc + progress) / BLOCK_SIZE;
|
||||
|
||||
int ret;
|
||||
if ((ret = cache_block(drive, block)))
|
||||
if ((ret = cache_block(drive, block, sector_size)))
|
||||
return ret;
|
||||
|
||||
uint64_t chunk = count - progress;
|
||||
|
Loading…
Reference in New Issue
Block a user