Rev 3534 | Rev 3545 | Go to most recent revision | Show entire file | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 3534 | Rev 3539 | ||
---|---|---|---|
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: 3534 $ |
8 | $Revision: 3539 $ |
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) |
Line 203... | Line 203... | ||
203 | jmp RemoveEventTo |
203 | jmp RemoveEventTo |
204 | ;----------------------------------------------------------------------------- |
204 | ;----------------------------------------------------------------------------- |
205 | align 4 |
205 | align 4 |
206 | send_event: ;; EXPORT use |
206 | send_event: ;; EXPORT use |
207 | ;info: |
207 | ;info: |
208 | ; Ñîçäàåò íîâûé EVENT (âûòàñêèâàåò èç ñïèñêà FreeEvents) â ñïèñêå EventList |
208 | ; Создает новый EVENT (вытаскивает из списка FreeEvents) в списке EventList |
209 | ; öåëåâîãî ñëîòà (eax=pid), ñ äàííûìè èç esi êîñâåííî, è state=EVENT_SIGNALED |
209 | ; целевого слота (eax=pid), с данными из esi косвенно, и state=EVENT_SIGNALED |
210 | ;param: |
210 | ;param: |
211 | ; eax - slots pid, to sending new event |
211 | ; eax - slots pid, to sending new event |
212 | ; esi - pointer to sending data (in code field of new event) |
212 | ; esi - pointer to sending data (in code field of new event) |
213 | ;retval: |
213 | ;retval: |
214 | ; eax - event (=0 => fail) |
214 | ; eax - event (=0 => fail) |
Line 249... | Line 249... | ||
249 | or ebx, -1; infinite timeout |
249 | or ebx, -1; infinite timeout |
250 | ;-------------------------------------- |
250 | ;-------------------------------------- |
251 | align 4 |
251 | align 4 |
252 | Wait_events_ex: |
252 | Wait_events_ex: |
253 | ;info: |
253 | ;info: |
254 | ; Îæèäàíèå "àáñòðàêòíîãî" ñîáûòèÿ ÷åðåç ïåðåâîä ñëîòà â 5-þ ïîçèöèþ. |
254 | ; Ожидание "абстрактного" события через перевод слота в 5-ю позицию. |
255 | ; Àáñòðàêòíîñòü çàêëþ÷åíà â òîì, ÷òî ôàêò ñîáûòèÿ îïðåäåëÿåòñÿ ôóíêöèåé APPDATA.wait_test, |
255 | ; Абстрактность заключена в том, что факт события определяется функцией APPDATA.wait_test, |
256 | ; êîòîðàÿ çàäàåòñÿ êëèåíòîì è ìîæåò áûòü ôàêòè÷åñêè ëþáîé. |
256 | ; которая задается клиентом и может быть фактически любой. |
257 | ; Ýòî ïîçâîëÿåò shed-ó íàäåæíî îïðåäåëèòü ôàêò ñîáûòèÿ, è íå ñîâåðøàòü "õîëîñòûõ" ïåðåêëþ÷åíèé, |
257 | ; Это позволяет shed-у надежно определить факт события, и не совершать "холостых" переключений, |
258 | ; ïðåäíàçíà÷åííûõ äëÿ ðàçáîðîê òèïà "ñâîé/÷óæîé" âíóòðè çàäà÷è. |
258 | ; предназначенных для разборок типа "свой/чужой" внутри задачи. |
259 | ;param: |
259 | ;param: |
260 | ; edx - wait_test, êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ (àäðåñ êîäà) |
260 | ; edx - wait_test, клиентская ф-я тестирования (адрес кода) |
261 | ; ecx - wait_param, äîïîëíèòåëüíûé ïàðàìåòð, âîçìîæíî íåîáõîäèìûé äëÿ [wait_test] |
261 | ; ecx - wait_param, дополнительный параметр, возможно необходимый для [wait_test] |
262 | ; ebx - wait_timeout |
262 | ; ebx - wait_timeout |
263 | ;retval: |
263 | ;retval: |
264 | ; eax - ðåçóëüòàò âûçîâà [wait_test] (=0 => timeout) |
264 | ; eax - результат вызова [wait_test] (=0 => timeout) |
265 | ;scratched: esi |
265 | ;scratched: esi |
266 | mov esi, [current_slot] |
266 | mov esi, [current_slot] |
267 | mov [esi+APPDATA.wait_param], ecx |
267 | mov [esi+APPDATA.wait_param], ecx |
268 | pushad |
268 | pushad |
269 | mov ebx, esi;ïîêà ýòî âîïðîñ, ÷åãî êóäû ñóâàòü.......... |
269 | mov ebx, esi;пока это вопрос, чего куды сувать.......... |
270 | pushfd ; ýòî ñëåäñòâèå îáùåé êîíöåïöèè: ïóñòü ô-ÿ òåñòèðîâàíèÿ èìååò |
270 | pushfd ; это следствие общей концепции: пусть ф-я тестирования имеет |
271 | cli ; ïðàâî ðàññ÷èòûâàòü íà çàêðûòûå ïðåðûâàíèÿ, êàê ïðè âûçîâå èç shed |
271 | cli ; право рассчитывать на закрытые прерывания, как при вызове из shed |
272 | call edx |
272 | call edx |
273 | popfd |
273 | popfd |
274 | mov [esp+28], eax |
274 | mov [esp+28], eax |
275 | popad |
275 | popad |
276 | or eax, eax |
276 | or eax, eax |
Line 288... | Line 288... | ||
288 | ret |
288 | ret |
289 | ;----------------------------------------------------------------------------- |
289 | ;----------------------------------------------------------------------------- |
290 | align 4 |
290 | align 4 |
291 | wait_event: ;; EXPORT use |
291 | wait_event: ;; EXPORT use |
292 | ;info: |
292 | ;info: |
293 | ; Îæèäàíèå ôëàãà EVENT_SIGNALED â ñîâåðøåííî êîíêðåòíîì Event |
293 | ; Ожидание флага EVENT_SIGNALED в совершенно конкретном Event |
294 | ; (óñòàíàâëèâàåìîãî, íàäî ïîëàãàòü, ÷åðåç raise_event) |
294 | ; (устанавливаемого, надо полагать, через raise_event) |
295 | ; Ïðè àêòèâíîì ôëàãå MANUAL_RESET - áîëüøå íè÷åãî |
295 | ; При активном флаге MANUAL_RESET - больше ничего |
296 | ; Èíà÷å: ôëàãè EVENT_SIGNALED è EVENT_WATCHED ó ïîëó÷åííîãî ñîáûòèÿ ñáðàñûâàþòñÿ, |
296 | ; Иначе: флаги EVENT_SIGNALED и EVENT_WATCHED у полученного события сбрасываются, |
297 | ; è, ïðè àêòèâíîì MANUAL_DESTROY - ïåðåìåùàåòñÿ â ñïèñîê ObjList òåêóùåãî ñëîòà, |
297 | ; и, при активном MANUAL_DESTROY - перемещается в список ObjList текущего слота, |
298 | ; à ïðè íå àêòèâíîì - óíè÷òîæàåòñÿ øòàòíî (destroy_event.internal) |
298 | ; а при не активном - уничтожается штатно (destroy_event.internal) |
299 | ;param: |
299 | ;param: |
300 | ; eax - event |
300 | ; eax - event |
301 | ; ebx - uid (for Dummy testing) |
301 | ; ebx - uid (for Dummy testing) |
302 | ;scratched: ecx,edx,esi |
302 | ;scratched: ecx,edx,esi |
303 | call DummyTest |
303 | call DummyTest |
Line 324... | Line 324... | ||
324 | ret |
324 | ret |
325 | ;----------------------------------------------------------------------------- |
325 | ;----------------------------------------------------------------------------- |
326 | align 4 |
326 | align 4 |
327 | get_event_ex: ;; f68:14 |
327 | get_event_ex: ;; f68:14 |
328 | ;info: |
328 | ;info: |
329 | ; Îæèäàíèå ëþáîãî ñîáûòèÿ â î÷åðåäè EventList òåêóùåãî ñëîòà |
329 | ; Ожидание любого события в очереди EventList текущего слота |
330 | ; Äàííûå ñîáûòèÿ code - êîïèðóþòñÿ â ïàìÿòü ïðèëîæåíèÿ (êîñâåííî ïî edi) |
330 | ; Данные события code - копируются в память приложения (косвенно по edi) |
331 | ; Ïðè àêòèâíîì ôëàãå MANUAL_RESET - áîëüøå íè÷åãî |
331 | ; При активном флаге MANUAL_RESET - больше ничего |
332 | ; Èíà÷å: ôëàãè EVENT_SIGNALED è EVENT_WATCHED ó ïîëó÷åííîãî ñîáûòèÿ ñáðàñûâàþòñÿ, |
332 | ; Иначе: флаги EVENT_SIGNALED и EVENT_WATCHED у полученного события сбрасываются, |
333 | ; è, ïðè àêòèâíîì MANUAL_DESTROY - ïåðåìåùàåòñÿ â ñïèñîê ObjList òåêóùåãî ñëîòà, |
333 | ; и, при активном MANUAL_DESTROY - перемещается в список ObjList текущего слота, |
334 | ; à ïðè íå àêòèâíîì - óíè÷òîæàåòñÿ øòàòíî (destroy_event.internal) |
334 | ; а при не активном - уничтожается штатно (destroy_event.internal) |
335 | ;param: |
335 | ;param: |
336 | ; edi - àäðåñ â êîäå ïðèëîæåíèÿ äëÿ êîïèðîâàíèÿ äàííûõ èç EVENT.code |
336 | ; edi - адрес в коде приложения для копирования данных из EVENT.code |
337 | ;retval: |
337 | ;retval: |
338 | ; eax - ñîáñòâåííî EVENT (áóäåì íàçûâàòü ýòî åãî õýíäëîì) |
338 | ; eax - собственно EVENT (будем называть это его хэндлом) |
339 | ;scratched: ebx,ecx,edx,esi,edi |
339 | ;scratched: ebx,ecx,edx,esi,edi |
340 | mov edx, get_event_queue ; wait_test |
340 | mov edx, get_event_queue ; wait_test |
341 | call Wait_events ; timeout ignored |
341 | call Wait_events ; timeout ignored |
342 | lea esi, [eax+EVENT.code] |
342 | lea esi, [eax+EVENT.code] |
343 | mov ecx, (sizeof.EVENT-EVENT.code)/4 |
343 | mov ecx, (sizeof.EVENT-EVENT.code)/4 |
Line 359... | Line 359... | ||
359 | jmp RemoveEventTo |
359 | jmp RemoveEventTo |
360 | ;----------------------------------------------------------------------------- |
360 | ;----------------------------------------------------------------------------- |
361 | align 4 |
361 | align 4 |
362 | destroy_event: ;; EXPORT use |
362 | destroy_event: ;; EXPORT use |
363 | ;info: |
363 | ;info: |
364 | ; Ïåðåíîñèì EVENT â ñïèñîê FreeEvents, ÷èñòèì ïîëÿ magic,destroy,pid,id |
364 | ; Переносим EVENT в список FreeEvents, чистим поля magic,destroy,pid,id |
365 | ;param: |
365 | ;param: |
366 | ; eax - event |
366 | ; eax - event |
367 | ; ebx - uid (for Dummy testing) |
367 | ; ebx - uid (for Dummy testing) |
368 | ;retval: |
368 | ;retval: |
369 | ; eax - àäðåñ îáúåêòà EVENT (=0 => fail) |
369 | ; eax - адрес объекта EVENT (=0 => fail) |
370 | ;scratched: ebx,ecx |
370 | ;scratched: ebx,ecx |
371 | call DummyTest ; not returned for fail !!! |
371 | call DummyTest ; not returned for fail !!! |
372 | ;-------------------------------------- |
372 | ;-------------------------------------- |
373 | align 4 |
373 | align 4 |
374 | .internal: |
374 | .internal: |
Line 383... | Line 383... | ||
383 | jmp RemoveEventTo |
383 | jmp RemoveEventTo |
384 | ;----------------------------------------------------------------------------- |
384 | ;----------------------------------------------------------------------------- |
385 | align 4 |
385 | align 4 |
386 | get_event_queue: |
386 | get_event_queue: |
387 | ;info: |
387 | ;info: |
388 | ; êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ äëÿ get_event_ex |
388 | ; клиентская ф-я тестирования для get_event_ex |
389 | ;warning: |
389 | ;warning: |
390 | ; -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 |
391 | ; -may be assumed, that interrupt are disabled |
391 | ; -may be assumed, that interrupt are disabled |
392 | ; -it is not restriction for scratched registers |
392 | ; -it is not restriction for scratched registers |
393 | ;param: |
393 | ;param: |
394 | ; ebx - àäðåñ APPDATA ñëîòà òåñòèðîâàíèÿ |
394 | ; ebx - адрес APPDATA слота тестирования |
395 | ;retval: |
395 | ;retval: |
396 | ; eax - àäðåñ îáúåêòà EVENT (=0 => fail) |
396 | ; eax - адрес объекта EVENT (=0 => fail) |
397 | add ebx, APP_EV_OFFSET |
397 | add ebx, APP_EV_OFFSET |
398 | mov eax, [ebx+APPOBJ.bk] ; âûáèðàåì ñ êîíöà, ïî ïðèíöèïó FIFO |
398 | mov eax, [ebx+APPOBJ.bk] ; выбираем с конца, по принципу FIFO |
399 | cmp eax, ebx ; empty ??? |
399 | cmp eax, ebx ; empty ??? |
400 | je get_event_alone.ret0 |
400 | je get_event_alone.ret0 |
401 | ;-------------------------------------- |
401 | ;-------------------------------------- |
402 | align 4 |
402 | align 4 |
403 | .ret: |
403 | .ret: |
404 | ret |
404 | ret |
405 | ;----------------------------------------------------------------------------- |
405 | ;----------------------------------------------------------------------------- |
406 | align 4 |
406 | align 4 |
407 | get_event_alone: |
407 | get_event_alone: |
408 | ;info: |
408 | ;info: |
409 | ; êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ äëÿ wait_event |
409 | ; клиентская ф-я тестирования для wait_event |
410 | ;warning: |
410 | ;warning: |
411 | ; -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 |
412 | ; -may be assumed, that interrupt are disabled |
412 | ; -may be assumed, that interrupt are disabled |
413 | ; -it is not restriction for scratched registers |
413 | ; -it is not restriction for scratched registers |
414 | ;param: |
414 | ;param: |
415 | ; ebx - àäðåñ APPDATA ñëîòà òåñòèðîâàíèÿ |
415 | ; ebx - адрес APPDATA слота тестирования |
416 | ;retval: |
416 | ;retval: |
417 | ; eax - àäðåñ îáúåêòà EVENT (=0 => fail) |
417 | ; eax - адрес объекта EVENT (=0 => fail) |
418 | mov eax, [ebx+APPDATA.wait_param] |
418 | mov eax, [ebx+APPDATA.wait_param] |
419 | test byte[eax+EVENT.state+3], EVENT_SIGNALED shr 24 |
419 | test byte[eax+EVENT.state+3], EVENT_SIGNALED shr 24 |
420 | jnz .ret |
420 | jnz .ret |
421 | or byte[eax+EVENT.state+3], EVENT_WATCHED shr 24 |
421 | or byte[eax+EVENT.state+3], EVENT_WATCHED shr 24 |
422 | ;-------------------------------------- |
422 | ;-------------------------------------- |
Line 456... | Line 456... | ||
456 | inc byte[KEY_COUNT] |
456 | inc byte[KEY_COUNT] |
457 | mov [KEY_COUNT+1+eax], dl |
457 | mov [KEY_COUNT+1+eax], dl |
458 | ;-------------------------------------- |
458 | ;-------------------------------------- |
459 | align 4 |
459 | align 4 |
460 | .result: |
460 | .result: |
461 | setae byte[esp+32+4] ;ñ÷èòàåì, ÷òî èñõîäíî: dword[esp+32+4]==72 |
461 | setae byte[esp+32+4] ;считаем, что исходно: dword[esp+32+4]==72 |
462 | ;-------------------------------------- |
462 | ;-------------------------------------- |
463 | align 4 |
463 | align 4 |
464 | .retf: |
464 | .retf: |
465 | popfd |
465 | popfd |
466 | ;-------------------------------------- |
466 | ;-------------------------------------- |
Line 468... | Line 468... | ||
468 | .ret: |
468 | .ret: |
469 | ret |
469 | ret |
470 | ;----------------------------------------------------------------------------- |
470 | ;----------------------------------------------------------------------------- |
471 | align 4 |
471 | align 4 |
472 | sys_getevent: ;; f11 |
472 | sys_getevent: ;; f11 |
473 | mov ebx, [current_slot];ïîêà ýòî âîïðîñ, ÷åãî êóäû ñóâàòü.......... |
473 | mov ebx, [current_slot];пока это вопрос, чего куды сувать.......... |
474 | pushfd ; ýòî ñëåäñòâèå îáùåé êîíöåïöèè: ïóñòü ô-ÿ òåñòèðîâàíèÿ èìååò |
474 | pushfd ; это следствие общей концепции: пусть ф-я тестирования имеет |
475 | cli ; ïðàâî ðàññ÷èòûâàòü íà çàêðûòûå ïðåðûâàíèÿ, êàê ïðè âûçîâå èç shed |
475 | cli ; право рассчитывать на закрытые прерывания, как при вызове из shed |
476 | call get_event_for_app |
476 | call get_event_for_app |
477 | popfd |
477 | popfd |
478 | mov [esp+32], eax |
478 | mov [esp+32], eax |
479 | ret |
479 | ret |
480 | ;----------------------------------------------------------------------------- |
480 | ;----------------------------------------------------------------------------- |
Line 492... | Line 492... | ||
492 | ret |
492 | ret |
493 | ;----------------------------------------------------------------------------- |
493 | ;----------------------------------------------------------------------------- |
494 | align 4 |
494 | align 4 |
495 | get_event_for_app: ;; used from f10,f11,f23 |
495 | get_event_for_app: ;; used from f10,f11,f23 |
496 | ;info: |
496 | ;info: |
497 | ; êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ äëÿ ïðèëîæåíèé (f10,f23) |
497 | ; клиентская ф-я тестирования для приложений (f10,f23) |
498 | ;warning: |
498 | ;warning: |
499 | ; -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 |
500 | ; -may be assumed, that interrupt are disabled |
500 | ; -may be assumed, that interrupt are disabled |
501 | ; -it is not restriction for scratched registers |
501 | ; -it is not restriction for scratched registers |
502 | ;param: |
502 | ;param: |
503 | ; ebx - àäðåñ APPDATA ñëîòà òåñòèðîâàíèÿ |
503 | ; ebx - адрес APPDATA слота тестирования |
504 | ;retval: |
504 | ;retval: |
505 | ; eax - íîìåð ñîáûòèÿ (=0 => no events) |
505 | ; eax - номер события (=0 => no events) |
506 | movzx edi, bh ; bh is assumed as [CURRENT_TASK] |
506 | movzx edi, bh ; bh is assumed as [CURRENT_TASK] |
507 | shl edi, 5 |
507 | shl edi, 5 |
508 | add edi, CURRENT_TASK ; edi is assumed as [TASK_BASE] |
508 | add edi, CURRENT_TASK ; edi is assumed as [TASK_BASE] |
509 | mov ecx, [edi+TASKDATA.event_mask] |
509 | mov ecx, [edi+TASKDATA.event_mask] |
510 | and ecx, 0x7FFFFFFF |
510 | and ecx, 0x7FFFFFFF |
511 | ;-------------------------------------- |
511 | ;-------------------------------------- |
512 | align 4 |
512 | align 4 |
513 | .loop: ; ïîêà íå èñ÷åðïàåì âñå áèòû ìàñêè |
513 | .loop: ; пока не исчерпаем все биты маски |
514 | bsr eax, ecx ; íàõîäèì íåíóëåâîé áèò ìàñêè (31 -> 0) |
514 | bsr eax, ecx ; находим ненулевой бит маски (31 -> 0) |
515 | jz .no_events ; èñ÷åðïàëè âñå áèòû ìàñêè, íî íè÷åãî íå íàøëè ??? |
515 | jz .no_events ; исчерпали все биты маски, но ничего не нашли ??? |
516 | btr ecx, eax ; ñáðàñûâàåì ïðîâåðÿåìûé áèò ìàñêè |
516 | btr ecx, eax ; сбрасываем проверяемый бит маски |
517 | ; ïåðåõîäèì íà îáðàáîò÷èê ýòîãî (eax) áèòà |
517 | ; переходим на обработчик этого (eax) бита |
518 | cmp eax, 9 |
518 | cmp eax, 9 |
519 | jae .loop ; eax=[9..31], ignored (event 10...32) |
519 | jae .loop ; eax=[9..31], ignored (event 10...32) |
Line 520... | Line 520... | ||
520 | 520 | ||
521 | cmp eax, 3 |
521 | cmp eax, 3 |