StupidOS/kernel/dev/at/floppy.inc

281 lines
5.7 KiB
PHP

;; File: floppy.inc
;;
;; Usefull links:
;; - <https://wiki.osdev.org/Floppy_Disk_Controller>
;; - <datasheet at http://www.osdever.net/documents/82077AA_FloppyControllerDatasheet.pdf>
FLOPPY_BDEV_MAJOR = 0
FLOPPY_CDEV_MAJOR = 9
FLOPPY_NONE = 0x0
FLOPPY_360KB = 0x1
FLOPPY_1_2MB = 0x2
FLOPPY_720KB = 0x3
FLOPPY_1_44MB = 0x4
FLOPPY_2_88MB = 0x5
;; TODO: disk geometry for each floppy type
HEADS_PER_CYLINDER = 2
SECTORS_PER_CLUSTER = 1
BYTES_PER_SECTOR = 512
SECTORS_PER_TRACK = 18
TOTAL_SECTORS = 2880
FLOPPY_MAX = 2
;; Constants: Registers
;;
;; FLOPPY_STATUS_REGA - Read-only register
;; FLOPPY_STATUS_REGB - Read-only register
;; FLOPPY_DIGITAL_OUTPUT_REG - XXX
;; FLOPPY_TAPE_DRIVE_REG - XXX
;; FLOPPY_MAIN_STATUS_REG - Read-only register
;; FLOPPY_DATARATE_SELECT_REG - Write-only register
;; FLOPPY_DATA_FIFO - XXX
;; FLOPPY_DIGITAL_INPUT_REG - Read-only register
;; FLOPPY_CONF_CONTROL_REG - Write-only register
FLOPPY_STATUS_REGA = 0x3F0
FLOPPY_STATUS_REGB = 0x3F1
FLOPPY_DIGITAL_OUTPUT_REG = 0x3F2
FLOPPY_TAPE_DRIVE_REG = 0x3F3
FLOPPY_MAIN_STATUS_REG = 0x3F4
FLOPPY_DATARATE_SELECT_REG = 0x3F4
FLOPPY_DATA_FIFO = 0x3F5
FLOPPY_DIGITAL_INPUT_REG = 0x3F7
FLOPPY_CONF_CONTROL_REG = 0x3F7
;; Constants: Floppy commands
;;
;; FLOPPY_READ_TRACK - XXX
;; FLOPPY_SPECIFY - XXX
;; FLOPPY_SENSE_DRIVE_STATUS - XXX
;; FLOPPY_WRITE_DATA - XXX
;; FLOPPY_READ_DATA - XXX
;; FLOPPY_RECALIBRATE - XXX
;; FLOPPY_SENSE_INTERRUPT - XXX
;; FLOPPY_WRITE_DELETED_DATA - XXX
;; FLOPPY_READ_ID - XXX
;; FLOPPY_READ_DELETED_DATA - XXX
;; FLOPPY_FORMAT_TRACK - XXX
;; FLOPPY_DUMPREG - XXX
;; FLOPPY_SEEK - XXX
;; FLOPPY_VERSION - XXX
;; FLOPPY_SCAN_EQUAL - XXX
;; FLOPPY_PERPENDICULAR_MODE - XXX
;; FLOPPY_CONFIGURE - XXX
;; FLOPPY_LOCK - XXX
;; FLOPPY_VERIFY - XXX
;; FLOPPY_SCAN_LOW_OR_EQUAL - XXX
;; FLOPPY_SCAN_HIGH_OR_EQUAL - XXX
FLOPPY_READ_TRACK = 2
FLOPPY_SPECIFY = 3
FLOPPY_SENSE_DRIVE_STATUS = 4
FLOPPY_WRITE_DATA = 5
FLOPPY_READ_DATA = 6
FLOPPY_RECALIBRATE = 7
FLOPPY_SENSE_INTERRUPT = 8
FLOPPY_WRITE_DELETED_DATA = 9
FLOPPY_READ_ID = 10
FLOPPY_READ_DELETED_DATA = 12
FLOPPY_FORMAT_TRACK = 13
FLOPPY_DUMPREG = 14
FLOPPY_SEEK = 15
FLOPPY_VERSION = 16
FLOPPY_SCAN_EQUAL = 17
FLOPPY_PERPENDICULAR_MODE = 18
FLOPPY_CONFIGURE = 19
FLOPPY_LOCK = 20
FLOPPY_VERIFY = 22
FLOPPY_SCAN_LOW_OR_EQUAL = 25
FLOPPY_SCAN_HIGH_OR_EQUAL = 29
;; Constants: DOR bitflag
;;
;; FLOPPY_DOR_MOTD - Set to turn drive 3's motor ON
;; FLOPPY_DOR_MOTC - Set to turn drive 2's motor ON
;; FLOPPY_DOR_MOTB - Set to turn drive 1's motor ON
;; FLOPPY_DOR_MOTA - Set to turn drive 0's motor ON
;; FLOPPY_DOR_IRQ - Set to enable IRQs and DMA
;; FLOPPY_DOR_RESET - Reset on clear
;; FLOPPY_DOR_DSEL - Select drive
FLOPPY_DOR_MOTD = 0x80
FLOPPY_DOR_MOTC = 0x40
FLOPPY_DOR_MOTB = 0x20
FLOPPY_DOR_MOTA = 0x10
FLOPPY_DOR_IRQ = 0x08
FLOPPY_DOR_RESET = 0x04
FLOPPY_DOR_DSEL = 0x03
;; Constants: MSR bitflag
;;
;; FLOPPY_MSR_RQM - XXX
;; FLOPPY_MSR_DIO - XXX
;; FLOPPY_MSR_NDMA - XXX
;; FLOPPY_MSR_CB - XXX
;; FLOPPY_MSR_ACTD - XXX
;; FLOPPY_MSR_ACTC - XXX
;; FLOPPY_MSR_ACTB - XXX
;; FLOPPY_MSR_ACTA - XXX
FLOPPY_MSR_RQM = 0x80
FLOPPY_MSR_DIO = 0x40
FLOPPY_MSR_NDMA = 0x20
FLOPPY_MSR_CB = 0x10
FLOPPY_MSR_ACTD = 0x08
FLOPPY_MSR_ACTC = 0x04
FLOPPY_MSR_ACTB = 0x02
FLOPPY_MSR_ACTA = 0x01
;; Struct: Floppy
;;
;; .active - XXX
;; .motor - XXX
struc Floppy {
.active db ?
.motor db ?
}
DEFN Floppy
floppy_probe:
mov al, CMOS_FLOPPY_TYPE
out CMOS_COMMAND, al
in al, CMOS_DATA
mov ah, al
and al, 0x0F
and ah, 0xF0
or al, al
jz @f
push ax
mov esi, szMsgFloppy1Found
call klog
pop ax
@@:
or ah, ah
jz @f
mov esi, szMsgFloppy0Found
call klog
@@:
ret
floppy_init:
call floppy_probe
ret
;; Function: floppy_lba_to_chs
;; Convert LBA to CHS
;;
;; In:
;; EAX - LBA
;;
;; Out:
;; AL - Cylinder
;; AH - Head
;; CL - Sector
floppy_lba_to_chs:
push ebp
mov ebp, esp
sub esp, 1
; CYL = LBA / (HPC * SPT)
; HEAD = (LBA % (HPC * SPT)) / SPT
; SECT = (LBA % (HPC * SPT)) % SPT + 1
mov edx, eax
shr edx, 16
mov cx, (HEADS_PER_CYLINDER * SECTORS_PER_TRACK)
div cx
mov [ebp-1], al ; cyl
mov ax, dx
mov cl, SECTORS_PER_TRACK
div cl
mov cl, ah
inc cl
xchg al, ah
mov al, [ebp-1]
leave
ret
;; Function: floppy_strategy
;; Do a read or write operation
;;
;; In:
;; EAX - Address of <Buffer>
floppy_strategy:
push ebp
mov esp, ebp
sub esp, 4
mov [ebp-4], eax
push esi
mov esi, szMsgFdStrat
push [eax+Buffer.block]
mov ax, [eax+Buffer.dev]
movzx ecx, al
push ecx
call klog
pop esi
leave
ret
;; Function: floppy_open
;; Open the device for I/O operations
floppy_open:
push ebp
mov ebp, esp
mov eax, [ebp+4]
cmp al, FLOPPY_MAX
jb @f
mov eax, ENXIO
jmp .end
@@:
xor eax, eax
.end:
pop ebp
ret
;; Function: floppy_close
;; Close a device.
floppy_close:
xor eax, eax
ret
floppy_ioctl:
mov eax, ENODEV
ret
floppy_dump:
ret
floppy_psize:
xor eax, eax
ret
floppy_irq:
pusha
mov esi, szMsgFloppyIRQ
popa
iret
szMsgFloppyIRQ db 'Floppy: IRQ', 0
floppy_device:
db 'floppy', 0, 0
dd floppy_init
db FLOPPY_BDEV_MAJOR
db FLOPPY_CDEV_MAJOR
floppy_bdevsw:
dd floppy_open
dd floppy_strategy
dd floppy_ioctl
dd floppy_close
dd floppy_dump
dd floppy_psize
szMsgFloppy0Found db "floppy: fd0 found", 0
szMsgFloppy1Found db "floppy: fd1 found", 0
szMsgFdStrat db "fd%u: strategy (blk: %u)", 0