small changes and optimization

git-svn-id: svn://kolibrios.org@1369 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Alexey Teplov ( 2010-01-08 12:39:50 +00:00
parent dd75d94380
commit abfe37adc4
6 changed files with 230 additions and 346 deletions

View File

@ -428,16 +428,6 @@ sys_resize_app_memory:
.no_application_mem_resize: .no_application_mem_resize:
ret ret
sys_threads:
; eax=1 create thread
;
; ebx=thread start
; ecx=thread stack value
;
; on return : eax = pid
jmp new_sys_threads
iglobal iglobal
; process_terminating db 'K : Process - terminating',13,10,0 ; process_terminating db 'K : Process - terminating',13,10,0
; process_terminated db 'K : Process - done',13,10,0 ; process_terminated db 'K : Process - done',13,10,0

View File

@ -126,35 +126,35 @@ iglobal
dd 0 dd 0
dd 0 dd 0
dd 0 dd 0
dd 0 ; 24-PlayCdTrack,StopCd and GetCdPlaylist
dd 0 ; 25
dd 0 ; 26
dd 0
dd 0 ;
dd 0
dd 0 ; 30-Get/SetCurrentDirectory
dd 0 dd 0
dd 0 dd 0
dd 0 dd 0
dd 0 dd 0
dd 0 dd 0
dd 0 dd 0
dd 0 ; 37-GetMousePosition_ScreenRelative,.
dd 0 ; 38-DrawLine
dd 0 ; 39-GetBackgroundSize,ReadBgrData,.
dd 0 dd 0
dd 0 dd 0
dd 0 dd 0
dd 0 ; 43-SendDeviceData
dd 0 dd 0
dd 0 dd 0
dd 0 ; 46-ReservePortArea and FreePortArea dd 0
dd display_number ; 47-WriteNum dd 0
dd 0 ; 48-SetRedrawType and SetButtonType dd 0
dd 0 ; 49-Advanced Power Management (APM) dd 0
dd syscall_set_window_shape ; 50-Window shape & scale dd 0
dd syscall_threads ; 51-Threads dd 0
dd stack_driver_stat ; 52-Stack driver status dd 0
dd 0
dd 0
dd 0
dd 0
dd 0
dd 0
dd 0
dd 0
dd 0
dd 0
dd 0
dd socket ; 53-Socket interface dd socket ; 53-Socket interface
dd 0 dd 0
dd sound_interface ; 55-Sound interface dd sound_interface ; 55-Sound interface
@ -166,14 +166,13 @@ iglobal
dd sys_gs ; 61-Direct graphics access dd sys_gs ; 61-Direct graphics access
dd sys_pci ; 62-PCI functions dd sys_pci ; 62-PCI functions
dd sys_msg_board ; 63-System message board dd sys_msg_board ; 63-System message board
dd 0 ; 64-Resize application memory usage dd 0
dd syscall_putimage_palette; 65-PutImagePalette dd syscall_putimage_palette; 65-PutImagePalette
dd sys_process_def ; 66-Process definitions - keyboard dd sys_process_def ; 66-Process definitions - keyboard
dd sys_window_move ; 67-Window move or resize dd sys_window_move ; 67-Window move or resize
dd 0 ; 68-Some internal services dd 0
dd 0 ; 69-Debug dd 0
dd file_system_lfn ; 70-Common file system interface, version 2 dd file_system_lfn ; 70-Common file system interface, version 2
; dd 0 ; 71-Window settings
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; NEW SYSTEM FUNCTIONS TABLE ;; ;; NEW SYSTEM FUNCTIONS TABLE ;;
@ -228,12 +227,12 @@ iglobal
dd sys_programirq ; 44-ProgramIrqs dd sys_programirq ; 44-ProgramIrqs
dd reserve_free_irq ; 45-ReserveIrq and FreeIrq dd reserve_free_irq ; 45-ReserveIrq and FreeIrq
dd syscall_reserveportarea ; 46-ReservePortArea and FreePortArea dd syscall_reserveportarea ; 46-ReservePortArea and FreePortArea
dd cross_order ; 47-WriteNum dd display_number ; 47-WriteNum
dd syscall_display_settings ; 48-SetRedrawType and SetButtonType dd syscall_display_settings ; 48-SetRedrawType and SetButtonType
dd sys_apm ; 49-Advanced Power Management (APM) dd sys_apm ; 49-Advanced Power Management (APM)
dd cross_order ; 50-Window shape & scale dd syscall_set_window_shape ; 50-Window shape & scale
dd cross_order ; 51-Threads dd syscall_threads ; 51-Threads
dd cross_order ; 52-Stack driver status dd stack_driver_stat ; 52-Stack driver status
dd cross_order ; 53-Socket interface dd cross_order ; 53-Socket interface
dd undefined_syscall ; 54-reserved dd undefined_syscall ; 54-reserved
dd cross_order ; 55-Sound interface dd cross_order ; 55-Sound interface

View File

@ -864,15 +864,14 @@ proc new_sys_threads
app_mem dd ? ;0x10 app_mem dd ? ;0x10
endl endl
cmp eax,1 cmp ebx,1
jne .failed ;other subfunctions jne .failed ;other subfunctions
xor eax,eax xor eax,eax
mov [app_eip], ecx
mov [app_cmdline], eax mov [app_cmdline], eax
mov [app_esp], edx
mov [app_path], eax mov [app_path], eax
mov [app_eip], ebx
mov [app_esp], ecx
;mov esi,new_process_loading ;mov esi,new_process_loading
;call sys_msg_board_str ;call sys_msg_board_str
.wait_lock: .wait_lock:

View File

@ -246,23 +246,23 @@ align 4
syscall_set_window_shape: ;///// system function 50 /////////////////////////// syscall_set_window_shape: ;///// system function 50 ///////////////////////////
;------------------------------------------------------------------------------ ;------------------------------------------------------------------------------
;; Set window shape address: ;; Set window shape address:
;> eax = 0 ;> ebx = 0
;> ebx = shape data address ;> ecx = shape data address
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
;; Set window shape scale: ;; Set window shape scale:
;> eax = 1 ;> ebx = 1
;> ebx = scale power (resulting scale is 2^ebx) ;> ecx = scale power (resulting scale is 2^ebx)
;------------------------------------------------------------------------------ ;------------------------------------------------------------------------------
mov edi, [current_slot] mov edi, [current_slot]
test eax, eax test ebx, ebx
jne .shape_scale jne .shape_scale
mov [edi + APPDATA.wnd_shape], ebx mov [edi + APPDATA.wnd_shape], ecx
.shape_scale: .shape_scale:
dec eax dec ebx
jnz .exit jnz .exit
mov [edi + APPDATA.wnd_shape_scale], ebx mov [edi + APPDATA.wnd_shape_scale], ecx
.exit: .exit:
ret ret

View File

@ -1245,7 +1245,12 @@ sys_outport:
ret ret
display_number: display_number:
;It is not optimization
mov eax, ebx
mov ebx, ecx
mov ecx, edx
mov edx, esi
mov esi, edi
; eax = print type, al=0 -> ebx is number ; eax = print type, al=0 -> ebx is number
; al=1 -> ebx is pointer ; al=1 -> ebx is pointer
; ah=0 -> display decimal ; ah=0 -> display decimal
@ -5371,9 +5376,16 @@ syscall_reserveportarea: ; ReservePortArea and FreePortArea
align 4 align 4
syscall_threads: ; CreateThreads syscall_threads: ; CreateThreads
; eax=1 create thread
;
; ebx=thread start
; ecx=thread stack value
;
; on return : eax = pid
call sys_threads call new_sys_threads
mov [esp+36],eax
mov [esp+32],eax
ret ret
align 4 align 4
@ -5385,7 +5397,7 @@ stack_driver_stat:
; mov [check_idle_semaphore],5 ; enable these for zero delay ; mov [check_idle_semaphore],5 ; enable these for zero delay
; call change_task ; between sent packet ; call change_task ; between sent packet
mov [esp+36],eax mov [esp+32],eax
ret ret
align 4 align 4

View File

@ -361,185 +361,141 @@ cs_exit:
; It provides application access to the network interface layer ; It provides application access to the network interface layer
; ;
;*************************************************************************** ;***************************************************************************
iglobal
align 4
f52call:
dd app_stack_handler.00
dd app_stack_handler.01
dd app_stack_handler.02
dd app_stack_handler.03
dd app_stack_handler.fail ;04
dd app_stack_handler.fail ;05
dd stack_insert_packet ;app_stack_handler.06
dd app_stack_handler.fail ;07
dd stack_get_packet ;app_stack_handler.08
dd app_stack_handler.09
dd app_stack_handler.10
dd app_stack_handler.11
dd app_stack_handler.12
dd app_stack_handler.13
dd app_stack_handler.14
dd app_stack_handler.15
endg
app_stack_handler: app_stack_handler:
cmp eax, 0 ;in ebx,ecx
jnz not0 ;out eax
; Read the configuration word cmp ebx,15
mov eax, [stack_config] ja .fail ;if more than 15 then exit
ret
not0: jmp dword [f52call+ebx*4]
cmp eax, 1
jnz not1
; read the IP address
mov eax, [stack_ip]
ret
not1: .00:
cmp eax, 2 ; Read the configuration word
jnz not2 mov eax, [stack_config]
ret
; write the configuration word .01:
mov [stack_config], ebx ; read the IP address
mov eax, [stack_ip]
ret
; <Slip shouldn't be active anyway - thats an operational issue.> .02:
; If ethernet now enabled, probe for the card, reset it and empty ; write the configuration word
; the packet buffer mov [stack_config], ecx
; If all successfull, enable the card.
; If ethernet now disabled, set it as disabled. Should really
; empty the tcpip data area too.
; ethernet interface is '3' in ls 7 bits ; <Slip shouldn't be active anyway - thats an operational issue.>
and bl, 0x7f ; If ethernet now enabled, probe for the card, reset it and empty
cmp bl, 3 ; the packet buffer
; If all successfull, enable the card.
; If ethernet now disabled, set it as disabled. Should really
; empty the tcpip data area too.
je ash_eth_enable ; ethernet interface is '3' in ls 7 bits
; Ethernet isn't enabled, so make sure that the card is disabled and cl, 0x7f
mov [ethernet_active], byte 0 cmp cl, 3
je ash_eth_enable
ret ; Ethernet isn't enabled, so make sure that the card is disabled
mov [ethernet_active], byte 0
ash_eth_enable: ret
; Probe for the card. This will reset it and enable the interface
; if found
call eth_probe
cmp eax, 0
je ash_eth_done ; Abort if no hardware found
mov [ethernet_active], byte 1
ash_eth_done:
ret
not2:
cmp eax, 3
jnz not3
; write the IP Address
mov [stack_ip], ebx
ret
.03:
; write the IP Address
mov [stack_ip], ecx
ret
;old functions was deleted ;old functions was deleted
;.06:
; Insert an IP packet into the stacks received packet queue
; call stack_insert_packet
; ret
not3: ; Test for any packets queued for transmission over the network
cmp eax, 6
jnz not6
; Insert an IP packet into the stacks received packet queue ;.08:
call stack_insert_packet ; call stack_get_packet
ret ; Extract a packet queued for transmission by the network
; ret
not6: .09:
cmp eax, 7 ; read the gateway IP address
jnz not7 mov eax, [gateway_ip]
ret
; Test for any packets queued for transmission over the network .10:
; read the subnet mask
mov eax, [subnet_mask]
ret
.11:
; write the gateway IP Address
mov [gateway_ip], ecx
ret
not7: .12:
cmp eax, 8 ; write the subnet mask
jnz not8 mov [subnet_mask], ecx
ret
call stack_get_packet .13:
; Extract a packet queued for transmission by the network ; read the dns
ret mov eax, [dns_ip]
ret
not8: .14:
cmp eax, 9 ; write the dns IP Address
jnz not9 mov [dns_ip], ecx
ret
; read the gateway IP address
mov eax, [gateway_ip]
ret
not9:
cmp eax, 10
jnz not10
; read the subnet mask
mov eax, [subnet_mask]
ret
not10:
cmp eax, 11
jnz not11
; write the gateway IP Address
mov [gateway_ip], ebx
ret
not11:
cmp eax, 12
jnz not12
; write the subnet mask
mov [subnet_mask], ebx
not12:
cmp eax, 13
jnz not13
; read the dns
mov eax, [dns_ip]
ret
not13:
cmp eax, 14
jnz not14
; write the dns IP Address
mov [dns_ip], ebx
ret
.15:
;<added by Frank Sommer> ;<added by Frank Sommer>
not14: ; in ecx we need 4 to read the last 2 bytes
cmp eax, 15 ; or we need 0 to read the first 4 bytes
jnz not15 cmp ecx,4
ja .param_error
; in ebx we need 4 to read the last 2 bytes ; read MAC, returned (in mirrored byte order) in eax
cmp ebx, dword 4 mov eax, [node_addr + ecx]
je read
; or we need 0 to read the first 4 bytes
cmp ebx, dword 0
jnz param_error
; read MAC, returned (in mirrored byte order) in eax
read:
mov eax, [node_addr + ebx]
jmp @f
param_error:
mov eax, -1 ; params not accepted
@@:
ret ret
.param_error:
or eax, -1 ; params not accepted
ret
.16:
; 0 -> arp_probe ; 0 -> arp_probe
; 1 -> arp_announce ; 1 -> arp_announce
; 2 -> arp_responce (not supported yet) ; 2 -> arp_responce (not supported yet)
test ecx,ecx
not15: ; ARP stuff
cmp eax, 16
jnz not16
cmp ebx, 0
je a_probe je a_probe
cmp ebx, 1 dec ebx
je a_ann ; arp announce jz a_ann ; arp announce
.fail:
or eax, -1
ret
; cmp ebx,2 ; cmp ebx,2
; jne a_resp ; arp response ; jne a_resp ; arp response
jmp param15_error
; arp probe, sender IP must be set to 0.0.0.0, target IP is set to address being probed ; arp probe, sender IP must be set to 0.0.0.0, target IP is set to address being probed
; ecx: pointer to target MAC, MAC should set to 0 by application ; ecx: pointer to target MAC, MAC should set to 0 by application
; edx: target IP ; edx: target IP
@ -547,12 +503,12 @@ a_probe:
push dword [stack_ip] push dword [stack_ip]
mov edx, [stack_ip] mov edx, [stack_ip]
mov [stack_ip], dword 0 and [stack_ip], dword 0
mov esi, ecx ; pointer to target MAC address mov esi, ecx ; pointer to target MAC address
call arp_request call arp_request
pop dword [stack_ip] pop dword [stack_ip]
jmp @f ret
; arp announce, sender IP must be set to target IP ; arp announce, sender IP must be set to target IP
; ecx: pointer to target MAC ; ecx: pointer to target MAC
@ -560,33 +516,30 @@ a_ann:
mov edx, [stack_ip] mov edx, [stack_ip]
mov esi, ecx ; pointer to target MAC address mov esi, ecx ; pointer to target MAC address
call arp_request call arp_request
jmp @f
param15_error:
mov eax, -1
@@:
ret ret
.17:
;</added by Frank Sommer> ;</added by Frank Sommer>
; modified by [smb] ; modified by [smb]
;<added by Johnny_B> ;<added by Johnny_B>
; ARPTable manager interface ; ARPTable manager interface
not16:
cmp eax, 17
jnz stack_driver_end
;see "proc arp_table_manager" for more details ;see "proc arp_table_manager" for more details
stdcall arp_table_manager,ebx,ecx,edx ;Opcode,Index,Extra stdcall arp_table_manager,ecx,edx,esi ;Opcode,Index,Extra
ret ret
;</added by Johnny_B> ;</added by Johnny_B>
stack_driver_end: ;;;;;;;;;;;;;;;;;;;;;;;;;;;;
ret ash_eth_enable:
; Probe for the card. This will reset it and enable the interface
; if found
call eth_probe
test eax,eax
jz ash_eth_done ; Abort if no hardware found
mov [ethernet_active], byte 1
ash_eth_done:
ret
;*************************************************************************** ;***************************************************************************
; Function ; Function
; app_socket_handler ; app_socket_handler
@ -597,139 +550,46 @@ stack_driver_end:
; such as opening sockets ; such as opening sockets
; ;
;*************************************************************************** ;***************************************************************************
iglobal
align 4
f53call:
dd socket_open ;00
dd socket_close ;01
dd socket_poll ;02
dd socket_read ;03
dd socket_write ;04
dd socket_open_tcp ;05
dd socket_status ;06
dd socket_write_tcp ;07
dd socket_close_tcp ;08
dd is_localport_unused ;09
dd app_socket_handler.10
dd socket_read_packet ;11
endg
app_socket_handler: app_socket_handler:
cmp eax, 0 ;in ebx,ecx,edx,wsi
jnz nots0 ;out eax
cmp eax,255
je stack_internal_status
call socket_open cmp eax,11
ret ja .fail ;if more than 15 then exit
nots0: jmp dword [f53call+eax*4]
cmp eax, 1
jnz nots1
call socket_close
ret
nots1:
cmp eax, 2
jnz nots2
call socket_poll
ret
nots2:
cmp eax, 3
jnz nots3
call socket_read
ret
nots3:
cmp eax, 4
jnz nots4
call socket_write
ret
nots4:
cmp eax, 5
jnz nots5
call socket_open_tcp
ret
nots5:
cmp eax, 6
jnz nots6
call socket_status
ret
nots6:
cmp eax, 7
jnz nots7
call socket_write_tcp
ret
nots7:
cmp eax, 8
jnz nots8
call socket_close_tcp
ret
nots8:
cmp eax, 9
jnz nots9
call is_localport_unused
ret
nots9:
cmp eax, 10
jnz nots10
mov eax,dword[drvr_cable]
test eax,eax
jnz @f ; if function is not implented, return -1
mov al,-1
ret
@@:
call dword[drvr_cable]
ret
nots10:
cmp eax, 11
jnz nots11
call socket_read_packet
ret
nots11:
cmp eax, 254
jnz notdump
ret
notdump:
cmp eax, 255
jnz notsdebug
; This sub function allows access to debugging information on the stack
; ebx holds the request:
; 100 : return length of empty queue
; 101 : return length of IPOUT QUEUE
; 102 : return length of IPIN QUEUE
; 103 : return length of NET1OUT QUEUE
; 200 : return # of ARP entries
; 201 : return size of ARP table ( max # entries )
; 202 : select ARP table entry #
; 203 : return IP of selected table entry
; 204 : return High 4 bytes of MAC address of selected table entry
; 205 : return low 2 bytes of MAC address of selected table entry
; 206 : return status word of selected table entry
; 207 : return Time to live of selected table entry
; 2 : return number of IP packets received
; 3 : return number of packets transmitted
; 4 : return number of received packets dumped
; 5 : return number of arp packets received
; 6 : return status of packet driver
; ( 0 == not active, FFFFFFFF = successful )
call stack_internal_status
ret
notsdebug:
; Invalid Option
ret
.10:
mov eax,dword[drvr_cable]
test eax,eax
jnz @f ; if function is not implented, return -1
or al,-1
ret
@@:
jmp dword[drvr_cable]
.fail:
or eax,-1
ret
uglobal uglobal
ARPTmp: ARPTmp:
times 14 db 0 times 14 db 0
@ -747,6 +607,30 @@ endg
; return requested data in eax ; return requested data in eax
; ;
;*************************************************************************** ;***************************************************************************
; This sub function allows access to debugging information on the stack
; ecx holds the request:
; 100 : return length of empty queue
; 101 : return length of IPOUT QUEUE
; 102 : return length of IPIN QUEUE
; 103 : return length of NET1OUT QUEUE
; 200 : return # of ARP entries
; 201 : return size of ARP table ( max # entries )
; 202 : select ARP table entry #
; 203 : return IP of selected table entry
; 204 : return High 4 bytes of MAC address of selected table entry
; 205 : return low 2 bytes of MAC address of selected table entry
; 206 : return status word of selected table entry
; 207 : return Time to live of selected table entry
; 2 : return number of IP packets received
; 3 : return number of packets transmitted
; 4 : return number of received packets dumped
; 5 : return number of arp packets received
; 6 : return status of packet driver
; ( 0 == not active, FFFFFFFF = successful )
stack_internal_status: stack_internal_status:
cmp ebx, 100 cmp ebx, 100
jnz notsis100 jnz notsis100
@ -762,7 +646,7 @@ notsis100:
; 101 : return length of IPOUT QUEUE ; 101 : return length of IPOUT QUEUE
mov ebx, IPOUT_QUEUE mov ebx, IPOUT_QUEUE
call queueSize call queueSize
ret ret
notsis101: notsis101: