;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; RDOS operating system ; Copyright (C) 1988-2000, Leif Ekblad ; ; This program is free software; you can redistribute it and/or modify ; it under the terms of the GNU General Public License as published by ; the Free Software Foundation; either version 2 of the License, or ; (at your option) any later version. The only exception to this rule ; is for commercial usage in embedded systems. For information on ; usage in commercial embedded systems, contact embedded@rdos.net ; ; This program is distributed in the hope that it will be useful, ; but WITHOUT ANY WARRANTY; without even the implied warranty of ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ; GNU General Public License for more details. ; ; You should have received a copy of the GNU General Public License ; along with this program; if not, write to the Free Software ; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ; ; The author of this program may be contacted at leif@rdos.net ; ; PROC.ASM ; Thread & process handling module ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; INCLUDE protseg.def INCLUDE ..\user.def INCLUDE ..\os.def INCLUDE ..\os.inc INCLUDE system.def INCLUDE system.inc INCLUDE ..\user.inc INCLUDE ..\driver.def INCLUDE ..\handle.inc include proc.inc thread_data_seg STRUC create_thread_hooks DB ? terminate_thread_hooks DB ? create_process_hooks DB ? terminate_process_hooks DB ? start_program_hooks DB ? end_program_hooks DB ? init_tasking_hooks DB ? start_program_arr DD 2*32 DUP(?) end_program_arr DD 2*32 DUP(?) create_process_arr DD 2*32 DUP(?) terminate_process_arr DD 2*32 DUP(?) create_thread_arr DD 2*8 DUP(?) terminate_thread_arr DD 2*8 DUP(?) init_tasking_arr DD 2*64 DUP(?) thread_data_seg ENDS .386p code SEGMENT byte public use16 'CODE' extrn init_process_mem:near extrn init_program_mem:near extrn free_process_proc:word extrn free_handle_process:near extrn init_double_fault:near assume cs:code ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: TRAP_CREATE_THREAD ; ; DESCRIPTION: Handle CreateThread hooks ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; trap_create_thread PROC near sti push cx mov ax,proc_data_sel mov ds,ax mov cl,ds:create_thread_hooks or cl,cl je trap_create_thread_done mov bx,OFFSET create_thread_arr trap_create_thread_loop: push ds push bx push cx call fword ptr [bx] pop cx pop bx pop ds add bx,8 dec cl jnz trap_create_thread_loop trap_create_thread_done: pop cx ret trap_create_thread ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: TRAP_TERMINATE_THREAD ; ; DESCRIPTION: Handle TerminateThread hooks ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; trap_terminate_thread PROC near push cx mov ax,proc_data_sel mov ds,ax mov cl,ds:terminate_thread_hooks or cl,cl je trap_terminate_thread_done mov bx,OFFSET terminate_thread_arr trap_terminate_thread_loop: push ds push bx push cx call fword ptr [bx] pop cx pop bx pop ds add bx,8 dec cl jnz trap_terminate_thread_loop trap_terminate_thread_done: pop cx ret trap_terminate_thread ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: TRAP_START_PROGRAM ; ; DESCRIPTION: Handle StartProgram hooks ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; trap_start_program PROC near push cx push si ; call init_program_mem ; mov ax,proc_data_sel mov ds,ax mov cl,ds:start_program_hooks or cl,cl je trap_start_program_done ; mov bx,OFFSET start_program_arr trap_start_program_loop: push ds push bx push cx call fword ptr [bx] pop cx pop bx pop ds add bx,8 dec cl jnz trap_start_program_loop trap_start_program_done: pop si pop cx ret trap_start_program ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: TRAP_CREATE_PROCESS ; ; DESCRIPTION: Handle CreateProcess hooks ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; trap_create_process PROC near sti push cx push si ; call init_process_mem InitAppProcess ; mov ax,proc_data_sel mov ds,ax mov cl,ds:create_process_hooks or cl,cl je trap_create_process_done mov bx,OFFSET create_process_arr trap_create_process_loop: push ds push bx push cx call fword ptr [bx] pop cx pop bx pop ds add bx,8 dec cl jnz trap_create_process_loop trap_create_process_done: pop si pop cx ; xor ebp,ebp call trap_create_thread call trap_start_program ret trap_create_process ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: TRAP_END_PROGRAM ; ; DESCRIPTION: Handle EndProgram hooks ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; trap_end_program PROC near push cx mov ax,proc_data_sel mov ds,ax mov cl,ds:end_program_hooks or cl,cl je trap_end_program_done ; mov bx,OFFSET end_program_arr trap_end_program_loop: push ds push bx push cx call fword ptr [bx] pop cx pop bx pop ds add bx,8 dec cl jnz trap_end_program_loop trap_end_program_done: ExitAppProcess pop cx ret trap_end_program ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: TRAP_TERMINATE_PROCESS ; ; DESCRIPTION: Handle TerminateProcess hooks ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; trap_terminate_process PROC near call trap_end_program call cs:free_process_proc push cx mov ax,proc_data_sel mov ds,ax mov cl,ds:terminate_process_hooks or cl,cl je trap_terminate_process_done mov bx,OFFSET terminate_process_arr trap_terminate_process_loop: push ds push bx push cx call fword ptr [bx] pop cx pop bx pop ds add bx,8 dec cl jnz trap_terminate_process_loop trap_terminate_process_done: pop cx ret trap_terminate_process ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: TRAP_INIT_TASKING ; ; DESCRIPTION: Handle init-tasking hooks ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; trap_init_tasking PROC near InitTrapGates call trap_create_process push cx mov ax,proc_data_sel mov ds,ax mov cl,ds:init_tasking_hooks or cl,cl je trap_init_tasking_done mov bx,OFFSET init_tasking_arr trap_init_tasking_loop: push ds push bx push cx call fword ptr [bx] pop cx pop bx pop ds ; add bx,8 dec cl jnz trap_init_tasking_loop trap_init_tasking_done: pop cx ret trap_init_tasking ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: HOOK_CREATE_THREAD ; ; DESCRIPTION: Add CreateThread hook ; ; PARAMETERS: ES:EDI Callback ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; hook_create_thread_name DB 'Hook Create Thread',0 hook_create_thread PROC far push ds push ax push bx mov ax,proc_data_sel mov ds,ax mov al,ds:create_thread_hooks mov bl,al xor bh,bh shl bx,3 add bx,OFFSET create_thread_arr mov [bx],edi mov [bx+4],es inc al mov ds:create_thread_hooks,al pop bx pop ax pop ds retf32 hook_create_thread ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: HOOK_TERMINATE_THREAD ; ; DESCRIPTION: Add TerminateThread hook ; ; PARAMETERS: ES:EDI Callback ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; hook_terminate_thread_name DB 'Hook Terminate Thread',0 hook_terminate_thread PROC far push ds push ax push bx mov ax,proc_data_sel mov ds,ax mov al,ds:terminate_thread_hooks mov bl,al xor bh,bh shl bx,3 add bx,OFFSET terminate_thread_arr mov [bx],edi mov [bx+4],es inc al mov ds:terminate_thread_hooks,al pop bx pop ax pop ds retf32 hook_terminate_thread ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: HOOK_CREATE_PROCESS ; ; DESCRIPTION: Add CreateProcess hook ; ; PARAMETERS: ES:EDI Callback ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; hook_create_process_name DB 'Hook Create Process',0 hook_create_process PROC far push ds push ax push bx mov ax,proc_data_sel mov ds,ax mov al,ds:create_process_hooks mov bl,al xor bh,bh shl bx,3 add bx,OFFSET create_process_arr mov [bx],edi mov [bx+4],es inc al mov ds:create_process_hooks,al pop bx pop ax pop ds retf32 hook_create_process ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: HOOK_TERMINATE_PROCESS ; ; DESCRIPTION: Add TerminateProcess hook ; ; PARAMETERS: ES:EDI Callback ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; hook_terminate_process_name DB 'Hook Terminate Process',0 hook_terminate_process PROC far push ds push ax push bx mov ax,proc_data_sel mov ds,ax mov al,ds:terminate_process_hooks mov bl,al xor bh,bh shl bx,3 add bx,OFFSET terminate_process_arr mov [bx],edi mov [bx+4],es inc al mov ds:terminate_process_hooks,al pop bx pop ax pop ds retf32 hook_terminate_process ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: HOOK_START_PROGRAM ; ; DESCRIPTION: Add StartProgram hook ; ; PARAMETERS: ES:EDI Callback ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; hook_start_program_name DB 'Hook Start Program',0 hook_start_program PROC far push ds push ax push bx mov ax,proc_data_sel mov ds,ax mov al,ds:start_program_hooks mov bl,al xor bh,bh shl bx,3 add bx,OFFSET start_program_arr mov [bx],edi mov [bx+4],es inc al mov ds:start_program_hooks,al pop bx pop ax pop ds retf32 hook_start_program ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: HOOK_END_PROGRAM ; ; DESCRIPTION: Add EndProgram hook ; ; PARAMETERS: ES:EDI Callback ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; hook_end_program_name DB 'Hook End Program',0 hook_end_program PROC far push ds push ax push bx mov ax,proc_data_sel mov ds,ax mov al,ds:end_program_hooks mov bl,al xor bh,bh shl bx,3 add bx,OFFSET end_program_arr mov [bx],edi mov [bx+4],es inc al mov ds:end_program_hooks,al pop bx pop ax pop ds retf32 hook_end_program ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: HOOK_INIT_TASKING ; ; DESCRIPTION: Add init-tasking hook ; ; PARAMETERS: ES:EDI Callback ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; hook_init_tasking_name DB 'Hook Init Tasking',0 hook_init_tasking PROC far push ds push ax push bx mov ax,proc_data_sel mov ds,ax mov al,ds:init_tasking_hooks mov bl,al xor bh,bh shl bx,3 add bx,OFFSET init_tasking_arr mov [bx],edi mov [bx+4],es inc al mov ds:init_tasking_hooks,al pop bx pop ax pop ds retf32 hook_init_tasking ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: NotifyThreadCreated ; ; DESCRIPTION: Notify thread created ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; notify_thread_created_name DB 'Notify Thread Created',0 notify_thread_created PROC far call trap_create_thread retf32 notify_thread_created ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: NotifyThreadExit ; ; DESCRIPTION: Notify thread exit ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; notify_thread_exit_name DB 'Notify Thread Exit',0 notify_thread_exit PROC far call trap_terminate_thread retf32 notify_thread_exit ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: NotifyProcessCreated ; ; DESCRIPTION: Notify process created ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; notify_process_created_name DB 'Notify Process Created',0 notify_process_created PROC far call trap_create_process retf32 notify_process_created ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: NotifyProcessExit ; ; DESCRIPTION: Notify process exit ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; notify_process_exit_name DB 'Notify Process Exit',0 notify_process_exit PROC far call free_handle_process call trap_terminate_process retf32 notify_process_exit ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: NotifyStartProgram ; ; DESCRIPTION: Notify program started ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; notify_start_program_name DB 'Notify Start Program',0 notify_start_program PROC far call trap_start_program retf32 notify_start_program ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: NotifyEndProgram ; ; DESCRIPTION: Notify program end ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; notify_end_program_name DB 'Notify End Program',0 notify_end_program PROC far call free_handle_process call trap_end_program retf32 notify_end_program ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: NotifyInitTasking ; ; DESCRIPTION: Notify init tasking ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; notify_init_tasking_name DB 'Notify Init Tasking',0 notify_init_tasking PROC far call init_double_fault call trap_init_tasking retf32 notify_init_tasking ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: sim_sti ; ; DESCRIPTION: Simulate STI ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; sim_sti_name DB 'Simulate Sti',0 sim_sti PROC far push ds push ax sti GetThread mov ds,ax mov ds,ds:p_process_sel mov ds:ms_virt_flags,7200h sim_sti_test_wake: cmp ds:ms_wait_sti,0 jz sim_sti_nowake push si mov si,OFFSET ms_wait_sti Wake pop si jmp sim_sti_test_wake sim_sti_nowake: pop ax pop ds retf32 sim_sti ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: sim_cli ; ; DESCRIPTION: Simulate CLI ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; sim_cli_name DB 'Simulate Cli',0 sim_cli PROC far push ds push ax GetThread mov ds,ax mov ds,ds:p_process_sel cli mov ds:ms_cli_thread,ax mov ds:ms_virt_flags,7000h sti pop ax pop ds retf32 sim_cli ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: set_flags ; ; DESCRIPTION: Simulate set flags ; ; PARAMETERS: AX FLAGS ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; public set_flags set_flags PROC near push ax GetThread mov ds,ax mov bx,ax pop ax mov ds,ds:p_process_sel cli mov ds:ms_cli_thread,bx mov bx,ax and bx,200h or bx,7000h mov ds:ms_virt_flags,bx sti test bx,200h jz set_flags_nowake set_flags_test_wake: cmp ds:ms_wait_sti,0 jz set_flags_nowake push si mov si,OFFSET ms_wait_sti Wake pop si jmp set_flags_test_wake set_flags_nowake: and ax,NOT 7000h ; or ax,ds:ms_iopl or ax,200h ret set_flags ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: sim_set_flags ; ; DESCRIPTION: Simulate set flags ; ; PARAMETERS: AX FLAGS ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; sim_set_flags_name DB 'Set Flags',0 sim_set_flags PROC far push ds push bx call set_flags pop bx pop ds retf32 sim_set_flags ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: get_flags ; ; DESCRIPTION: Modify int bit in simulated flags ; ; PARAMETERS: AX FLAGS ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; public get_flags get_flags PROC near push ax GetThread mov ds,ax pop ax mov ds,ds:p_process_sel and ax,NOT 200h mov bx,ds:ms_virt_flags and bx,200h or ax,bx or ax,7000h ret get_flags ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: sim_get_flags ; ; DESCRIPTION: Modify int bit in simulated flags ; ; PARAMETERS: AX FLAGS ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; sim_get_flags_name DB 'Get Flags',0 sim_get_flags PROC far push ds push bx call get_flags pop bx pop ds retf32 sim_get_flags ENDP ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; ; ; NAME: INIT_THREAD ; ; DESCRIPTION: Init module ; ; PARAMETERS: ; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; terminate_user_start: TerminateThread terminate_user_end: public init_thread init_thread PROC near pusha push ds ; mov bx,proc_data_sel mov eax,SIZE thread_data_seg AllocateFixedSystemMem mov ds,bx xor ax,ax mov ds:create_thread_hooks,al mov ds:terminate_thread_hooks,al mov ds:start_program_hooks,al mov ds:end_program_hooks,al mov ds:create_process_hooks,al mov ds:terminate_process_hooks,al mov ds:init_tasking_hooks,al ; mov eax,OFFSET terminate_user_end - OFFSET terminate_user_start AllocateSmallLinear mov bx,term_code_sel mov ecx,eax CreateDataSelector16 ; mov es,bx xor di,di mov ax,cs mov ds,ax mov si,OFFSET terminate_user_start mov cx,OFFSET terminate_user_end - OFFSET terminate_user_start rep movsb and bx,0FFF8h mov ax,gdt_sel mov ds,ax mov byte ptr [bx+5],0FAh ; mov edx,fixed_process_linear mov ecx,SIZE process_seg mov bx,process_sel CreateDataSelector16 ; mov ax,cs mov ds,ax mov es,ax xor ebx,ebx xor esi,esi xor edi,edi ; mov si,OFFSET hook_create_thread mov di,OFFSET hook_create_thread_name xor cl,cl mov ax,hook_create_thread_nr RegisterOsGate ; mov si,OFFSET hook_terminate_thread mov di,OFFSET hook_terminate_thread_name xor cl,cl mov ax,hook_terminate_thread_nr RegisterOsGate ; mov si,OFFSET hook_create_process mov di,OFFSET hook_create_process_name xor cl,cl mov ax,hook_create_process_nr RegisterOsGate ; mov si,OFFSET hook_terminate_process mov di,OFFSET hook_terminate_process_name xor cl,cl mov ax,hook_terminate_process_nr RegisterOsGate ; mov si,OFFSET hook_start_program mov di,OFFSET hook_start_program_name xor cl,cl mov ax,hook_start_program_nr RegisterOsGate ; mov si,OFFSET hook_end_program mov di,OFFSET hook_end_program_name xor cl,cl mov ax,hook_end_program_nr RegisterOsGate ; mov si,OFFSET hook_init_tasking mov di,OFFSET hook_init_tasking_name xor cl,cl mov ax,hook_init_tasking_nr RegisterOsGate ; mov si,OFFSET notify_thread_created mov di,OFFSET notify_thread_created_name xor cl,cl mov ax,notify_thread_created_nr RegisterOsGate ; mov si,OFFSET notify_thread_exit mov di,OFFSET notify_thread_exit_name xor cl,cl mov ax,notify_thread_exit_nr RegisterOsGate ; mov si,OFFSET notify_process_created mov di,OFFSET notify_process_created_name xor cl,cl mov ax,notify_process_created_nr RegisterOsGate ; mov si,OFFSET notify_process_exit mov di,OFFSET notify_process_exit_name xor cl,cl mov ax,notify_process_exit_nr RegisterOsGate ; mov si,OFFSET notify_start_program mov di,OFFSET notify_start_program_name xor cl,cl mov ax,notify_start_program_nr RegisterOsGate ; mov si,OFFSET notify_end_program mov di,OFFSET notify_end_program_name xor cl,cl mov ax,notify_end_program_nr RegisterOsGate ; mov si,OFFSET notify_init_tasking mov di,OFFSET notify_init_tasking_name xor cl,cl mov ax,notify_init_tasking_nr RegisterOsGate ; mov si,OFFSET sim_sti mov di,OFFSET sim_sti_name xor cl,cl mov ax,sim_sti_nr RegisterOsGate ; mov si,OFFSET sim_cli mov di,OFFSET sim_cli_name xor cl,cl mov ax,sim_cli_nr RegisterOsGate ; mov si,OFFSET sim_set_flags mov di,OFFSET sim_set_flags_name xor cl,cl mov ax,sim_set_flags_nr RegisterOsGate ; mov si,OFFSET sim_get_flags mov di,OFFSET sim_get_flags_name xor cl,cl mov ax,sim_get_flags_nr RegisterOsGate ; pop ds popa ret init_thread ENDP code ENDS END