From e633ea8eacfd0116c8dc5d76078803509df4c107 Mon Sep 17 00:00:00 2001 From: Ivan Baravy Date: Sat, 22 Feb 2025 19:04:12 +0000 Subject: [PATCH] Fix extended_primary_loader for native CD boot When the extended primary loader for CD was introduced in 2008-2009 it used to load a relatively small secondary loader. Later the secondary loader was integrated into the kernel, hence the primary loader had to load the kernel which is 100kB+. The EDD BIOS specification allows to read less than 0x80 sectors at once using Int 0x13 0x42 service. For a 512-byte sector this is less than 0x10000 bytes which is a 64kB limit. The same limit of 64kB is reached on a CD with only 0x20 sectors, because the sector size is 2048 bytes here. This commit changes the maximum number of sectors that can be read by the loader at once from 0x7f to 0x20, i.e. reading is done in 64kB blocks now. --- .../extended_primary_loader/cdfs/bootsect.asm | 7 ++++--- .../extended_primary_loader/cdfs/bootsect.txt | 10 ++++++---- 2 files changed, 10 insertions(+), 7 deletions(-) diff --git a/kernel/trunk/bootloader/extended_primary_loader/cdfs/bootsect.asm b/kernel/trunk/bootloader/extended_primary_loader/cdfs/bootsect.asm index 4694e005e..34137345f 100644 --- a/kernel/trunk/bootloader/extended_primary_loader/cdfs/bootsect.asm +++ b/kernel/trunk/bootloader/extended_primary_loader/cdfs/bootsect.asm @@ -170,9 +170,10 @@ read_sectors: do_read_sectors: push ax push cx - cmp cx, 0x7F +; read no more than 64kB at once, i.e. 0x20 sectors + cmp cx, 0x20 jbe @f - mov cx, 0x7F + mov cx, 0x20 @@: ; create disk address packet on the stack ; dq starting LBA @@ -182,7 +183,7 @@ do_read_sectors: ; dd buffer push es push bx -; dw number of blocks to transfer (no more than 0x7F) +; dw number of blocks to transfer (no more than 0x20) push cx ; dw packet size in bytes push 10h diff --git a/kernel/trunk/bootloader/extended_primary_loader/cdfs/bootsect.txt b/kernel/trunk/bootloader/extended_primary_loader/cdfs/bootsect.txt index 7fedad177..426c11d2a 100644 --- a/kernel/trunk/bootloader/extended_primary_loader/cdfs/bootsect.txt +++ b/kernel/trunk/bootloader/extended_primary_loader/cdfs/bootsect.txt @@ -156,10 +156,12 @@ es:bx указывает на конец буфера, в который были прочитаны данные если произошла ошибка чтения, флаг CF установлен 1. В цикле (шаги 2-4) читает секторы, следит за тем, чтобы на каждой итерации - число читаемых секторов не превосходило 7Fh (требование спецификации - EDD BIOS). -2. Если число секторов для чтения больше 7Fh, уменьшает его (для текущей - итерации) до 7Fh. + число читаемых секторов не превосходило 20h. Требование спецификации + EDD BIOS не более 7Fh секторов за раз, что почти 64кБ для 512-байтного + сектора. Однако при размере сектора 2048 байт размер буфера в 64кБ + достигается уже при 20h секторах. +2. Если число секторов для чтения больше 20h, уменьшает его (для текущей + итерации) до 20h. 3. Формирует в стеке пакет для int 13h (кладёт все нужные данные командами push, причём в обратном порядке: стек - структура LIFO, и данные в стеке хранятся в обратном порядке по отношению к тому, как их туда