| 1 | /* $Id: winprocess.h,v 1.2 1999-06-19 13:57:50 sandervl Exp $ */ | 
|---|
| 2 |  | 
|---|
| 3 | /* | 
|---|
| 4 | * Process definitions | 
|---|
| 5 | * | 
|---|
| 6 | * Copyright 1996 Alexandre Julliard | 
|---|
| 7 | */ | 
|---|
| 8 |  | 
|---|
| 9 | #ifndef __WINE_PROCESS_H | 
|---|
| 10 | #define __WINE_PROCESS_H | 
|---|
| 11 |  | 
|---|
| 12 | #include "windef.h" | 
|---|
| 13 | //#include "module.h" | 
|---|
| 14 |  | 
|---|
| 15 | //TODO: Fix this | 
|---|
| 16 | typedef ULONG WINE_MODREF; | 
|---|
| 17 |  | 
|---|
| 18 | struct _NE_MODULE; | 
|---|
| 19 | struct _THREAD_ENTRY; | 
|---|
| 20 | struct _UTINFO; | 
|---|
| 21 |  | 
|---|
| 22 | /* Current Process pseudo-handle - Returned by GetCurrentProcess*/ | 
|---|
| 23 | #define CURRENT_PROCESS_PSEUDOHANDLE ((HANDLE)0x7fffffff) | 
|---|
| 24 |  | 
|---|
| 25 | /* Win32 process environment database */ | 
|---|
| 26 | typedef struct | 
|---|
| 27 | { | 
|---|
| 28 | LPSTR            environ;          /* 00 Process environment strings */ | 
|---|
| 29 | DWORD            unknown1;         /* 04 Unknown */ | 
|---|
| 30 | LPSTR            cmd_line;         /* 08 Command line */ | 
|---|
| 31 | LPSTR            cur_dir;          /* 0c Current directory */ | 
|---|
| 32 | STARTUPINFOA    *startup_info;     /* 10 Startup information */ | 
|---|
| 33 | HANDLE           hStdin;           /* 14 Handle for standard input */ | 
|---|
| 34 | HANDLE           hStdout;          /* 18 Handle for standard output */ | 
|---|
| 35 | HANDLE           hStderr;          /* 1c Handle for standard error */ | 
|---|
| 36 | DWORD            unknown2;         /* 20 Unknown */ | 
|---|
| 37 | DWORD            inherit_console;  /* 24 Inherit console flag */ | 
|---|
| 38 | DWORD            break_type;       /* 28 Console events flag */ | 
|---|
| 39 | void            *break_sem;        /* 2c SetConsoleCtrlHandler semaphore */ | 
|---|
| 40 | void            *break_event;      /* 30 SetConsoleCtrlHandler event */ | 
|---|
| 41 | void            *break_thread;     /* 34 SetConsoleCtrlHandler thread */ | 
|---|
| 42 | void            *break_handlers;   /* 38 List of console handlers */ | 
|---|
| 43 | /* The following are Wine-specific fields */ | 
|---|
| 44 | CRITICAL_SECTION section;          /* 3c Env DB critical section */ | 
|---|
| 45 | LPWSTR           cmd_lineW;        /* 40 Unicode command line */ | 
|---|
| 46 | WORD             env_sel;          /* 44 Environment strings selector */ | 
|---|
| 47 | } ENVDB; | 
|---|
| 48 |  | 
|---|
| 49 | /* Win32 process database */ | 
|---|
| 50 | typedef struct _PDB | 
|---|
| 51 | { | 
|---|
| 52 | LONG             header[2];        /* 00 Kernel object header */ | 
|---|
| 53 | DWORD            unknown1;         /* 08 Unknown */ | 
|---|
| 54 | void            *event;            /* 0c Pointer to an event object (unused) */ | 
|---|
| 55 | DWORD            exit_code;        /* 10 Process exit code */ | 
|---|
| 56 | DWORD            unknown2;         /* 14 Unknown */ | 
|---|
| 57 | HANDLE           heap;             /* 18 Default process heap */ | 
|---|
| 58 | HANDLE           mem_context;      /* 1c Process memory context */ | 
|---|
| 59 | DWORD            flags;            /* 20 Flags */ | 
|---|
| 60 | void            *pdb16;            /* 24 DOS PSP */ | 
|---|
| 61 | WORD             PSP_sel;          /* 28 Selector to DOS PSP */ | 
|---|
| 62 | WORD             module;           /* 2a IMTE for the process module */ | 
|---|
| 63 | WORD             threads;          /* 2c Number of threads */ | 
|---|
| 64 | WORD             running_threads;  /* 2e Number of running threads */ | 
|---|
| 65 | WORD             unknown3;         /* 30 Unknown */ | 
|---|
| 66 | WORD             ring0_threads;    /* 32 Number of ring 0 threads */ | 
|---|
| 67 | HANDLE           system_heap;      /* 34 System heap to allocate handles */ | 
|---|
| 68 | HTASK            task;             /* 38 Win16 task */ | 
|---|
| 69 | void            *mem_map_files;    /* 3c Pointer to mem-mapped files */ | 
|---|
| 70 | ENVDB           *env_db;           /* 40 Environment database */ | 
|---|
| 71 | void            *handle_table;     /* 44 Handle table */ | 
|---|
| 72 | struct _PDB     *parent;           /* 48 Parent process */ | 
|---|
| 73 | WINE_MODREF     *modref_list;      /* 4c MODREF list */ | 
|---|
| 74 | void            *thread_list;      /* 50 List of threads */ | 
|---|
| 75 | void            *debuggee_CB;      /* 54 Debuggee context block */ | 
|---|
| 76 | void            *local_heap_free;  /* 58 Head of local heap free list */ | 
|---|
| 77 | DWORD            unknown4;         /* 5c Unknown */ | 
|---|
| 78 | CRITICAL_SECTION crit_section;     /* 60 Critical section */ | 
|---|
| 79 | DWORD            unknown5[3];      /* 78 Unknown */ | 
|---|
| 80 | void            *console;          /* 84 Console */ | 
|---|
| 81 | DWORD            tls_bits[2];      /* 88 TLS in-use bits */ | 
|---|
| 82 | DWORD            process_dword;    /* 90 Unknown */ | 
|---|
| 83 | struct _PDB     *group;            /* 94 Process group */ | 
|---|
| 84 | WINE_MODREF     *exe_modref;       /* 98 MODREF for the process EXE */ | 
|---|
| 85 | LPTOP_LEVEL_EXCEPTION_FILTER top_filter; /* 9c Top exception filter */ | 
|---|
| 86 | DWORD            priority;         /* a0 Priority level */ | 
|---|
| 87 | HANDLE           heap_list;        /* a4 Head of process heap list */ | 
|---|
| 88 | void            *heap_handles;     /* a8 Head of heap handles list */ | 
|---|
| 89 | DWORD            unknown6;         /* ac Unknown */ | 
|---|
| 90 | void            *console_provider; /* b0 Console provider (??) */ | 
|---|
| 91 | WORD             env_selector;     /* b4 Selector to process environment */ | 
|---|
| 92 | WORD             error_mode;       /* b6 Error mode */ | 
|---|
| 93 | HANDLE           load_done_evt;    /* b8 Event for process loading done */ | 
|---|
| 94 | struct _UTINFO  *UTState;          /* bc Head of Univeral Thunk list */ | 
|---|
| 95 | DWORD            unknown8;         /* c0 Unknown (NT) */ | 
|---|
| 96 | LCID             locale;           /* c4 Locale to be queried by GetThreadLocale (NT) */ | 
|---|
| 97 | /* The following are Wine-specific fields */ | 
|---|
| 98 | void            *server_pid;       /*    Server id for this process */ | 
|---|
| 99 | HANDLE          *dos_handles;      /*    Handles mapping DOS -> Win32 */ | 
|---|
| 100 | struct _PDB     *next;             /*    List reference - list of PDB's */ | 
|---|
| 101 | } PDB; | 
|---|
| 102 |  | 
|---|
| 103 | /* Process flags */ | 
|---|
| 104 | #define PDB32_WIN16_PROC    0x0008  /* Win16 process */ | 
|---|
| 105 | #define PDB32_DOS_PROC      0x0010  /* Dos process */ | 
|---|
| 106 | #define PDB32_CONSOLE_PROC  0x0020  /* Console process */ | 
|---|
| 107 | #define PDB32_FILE_APIS_OEM 0x0040  /* File APIs are OEM */ | 
|---|
| 108 | #define PDB32_WIN32S_PROC   0x8000  /* Win32s process */ | 
|---|
| 109 |  | 
|---|
| 110 | /* USER signal proc flags and codes */ | 
|---|
| 111 | /* See PROCESS_CallUserSignalProc for comments */ | 
|---|
| 112 | #define USIG_FLAGS_WIN32          0x0001 | 
|---|
| 113 | #define USIG_FLAGS_GUI            0x0002 | 
|---|
| 114 | #define USIG_FLAGS_FEEDBACK       0x0004 | 
|---|
| 115 | #define USIG_FLAGS_FAULT          0x0008 | 
|---|
| 116 |  | 
|---|
| 117 | #define USIG_DLL_UNLOAD_WIN16     0x0001 | 
|---|
| 118 | #define USIG_DLL_UNLOAD_WIN32     0x0002 | 
|---|
| 119 | #define USIG_FAULT_DIALOG_PUSH    0x0003 | 
|---|
| 120 | #define USIG_FAULT_DIALOG_POP     0x0004 | 
|---|
| 121 | #define USIG_DLL_UNLOAD_ORPHANS   0x0005 | 
|---|
| 122 | #define USIG_THREAD_INIT          0x0010 | 
|---|
| 123 | #define USIG_THREAD_EXIT          0x0020 | 
|---|
| 124 | #define USIG_PROCESS_CREATE       0x0100 | 
|---|
| 125 | #define USIG_PROCESS_INIT         0x0200 | 
|---|
| 126 | #define USIG_PROCESS_EXIT         0x0300 | 
|---|
| 127 | #define USIG_PROCESS_DESTROY      0x0400 | 
|---|
| 128 | #define USIG_PROCESS_RUNNING      0x0500 | 
|---|
| 129 | #define USIG_PROCESS_LOADED       0x0600 | 
|---|
| 130 |  | 
|---|
| 131 | /* [GS]etProcessDword offsets */ | 
|---|
| 132 | #define  GPD_APP_COMPAT_FLAGS    (-56) | 
|---|
| 133 | #define  GPD_LOAD_DONE_EVENT     (-52) | 
|---|
| 134 | #define  GPD_HINSTANCE16         (-48) | 
|---|
| 135 | #define  GPD_WINDOWS_VERSION     (-44) | 
|---|
| 136 | #define  GPD_THDB                (-40) | 
|---|
| 137 | #define  GPD_PDB                 (-36) | 
|---|
| 138 | #define  GPD_STARTF_SHELLDATA    (-32) | 
|---|
| 139 | #define  GPD_STARTF_HOTKEY       (-28) | 
|---|
| 140 | #define  GPD_STARTF_SHOWWINDOW   (-24) | 
|---|
| 141 | #define  GPD_STARTF_SIZE         (-20) | 
|---|
| 142 | #define  GPD_STARTF_POSITION     (-16) | 
|---|
| 143 | #define  GPD_STARTF_FLAGS        (-12) | 
|---|
| 144 | #define  GPD_PARENT              (- 8) | 
|---|
| 145 | #define  GPD_FLAGS               (- 4) | 
|---|
| 146 | #define  GPD_USERDATA            (  0) | 
|---|
| 147 |  | 
|---|
| 148 | extern DWORD WINAPI GetProcessDword( DWORD dwProcessID, INT offset ); | 
|---|
| 149 | void WINAPI SetProcessDword( DWORD dwProcessID, INT offset, DWORD value ); | 
|---|
| 150 |  | 
|---|
| 151 | /* scheduler/environ.c */ | 
|---|
| 152 | extern BOOL ENV_BuildEnvironment( PDB *pdb ); | 
|---|
| 153 | extern BOOL ENV_InheritEnvironment( PDB *pdb, LPCSTR env ); | 
|---|
| 154 | extern void ENV_FreeEnvironment( PDB *pdb ); | 
|---|
| 155 |  | 
|---|
| 156 | /* scheduler/process.c */ | 
|---|
| 157 | extern BOOL PROCESS_Init( void ); | 
|---|
| 158 | extern PDB *PROCESS_Current(void); | 
|---|
| 159 | extern BOOL PROCESS_IsCurrent( HANDLE handle ); | 
|---|
| 160 | extern PDB *PROCESS_Initial(void); | 
|---|
| 161 | extern PDB *PROCESS_IdToPDB( DWORD id ); | 
|---|
| 162 | extern void PROCESS_CallUserSignalProc( UINT uCode, DWORD dwThreadOrProcessId, HMODULE hModule ); | 
|---|
| 163 | extern PDB *PROCESS_Create( struct _NE_MODULE *pModule, | 
|---|
| 164 | LPCSTR cmd_line, LPCSTR env, | 
|---|
| 165 | HINSTANCE16 hInstance, HINSTANCE16 hPrevInstance, | 
|---|
| 166 | LPSECURITY_ATTRIBUTES psa, LPSECURITY_ATTRIBUTES tsa, | 
|---|
| 167 | BOOL inherit, | 
|---|
| 168 | STARTUPINFOA *startup, PROCESS_INFORMATION *info ); | 
|---|
| 169 | extern void PROCESS_FreePDB( PDB *pdb ); | 
|---|
| 170 |  | 
|---|
| 171 | #endif  /* __WINE_PROCESS_H */ | 
|---|
| 172 |  | 
|---|