small optimization

git-svn-id: svn://kolibrios.org@1203 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Alexey Teplov ( 2009-10-11 17:30:06 +00:00
parent f6498da63c
commit 04c674ce1a

View File

@ -20,35 +20,41 @@ STACK_SIZE=1024
include 'lang.inc' include 'lang.inc'
include '..\..\..\macros.inc' include '..\..\..\macros.inc'
display_processes=32 ; number of processes to show display_processes=32 ; number of processes to show
align 4
START: ; start of execution START: ; start of execution
; calculate window position ; calculate window position
; at the center of the screen ; at the center of the screen
call calculate_window_pos call calculate_window_pos
;main loop when process name isn't edited. ;main loop when process name isn't edited.
align 4
red: red:
mov ebp,1 xor ebp,ebp
inc ebp
; mov ebp,1
call draw_window ; redraw all window call draw_window ; redraw all window
align 4
still: still:
mov eax,23 ; wait here for event mov eax,23 ; wait here for event
mov ebx,100 ; 1 sec. mov ebx,200 ; 2 sec.
int 0x40 mcall
cmp eax,1 ; redraw request ? dec eax ; redraw request ?
je red jz red
cmp eax,2 ; key in buffer ? dec eax ; key in buffer ?
je key jz key
cmp eax,3 ; button in buffer ? dec eax ; button in buffer ?
je button jz button
align 4
still_end: still_end:
xor ebp,ebp ; draw new state of processes xor ebp,ebp ; draw new state of processes
call draw_window call draw_window
jmp still jmp still
align 4
key: ; key key: ; key
mov eax,2 mov eax,2
int 0x40 mcall
cmp ah,184 ; PageUp cmp ah,184 ; PageUp
je pgdn je pgdn
cmp ah,183 cmp ah,183
@ -56,11 +62,11 @@ still_end:
cmp ah,27 cmp ah,27
je close ; Esc je close ; Esc
jmp still_end jmp still_end
align 4
button: button:
; get button id ; get button id
mov eax,17 mov eax,17
int 0x40 mcall
shr eax,8 shr eax,8
;id in [10,50] corresponds to terminate buttons. ;id in [10,50] corresponds to terminate buttons.
@ -81,54 +87,57 @@ still_end:
;terminate application ;terminate application
mov eax,18 mov eax,18
mov ebx,2 mov ebx,2
int 0x40 mcall
jmp still_end jmp still_end
align 4
noterm: noterm:
;special buttons ;special buttons
cmp eax,51 dec eax
jz pgdn
cmp eax,52
jz pgup
cmp eax,53
jz read_string
cmp eax,54
jz program_start
cmp eax,55
jz reboot
cmp eax,1
jz close jz close
sub eax,50
jz pgdn
dec eax
jz pgup
dec eax
jz read_string
dec eax
jz program_start
dec eax
jz reboot
jmp still_end jmp still_end
;buttons handlers ;buttons handlers
align 4
pgdn: pgdn:
sub [list_start],display_processes sub [list_start],display_processes
; cmp [list_start],0 ; cmp [list_start],0
jge still_end jge still_end
mov [list_start],0 mov [list_start],0
jmp still_end jmp still_end
align 4
pgup: pgup:
mov eax,[list_add] ;maximal displayed process slot mov eax,[list_add] ;maximal displayed process slot
mov [list_start],eax mov [list_start],eax
jmp still_end jmp still_end
align 4
program_start: program_start:
mov eax,70 mov eax,70
mov ebx,file_start mov ebx,file_start
int 0x40 mcall
jmp still_end jmp still_end
align 4
reboot: reboot:
mov eax,70 mov eax,70
mov ebx,sys_reboot mov ebx,sys_reboot
int 0x40 mcall
;close program if we going to reboot ;close program if we going to reboot
align 4
close: close:
or eax,-1 ; close this program or eax,-1 ; close this program
int 0x40 mcall
align 4
draw_next_process: draw_next_process:
;input: ;input:
; edi - current slot ; edi - current slot
@ -144,7 +153,8 @@ draw_next_process:
mov eax,8 mov eax,8
mov edx,[index] mov edx,[index]
add edx,(1 shl 31)+11 add edx,(1 shl 31)+11
int 0x40 mcall
align 4
.nodelete: .nodelete:
;create terminate process button ;create terminate process button
mov eax,8 mov eax,8
@ -159,8 +169,9 @@ draw_next_process:
test dword [index],1 test dword [index],1
jz .change_color_button jz .change_color_button
mov esi,0x8899aa mov esi,0x8899aa
align 4
.change_color_button: .change_color_button:
int 0x40 mcall
;draw background for proccess information ;draw background for proccess information
mov eax,13 mov eax,13
@ -171,8 +182,9 @@ draw_next_process:
test dword [index],1 test dword [index],1
jz .change_color_info jz .change_color_info
mov edx,0xddffdd mov edx,0xddffdd
align 4
.change_color_info: .change_color_info:
int 0x40 mcall
;nothing else should be done ;nothing else should be done
;if there is no process for this button ;if there is no process for this button
@ -187,6 +199,7 @@ draw_next_process:
mov ebx,process_info_buffer mov ebx,process_info_buffer
;find process loop ;find process loop
align 4
.find_loop: .find_loop:
cmp ecx,256 cmp ecx,256
jge .no_processes jge .no_processes
@ -194,7 +207,7 @@ draw_next_process:
;load process information in buffer ;load process information in buffer
mov eax,9 mov eax,9
; mov ebx,process_info_buffer ; mov ebx,process_info_buffer
int 0x40 mcall
;if current slot greater than maximal slot, ;if current slot greater than maximal slot,
;there is no more proccesses. ;there is no more proccesses.
@ -207,11 +220,11 @@ draw_next_process:
inc ecx inc ecx
jmp .find_loop jmp .find_loop
align 4
.no_processes: .no_processes:
mov edi,-1 mov edi,-1
ret ret
align 4
.process_found: .process_found:
mov edi,ecx mov edi,ecx
mov [list_add],ecx mov [list_add],ecx
@ -220,7 +233,7 @@ draw_next_process:
;for percent calculating ;for percent calculating
mov eax,18 mov eax,18
mov ebx,5 mov ebx,5
int 0x40 mcall
xor edx,edx xor edx,edx
mov ebx,100 mov ebx,100
@ -231,7 +244,7 @@ draw_next_process:
mov ebx,eax mov ebx,eax
mov eax,[process_info_buffer+process_information.cpu_usage] mov eax,[process_info_buffer+process_information.cpu_usage]
; cdq ; cdq
xor edx,edx ; for CPU more 2 GHz - mike.dld xor edx,edx ; for CPU more 2 GHz - mike.dld
div ebx div ebx
mov [cpu_percent],eax mov [cpu_percent],eax
@ -245,11 +258,13 @@ draw_next_process:
jg .no_black jg .no_black
mov [tcolor],eax mov [tcolor],eax
jmp .color_set jmp .color_set
align 4
.no_black: .no_black:
cmp eax,80 cmp eax,80
ja .no_green ja .no_green
mov dword [tcolor],0x107a30 mov dword [tcolor],0x107a30
jmp .color_set jmp .color_set
align 4
.no_green: .no_green:
mov dword [tcolor],0xac0000 mov dword [tcolor],0xac0000
.color_set: .color_set:
@ -262,7 +277,7 @@ draw_next_process:
mov edx,[curposy] mov edx,[curposy]
add edx,20*65536+1 add edx,20*65536+1
mov esi,[tcolor] mov esi,[tcolor]
int 0x40 mcall
;show process name ;show process name
mov eax,4 mov eax,4
@ -271,7 +286,7 @@ draw_next_process:
mov ecx,[tcolor] mov ecx,[tcolor]
mov edx,process_info_buffer.process_name mov edx,process_info_buffer.process_name
mov esi,11 mov esi,11
int 0x40 mcall
;show pid ;show pid
mov eax,47 mov eax,47
@ -280,49 +295,49 @@ draw_next_process:
mov edx,[curposy] mov edx,[curposy]
add edx,130*65536+1 add edx,130*65536+1
mov esi,[tcolor] mov esi,[tcolor]
int 0x40 mcall
;show cpu usage ;show cpu usage
mov ecx,[process_info_buffer.cpu_usage] mov ecx,[process_info_buffer.cpu_usage]
add edx,60*65536 add edx,60*65536
int 0x40 mcall
;show cpu percent ;show cpu percent
mov ebx,3*65536+0*256 mov ebx,3*65536+0*256
mov ecx,[cpu_percent] mov ecx,[cpu_percent]
add edx,60*65536 add edx,60*65536
int 0x40 mcall
;show memory start - obsolete ;show memory start - obsolete
mov ebx,8*65536+1*256 mov ebx,8*65536+1*256
mov ecx,[process_info_buffer.memory_start] mov ecx,[process_info_buffer.memory_start]
add edx,30*65536 add edx,30*65536
int 0x40 mcall
;show memory usage ;show memory usage
mov ecx,[process_info_buffer.used_memory] mov ecx,[process_info_buffer.used_memory]
inc ecx inc ecx
add edx,60*65536 add edx,60*65536
int 0x40 mcall
;show window stack and value ;show window stack and value
mov ecx,dword [process_info_buffer.window_stack_position] mov ecx,dword [process_info_buffer.window_stack_position]
add edx,60*65536 add edx,60*65536
int 0x40 mcall
;show window xy size ;show window xy size
mov ecx,[process_info_buffer.box.left] mov ecx,[process_info_buffer.box.left]
shl ecx,16 shl ecx,16
add ecx,[process_info_buffer.box.top] add ecx,[process_info_buffer.box.top]
add edx,60*65536 add edx,60*65536
int 0x40 mcall
align 4
.ret: .ret:
;build index->slot map for terminating processes. ;build index->slot map for terminating processes.
mov eax,[index] mov eax,[index]
mov [tasklist+4*eax],edi mov [tasklist+4*eax],edi
ret ret
align 4
read_string: read_string:
;clean string ;clean string
@ -338,17 +353,19 @@ read_string:
jmp still1 jmp still1
;read string main loop ;read string main loop
align 4
f11: f11:
;full update ;full update
push edi push edi
mov ebp,1 mov ebp,1
call draw_window call draw_window
pop edi pop edi
align 4
still1: still1:
;wait for message ;wait for message
mov eax,23 mov eax,23
mov ebx,100 mov ebx,100
int 0x40 mcall
cmp eax,1 cmp eax,1
je f11 je f11
;if no message - update process information ;if no message - update process information
@ -359,13 +376,13 @@ read_string:
call draw_window call draw_window
pop edi pop edi
jmp still1 jmp still1
align 4
.message_received: .message_received:
cmp eax,2 cmp eax,2
jne read_done ;buttons message jne read_done ;buttons message
;read char ;read char
mov eax,2 mov eax,2
int 0x40 mcall
shr eax,8 shr eax,8
;if enter pressed, exit read string loop ;if enter pressed, exit read string loop
@ -383,7 +400,7 @@ read_string:
mov [edi],byte 32 mov [edi],byte 32
call print_text call print_text
jmp still1 jmp still1
align 4
nobsl: nobsl:
;write new symbol ;write new symbol
mov [edi],al mov [edi],al
@ -398,6 +415,7 @@ read_string:
jnz still1 jnz still1
;exiting from read string loop ;exiting from read string loop
align 4
read_done: read_done:
;terminate string for file functions ;terminate string for file functions
mov [edi],byte 0 mov [edi],byte 0
@ -405,7 +423,7 @@ read_string:
call print_text call print_text
jmp still jmp still
align 4
print_text: print_text:
;display start_application string ;display start_application string
@ -416,7 +434,7 @@ print_text:
mov ebx,64*65536+62*6 mov ebx,64*65536+62*6
mov ecx,400*65536+12 mov ecx,400*65536+12
mov edx,0xffffcc ;0xeeeeee mov edx,0xffffcc ;0xeeeeee
int 0x40 mcall
;display text ;display text
mov eax,4 mov eax,4
@ -424,20 +442,21 @@ print_text:
mov ebx,70*65536+402 ;text center-aligned mov ebx,70*65536+402 ;text center-aligned
xor ecx,ecx ;black text xor ecx,ecx ;black text
mov esi,60 ;60 symbols mov esi,60 ;60 symbols
int 0x40 mcall
popad popad
ret ret
window_x_size=524 window_x_size=524
window_y_size=430 window_y_size=430
align 4
calculate_window_pos: calculate_window_pos:
;set window size and position for 0 function ;set window size and position for 0 function
;to [winxpos] and [winypos] variables ;to [winxpos] and [winypos] variables
;get screen size ;get screen size
mov eax,14 mov eax,14
int 0x40 mcall
mov ebx,eax mov ebx,eax
;calculate (x_screen-window_x_size)/2 ;calculate (x_screen-window_x_size)/2
@ -463,7 +482,7 @@ calculate_window_pos:
; ******* WINDOW DEFINITIONS AND DRAW ******** ; ******* WINDOW DEFINITIONS AND DRAW ********
; ********************************************* ; *********************************************
align 4
draw_window: draw_window:
;ebp=1 - redraw all ;ebp=1 - redraw all
;ebp=0 - redraw only process information ;ebp=0 - redraw only process information
@ -472,8 +491,10 @@ draw_window:
jz .show_process_info jz .show_process_info
mov eax,12 ; function 12:tell os about windowdraw mov eax,12 ; function 12:tell os about windowdraw
mov ebx,1 ; 1, start of draw ; mov ebx,1 ; 1, start of draw
int 0x40 xor ebx,ebx
inc ebx
mcall
; DRAW WINDOW ; DRAW WINDOW
xor eax,eax ; function 0 : define and draw window xor eax,eax ; function 0 : define and draw window
@ -481,7 +502,7 @@ draw_window:
mov ecx,[winypos] ; [y start] *65536 + [y size] mov ecx,[winypos] ; [y start] *65536 + [y size]
mov edx,0x14ddffdd ;ffffff ; color of work area RRGGBB,8->color mov edx,0x14ddffdd ;ffffff ; color of work area RRGGBB,8->color
mov edi,title ; WINDOW CAPTION; mov edi,title ; WINDOW CAPTION;
int 0x40 mcall
mov eax,4 ; function 4 : write text to window mov eax,4 ; function 4 : write text to window
@ -489,14 +510,14 @@ draw_window:
xor ecx,ecx xor ecx,ecx
mov edx,text mov edx,text
mov esi,text_len mov esi,text_len
mov eax,4 mcall
int 0x40 align 4
.show_process_info: .show_process_info:
mov edi,[list_start] mov edi,[list_start]
mov [list_add],edi mov [list_add],edi
mov dword [index],0 mov dword [index],0
mov dword [curposy],54 mov dword [curposy],54
align 4
.loop_draw: .loop_draw:
call draw_next_process call draw_next_process
inc dword [index] inc dword [index]
@ -513,30 +534,30 @@ draw_window:
mov ebx,30*65536+96 mov ebx,30*65536+96
mov ecx,380*65536+10 mov ecx,380*65536+10
mov edx,51 mov edx,51
int 0x40 mcall
; next page button ; next page button
mov ebx,130*65536+96 mov ebx,130*65536+96
inc edx inc edx
int 0x40 mcall
; ">" (text enter) button ; ">" (text enter) button
mov ebx,30*65536+20 mov ebx,30*65536+20
add ecx,20 shl 16 add ecx,20 shl 16
inc edx inc edx
int 0x40 mcall
; run button ; run button
mov ebx,456*65536+50 mov ebx,456*65536+50
inc edx inc edx
int 0x40 mcall
; reboot button ; reboot button
sub ebx,120*65536 sub ebx,120*65536
add ebx,60 add ebx,60
sub ecx,20 shl 16 sub ecx,20 shl 16
inc edx inc edx
int 0x40 mcall
;"PREV PAGE", "NEXT PAGE" and "REBOOT" labels ;"PREV PAGE", "NEXT PAGE" and "REBOOT" labels
mov eax,4 mov eax,4
@ -544,7 +565,7 @@ draw_window:
xor ecx,ecx xor ecx,ecx
mov edx,tbts mov edx,tbts
mov esi,tbte-tbts mov esi,tbte-tbts
int 0x40 mcall
;">" labels ;">" labels
mov eax,4 mov eax,4
@ -552,7 +573,7 @@ draw_window:
xor ecx,ecx xor ecx,ecx
mov edx,tbts_2 mov edx,tbts_2
mov esi,1 mov esi,1
int 0x40 mcall
;"RUN" labels ;"RUN" labels
mov eax,4 mov eax,4
@ -560,15 +581,15 @@ draw_window:
xor ecx,ecx xor ecx,ecx
mov edx,tbts_3 mov edx,tbts_3
mov esi,tbte_2-tbts_3 mov esi,tbte_2-tbts_3
int 0x40 mcall
;print application name in text box ;print application name in text box
call print_text call print_text
mov eax,12 ; function 12:tell os about windowdraw mov eax,12 ; function 12:tell os about windowdraw
mov ebx,2 ; 2, end of draw mov ebx,2 ; 2, end of draw
int 0x40 mcall
align 4
.end_redraw: .end_redraw:
ret ret