2005-10-06 17:56:22 +00:00
|
|
|
sys_getevent:
|
|
|
|
|
|
|
|
call get_event_for_app
|
|
|
|
mov [esp+36],eax
|
|
|
|
ret
|
|
|
|
|
|
|
|
|
|
|
|
align 4
|
|
|
|
|
|
|
|
sys_wait_event_timeout:
|
|
|
|
|
2005-11-07 15:50:30 +00:00
|
|
|
mov ebx,[timer_ticks]
|
2005-10-06 17:56:22 +00:00
|
|
|
add ebx,eax
|
2005-11-07 15:50:30 +00:00
|
|
|
cmp ebx,[timer_ticks]
|
2005-10-06 17:56:22 +00:00
|
|
|
jna .swfet2
|
|
|
|
.swfet1:
|
|
|
|
call get_event_for_app
|
|
|
|
test eax,eax
|
|
|
|
jne .eventoccur_time
|
|
|
|
call change_task
|
2005-11-07 15:50:30 +00:00
|
|
|
cmp ebx,[timer_ticks]
|
2005-10-06 17:56:22 +00:00
|
|
|
jg .swfet1
|
|
|
|
.swfet2:
|
|
|
|
xor eax,eax
|
|
|
|
.eventoccur_time:
|
|
|
|
mov [esp+36],eax
|
|
|
|
ret
|
|
|
|
|
|
|
|
|
|
|
|
align 4
|
|
|
|
|
|
|
|
sys_waitforevent:
|
|
|
|
|
|
|
|
call get_event_for_app
|
|
|
|
test eax,eax
|
|
|
|
jne eventoccur
|
|
|
|
newwait:
|
|
|
|
|
2005-11-07 15:50:30 +00:00
|
|
|
mov eax, [0x3010]
|
2006-08-06 10:29:45 +00:00
|
|
|
mov [eax+TASKDATA.state], byte 5
|
2005-10-06 17:56:22 +00:00
|
|
|
call change_task
|
2005-11-07 15:50:30 +00:00
|
|
|
|
|
|
|
mov eax, [event_sched]
|
2005-10-06 17:56:22 +00:00
|
|
|
|
|
|
|
eventoccur:
|
|
|
|
mov [esp+36],eax
|
|
|
|
ret
|
|
|
|
|
|
|
|
|
|
|
|
get_event_for_app:
|
|
|
|
|
|
|
|
pushad
|
|
|
|
|
|
|
|
mov edi,[0x3010] ; WINDOW REDRAW
|
2006-08-06 10:29:45 +00:00
|
|
|
test [edi+TASKDATA.event_mask],dword 1
|
2005-10-06 17:56:22 +00:00
|
|
|
jz no_eventoccur1
|
2005-11-07 15:50:30 +00:00
|
|
|
;mov edi,[0x3010]
|
2006-08-06 10:29:45 +00:00
|
|
|
cmp [edi-twdw+WDATA.fl_redraw],byte 0
|
2005-10-06 17:56:22 +00:00
|
|
|
je no_eventoccur1
|
|
|
|
popad
|
|
|
|
mov eax,1
|
|
|
|
ret
|
|
|
|
no_eventoccur1:
|
|
|
|
|
2005-11-07 15:50:30 +00:00
|
|
|
;mov edi,[0x3010] ; KEY IN BUFFER
|
2006-08-06 10:29:45 +00:00
|
|
|
test [edi+TASKDATA.event_mask],dword 2
|
2005-10-06 17:56:22 +00:00
|
|
|
jz no_eventoccur2
|
|
|
|
mov ecx, [0x3000]
|
|
|
|
movzx edx,word [0xC000+ecx*2]
|
|
|
|
mov eax, [0x3004]
|
|
|
|
cmp eax,edx
|
2006-06-30 12:23:15 +00:00
|
|
|
jne no_eventoccur2x
|
2005-10-06 17:56:22 +00:00
|
|
|
cmp [0xf400],byte 0
|
2006-06-30 12:23:15 +00:00
|
|
|
je no_eventoccur2x
|
|
|
|
eventoccur2:
|
2005-10-06 17:56:22 +00:00
|
|
|
popad
|
|
|
|
mov eax,2
|
|
|
|
ret
|
2006-06-30 12:23:15 +00:00
|
|
|
no_eventoccur2x:
|
|
|
|
mov eax, hotkey_buffer
|
|
|
|
@@:
|
|
|
|
cmp [eax], ecx
|
|
|
|
jz eventoccur2
|
|
|
|
add eax, 8
|
|
|
|
cmp eax, hotkey_buffer+120*8
|
|
|
|
jb @b
|
2005-10-06 17:56:22 +00:00
|
|
|
no_eventoccur2:
|
|
|
|
|
2005-11-07 15:50:30 +00:00
|
|
|
;mov edi,[0x3010] ; BUTTON IN BUFFER
|
2006-08-06 10:29:45 +00:00
|
|
|
test [edi+TASKDATA.event_mask],dword 4
|
2005-10-06 17:56:22 +00:00
|
|
|
jz no_eventoccur3
|
2005-11-07 15:50:30 +00:00
|
|
|
cmp [0xf500],byte 0
|
|
|
|
je no_eventoccur3
|
2005-10-06 17:56:22 +00:00
|
|
|
mov ecx, [0x3000]
|
|
|
|
movzx edx, word [0xC000+ecx*2]
|
|
|
|
mov eax, [0x3004]
|
|
|
|
cmp eax,edx
|
|
|
|
jnz no_eventoccur3
|
|
|
|
popad
|
|
|
|
mov eax,[0xf501]
|
|
|
|
cmp eax,65535
|
|
|
|
je no_event_1
|
|
|
|
mov eax,3
|
|
|
|
ret
|
|
|
|
|
|
|
|
no_event_1:
|
|
|
|
mov [window_minimize],1
|
|
|
|
mov [0xf500],byte 0
|
|
|
|
xor eax, eax
|
|
|
|
ret
|
|
|
|
|
|
|
|
no_eventoccur3:
|
2005-11-07 15:50:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
;mov edi,[0x3010] ; mouse event
|
2006-08-06 10:29:45 +00:00
|
|
|
test [edi+TASKDATA.event_mask],dword 00100000b
|
2005-11-07 15:50:30 +00:00
|
|
|
jz no_mouse_event
|
|
|
|
mov eax,[0x3000]
|
|
|
|
shl eax,8
|
2006-08-06 10:29:45 +00:00
|
|
|
test [eax+0x80000+APPDATA.event_mask],dword 00100000b
|
2005-11-07 15:50:30 +00:00
|
|
|
jz no_mouse_event
|
2006-08-06 10:29:45 +00:00
|
|
|
and [eax+0x80000+APPDATA.event_mask],dword 0xffffffff-00100000b
|
2005-11-07 15:50:30 +00:00
|
|
|
popad
|
|
|
|
mov eax,6
|
|
|
|
ret
|
|
|
|
no_mouse_event:
|
|
|
|
|
2005-10-06 17:56:22 +00:00
|
|
|
|
2005-11-07 15:50:30 +00:00
|
|
|
;mov edi,[0x3010] ; DESKTOP BACKGROUND REDRAW
|
2006-08-06 10:29:45 +00:00
|
|
|
test [edi+TASKDATA.event_mask],dword 16
|
2005-10-06 17:56:22 +00:00
|
|
|
jz no_eventoccur5
|
|
|
|
cmp [0xfff0],byte 2
|
|
|
|
jnz no_eventoccur5
|
|
|
|
popad
|
|
|
|
mov eax,5
|
|
|
|
ret
|
|
|
|
no_eventoccur5:
|
|
|
|
|
2005-11-07 15:50:30 +00:00
|
|
|
;mov edi,[0x3010] ; IPC
|
2006-08-06 10:29:45 +00:00
|
|
|
test [edi+TASKDATA.event_mask],dword 01000000b
|
2005-10-06 17:56:22 +00:00
|
|
|
jz no_ipc
|
2005-11-07 15:50:30 +00:00
|
|
|
mov eax,[0x3000]
|
|
|
|
shl eax,8
|
2006-08-06 10:29:45 +00:00
|
|
|
test [eax+0x80000+APPDATA.event_mask],dword 01000000b
|
2005-10-06 17:56:22 +00:00
|
|
|
jz no_ipc
|
2006-08-06 10:29:45 +00:00
|
|
|
and [eax+0x80000+APPDATA.event_mask],dword 0xffffffff-01000000b
|
2005-10-06 17:56:22 +00:00
|
|
|
popad
|
|
|
|
mov eax,7
|
|
|
|
ret
|
|
|
|
no_ipc:
|
|
|
|
|
|
|
|
|
2005-11-07 15:50:30 +00:00
|
|
|
;mov edi,[0x3010] ; STACK
|
2006-08-06 10:29:45 +00:00
|
|
|
test [edi+TASKDATA.event_mask],dword 10000000b
|
2005-10-06 17:56:22 +00:00
|
|
|
jz no_stack_event
|
2005-11-07 15:50:30 +00:00
|
|
|
mov eax,[0x3000]
|
|
|
|
shl eax,8
|
2006-08-06 10:29:45 +00:00
|
|
|
test [eax+0x80000+APPDATA.event_mask],dword 10000000b
|
2005-10-06 17:56:22 +00:00
|
|
|
jz no_stack_event
|
2006-08-06 10:29:45 +00:00
|
|
|
and [eax+0x80000+APPDATA.event_mask],dword 0xffffffff-10000000b
|
2005-10-06 17:56:22 +00:00
|
|
|
popad
|
2005-11-07 15:50:30 +00:00
|
|
|
mov eax,8
|
2005-10-06 17:56:22 +00:00
|
|
|
ret
|
|
|
|
no_stack_event:
|
|
|
|
|
2006-08-06 10:29:45 +00:00
|
|
|
test byte [edi+TASKDATA.event_mask+1], 1 ; DEBUG
|
2006-01-25 13:19:21 +00:00
|
|
|
jz no_debug_event
|
|
|
|
mov eax, [0x3000]
|
|
|
|
shl eax, 8
|
2006-08-06 10:29:45 +00:00
|
|
|
test byte [eax+0x80000+APPDATA.event_mask+1], byte 1
|
2006-01-25 13:19:21 +00:00
|
|
|
jz no_debug_event
|
2006-08-06 10:29:45 +00:00
|
|
|
and byte [eax+0x80000+APPDATA.event_mask+1], not 1
|
2006-01-25 13:19:21 +00:00
|
|
|
popad
|
|
|
|
mov eax, 9
|
|
|
|
ret
|
|
|
|
no_debug_event:
|
|
|
|
|
2006-08-06 10:29:45 +00:00
|
|
|
cmp dword [edi+TASKDATA.event_mask], 0xFFFF
|
2005-11-07 15:50:30 +00:00
|
|
|
jbe no_events
|
2005-10-06 17:56:22 +00:00
|
|
|
|
|
|
|
mov esi,0x2e0000 ; IRQ'S AND DATA
|
|
|
|
mov ebx,0x00010000
|
|
|
|
xor ecx, ecx
|
|
|
|
irq_event_test:
|
|
|
|
mov edi,[0x3010]
|
2006-08-06 10:29:45 +00:00
|
|
|
test [edi+TASKDATA.event_mask],ebx
|
2005-10-06 17:56:22 +00:00
|
|
|
jz no_irq_event
|
|
|
|
mov edi,ecx
|
|
|
|
shl edi,2
|
|
|
|
add edi,irq_owner
|
|
|
|
mov edx,[edi]
|
|
|
|
mov eax,[0x3010]
|
2006-08-06 10:29:45 +00:00
|
|
|
mov eax,[eax+TASKDATA.pid]
|
2005-10-06 17:56:22 +00:00
|
|
|
cmp edx,eax
|
|
|
|
jne no_irq_event
|
|
|
|
cmp [esi],dword 0
|
|
|
|
jz no_irq_event
|
|
|
|
mov eax,ecx
|
|
|
|
add eax,16
|
|
|
|
mov [esp+28],eax
|
|
|
|
popad
|
|
|
|
ret
|
|
|
|
no_irq_event:
|
|
|
|
add esi,0x1000
|
|
|
|
shl ebx,1
|
|
|
|
inc ecx
|
|
|
|
cmp ecx,16
|
|
|
|
jb irq_event_test
|
|
|
|
|
2005-11-07 15:50:30 +00:00
|
|
|
no_events:
|
2005-10-06 17:56:22 +00:00
|
|
|
popad
|
|
|
|
xor eax, eax
|
|
|
|
ret
|
|
|
|
|
|
|
|
|