X-Git-Url: https://git.wirehaze.ovh/BOS.git/blobdiff_plain/0af2320324eedb4577b402e65b1a9df017fac87c..08bb2f475e10fda9373da243b2adcf37cfc6fcca:/kernel/vfs/vfs.asm?ds=sidebyside diff --git a/kernel/vfs/vfs.asm b/kernel/vfs/vfs.asm index ab2f0fa..30d5590 100644 --- a/kernel/vfs/vfs.asm +++ b/kernel/vfs/vfs.asm @@ -6,6 +6,13 @@ ; ; ;----------------------------------------------------------; + + ; file handles need to be dword, where the high + ; word contains drive number, and the low word + ; is the drive/FS specific handle. limits FS to + ; a max of 65535 opened files. should be alright. ;) + + ;---------------------------------------------; ; VFS main structure ; ;---------------------------------------------; @@ -16,6 +23,8 @@ times 255 * sizeof.VFS_storage db 0 ; storage driver structure .filesystem: times 255 * sizeof.VFS_filesystem db 0 ; filesystem driver structure + .mounted db 0 ; 1/0 switch if mounted + .current_path: times 255 db 0 ; drive opened path (increase max path size?) } virtual at 0 ; could use "at esi" instead @@ -68,20 +77,63 @@ sizeof.VFS_filesystem = $-$$ end virtual + ;---------------------------------------------; + ; VFS structure pointer ; + ;---------------------------------------------; + VFS_structure dd 0 -VFS_structure VFS ;--------------------------------------------------------------; ; init_vfs - detect connected drives ; ;--------------------------------------------------------------; ; ; +; out: cf = set if failed ; +; ; +;--------------------------------------------------------------; +init_vfs: + push eax + push ebx + + mov ebx, sizeof.VFS ; allocate structure size + call allocate_mem + cmp eax, 0 + jne .ok + stc ; if error, set carry + mov ebx, 0 + + .ok: + mov dword [VFS_structure], ebx + + pop ebx + pop eax + ret + +;--------------------------------------------------------------; +; add_media - add media driver ; +;--------------------------------------------------------------; +; ; ; in: reg = pointer to VFS drive info ; ; ; ; out: reg = pointer to struct(s) if FAT12 found ; ; ; ;--------------------------------------------------------------; -init_vfs: +add_media: + push eax + ;... + pop eax + ret + +;--------------------------------------------------------------; +; add_fs - add filesystem driver ; +;--------------------------------------------------------------; +; ; +; in: reg = pointer to VFS drive info ; +; ; +; out: reg = pointer to struct(s) if FAT12 found ; +; ; +;--------------------------------------------------------------; +add_fs: push eax - ; a bit more code here + ;... pop eax ret \ No newline at end of file