Subversion Repositories Kolibri OS

Rev

Rev 3500 | Rev 3589 | Go to most recent revision | Show entire file | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 3500 Rev 3555
Line 3... Line 3...
3
;; Copyright (C) KolibriOS team 2004-2012. All rights reserved. ;;
3
;; Copyright (C) KolibriOS team 2004-2012. All rights reserved. ;;
4
;; Copyright (C) MenuetOS 2000-2004 Ville Mikael Turjanmaa      ;;
4
;; Copyright (C) MenuetOS 2000-2004 Ville Mikael Turjanmaa      ;;
5
;; Distributed under terms of the GNU General Public License    ;;
5
;; Distributed under terms of the GNU General Public License    ;;
6
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
6
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
Line 7... Line 7...
7
 
7
 
Line 8... Line 8...
8
$Revision: 3500 $
8
$Revision: 3555 $
9
 
9
 
10
WINDOW_MOVE_AND_RESIZE_FLAGS = \
10
WINDOW_MOVE_AND_RESIZE_FLAGS = \
11
  mouse.WINDOW_RESIZE_N_FLAG + \
11
  mouse.WINDOW_RESIZE_N_FLAG + \
Line 19... Line 19...
19
  event_start   dd ?
19
  event_start   dd ?
20
  event_end     dd ?
20
  event_end     dd ?
21
  event_uid     dd 0
21
  event_uid     dd 0
22
endg
22
endg
23
EV_SPACE   = 512
23
EV_SPACE   = 512
24
FreeEvents = event_start-EVENT.fd    ; "âèðòóàëüíûé" event, èñïîëüçóþòñÿ òîëüêî ïîëÿ:
24
FreeEvents = event_start-EVENT.fd    ; "виртуальный" event, используются только поля:
25
                                     ;  FreeEvents.fd=event_start è FreeEvents.bk=event_end
25
                                     ;  FreeEvents.fd=event_start и FreeEvents.bk=event_end
26
;-----------------------------------------------------------------------------
26
;-----------------------------------------------------------------------------
27
align 4
27
align 4
28
init_events:                                       ;; used from kernel.asm
28
init_events:                                       ;; used from kernel.asm
29
        stdcall kernel_alloc, EV_SPACE*sizeof.EVENT
29
        stdcall kernel_alloc, EV_SPACE*sizeof.EVENT
30
        or      eax, eax
30
        or      eax, eax
31
        jz      .fail
31
        jz      .fail
32
      ; eax - current event, ebx - previos event below
32
      ; eax - current event, ebx - previos event below
33
        mov     ecx, EV_SPACE        ; current - in allocated space
33
        mov     ecx, EV_SPACE        ; current - in allocated space
34
        mov     ebx, FreeEvents      ; previos - íà÷àëî ñïèñêà
34
        mov     ebx, FreeEvents      ; previos - начало списка
35
        push    ebx                  ; îíî æå è êîíåö ïîòîì áóäåò
35
        push    ebx                  ; оно же и конец потом будет
36
;--------------------------------------
36
;--------------------------------------
37
align 4
37
align 4
38
@@:
38
@@:
39
        mov     [ebx+EVENT.fd], eax
39
        mov     [ebx+EVENT.fd], eax
40
        mov     [eax+EVENT.bk], ebx
40
        mov     [eax+EVENT.bk], ebx
41
        mov     ebx, eax             ; previos <- current
41
        mov     ebx, eax             ; previos <- current
42
        add     eax, sizeof.EVENT    ; new current
42
        add     eax, sizeof.EVENT    ; new current
43
        loop    @b
43
        loop    @b
44
        pop     eax                  ; âîò îíî êîíöîì è ñòàëî
44
        pop     eax                  ; вот оно концом и стало
45
        mov     [ebx+EVENT.fd], eax
45
        mov     [ebx+EVENT.fd], eax
46
        mov     [eax+EVENT.bk], ebx
46
        mov     [eax+EVENT.bk], ebx
47
;--------------------------------------
47
;--------------------------------------
48
align 4
48
align 4
49
.fail:
49
.fail:
50
        ret
50
        ret
51
;-----------------------------------------------------------------------------
51
;-----------------------------------------------------------------------------
52
EVENT_WATCHED    equ 0x10000000 ;áèò 28
52
EVENT_WATCHED    equ 0x10000000 ;бит 28
53
EVENT_SIGNALED   equ 0x20000000 ;áèò 29
53
EVENT_SIGNALED   equ 0x20000000 ;бит 29
54
MANUAL_RESET     equ 0x40000000 ;áèò 30
54
MANUAL_RESET     equ 0x40000000 ;бит 30
55
MANUAL_DESTROY   equ 0x80000000 ;áèò 31
55
MANUAL_DESTROY   equ 0x80000000 ;бит 31
56
;-----------------------------------------------------------------------------
56
;-----------------------------------------------------------------------------
57
align 4
57
align 4
58
create_event:                                      ;; EXPORT use
58
create_event:                                      ;; EXPORT use
59
;info:
59
;info:
60
;   Ïåðåíîñèì EVENT èç ñïèñêà FreeEvents â ñïèñîê ObjList òåêóùåãî ñëîòà
60
;   Переносим EVENT из списка FreeEvents в список ObjList текущего слота
61
;   EVENT.state óñòàíàâëèâàåì èç ecx, EVENT.code êîñâåííî èç esi (åñëè esi<>0)
61
;   EVENT.state устанавливаем из ecx, EVENT.code косвенно из esi (если esi<>0)
62
;param:
62
;param:
63
;   esi - event data
63
;   esi - event data
64
;   ecx - flags
64
;   ecx - flags
65
;retval:
65
;retval:
66
;   eax - event (=0 => fail)
66
;   eax - event (=0 => fail)
Line 74... Line 74...
74
        cli
74
        cli
75
;--------------------------------------
75
;--------------------------------------
76
align 4
76
align 4
77
set_event:                                         ;; INTERNAL use !!! don't use for Call
77
set_event:                                         ;; INTERNAL use !!! don't use for Call
78
;info:
78
;info:
79
;   Áåðåì íîâûé event èç FreeEvents, çàïîëíÿåì åãî ïîëÿ, êàê óêàçàíî â ecx,edx,esi
79
;   Берем новый event из FreeEvents, заполняем его поля, как указано в ecx,edx,esi
80
;   è óñòàíàâëèâàåì â ñïèñîê, óêàçàííûé â ebx.
80
;   и устанавливаем в список, указанный в ebx.
81
;   Âîçâðàùàåì ñàì event (â eax), è åãî uid (â edx)
81
;   Возвращаем сам event (в eax), и его uid (в edx)
82
;param:
82
;param:
83
;   ebx - start-chain "virtual" event for entry new event Right of him
83
;   ebx - start-chain "virtual" event for entry new event Right of him
84
;   ecx - flags      (copied to EVENT.state)
84
;   ecx - flags      (copied to EVENT.state)
85
;   edx - pid        (copied to EVENT.pid)
85
;   edx - pid        (copied to EVENT.pid)
86
;   esi - event data (copied to EVENT.code indirect, =0 => skip)
86
;   esi - event data (copied to EVENT.code indirect, =0 => skip)
Line 113... Line 113...
113
        rep movsd
113
        rep movsd
114
;--------------------------------------
114
;--------------------------------------
115
align 4
115
align 4
116
RemoveEventTo:                                     ;; INTERNAL use !!! don't use for Call
116
RemoveEventTo:                                     ;; INTERNAL use !!! don't use for Call
117
;param:
117
;param:
118
;   eax - óêàçàòåëü íà event, ÊÎÒÎÐÛÉ âñòàâëÿåì
118
;   eax - указатель на event, КОТОРЫЙ вставляем
119
;   ebx - óêàçàòåëü íà event, ÏÎÑËÅ êîòîðîãî âñòàâëÿåì
119
;   ebx - указатель на event, ПОСЛЕ которого вставляем
120
;scratched: ebx,ecx
120
;scratched: ebx,ecx
121
        mov     ecx, eax             ; ecx=eax=Self,      ebx=NewLeft
121
        mov     ecx, eax             ; ecx=eax=Self,      ebx=NewLeft
122
        xchg    ecx, [ebx+EVENT.fd]  ; NewLeft.fd=Self,   ecx=NewRight
122
        xchg    ecx, [ebx+EVENT.fd]  ; NewLeft.fd=Self,   ecx=NewRight
123
        cmp     eax, ecx             ; ñòîï, ñåáå äóìàþ...
123
        cmp     eax, ecx             ; стоп, себе думаю...
124
        je      .break               ; - à íå äóðàê ëè ÿ?
124
        je      .break               ; - а не дурак ли я?
125
        mov     [ecx+EVENT.bk], eax  ; NewRight.bk=Self
125
        mov     [ecx+EVENT.bk], eax  ; NewRight.bk=Self
126
        xchg    ebx, [eax+EVENT.bk]  ; Self.bk=NewLeft,   ebx=OldLeft
126
        xchg    ebx, [eax+EVENT.bk]  ; Self.bk=NewLeft,   ebx=OldLeft
127
        xchg    ecx, [eax+EVENT.fd]  ; Self.fd=NewRight,  ecx=OldRight
127
        xchg    ecx, [eax+EVENT.fd]  ; Self.fd=NewRight,  ecx=OldRight
128
        mov     [ebx+EVENT.fd], ecx  ; OldLeft.fd=OldRight
128
        mov     [ebx+EVENT.fd], ecx  ; OldLeft.fd=OldRight
129
        mov     [ecx+EVENT.bk], ebx  ; OldRight.bk=OldLeft
129
        mov     [ecx+EVENT.bk], ebx  ; OldRight.bk=OldLeft
Line 140... Line 140...
140
        mov     ebx, eax
140
        mov     ebx, eax
141
        mov     eax, [ebx+EVENT.pid]
141
        mov     eax, [ebx+EVENT.pid]
142
        push    edi
142
        push    edi
143
;--------------------------------------
143
;--------------------------------------
144
align 4
144
align 4
145
.small: ; êðèâî êàê-òî...
145
.small: ; криво как-то...
146
        pop     edi
146
        pop     edi
147
        pushfd
147
        pushfd
148
        cli
148
        cli
149
        call    pid_to_slot ; saved all registers (eax - retval)
149
        call    pid_to_slot ; saved all registers (eax - retval)
150
        shl     eax, 8
150
        shl     eax, 8
151
        jz      RemoveEventTo.break ; POPF+RET
151
        jz      RemoveEventTo.break ; POPF+RET
152
        jmp     edi ; øòàòíûé âîçâðàò
152
        jmp     edi ; штатный возврат
153
;-----------------------------------------------------------------------------
153
;-----------------------------------------------------------------------------
154
align 4
154
align 4
155
raise_event:                                       ;; EXPORT use
155
raise_event:                                       ;; EXPORT use
156
;info:
156
;info:
157
;   Óñòàíàâëèâàåì äàííûå EVENT.code
157
;   Устанавливаем данные EVENT.code
158
;   Åñëè òàì ôëàã EVENT_SIGNALED óæå àêòèâåí - áîëüøå íè÷åãî
158
;   Если там флаг EVENT_SIGNALED уже активен - больше ничего
159
;   Èíà÷å: ýòîò ôëàã âçâîäèòñÿ, çà èñêëþ÷åíèåì ñëó÷àÿ íàëè÷èÿ ôëàãà EVENT_WATCHED â edx
159
;   Иначе: этот флаг взводится, за исключением случая наличия флага EVENT_WATCHED в edx
160
;    ýòîì ñëó÷àå EVENT_SIGNALED âçâîäèòñÿ ëèøü ïðè íàëè÷èå EVENT_WATCHED â ñàìîì ñîáûòèè
160
;   В этом случае EVENT_SIGNALED взводится лишь при наличие EVENT_WATCHED в самом событии
161
;param:
161
;param:
162
;   eax - event
162
;   eax - event
163
;   ebx - uid (for Dummy testing)
163
;   ebx - uid (for Dummy testing)
164
;   edx - flags
164
;   edx - flags
165
;   esi - event data (=0 => skip)
165
;   esi - event data (=0 => skip)
166
;scratched: ebx,ecx,esi,edi
166
;scratched: ebx,ecx,esi,edi
167
        call    NotDummyTest ; not returned for fail !!!
167
        call    NotDummyTest ; not returned for fail !!!
168
        mov     [check_idle_semaphore], 5
-
 
169
        or      esi, esi
168
        or      esi, esi
170
        jz      @f
169
        jz      @f
171
        lea     edi, [ebx+EVENT.code]
170
        lea     edi, [ebx+EVENT.code]
172
        mov     ecx, (sizeof.EVENT -EVENT.code)/4
171
        mov     ecx, (sizeof.EVENT -EVENT.code)/4
173
        cld
172
        cld
Line 204... Line 203...
204
        jmp     RemoveEventTo
203
        jmp     RemoveEventTo
205
;-----------------------------------------------------------------------------
204
;-----------------------------------------------------------------------------
206
align 4
205
align 4
207
send_event:                                        ;; EXPORT use
206
send_event:                                        ;; EXPORT use
208
;info:
207
;info:
209
;   Ñîçäàåò íîâûé EVENT (âûòàñêèâàåò èç ñïèñêà FreeEvents) â ñïèñêå EventList
208
;   Создает новый EVENT (вытаскивает из списка FreeEvents) в списке EventList
210
;   öåëåâîãî ñëîòà (eax=pid), ñ äàííûìè èç esi êîñâåííî, è state=EVENT_SIGNALED
209
;   целевого слота (eax=pid), с данными из esi косвенно, и state=EVENT_SIGNALED
211
;param:
210
;param:
212
;   eax - slots pid, to sending new event
211
;   eax - slots pid, to sending new event
213
;   esi - pointer to sending data (in code field of new event)
212
;   esi - pointer to sending data (in code field of new event)
214
;retval:
213
;retval:
215
;   eax - event (=0 => fail)
214
;   eax - event (=0 => fail)
Line 250... Line 249...
250
        or      ebx, -1; infinite timeout
249
        or      ebx, -1; infinite timeout
251
;--------------------------------------
250
;--------------------------------------
252
align 4
251
align 4
253
Wait_events_ex:
252
Wait_events_ex:
254
;info:
253
;info:
255
;   Îæèäàíèå "àáñòðàêòíîãî" ñîáûòèÿ ÷åðåç ïåðåâîä ñëîòà â 5-þ ïîçèöèþ.
254
;   Ожидание "абстрактного" события через перевод слота в 5-ю позицию.
256
;   Àáñòðàêòíîñòü çàêëþ÷åíà â òîì, ÷òî ôàêò ñîáûòèÿ îïðåäåëÿåòñÿ ôóíêöèåé APPDATA.wait_test,
255
;   Абстрактность заключена в том, что факт события определяется функцией APPDATA.wait_test,
257
;   êîòîðàÿ çàäàåòñÿ êëèåíòîì è ìîæåò áûòü ôàêòè÷åñêè ëþáîé.
256
;   которая задается клиентом и может быть фактически любой.
258
;   Ýòî ïîçâîëÿåò shed-ó íàäåæíî îïðåäåëèòü ôàêò ñîáûòèÿ, è íå ñîâåðøàòü "õîëîñòûõ" ïåðåêëþ÷åíèé,
257
;   Это позволяет shed-у надежно определить факт события, и не совершать "холостых" переключений,
259
;   ïðåäíàçíà÷åííûõ äëÿ ðàçáîðîê òèïà "ñâîé/÷óæîé" âíóòðè çàäà÷è.
258
;   предназначенных для разборок типа "свой/чужой" внутри задачи.
260
;param:
259
;param:
261
;   edx - wait_test, êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ (àäðåñ êîäà)
260
;   edx - wait_test, клиентская ф-я тестирования (адрес кода)
262
;   ecx - wait_param, äîïîëíèòåëüíûé ïàðàìåòð, âîçìîæíî íåîáõîäèìûé äëÿ [wait_test]
261
;   ecx - wait_param, дополнительный параметр, возможно необходимый для [wait_test]
263
;   ebx - wait_timeout
262
;   ebx - wait_timeout
264
;retval:
263
;retval:
265
;   eax - ðåçóëüòàò âûçîâà [wait_test] (=0 => timeout)
264
;   eax - результат вызова [wait_test] (=0 => timeout)
266
;scratched: esi
265
;scratched: esi
267
        mov     esi, [current_slot]
266
        mov     esi, [current_slot]
268
        mov     [esi+APPDATA.wait_param], ecx
267
        mov     [esi+APPDATA.wait_param], ecx
269
        pushad
268
        pushad
270
        mov     ebx, esi;ïîêà ýòî âîïðîñ, ÷åãî êóäû ñóâàòü..........
269
        mov     ebx, esi;пока это вопрос, чего куды сувать..........
271
        pushfd  ; ýòî ñëåäñòâèå îáùåé êîíöåïöèè: ïóñòü ô-ÿ òåñòèðîâàíèÿ èìååò
270
        pushfd  ; это следствие общей концепции: пусть ф-я тестирования имеет
272
        cli     ; ïðàâî ðàññ÷èòûâàòü íà çàêðûòûå ïðåðûâàíèÿ, êàê ïðè âûçîâå èç shed
271
        cli     ; право рассчитывать на закрытые прерывания, как при вызове из shed
273
        call    edx
272
        call    edx
274
        popfd
273
        popfd
275
        mov     [esp+28], eax
274
        mov     [esp+28], eax
276
        popad
275
        popad
277
        or      eax, eax
276
        or      eax, eax
Line 289... Line 288...
289
        ret
288
        ret
290
;-----------------------------------------------------------------------------
289
;-----------------------------------------------------------------------------
291
align 4
290
align 4
292
wait_event:                                        ;; EXPORT use
291
wait_event:                                        ;; EXPORT use
293
;info:
292
;info:
294
;   Îæèäàíèå ôëàãà EVENT_SIGNALED â ñîâåðøåííî êîíêðåòíîì Event
293
;   Ожидание флага EVENT_SIGNALED в совершенно конкретном Event
295
;   (óñòàíàâëèâàåìîãî, íàäî ïîëàãàòü, ÷åðåç raise_event)
294
;   (устанавливаемого, надо полагать, через raise_event)
296
;   Ïðè àêòèâíîì ôëàãå MANUAL_RESET - áîëüøå íè÷åãî
295
;   При активном флаге MANUAL_RESET - больше ничего
297
;   Èíà÷å: ôëàãè EVENT_SIGNALED è EVENT_WATCHED ó ïîëó÷åííîãî ñîáûòèÿ ñáðàñûâàþòñÿ,
296
;   Иначе: флаги EVENT_SIGNALED и EVENT_WATCHED у полученного события сбрасываются,
298
;   è, ïðè àêòèâíîì MANUAL_DESTROY - ïåðåìåùàåòñÿ â ñïèñîê ObjList òåêóùåãî ñëîòà,
297
;   и, при активном MANUAL_DESTROY - перемещается в список ObjList текущего слота,
299
;   à ïðè íå àêòèâíîì - óíè÷òîæàåòñÿ øòàòíî (destroy_event.internal)
298
;   а при не активном - уничтожается штатно (destroy_event.internal)
300
;param:
299
;param:
301
;   eax - event
300
;   eax - event
302
;   ebx - uid (for Dummy testing)
301
;   ebx - uid (for Dummy testing)
303
;scratched: ecx,edx,esi
302
;scratched: ecx,edx,esi
304
        call    DummyTest
303
        call    DummyTest
Line 325... Line 324...
325
        ret
324
        ret
326
;-----------------------------------------------------------------------------
325
;-----------------------------------------------------------------------------
327
align 4
326
align 4
328
get_event_ex:                                      ;; f68:14
327
get_event_ex:                                      ;; f68:14
329
;info:
328
;info:
330
;   Îæèäàíèå ëþáîãî ñîáûòèÿ â î÷åðåäè EventList òåêóùåãî ñëîòà
329
;   Ожидание любого события в очереди EventList текущего слота
331
;   Äàííûå ñîáûòèÿ code - êîïèðóþòñÿ â ïàìÿòü ïðèëîæåíèÿ (êîñâåííî ïî edi)
330
;   Данные события code - копируются в память приложения (косвенно по edi)
332
;   Ïðè àêòèâíîì ôëàãå MANUAL_RESET - áîëüøå íè÷åãî
331
;   При активном флаге MANUAL_RESET - больше ничего
333
;   Èíà÷å: ôëàãè EVENT_SIGNALED è EVENT_WATCHED ó ïîëó÷åííîãî ñîáûòèÿ ñáðàñûâàþòñÿ,
332
;   Иначе: флаги EVENT_SIGNALED и EVENT_WATCHED у полученного события сбрасываются,
334
;   è, ïðè àêòèâíîì MANUAL_DESTROY - ïåðåìåùàåòñÿ â ñïèñîê ObjList òåêóùåãî ñëîòà,
333
;   и, при активном MANUAL_DESTROY - перемещается в список ObjList текущего слота,
335
;   à ïðè íå àêòèâíîì - óíè÷òîæàåòñÿ øòàòíî (destroy_event.internal)
334
;   а при не активном - уничтожается штатно (destroy_event.internal)
336
;param:
335
;param:
337
;   edi - àäðåñ â êîäå ïðèëîæåíèÿ äëÿ êîïèðîâàíèÿ äàííûõ èç EVENT.code
336
;   edi - адрес в коде приложения для копирования данных из EVENT.code
338
;retval:
337
;retval:
339
;   eax - ñîáñòâåííî EVENT (áóäåì íàçûâàòü ýòî åãî õýíäëîì)
338
;   eax - собственно EVENT (будем называть это его хэндлом)
340
;scratched: ebx,ecx,edx,esi,edi
339
;scratched: ebx,ecx,edx,esi,edi
341
        mov     edx, get_event_queue ; wait_test
340
        mov     edx, get_event_queue ; wait_test
342
        call    Wait_events          ; timeout ignored
341
        call    Wait_events          ; timeout ignored
343
        lea     esi, [eax+EVENT.code]
342
        lea     esi, [eax+EVENT.code]
344
        mov     ecx, (sizeof.EVENT-EVENT.code)/4
343
        mov     ecx, (sizeof.EVENT-EVENT.code)/4
Line 360... Line 359...
360
        jmp     RemoveEventTo
359
        jmp     RemoveEventTo
361
;-----------------------------------------------------------------------------
360
;-----------------------------------------------------------------------------
362
align 4
361
align 4
363
destroy_event:                                     ;; EXPORT use
362
destroy_event:                                     ;; EXPORT use
364
;info:
363
;info:
365
;   Ïåðåíîñèì EVENT â ñïèñîê FreeEvents, ÷èñòèì ïîëÿ magic,destroy,pid,id
364
;   Переносим EVENT в список FreeEvents, чистим поля magic,destroy,pid,id
366
;param:
365
;param:
367
;   eax - event
366
;   eax - event
368
;   ebx - uid (for Dummy testing)
367
;   ebx - uid (for Dummy testing)
369
;retval:
368
;retval:
370
;   eax - àäðåñ îáúåêòà EVENT (=0 => fail)
369
;   eax - адрес объекта EVENT (=0 => fail)
371
;scratched: ebx,ecx
370
;scratched: ebx,ecx
372
        call    DummyTest ; not returned for fail !!!
371
        call    DummyTest ; not returned for fail !!!
373
;--------------------------------------
372
;--------------------------------------
374
align 4
373
align 4
375
.internal:
374
.internal:
Line 384... Line 383...
384
        jmp     RemoveEventTo
383
        jmp     RemoveEventTo
385
;-----------------------------------------------------------------------------
384
;-----------------------------------------------------------------------------
386
align 4
385
align 4
387
get_event_queue:
386
get_event_queue:
388
;info:
387
;info:
389
;   êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ äëÿ get_event_ex
388
;   клиентская ф-я тестирования для get_event_ex
390
;warning:
389
;warning:
391
;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
390
;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
392
;  -may be assumed, that interrupt are disabled
391
;  -may be assumed, that interrupt are disabled
393
;  -it is not restriction for scratched registers
392
;  -it is not restriction for scratched registers
394
;param:
393
;param:
395
;   ebx - àäðåñ APPDATA ñëîòà òåñòèðîâàíèÿ
394
;   ebx - адрес APPDATA слота тестирования
396
;retval:
395
;retval:
397
;   eax - àäðåñ îáúåêòà EVENT (=0 => fail)
396
;   eax - адрес объекта EVENT (=0 => fail)
398
        add     ebx, APP_EV_OFFSET
397
        add     ebx, APP_EV_OFFSET
399
        mov     eax, [ebx+APPOBJ.bk] ; âûáèðàåì ñ êîíöà, ïî ïðèíöèïó FIFO
398
        mov     eax, [ebx+APPOBJ.bk] ; выбираем с конца, по принципу FIFO
400
        cmp     eax, ebx ; empty ???
399
        cmp     eax, ebx ; empty ???
401
        je      get_event_alone.ret0
400
        je      get_event_alone.ret0
402
;--------------------------------------
401
;--------------------------------------
403
align 4
402
align 4
404
.ret:
403
.ret:
405
        ret
404
        ret
406
;-----------------------------------------------------------------------------
405
;-----------------------------------------------------------------------------
407
align 4
406
align 4
408
get_event_alone:
407
get_event_alone:
409
;info:
408
;info:
410
;   êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ äëÿ wait_event
409
;   клиентская ф-я тестирования для wait_event
411
;warning:
410
;warning:
412
;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
411
;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
413
;  -may be assumed, that interrupt are disabled
412
;  -may be assumed, that interrupt are disabled
414
;  -it is not restriction for scratched registers
413
;  -it is not restriction for scratched registers
415
;param:
414
;param:
416
;   ebx - àäðåñ APPDATA ñëîòà òåñòèðîâàíèÿ
415
;   ebx - адрес APPDATA слота тестирования
417
;retval:
416
;retval:
418
;   eax - àäðåñ îáúåêòà EVENT (=0 => fail)
417
;   eax - адрес объекта EVENT (=0 => fail)
419
        mov     eax, [ebx+APPDATA.wait_param]
418
        mov     eax, [ebx+APPDATA.wait_param]
420
        test    byte[eax+EVENT.state+3], EVENT_SIGNALED shr 24
419
        test    byte[eax+EVENT.state+3], EVENT_SIGNALED shr 24
421
        jnz     .ret
420
        jnz     .ret
422
        or      byte[eax+EVENT.state+3], EVENT_WATCHED shr 24
421
        or      byte[eax+EVENT.state+3], EVENT_WATCHED shr 24
423
;--------------------------------------
422
;--------------------------------------
Line 457... Line 456...
457
        inc     byte[KEY_COUNT]
456
        inc     byte[KEY_COUNT]
458
        mov     [KEY_COUNT+1+eax], dl
457
        mov     [KEY_COUNT+1+eax], dl
459
;--------------------------------------
458
;--------------------------------------
460
align 4
459
align 4
461
.result:
460
.result:
462
        setae   byte[esp+32+4] ;ñ÷èòàåì, ÷òî èñõîäíî: dword[esp+32+4]==72
461
        setae   byte[esp+32+4] ;считаем, что исходно: dword[esp+32+4]==72
463
;--------------------------------------
462
;--------------------------------------
464
align 4
463
align 4
465
.retf:
464
.retf:
466
        popfd
465
        popfd
467
;--------------------------------------
466
;--------------------------------------
Line 469... Line 468...
469
.ret:
468
.ret:
470
        ret
469
        ret
471
;-----------------------------------------------------------------------------
470
;-----------------------------------------------------------------------------
472
align 4
471
align 4
473
sys_getevent:                                      ;; f11
472
sys_getevent:                                      ;; f11
474
        mov     ebx, [current_slot];ïîêà ýòî âîïðîñ, ÷åãî êóäû ñóâàòü..........
473
        mov     ebx, [current_slot];пока это вопрос, чего куды сувать..........
475
        pushfd  ; ýòî ñëåäñòâèå îáùåé êîíöåïöèè: ïóñòü ô-ÿ òåñòèðîâàíèÿ èìååò
474
        pushfd  ; это следствие общей концепции: пусть ф-я тестирования имеет
476
        cli     ; ïðàâî ðàññ÷èòûâàòü íà çàêðûòûå ïðåðûâàíèÿ, êàê ïðè âûçîâå èç shed
475
        cli     ; право рассчитывать на закрытые прерывания, как при вызове из shed
477
        call    get_event_for_app
476
        call    get_event_for_app
478
        popfd
477
        popfd
479
        mov     [esp+32], eax
478
        mov     [esp+32], eax
480
        ret
479
        ret
481
;-----------------------------------------------------------------------------
480
;-----------------------------------------------------------------------------
Line 493... Line 492...
493
        ret
492
        ret
494
;-----------------------------------------------------------------------------
493
;-----------------------------------------------------------------------------
495
align 4
494
align 4
496
get_event_for_app:                                 ;; used from f10,f11,f23
495
get_event_for_app:                                 ;; used from f10,f11,f23
497
;info:
496
;info:
498
;   êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ äëÿ ïðèëîæåíèé (f10,f23)
497
;   клиентская ф-я тестирования для приложений (f10,f23)
499
;warning:
498
;warning:
500
;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
499
;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
501
;  -may be assumed, that interrupt are disabled
500
;  -may be assumed, that interrupt are disabled
502
;  -it is not restriction for scratched registers
501
;  -it is not restriction for scratched registers
503
;param:
502
;param:
504
;   ebx - àäðåñ APPDATA ñëîòà òåñòèðîâàíèÿ
503
;   ebx - адрес APPDATA слота тестирования
505
;retval:
504
;retval:
506
;   eax - íîìåð ñîáûòèÿ (=0 => no events)
505
;   eax - номер события (=0 => no events)
507
        movzx   edi, bh               ; bh  is assumed as [CURRENT_TASK]
506
        movzx   edi, bh               ; bh  is assumed as [CURRENT_TASK]
508
        shl     edi, 5
507
        shl     edi, 5
509
        add     edi, CURRENT_TASK     ; edi is assumed as [TASK_BASE]
508
        add     edi, CURRENT_TASK     ; edi is assumed as [TASK_BASE]
510
        mov     ecx, [edi+TASKDATA.event_mask]
509
        mov     ecx, [edi+TASKDATA.event_mask]
511
        and     ecx, 0x7FFFFFFF
510
        and     ecx, 0x7FFFFFFF
512
;--------------------------------------
511
;--------------------------------------
513
align 4
512
align 4
514
.loop: ; ïîêà íå èñ÷åðïàåì âñå áèòû ìàñêè
513
.loop: ; пока не исчерпаем все биты маски
515
        bsr     eax, ecx       ; íàõîäèì íåíóëåâîé áèò ìàñêè (31 -> 0)
514
        bsr     eax, ecx       ; находим ненулевой бит маски (31 -> 0)
516
        jz      .no_events     ; èñ÷åðïàëè âñå áèòû ìàñêè, íî íè÷åãî íå íàøëè ???
515
        jz      .no_events     ; исчерпали все биты маски, но ничего не нашли ???
517
        btr     ecx, eax       ; ñáðàñûâàåì ïðîâåðÿåìûé áèò ìàñêè
516
        btr     ecx, eax       ; сбрасываем проверяемый бит маски
518
       ; ïåðåõîäèì íà îáðàáîò÷èê ýòîãî (eax) áèòà
517
       ; переходим на обработчик этого (eax) бита
519
        cmp     eax, 9
518
        cmp     eax, 10
520
        jae     .loop          ; eax=[9..31], ignored (event 10...32)
519
        jae     .loop          ; eax=[10..31], ignored (event 10...32)
Line 521... Line 520...
521
 
520
 
522
        cmp     eax, 3
521
        cmp     eax, 3
Line 523... Line 522...
523
        je      .loop          ; eax=3, ignored (event 4)
522
        je      .loop          ; eax=3, ignored (event 4)
524
 
523
 
Line 525... Line 524...
525
        cmp     eax, 4
524
        cmp     eax, 4
526
        je      .FlagAutoReset  ; eax=4, retvals=eax+1 (event 5)
525
        je      .FlagAutoReset  ; eax=4, retvals=eax+1 (event 5)
Line 527... Line 526...
527
 
526
 
Line 528... Line 527...
528
        cmp     eax, 5
527
        cmp     eax, 5
529
        je      .mouse_check  ; eax=5, retvals=eax+1 (event 6)
528
        je      .mouse_check  ; eax=5, retvals=eax+1 (event 6)
530
 
529
 
531
        ja      .FlagAutoReset ; eax=[6..8], retvals=eax+1 (event 7...9)
530
        ja      .FlagAutoReset ; eax=[6..9], retvals=eax+1 (event 7...10)
Line 588... Line 587...
588
        mov     edx, [BTN_BUFF]
587
        mov     edx, [BTN_BUFF]
589
        shr     edx, 8
588
        shr     edx, 8
590
        cmp     edx, 0xFFFF    ;-ID for Minimize-Button of Form
589
        cmp     edx, 0xFFFF    ;-ID for Minimize-Button of Form
591
        jne     .result
590
        jne     .result
592
        mov     [window_minimize], 1
591
        mov     [window_minimize], 1
-
 
592
        call    wakeup_osloop
593
        dec     byte[BTN_COUNT]
593
        dec     byte[BTN_COUNT]
594
        jmp     .loop
594
        jmp     .loop
595
;--------------------------------------
595
;--------------------------------------
596
align 4
596
align 4
597
.Keys:    ; eax==1
597
.Keys:    ; eax==1