Как любой программист в мире хотя бы раз в жизни, я пытаюсь создать свою «революционную», новую и единственную операционную систему. : DСборка - прочитайте следующий сектор виртуального диска
Ну, я использую виртуальный эмулятор (виртуальный ящик виртуальной машины Oracle), для которого я создаю новую операционную систему unknwon с диском vmdk. Мне нравится vmdk, потому что они просто простые файлы, поэтому я могу вставить мой загрузчик поверх первых 512 байт виртуального жесткого диска.
Теперь я пытаюсь прочитать следующий сектор этого виртуального диска, на котором я бы вставлял простое ядро, которое отображало бы сообщение.
У меня есть два вопрос:
Может ли я чтение второго сегмента (первый -512 bytes- занимаемого загрузчика) правильно? КОД:
ReadDisk: mov bx, 0x8000 ; segment mov es, bx mov bx, 0x0000 ; offset mov ah, 0x02 ; read function mov al, 0x01 ; sectors - this might be wrong, trying to read from hd mov ch, 0x00 ; cylinder mov cl, 0x02 ; sector mov dh, 0x00 ; head mov dl, 0x80 ; drive - trying to read from hd int 0x13 ; disk int jc ReadDisk jmp [es:bx] ; buffer
Здесь я получаю сообщение об ошибке, после проверки CF. Однако, если я использую INT 13, 1 для получения последнего сообщения о статусе , AL равно 0, поэтому ошибка не сохраняется.
Я вставляю свое простое ядро в нужное место внутри vmdk? То, что я делаю, вставляет его после 512-го байта файла, первые 512 байт, как я уже сказал, являются загрузчиками. файл будет выглядеть следующим образом:
BE 45 7C E8 16 00 EB FE B4 0E B7 00 B3 07 CD 10 <- First sector C3 AC 08 C0 74 05 E8 EF FF EB F6 C3 B4 00 B2 80 CD 13 BE 5D 7C 72 F5 BB 00 80 8E C3 BB 00 00 B4 02 B0 06 B5 00 B1 01 B6 00 B2 07 CD 13 BE 4E 7C 72 CF 26 FF 27 57 65 6C 63 6F 6D 65 21 00 52 65 61 64 69 6E 67 20 65 72 72 6F 72 21 00 52 65 73 65 74 74 69 6E 67 20 65 72 72 6F 72 21 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 55 AA <- Boot-loader signature B4 0E B0 2E CD 10 EB FE 00 00 00 00 00 00 00 00 <- Start of the second sector 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
Таким образом, это то, как я пытаюсь добавить ядро во второй сектор. Что вы думаете об этом неправильно? Благодаря!
ОБНОВЛЕНИЕ
O.K. Я не получаю никаких ошибок сейчас, но я не вижу, что загруженный код выполняется. Он должен отображать точку в окне:
;--------------------------------------------
; 'load.asm'
; loaded from 'boot.asm'
[org 0x8000]
[bits 16]
;--------------------------------------------
main:
mov ah, 0x0E ; print function
mov al, '.' ; ascii char
int 0x10 ; IO int
jmp $ ; hang
Вы должны действительно отправиться на http://osdev.org/ и попросить его там. И прочитайте некоторые статьи из своей вики. – Griwes