git-svn-id: svn://kolibrios.org@1516 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Evgeny Grechnikov (Diamond) 2010-07-14 17:17:52 +00:00
parent e8c7f3f1f6
commit 0d2b81dd89
4 changed files with 82 additions and 21 deletions

View File

@ -1423,9 +1423,9 @@ proc set_mtrr stdcall, base:dword,size:dword,mem_type:dword
mov ebx, [size]
dec ebx
mov eax, 0xFFFFFFFF
mov edx, 0x0000000F
; mov edx, 0x0000000F
sub eax, ebx
sbb edx, 0
; sbb edx, 0
or eax, 0x800
inc ecx
wrmsr

View File

@ -246,6 +246,7 @@ iglobal
dd file_system_lfn ; 70-Common file system interface, version 2
dd syscall_window_settings ; 71-Window settings
dd sys_sendwindowmsg ; 72-Send window message
dd ntfs_read_file_record_sysfn
times 255 - ( ($-servetable2) /4 ) dd undefined_syscall
dd sys_end ; -1-end application

View File

@ -740,6 +740,7 @@ ntfs_read_attr:
and eax, 0x1FF
mov [ntfs_cur_tail], eax
@@:
DEBUGF 1,'tail=%x, size=%x\n',[ntfs_cur_tail],[ntfs_cur_size]
cmp [ntfs_cur_size], 0
jz .okret
mov eax, [ntfs_cur_offs]
@ -774,6 +775,7 @@ ntfs_read_attr:
mov ecx, [ntfs_cur_size]
@@:
mov ebx, [ntfs_cur_buf]
DEBUGF 1,'eax=%x,ecx=%x,ebx=%x,offs=%x,size=%x\n',eax,ecx,ebx,[ntfs_cur_offs],[ntfs_cur_size]
@@:
call hd_read
cmp [hd_error], 0
@ -785,6 +787,7 @@ ntfs_read_attr:
dec [ntfs_cur_size]
inc [ntfs_cur_offs]
loop @b
DEBUGF 1,'cur_size=%x\n',[ntfs_cur_size]
pop ecx
xor eax, eax
xor edx, edx
@ -874,6 +877,16 @@ ntfs_read_file_record:
xor eax, eax
ret
ntfs_read_file_record_sysfn:
mov eax, ebx
call ntfs_read_file_record
mov [esp+20h], eax
mov edi, ecx
mov esi, [ntfs_data.frs_buffer]
mov ecx, 0x400/4
rep movsd
ret
ntfs_restore_usa_frs:
mov eax, [ntfs_data.frs_size]
ntfs_restore_usa:
@ -968,11 +981,15 @@ ntfs_find_lfn:
mov [ntfs_cur_buf], eax
call ntfs_read_attr
jnc @f
DEBUGF 1,'ntfs_find_lfn: $INDEX_ROOT not found in %s\n',esi
.ret:
ret
@@:
cmp [ntfs_cur_read], 0x20
jc .ret
jnc @f
DEBUGF 1,'ntfs_find_lfn: $INDEX_ROOT too small in %s\n',esi
jmp .ret
@@:
pushad
mov esi, [ntfs_data.cur_index_buf]
mov eax, [esi+14h]
@ -983,6 +1000,7 @@ ntfs_find_lfn:
shr eax, 9
cmp eax, [ntfs_data.cur_index_size]
ja @f
DEBUGF 1,'ntfs_find_lfn: err1 in %s\n',[esp+4]
.stc_ret:
popad
stc
@ -998,6 +1016,7 @@ ntfs_find_lfn:
call kernel_alloc
test eax, eax
jnz @f
DEBUGF 1,'ntfs_find_lfn: err2 in %s\n',[esp+4]
and [ntfs_data.cur_index_size], 0
and [ntfs_data.cur_index_buf], 0
jmp .stc_ret
@ -1015,7 +1034,10 @@ ntfs_find_lfn:
call kernel_alloc
pop ebp esi
test eax, eax
jz .stc_ret
jnz @f
DEBUGF 1,'ntfs_find_lfn: err3 in %s\n',[esp+4]
jmp .stc_ret
@@:
mov edi, eax
mov ecx, [ntfs_data.cur_index_size]
shl ecx, 9-2
@ -1067,7 +1089,10 @@ ntfs_find_lfn:
pop esi
.subnode:
test byte [esi+0Ch], 1
jz .notfound
jnz @f
DEBUGF 1,'ntfs_find_lfn: err4 in %s\n',[esp+4]
jmp .notfound
@@:
movzx eax, word [esi+8]
mov eax, [esi+eax-8]
mul [ntfs_data.sectors_per_cluster]
@ -1081,15 +1106,22 @@ ntfs_find_lfn:
mov eax, ebp
shl eax, 9
cmp [ntfs_cur_read], eax
jnz .notfound
jz @f
DEBUGF 1,'ntfs_find_lfn: err5 in %s\n',[esp+4]
jmp .notfound
@@:
cmp dword [esi], 'INDX'
jnz .notfound
jz @f
DEBUGF 1,'ntfs_find_lfn: err6 in %s\n',[esp+4]
jmp .notfound
@@:
mov ebx, esi
call ntfs_restore_usa
jc .notfound
add esi, 0x18
jmp .scanloop
.notfound:
DEBUGF 1,'ntfs_find_lfn: .notfound in %s\n',[esp+4]
popad
stc
ret
@ -1107,6 +1139,7 @@ ntfs_find_lfn:
pop esi
mov eax, [esi]
mov [ntfs_cur_iRecord], eax
DEBUGF 1,'ntfs_find_lfn: 0x%x is irecord for %s\n',eax,[esp+4]
mov [esp+1Ch], esi
mov [esp+4], edi
popad
@ -1150,6 +1183,7 @@ ntfs_HdRead:
pop eax
ret
.found:
DEBUGF 1,'ntfs_HdRead: irecord is 0x%x\n',[ntfs_cur_iRecord]
mov [ntfs_cur_attr], 0x80 ; $DATA
and [ntfs_cur_offs], 0
and [ntfs_cur_size], 0
@ -1228,11 +1262,14 @@ ntfs_HdRead:
mov eax, ecx
shr eax, 9
mov [ntfs_cur_size], eax
; DEBUGF 1,'ntfs_HdRead: [ntfs_cur_offs]=%x\n',[ntfs_cur_offs]
; DEBUGF 1,'ntfs_HdRead: [ntfs_cur_size]=%x\n',[ntfs_cur_size]
add eax, [ntfs_cur_offs]
push eax
call ntfs_read_attr.continue
pop [ntfs_cur_offs]
mov eax, [ntfs_cur_read]
; DEBUGF 1,'ntfs_HdRead: [ntfs_cur_read]=%x\n',[ntfs_cur_read]
add [esp+10h], eax
mov eax, ecx
and eax, not 0x1FF
@ -1285,6 +1322,7 @@ ntfs_HdReadFolder:
jz .doit
call ntfs_find_lfn
jnc .doit2
DEBUGF 1,'ntfs_HdReadFolder: ntfs_find_lfn failed\n'
.notfound:
or ebx, -1
push ERROR_FILE_NOT_FOUND
@ -1299,7 +1337,10 @@ ntfs_HdReadFolder:
mov [ntfs_cur_size], 1
mov [ntfs_cur_buf], ntfs_bitmap_buf
call ntfs_read_attr
jc .notfound
jnc @f
DEBUGF 1,'ntfs_HdReadFolder: no $STANDARD_INFORMATION\n'
jmp .notfound
@@:
mov [ntfs_cur_attr], 0x90 ; $INDEX_ROOT
and [ntfs_cur_offs], 0
mov eax, [ntfs_data.cur_index_size]
@ -1308,6 +1349,7 @@ ntfs_HdReadFolder:
mov [ntfs_cur_buf], eax
call ntfs_read_attr
jnc .ok
DEBUGF 1,'ntfs_HdReadFolder: no $INDEX_ROOT\n'
cmp [hd_error], 0
jz .notfound
or ebx, -1

View File

@ -4,30 +4,48 @@
CLANG=$1;
# set debug=true to print executed bash commands
debug=true
outDir=bin
outFileName=kernel.mnt
outFile=$outDir/$outFileName
usage()
{
echo "Usage: make.sh [en|ru|ge|et]"
exit 1
echo "Usage: make.sh [en|ru|ge|et]"
exit 1
}
compile()
{
fasm -m 65536 kernel.asm bin/kernel.mnt
rm -f lang.inc
exit 0
if [ -d "$outDir" ]; then
$debug && echo "rm -f $outFile"
rm -f $outFile
else
$debug && echo "mkdir $outDir"
mkdir $outDir
fi
$debug && echo "fasm -m 65536 kernel.asm $outFile"
fasm -m 65536 kernel.asm $outFile
$debug && echo "rm -f lang.inc"
rm -f lang.inc
$debug && echo "exit 0"
exit 0
}
if [ ! $CLANG ] ; then
usage
usage
fi
for i in "en" "ru" "ge" "et"; do
if [ $i == $CLANG ] ; then
echo "lang fix $i" > lang.inc
compile
fi
if [ $i == $CLANG ] ; then
$debug && echo "echo \"lang fix \$i\" > lang.inc"
echo "lang fix $i" > lang.inc
compile
fi
done
usage