reduce memory size

git-svn-id: svn://kolibrios.org@472 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Sergey Semyonov (Serge) 2007-04-28 12:45:22 +00:00
parent 614fe2dab1
commit 0cca9c7b8c
6 changed files with 37 additions and 40 deletions

View File

@ -6,7 +6,7 @@ $Revision$
;; ;; ;; ;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; Low-level driver for HDD access ; Low-level driver for HDD access
; DMA support by Mario79 ; DMA support by Mario79
;************************************************************************** ;**************************************************************************
@ -33,7 +33,7 @@ hd_read:
push ecx esi edi ; scan cache push ecx esi edi ; scan cache
mov ecx,cache_max ; entries in cache mov ecx,cache_max ; entries in cache
mov esi,OS_BASE+0x600000+8 mov esi,HD_CACHE+8
mov edi,1 mov edi,1
hdreadcache: hdreadcache:
@ -62,7 +62,7 @@ hd_read:
call hd_read_pio call hd_read_pio
@@: @@:
lea esi,[edi*8+OS_BASE+0x600000] lea esi,[edi*8+HD_CACHE]
mov [esi],eax ; sector number mov [esi],eax ; sector number
mov dword [esi+4],1 ; hd read - mark as same as in hd mov dword [esi+4],1 ; hd read - mark as same as in hd
@ -70,7 +70,7 @@ hd_read:
mov esi,edi mov esi,edi
shl esi,9 shl esi,9
add esi,OS_BASE+0x600000+65536 add esi,HD_CACHE+65536
mov edi,ebx mov edi,ebx
mov ecx,512/4 mov ecx,512/4
cld cld
@ -123,7 +123,7 @@ hd_read_pio:
cli cli
push edi push edi
shl edi,9 shl edi,9
add edi,OS_BASE+0x600000+65536 add edi,HD_CACHE+65536
mov ecx,256 mov ecx,256
mov edx,[hdbase] mov edx,[hdbase]
cld cld
@ -161,7 +161,7 @@ hd_write:
; check if the cache already has the sector and overwrite it ; check if the cache already has the sector and overwrite it
mov ecx,cache_max mov ecx,cache_max
mov esi,OS_BASE+0x600000+8 mov esi,HD_CACHE+8
mov edi,1 mov edi,1
hdwritecache: hdwritecache:
@ -186,7 +186,7 @@ hd_write:
cmp [hd_error],0 cmp [hd_error],0
jne hd_write_access_denied jne hd_write_access_denied
lea esi,[edi*8+OS_BASE+0x600000] lea esi,[edi*8+HD_CACHE]
mov [esi],eax ; sector number mov [esi],eax ; sector number
yes_in_cache_write: yes_in_cache_write:
@ -194,7 +194,7 @@ hd_write:
mov dword [esi+4],2 ; write - differs from hd mov dword [esi+4],2 ; write - differs from hd
shl edi,9 shl edi,9
add edi,OS_BASE+0x600000+65536 add edi,HD_CACHE+65536
mov esi,ebx mov esi,ebx
mov ecx,512/4 mov ecx,512/4
cld cld
@ -213,7 +213,7 @@ write_cache:
; write difference ( 2 ) from cache to hd ; write difference ( 2 ) from cache to hd
mov ecx,cache_max mov ecx,cache_max
mov esi,OS_BASE+0x600000+8 mov esi,HD_CACHE+8
mov edi,1 mov edi,1
write_cache_more: write_cache_more:
@ -331,7 +331,7 @@ cache_write_pio:
; cli ; cli
mov esi,edi mov esi,edi
shl esi,9 shl esi,9
add esi,OS_BASE+0x600000+65536 ; esi = from memory position add esi,HD_CACHE+65536 ; esi = from memory position
mov ecx,256 mov ecx,256
mov edx,[hdbase] mov edx,[hdbase]
cld cld
@ -365,7 +365,7 @@ find_empty_slot:
inside_cache: inside_cache:
cmp dword [edi*8+OS_BASE+0x600000+4],2 ; get cache slot info cmp dword [edi*8+HD_CACHE+4],2 ; get cache slot info
jb found_slot ; it's empty or read jb found_slot ; it's empty or read
dec ecx dec ecx
jnz search_for_empty jnz search_for_empty
@ -386,7 +386,7 @@ align 4
clear_hd_cache: clear_hd_cache:
push eax ecx edi push eax ecx edi
mov edi,OS_BASE+0x600000 mov edi, HD_CACHE
mov ecx,16384 mov ecx,16384
xor eax,eax xor eax,eax
cld cld
@ -680,7 +680,7 @@ hd_read_dma:
push ecx esi edi push ecx esi edi
mov esi, eax mov esi, eax
shl edi, 9 shl edi, 9
add edi, OS_BASE+0x610000 add edi, HD_CACHE+0x10000
mov ecx, 512/4 mov ecx, 512/4
cld cld
rep movsd rep movsd
@ -775,7 +775,7 @@ write_cache_chain:
mov eax, IDE_descriptor_table mov eax, IDE_descriptor_table
mov edx, [cache_chain_pos] mov edx, [cache_chain_pos]
shl edx, 9 shl edx, 9
add edx, 0x610000 add edx, DMA_HD_MEM+0x10000
mov [eax], edx mov [eax], edx
movzx edx, [cache_chain_size] movzx edx, [cache_chain_size]
shl edx, 9 shl edx, 9
@ -786,7 +786,7 @@ write_cache_sector:
mov eax, IDE_descriptor_table mov eax, IDE_descriptor_table
mov edx, edi mov edx, edi
shl edx, 9 shl edx, 9
add edx, 0x610000 add edx, DMA_HD_MEM+0x10000
mov [eax], edx mov [eax], edx
mov word [eax+4], 0x200 mov word [eax+4], 0x200
do_write_dma: do_write_dma:

View File

@ -282,27 +282,27 @@ BUTTON_INFO equ (OS_BASE+0x02C0000)
RESERVED_PORTS equ (OS_BASE+0x02D0000) RESERVED_PORTS equ (OS_BASE+0x02D0000)
IRQ_SAVE equ (OS_BASE+0x02E0000) IRQ_SAVE equ (OS_BASE+0x02E0000)
BOOT_VAR equ (OS_BASE+0x02f0000) BOOT_VAR equ (OS_BASE+0x02f0000)
WinMapAddress equ (OS_BASE+0x0460000)
display_data equ (OS_BASE+0x0460000)
HD_CACHE equ (OS_BASE+0x0600000) DMA_HD_MEM equ 0x0300000
HD_CACHE equ (OS_BASE+DMA_HD_MEM)
stack_data_start equ (OS_BASE+0x0700000) stack_data_start equ (OS_BASE+0x0400000)
eth_data_start equ (OS_BASE+0x0700000) eth_data_start equ (OS_BASE+0x0400000)
stack_data equ (OS_BASE+0x0704000) stack_data equ (OS_BASE+0x0404000)
stack_data_end equ (OS_BASE+0x071ffff) stack_data_end equ (OS_BASE+0x041ffff)
VMODE_BASE equ (OS_BASE+0x0760000) resendQ equ (OS_BASE+0x0420000)
resendQ equ (OS_BASE+0x0770000) VMODE_BASE equ (OS_BASE+0x0428000)
skin_data equ (OS_BASE+0x0430000)
draw_data equ (OS_BASE+0x0438000);
skin_data equ (OS_BASE+0x0778000) virtual at (OS_BASE+0x043BF80)
draw_data equ (OS_BASE+0x0780000);
virtual at (OS_BASE+0x0783F80)
tss TSS tss TSS
end virtual end virtual
tmp_page_tab equ 0x0786000; WinMapAddress equ (OS_BASE+0x043F000)
display_data equ (OS_BASE+0x043F000)
tmp_page_tab equ 0x057F000;
HEAP_BASE equ (OS_BASE+tmp_page_tab) HEAP_BASE equ (OS_BASE+tmp_page_tab)
HEAP_MIN_SIZE equ 0x01000000 HEAP_MIN_SIZE equ 0x01000000

View File

@ -16,7 +16,7 @@ use32
macro align value { rb (value-1) - ($ + value-1) mod value } macro align value { rb (value-1) - ($ + value-1) mod value }
org 0x80760000 org OS_BASE+0x0428000
headerstart=$ headerstart=$

View File

@ -3568,9 +3568,6 @@ calculatebackground: ; background
; all black ; all black
; mov [display_data-8],dword 4 ; size x
; mov [display_data-4],dword 2 ; size y
mov edi, [img_background] ;IMG_BACKGROUND ; set background to black mov edi, [img_background] ;IMG_BACKGROUND ; set background to black
xor eax, eax xor eax, eax
mov ecx, 1023 ;0x0fff00 / 4 mov ecx, 1023 ;0x0fff00 / 4
@ -3579,7 +3576,7 @@ calculatebackground: ; background
mov edi,display_data ; set os to use all pixels mov edi,display_data ; set os to use all pixels
mov eax,0x01010101 mov eax,0x01010101
mov ecx,0x15ff00 / 4 mov ecx,1280*1024 / 4
rep stosd rep stosd
mov byte [REDRAW_BACKGROUND], 0 ; do not draw background! mov byte [REDRAW_BACKGROUND], 0 ; do not draw background!

View File

@ -27,7 +27,7 @@ endg
pushd [ScreenWidth] [ScreenHeight] pushd [ScreenWidth] [ScreenHeight]
popd [old_screen_height] [old_screen_width] popd [old_screen_height] [old_screen_width]
or eax,-1 ; If driver is absent then eax does not change or eax,-1 ; If driver is absent then eax does not change
call OS_BASE+0x760100 ; Entry point of video driver call (VMODE_BASE+0x100) ; Entry point of video driver
mov [esp+36],eax mov [esp+36],eax
mov [esp+24],ebx mov [esp+24],ebx
mov [esp+32],ecx mov [esp+32],ecx

View File

@ -9,7 +9,7 @@ $Revision$
; ;
; Load of videomode driver in memory ; Load of videomode driver in memory
; ;
; (driver is located at 0x760000-0x768000 - 32kb) // if this area not occuped anything ; (driver is located at VMODE_BASE - 32kb) // if this area not occuped anything
; ;
; Author: Trans ; Author: Trans
; Date: 19.07.2003 ; Date: 19.07.2003
@ -21,11 +21,11 @@ $Revision$
; LOAD VIDEOMODE DRIVER ; LOAD VIDEOMODE DRIVER
; If vmode.mdr file not found ; If vmode.mdr file not found
or eax,-1 ; Driver ID = -1 (not present in system) or eax,-1 ; Driver ID = -1 (not present in system)
mov [OS_BASE+0x760000],eax ; mov [VMODE_BASE],eax ;
mov [OS_BASE+0x760100],byte 0xC3 ; Instruction RETN - driver loop mov [VMODE_BASE+0x100],byte 0xC3 ; Instruction RETN - driver loop
mov esi, vmode mov esi, vmode
xor ebx, ebx xor ebx, ebx
mov ecx, 0x8000 ; size of memory area for driver mov ecx, 0x8000 ; size of memory area for driver
mov edx, OS_BASE+0x760000 ; Memory position of driver mov edx, VMODE_BASE ; Memory position of driver
call fs_RamdiskRead call fs_RamdiskRead