| [21375] | 1 | /* $Id: win32k.h,v 1.13 2001-07-10 05:31:36 bird Exp $ | 
|---|
|  | 2 | * | 
|---|
|  | 3 | * Top level make file for the Win32k library. | 
|---|
|  | 4 | * Contains library and 32-bit IOCtl definition. | 
|---|
|  | 5 | * | 
|---|
|  | 6 | * Copyright (c) 2000 knut st. osmundsen (knut.stange.osmundsen@pmsc.no) | 
|---|
|  | 7 | * | 
|---|
|  | 8 | * Project Odin Software License can be found in LICENSE.TXT | 
|---|
|  | 9 | * | 
|---|
|  | 10 | */ | 
|---|
|  | 11 | /* NOINC */ | 
|---|
|  | 12 | #ifndef _WIN32K_H_ | 
|---|
|  | 13 | #define _WIN32K_H_ | 
|---|
|  | 14 | /* INC */ | 
|---|
|  | 15 |  | 
|---|
|  | 16 | /******************************************************************************* | 
|---|
|  | 17 | *   Defined Constants And Macros                                               * | 
|---|
|  | 18 | *******************************************************************************/ | 
|---|
|  | 19 | /* | 
|---|
|  | 20 | * IOCtls categories. | 
|---|
|  | 21 | */ | 
|---|
|  | 22 | #define IOCTL_W32K_K32          0xC1 | 
|---|
|  | 23 | #define IOCTL_W32K_ELF          0xC2 | 
|---|
|  | 24 |  | 
|---|
|  | 25 | /* | 
|---|
|  | 26 | * K32 category - these are the functions found in the k32 directory. | 
|---|
|  | 27 | */ | 
|---|
|  | 28 | #define K32_ALLOCMEMEX          0x01 | 
|---|
|  | 29 | #define K32_QUERYOTES           0x02 | 
|---|
|  | 30 | #define K32_QUERYOPTIONSSTATUS  0x03 | 
|---|
|  | 31 | #define K32_SETOPTIONS          0x04 | 
|---|
|  | 32 | #define K32_PROCESSREADWRITE    0x05 | 
|---|
|  | 33 | #define K32_HANDLESYSTEMEVENT   0x06 | 
|---|
|  | 34 | #define K32_QUERYSYSTEMMEMINFO  0x07 | 
|---|
|  | 35 | #define K32_QUERYCALLGATE       0x08 | 
|---|
|  | 36 | #define K32_SETENVIRONMENT      0x09 | 
|---|
|  | 37 | #define K32_KILLPROCESSEX       0x0a | 
|---|
|  | 38 | #define K32_LASTIOCTLFUNCTION   K32_KILLPROCESSEX | 
|---|
|  | 39 |  | 
|---|
|  | 40 |  | 
|---|
|  | 41 | /* | 
|---|
|  | 42 | * Elf category | 
|---|
|  | 43 | */ | 
|---|
|  | 44 | #define ELF_DUMMY               0x01 | 
|---|
|  | 45 |  | 
|---|
|  | 46 |  | 
|---|
|  | 47 | /* | 
|---|
|  | 48 | * DosAllocMemEx - Extra (bsememf.h) flag definitions. | 
|---|
|  | 49 | */ | 
|---|
|  | 50 | #define OBJ_ALIGNDEFAULT        0x00000000UL | 
|---|
|  | 51 | #define OBJ_ALIGN64K            0x10000000UL | 
|---|
|  | 52 | #define OBJ_ALIGNPAGE           0x20000000UL | 
|---|
|  | 53 | #define OBJ_ALIGNMASK           0x30000000UL | 
|---|
|  | 54 | #define OBJ_LOCATION            0x80000000UL | 
|---|
|  | 55 | #ifndef OBJ_SELMAPALL | 
|---|
|  | 56 | #define OBJ_SELMAPALL           0x00000800UL    /* This isn't ours. It just a dropout from bsememf.h */ | 
|---|
|  | 57 | #endif | 
|---|
|  | 58 | #ifndef OBJ_ANY | 
|---|
|  | 59 | #define OBJ_ANY                 0x00000400UL    /* This isn't ours. It just no present in all toolkits. */ | 
|---|
|  | 60 | #endif | 
|---|
|  | 61 |  | 
|---|
|  | 62 | /* | 
|---|
|  | 63 | * System event Identifiers. | 
|---|
|  | 64 | */ | 
|---|
|  | 65 | #define K32_SYSEVENT_SM_MOUSE               0x00    /* dh SendEvent - Session Manager (mouse)    */ | 
|---|
|  | 66 | #define K32_SYSEVENT_CTRL_BREAK             0x01    /* dh SendEvent - Ctrl-Break                 */ | 
|---|
|  | 67 | #define K32_SYSEVENT_CTRL_C                 0x02    /* dh SendEvent - Ctrl-C                     */ | 
|---|
|  | 68 | #define K32_SYSEVENT_CTRL_SCREEN_LOCK       0x03    /* dh SendEvent - Ctrl-ScrollLock            */ | 
|---|
|  | 69 | #define K32_SYSEVENT_CTRL_PRINT_SCREEN      0x04    /* dh SendEvent - Ctrl-PrtSc                 */ | 
|---|
|  | 70 | #define K32_SYSEVENT_SHIFT_PRINT_SCREEN     0x05    /* dh SendEvent - Shift-PrtSc                */ | 
|---|
|  | 71 | #define K32_SYSEVENT_SM_KEYBOARD            0x06    /* dh SendEvent - Session Manager (keyboard) */ | 
|---|
|  | 72 | #define K32_SYSEVENT_SM_CTRL_ALT_DELETE     0x07    /* dh SendEvent - Ctrl-Alt-Del               */ | 
|---|
|  | 73 | #define K32_SYSEVENT_HOT_PLUG               0x08    /* dh SendEvent - Keyboard Hot Plug/Reset    */ | 
|---|
|  | 74 | #define K32_SYSEVENT_POWER                  0x09    /* dh SendEvent - Power suspend event        */ | 
|---|
|  | 75 | #define K32_SYSEVENT_POWEROFF               0x0a    /* dh SendEvent - Power off event            */ | 
|---|
|  | 76 | #define K32_SYSEVENT_CTRL_ALT_2xNUMLOCK     0x0b    /* VectorSDF    - System Dump                */ | 
|---|
|  | 77 | #define K32_SYSEVENT_LAST                   K32_SYSEVENT_CTRL_ALT_2xNUMLOCK | 
|---|
|  | 78 |  | 
|---|
|  | 79 | /* | 
|---|
|  | 80 | * System Memory Info flags. | 
|---|
|  | 81 | */ | 
|---|
|  | 82 | #define K32_SYSMEMINFO_ALL                  0       /* Everything is queried. */ | 
|---|
|  | 83 | #define K32_SYSMEMINFO_SWAPFILE             0x01    /* Swapfile stuff is queried. */ | 
|---|
|  | 84 | #define K32_SYSMEMINFO_PAGING               0x02    /* Paging and Physical memory stuff is queried. */ | 
|---|
|  | 85 | #define K32_SYSMEMINFO_VM                   0x04    /* Virtual memory stuff is all queried. */ | 
|---|
|  | 86 |  | 
|---|
|  | 87 |  | 
|---|
|  | 88 | /* | 
|---|
|  | 89 | * DosKillProcessEx extra flags. | 
|---|
|  | 90 | * (DKP_PROCESS and DKP_PROCESSTREE is defined in the OS/2 toolkit headers.) | 
|---|
|  | 91 | */ | 
|---|
|  | 92 | #define DKP_ALLDECENDANTS               0x00000002UL/* Kill process all its decendants. */ | 
|---|
|  | 93 | #define DKP_SCREENGROUP                 0x00000003UL/* Kill all processes in that screen group. */ | 
|---|
|  | 94 | #define DKP_ACTION_MASK                 0x00000003UL/* Mask for actions (validation) */ | 
|---|
|  | 95 | #define DKP_FLAG_MASK                   (DKP_FLAG_KILL9) /* Mask for flags (validation) */ | 
|---|
|  | 96 | #define DKP_FLAG_KILL9                  0x80000000UL/* Very forceful kill */ | 
|---|
|  | 97 | /*  - not necessarily properly cleaned up. */ | 
|---|
|  | 98 |  | 
|---|
|  | 99 |  | 
|---|
|  | 100 | /* NOINC */ | 
|---|
|  | 101 | #ifndef INCL_16                         /* We don't need this in 16-bit code. */ | 
|---|
|  | 102 | /* INC */ | 
|---|
|  | 103 |  | 
|---|
|  | 104 | /******************************************************************************* | 
|---|
|  | 105 | *   Assembly Fixes                                                             * | 
|---|
|  | 106 | *******************************************************************************/ | 
|---|
|  | 107 | /*ASM | 
|---|
|  | 108 | BOOL struc | 
|---|
|  | 109 | dd ? | 
|---|
|  | 110 | BOOL ends | 
|---|
|  | 111 |  | 
|---|
|  | 112 | PID struc | 
|---|
|  | 113 | dd ? | 
|---|
|  | 114 | PID ends | 
|---|
|  | 115 |  | 
|---|
|  | 116 | HMODULE struc | 
|---|
|  | 117 | dd ? | 
|---|
|  | 118 | HMODULE ends | 
|---|
|  | 119 |  | 
|---|
|  | 120 | HEV struc | 
|---|
|  | 121 | dd ? | 
|---|
|  | 122 | HEV ends | 
|---|
|  | 123 |  | 
|---|
|  | 124 | PVOID struc | 
|---|
|  | 125 | dd ? | 
|---|
|  | 126 | PVOID ends | 
|---|
|  | 127 |  | 
|---|
|  | 128 | PPVOID struc | 
|---|
|  | 129 | dd ? | 
|---|
|  | 130 | PPVOID ends | 
|---|
|  | 131 |  | 
|---|
|  | 132 | PUSHORT struc | 
|---|
|  | 133 | dd ? | 
|---|
|  | 134 | PUSHORT ends | 
|---|
|  | 135 |  | 
|---|
|  | 136 | PSZ struc | 
|---|
|  | 137 | dd ? | 
|---|
|  | 138 | PSZ ends | 
|---|
|  | 139 |  | 
|---|
|  | 140 | CCHMAXPATH EQU 260 | 
|---|
|  | 141 |  | 
|---|
|  | 142 | */  /* end of assembly */ | 
|---|
|  | 143 |  | 
|---|
|  | 144 |  | 
|---|
|  | 145 | /******************************************************************************* | 
|---|
|  | 146 | *   Structures and Typedefs                                                    * | 
|---|
|  | 147 | *******************************************************************************/ | 
|---|
|  | 148 | #pragma pack(1) | 
|---|
|  | 149 |  | 
|---|
|  | 150 | /* | 
|---|
|  | 151 | * Object Table Entry buffer. | 
|---|
|  | 152 | */ | 
|---|
|  | 153 | struct _QueryOTE | 
|---|
|  | 154 | { | 
|---|
|  | 155 | ULONG   ote_size;                   /* Object virtual size */ | 
|---|
|  | 156 | ULONG   ote_base;                   /* Object base virtual address */ | 
|---|
|  | 157 | ULONG   ote_flags;                  /* Attribute flags */ | 
|---|
|  | 158 | ULONG   ote_pagemap;                /* Object page map index */ | 
|---|
|  | 159 | ULONG   ote_mapsize;                /* Num of entries in obj page map */ | 
|---|
|  | 160 | /*ULONG   ote_reserved;*/ | 
|---|
|  | 161 | USHORT  ote_sel;                    /* Object Selector */ | 
|---|
|  | 162 | USHORT  ote_hob;                    /* Object Handle */ | 
|---|
|  | 163 | }; | 
|---|
|  | 164 | typedef struct _QueryOTE    QOTE; | 
|---|
|  | 165 | typedef QOTE     *          PQOTE; | 
|---|
|  | 166 |  | 
|---|
|  | 167 |  | 
|---|
|  | 168 | typedef struct _QueryOTEBuffer | 
|---|
|  | 169 | { | 
|---|
|  | 170 | ULONG   cOTEs;                      /* Number of entries in aOTE. */ | 
|---|
|  | 171 | QOTE    aOTE[1];                    /* Array of OTEs. */ | 
|---|
|  | 172 | } QOTEBUFFER; | 
|---|
|  | 173 | typedef QOTEBUFFER *PQOTEBUFFER; | 
|---|
|  | 174 |  | 
|---|
|  | 175 |  | 
|---|
|  | 176 | /* | 
|---|
|  | 177 | * Options struct. | 
|---|
|  | 178 | * | 
|---|
|  | 179 | * (The function of these members are described in options.h in | 
|---|
|  | 180 | *  the src\win32k\include directory.) | 
|---|
|  | 181 | * All members of this struct (except cb ofcourse) is changable. | 
|---|
|  | 182 | */ | 
|---|
|  | 183 | typedef struct _K32Options | 
|---|
|  | 184 | { | 
|---|
|  | 185 | ULONG   cb; | 
|---|
|  | 186 |  | 
|---|
|  | 187 | /** @cat logging options */ | 
|---|
|  | 188 | USHORT      usCom;                  /* Output port no. */ | 
|---|
|  | 189 | ULONG       fLogging;               /* Logging. */ | 
|---|
|  | 190 |  | 
|---|
|  | 191 | /** @cat Options affecting the generated LX executables */ | 
|---|
|  | 192 | ULONG       fPE;                    /* Flags set the type of conversion. */ | 
|---|
|  | 193 | ULONG       fPEOneObject;           /* All in one object. */ | 
|---|
|  | 194 | ULONG       ulInfoLevel;            /* Pe2Lx InfoLevel. */ | 
|---|
|  | 195 |  | 
|---|
|  | 196 | /** @cat Options affecting the generated ELF executables */ | 
|---|
|  | 197 | ULONG       fElf;                   /* Elf flags. */ | 
|---|
|  | 198 |  | 
|---|
|  | 199 | /** @cat Options affecting the UNIX script executables */ | 
|---|
|  | 200 | ULONG       fUNIXScript;            /* UNIX script flags. */ | 
|---|
|  | 201 |  | 
|---|
|  | 202 | /** @cat Options affecting the REXX script executables */ | 
|---|
|  | 203 | ULONG       fREXXScript;            /* REXX script flags. */ | 
|---|
|  | 204 |  | 
|---|
|  | 205 | /** @cat Options affecting the JAVA executables */ | 
|---|
|  | 206 | ULONG       fJava;                  /* Java flags. */ | 
|---|
|  | 207 |  | 
|---|
|  | 208 | /** @cat Options affecting the  executables */ | 
|---|
|  | 209 | ULONG       fNoLoader;              /* No loader stuff. !FIXME! We should import / functions even if this flag is set!!! */ | 
|---|
|  | 210 |  | 
|---|
|  | 211 | /** @cat Options affecting the behaviour changes in the OS/2 loader */ | 
|---|
|  | 212 | ULONG       fDllFixes;              /* Enables the long DLL name and non .DLL extention fixes. */ | 
|---|
|  | 213 | ULONG       fExeFixes;              /* Enables EXE files to export entry points. */ | 
|---|
|  | 214 | ULONG       fForcePreload;          /* Forces the loader to preload executable images. Handy for ICAT Ring-3 debugging. */ | 
|---|
|  | 215 | ULONG       fApiEnh;                /* Enables the API enhancements */ | 
|---|
|  | 216 |  | 
|---|
|  | 217 | /** @cat Options affecting the heap. */ | 
|---|
|  | 218 | ULONG       cbSwpHeapMax;           /* Maximum heapsize. */ | 
|---|
|  | 219 | ULONG       cbResHeapMax;           /* Maxiumem residentheapsize. */ | 
|---|
|  | 220 | } K32OPTIONS; | 
|---|
|  | 221 | typedef K32OPTIONS  *PK32OPTIONS; | 
|---|
|  | 222 |  | 
|---|
|  | 223 |  | 
|---|
|  | 224 | /* | 
|---|
|  | 225 | * Status struct. | 
|---|
|  | 226 | * | 
|---|
|  | 227 | */ | 
|---|
|  | 228 | typedef struct _K32Status | 
|---|
|  | 229 | { | 
|---|
|  | 230 | ULONG   cb; | 
|---|
|  | 231 |  | 
|---|
|  | 232 | /** @cat Options status. */ | 
|---|
|  | 233 | ULONG       fQuiet;                 /* Quiet initialization. */ | 
|---|
|  | 234 |  | 
|---|
|  | 235 | /** @cat Kernel status. */ | 
|---|
|  | 236 | ULONG       fKernel;                /* Smp or uni kernel. */ | 
|---|
|  | 237 | ULONG       ulBuild;                /* Kernel build. */ | 
|---|
|  | 238 | USHORT      usVerMajor;             /* OS/2 major ver - 20 */ | 
|---|
|  | 239 | USHORT      usVerMinor;             /* OS/2 minor ver - 30,40 */ | 
|---|
|  | 240 |  | 
|---|
|  | 241 | /** @cat Heap status. */ | 
|---|
|  | 242 | ULONG       cbSwpHeapInit;          /* Initial heapsize. */ | 
|---|
|  | 243 | ULONG       cbSwpHeapFree;          /* Amount of used space. */ | 
|---|
|  | 244 | ULONG       cbSwpHeapUsed;          /* Amount of free space reserved. */ | 
|---|
|  | 245 | ULONG       cbSwpHeapSize;          /* Amount of memory used by the heap free and used++. */ | 
|---|
|  | 246 | ULONG       cSwpBlocksUsed;         /* Count of used blocks. */ | 
|---|
|  | 247 | ULONG       cSwpBlocksFree;         /* Count of free blocks. */ | 
|---|
|  | 248 |  | 
|---|
|  | 249 | ULONG       cbResHeapInit;          /* Initial heapsize. */ | 
|---|
|  | 250 | ULONG       cbResHeapFree;          /* Amount of free space reserved. */ | 
|---|
|  | 251 | ULONG       cbResHeapUsed;          /* Amount of used space. */ | 
|---|
|  | 252 | ULONG       cbResHeapSize;          /* Amount of memory used by the heap free and used++. */ | 
|---|
|  | 253 | ULONG       cResBlocksUsed;         /* Count of used blocks. */ | 
|---|
|  | 254 | ULONG       cResBlocksFree;         /* Count of free blocks. */ | 
|---|
|  | 255 |  | 
|---|
|  | 256 | /** @cat Win32k build, version and init stuff */ | 
|---|
|  | 257 | CHAR        szBuildDate[12];        /* Date of the win32k build. (Sep 02 2000) */ | 
|---|
|  | 258 | CHAR        szBuildTime[9];         /* Time of the win32k build. (11:44:21) */ | 
|---|
|  | 259 | ULONG       ulVersion;              /* Win32k version */ | 
|---|
|  | 260 | CHAR        szSymFile[CCHMAXPATH];  /* The name of the symbol file or sym database. */ | 
|---|
|  | 261 |  | 
|---|
|  | 262 | /** @cat Statistics */ | 
|---|
|  | 263 | ULONG       cPe2LxModules;          /* Number of Pe2Lx modules currently loaded. */ | 
|---|
|  | 264 | ULONG       cElf2LxModules;         /* Number of Elf2Lx modules currently loaded. */ | 
|---|
|  | 265 | /*...*/ | 
|---|
|  | 266 | } K32STATUS; | 
|---|
|  | 267 | typedef K32STATUS * PK32STATUS; | 
|---|
|  | 268 |  | 
|---|
|  | 269 |  | 
|---|
|  | 270 | /* | 
|---|
|  | 271 | * Memory information struct. | 
|---|
|  | 272 | */ | 
|---|
|  | 273 | typedef struct _k32SystemMemInfo | 
|---|
|  | 274 | { | 
|---|
|  | 275 | ULONG       cb;                     /* Size of this structure - must be set. */ | 
|---|
|  | 276 | /* This will be used to distinguish futher versions. */ | 
|---|
|  | 277 | ULONG       flFlags;                /* This is used to limit amount of information collected - must be set. (K32_SYSMEMINFO_*) */ | 
|---|
|  | 278 | /* Some conciderations. | 
|---|
|  | 279 | *    - VM uses worker functions which traverses internal lists. | 
|---|
|  | 280 | *    - Page and physical memory traverses one internal structure (PGPhysAvail()) | 
|---|
|  | 281 | *    - Swap File only accesses variables. | 
|---|
|  | 282 | */ | 
|---|
|  | 283 |  | 
|---|
|  | 284 | /* SwapFile Info */ | 
|---|
|  | 285 | BOOL        fSwapFile;              /* Swap File: Swapping enabled or disabled. (SMswapping) */ | 
|---|
|  | 286 | /*            (The SwapFile data below is valid when swapping is enbled!) */ | 
|---|
|  | 287 | ULONG       cbSwapFileSize;         /* Swap File: Current size. (smFileSize<<PAGESIZE) */ | 
|---|
|  | 288 | ULONG       cbSwapFileAvail;        /* Swap File: Available within current file. ((smFileSize-smcBrokenDF-SMcDFInuse)<<PAGESIZE) */ | 
|---|
|  | 289 | ULONG       cbSwapFileUsed;         /* Swap File: Used within current file. (SMcDFInuse<<PAGESIZE) */ | 
|---|
|  | 290 | ULONG       cbSwapFileMinFree;      /* Swap File: Addjusted min free on swap volume. (SMMinFree<<PAGESHIFT) */ | 
|---|
|  | 291 | ULONG       cbSwapFileCFGMinFree;   /* Swap File: Configured min free on swap volume. ((SMCFGMinFree<<PAGESHIFT)/4) */ | 
|---|
|  | 292 | ULONG       cbSwapFileCFGSwapSize;  /* Swap File: Configured initial swap file size. ((SMCFGSwapSize<<PAGESHIFT)/4) */ | 
|---|
|  | 293 | ULONG       cSwapFileBrokenDF;      /* Swap File: Number of broken disk frames (DF). (smcBrokenDF) */ | 
|---|
|  | 294 | ULONG       cSwapFileGrowFails;     /* Swap File: Number of times growoperation has failed. (smcGrowFails) */ | 
|---|
|  | 295 | ULONG       cSwapFileInMemFile;     /* Swap File: Number of pages in the "In-Memory-swapFile". (SMcInMemFile) */ | 
|---|
|  | 296 | /*            These pages are not counted into the SMcDFInuse count I think. */ | 
|---|
|  | 297 |  | 
|---|
|  | 298 | /* Physical Memory Info */ | 
|---|
|  | 299 | ULONG       cbPhysSize;             /* Physical memory: total (bytes). (pgPhysPages<<PAGESHIFT) */ | 
|---|
|  | 300 | ULONG       cbPhysAvail;            /* Physical memory: available (bytes). (PGPhysAvail()) */ | 
|---|
|  | 301 | ULONG       cbPhysUsed;             /* Physical memory: used (bytes). (PGPhysPresent()<<PAGESHIFT) */ | 
|---|
|  | 302 |  | 
|---|
|  | 303 | /* Other paging info */ | 
|---|
|  | 304 | BOOL        fPagingSwapEnabled;     /* Paging: TRUE when swapping is enabled, else false. (PGSwapEnabled) */ | 
|---|
|  | 305 | ULONG       cPagingPageFaults;      /* Paging: Number of pagefaults which has occured since boot. (pgcPageFaults) */ | 
|---|
|  | 306 | ULONG       cPagingPageFaultsActive;/* Paging: Number of pagefaults currently being processed. (pgcPageFaultsActive) */ | 
|---|
|  | 307 | ULONG       cPagingPhysPages;       /* Paging: Count of physical pages. (hope this is correct) (pgPhysPages) */ | 
|---|
|  | 308 | ULONG       ulPagingPhysMax;        /* Paging: Top of physical memory (physical page number) (pgPhysMax) */ | 
|---|
|  | 309 | ULONG       cPagingResidentPages;   /* Paging: Count of resident pages. (pgResidentPages) */ | 
|---|
|  | 310 | ULONG       cPagingSwappablePages;  /* Paging: Count of swappable pages which is currently present in memory. (pgSwappablePages) */ | 
|---|
|  | 311 | ULONG       cPagingDiscardableInmem;/* Paging: Count of discardable pages which is currently present in memory. (pgDiscardableInmem) */ | 
|---|
|  | 312 | ULONG       cPagingDiscardablePages;/* Paging: Count of discardable pages allocated. (pgDiscardablePages) */ | 
|---|
|  | 313 |  | 
|---|
|  | 314 | /* Virtual Memory manager info. */ | 
|---|
|  | 315 | ULONG       ulAddressLimit;         /* VM: Current user virtual address limit - use this for high arena check. (VirtualAddressLimit / 0x20000000) */ | 
|---|
|  | 316 | ULONG       ulVMArenaPrivMax;       /* VM: Current highest address in the private arena. (vmRecalcShrBound()) */ | 
|---|
|  | 317 | ULONG       ulVMArenaSharedMin;     /* VM: Current lowest address in the shared arena. (ahvmShr) */ | 
|---|
|  | 318 | ULONG       ulVMArenaSharedMax;     /* VM: Current highest address in the shared arena. (ahvmShr) */ | 
|---|
|  | 319 | ULONG       ulVMArenaSystemMin;     /* VM: Current lowest address in the system arena. (ahvmhSys) */ | 
|---|
|  | 320 | ULONG       ulVMArenaSystemMax;     /* VM: Current highest address in the system arena. (ahvmhSys) */ | 
|---|
|  | 321 | ULONG       ulVMArenaHighPrivMax;   /* VM: Current highest address in the high private arena - aurora/smp only. (vmRecalcShrBound) */ | 
|---|
|  | 322 | ULONG       ulVMArenaHighSharedMin; /* VM: Current lowest address in the high shared arena - aurora/smp only. (ahvmhShr) */ | 
|---|
|  | 323 | ULONG       ulVMArenaHighSharedMax; /* VM: Current highest address in the high shared arena - aurora/smp only. (ahvmhShr) */ | 
|---|
|  | 324 |  | 
|---|
|  | 325 | } K32SYSTEMMEMINFO; | 
|---|
|  | 326 | typedef K32SYSTEMMEMINFO *  PK32SYSTEMMEMINFO; | 
|---|
|  | 327 |  | 
|---|
|  | 328 |  | 
|---|
|  | 329 | /* | 
|---|
|  | 330 | * K32 category parameter structs | 
|---|
|  | 331 | * --- | 
|---|
|  | 332 | * First member is allways a K32HDR struct called hdr. | 
|---|
|  | 333 | * The rest of it should be exactly like the parameter list for the API call. | 
|---|
|  | 334 | */ | 
|---|
|  | 335 | struct _k32Header                       /* Common parameter header. */ | 
|---|
|  | 336 | { | 
|---|
|  | 337 | ULONG       cb;                     /* Size of the parameters struct. */ | 
|---|
|  | 338 | ULONG       rc;                     /* Return code. */ | 
|---|
|  | 339 | }; | 
|---|
|  | 340 | typedef struct _k32Header   K32HDR; | 
|---|
|  | 341 | typedef K32HDR *            PK32HDR; | 
|---|
|  | 342 |  | 
|---|
|  | 343 |  | 
|---|
|  | 344 | struct _k32AllocMemEx | 
|---|
|  | 345 | { | 
|---|
|  | 346 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 347 | PPVOID      ppv;                    /* Pointer to pointer to the allocated memory block */ | 
|---|
|  | 348 | /* On input it (*ppv) may hold the suggested  location of the block. */ | 
|---|
|  | 349 | ULONG       cb;                     /* Blocksize (bytes) */ | 
|---|
|  | 350 | ULONG       flFlags;                /* Flags (equal to DosAllocMem flags) */ | 
|---|
|  | 351 | ULONG       ulCS;                   /* Call CS */ | 
|---|
|  | 352 | ULONG       ulEIP;                  /* Call EIP */ | 
|---|
|  | 353 | }; | 
|---|
|  | 354 | typedef struct _k32AllocMemEx   K32ALLOCMEMEX; | 
|---|
|  | 355 | typedef K32ALLOCMEMEX *         PK32ALLOCMEMEX; | 
|---|
|  | 356 |  | 
|---|
|  | 357 |  | 
|---|
|  | 358 | struct _k32QueryOTEs | 
|---|
|  | 359 | { | 
|---|
|  | 360 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 361 | HMODULE     hMTE;                   /* Module handle. */ | 
|---|
|  | 362 | PQOTEBUFFER pQOte;                  /* Pointer to output buffer. */ | 
|---|
|  | 363 | ULONG       cbQOte;                 /* Size of the buffer pointed to by pQOte  */ | 
|---|
|  | 364 | }; | 
|---|
|  | 365 | typedef struct _k32QueryOTEs    K32QUERYOTES; | 
|---|
|  | 366 | typedef K32QUERYOTES *          PK32QUERYOTES; | 
|---|
|  | 367 |  | 
|---|
|  | 368 |  | 
|---|
|  | 369 | struct _k32QueryOptionsStatus | 
|---|
|  | 370 | { | 
|---|
|  | 371 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 372 | PK32OPTIONS pOptions;               /* Pointer to option struct. (NULL allowed) */ | 
|---|
|  | 373 | PK32STATUS  pStatus;                /* Pointer to status struct. (NULL allowed) */ | 
|---|
|  | 374 | }; | 
|---|
|  | 375 | typedef struct _k32QueryOptionsStatus   K32QUERYOPTIONSSTATUS; | 
|---|
|  | 376 | typedef K32QUERYOPTIONSSTATUS *         PK32QUERYOPTIONSSTATUS; | 
|---|
|  | 377 |  | 
|---|
|  | 378 |  | 
|---|
|  | 379 | struct _k32SetOptions | 
|---|
|  | 380 | { | 
|---|
|  | 381 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 382 | PK32OPTIONS pOptions;               /* Pointer to option struct. (NULL allowed) */ | 
|---|
|  | 383 | }; | 
|---|
|  | 384 | typedef struct _k32SetOptions           K32SETOPTIONS; | 
|---|
|  | 385 | typedef K32SETOPTIONS *                 PK32SETOPTIONS; | 
|---|
|  | 386 |  | 
|---|
|  | 387 |  | 
|---|
|  | 388 | struct _k32ProcessReadWrite | 
|---|
|  | 389 | { | 
|---|
|  | 390 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 391 | PID         pid;                    /* Process ID of the process to access memory in. */ | 
|---|
|  | 392 | ULONG       cb;                     /* Number of bytes to read or write. */ | 
|---|
|  | 393 | PVOID       pvSource;               /* Pointer to source data. */ | 
|---|
|  | 394 | PVOID       pvTarget;               /* Pointer to target area. */ | 
|---|
|  | 395 | BOOL        fRead;                  /* TRUE:   pvSource is within pid while pvTarget is ours. */ | 
|---|
|  | 396 | /* FALSE:  pvTarget is within pid while pvSource is ours. */ | 
|---|
|  | 397 | }; | 
|---|
|  | 398 | typedef struct _k32ProcessReadWrite     K32PROCESSREADWRITE; | 
|---|
|  | 399 | typedef K32PROCESSREADWRITE *           PK32PROCESSREADWRITE; | 
|---|
|  | 400 |  | 
|---|
|  | 401 |  | 
|---|
|  | 402 | struct _k32HandleSystemEvent | 
|---|
|  | 403 | { | 
|---|
|  | 404 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 405 | ULONG       ulEvent;                /* Event identifier. One of the K32_SYSEVENT_ defines. */ | 
|---|
|  | 406 | HEV         hev;                    /* Handle of shared event semaphore which should be */ | 
|---|
|  | 407 | /* posted when the the requested event occurs.      */ | 
|---|
|  | 408 | BOOL        fHandle;                /* Action flag. */ | 
|---|
|  | 409 | /* TRUE:  Take control of the event. */ | 
|---|
|  | 410 | /* FALSE: Give control back to the OS of this event. (hev must match the current handle!) */ | 
|---|
|  | 411 | }; | 
|---|
|  | 412 | typedef struct _k32HandleSystemEvent    K32HANDLESYSTEMEVENT; | 
|---|
|  | 413 | typedef K32HANDLESYSTEMEVENT *          PK32HANDLESYSTEMEVENT; | 
|---|
|  | 414 |  | 
|---|
|  | 415 |  | 
|---|
|  | 416 | struct _k32QuerySystemMemInfo | 
|---|
|  | 417 | { | 
|---|
|  | 418 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 419 | PK32SYSTEMMEMINFO   pMemInfo;       /* Pointer to system memory info structure with cb set. */ | 
|---|
|  | 420 | /* The other members will be filled on successful return. */ | 
|---|
|  | 421 | }; | 
|---|
|  | 422 | typedef struct _k32QuerySystemMemInfo   K32QUERYSYSTEMMEMINFO; | 
|---|
|  | 423 | typedef K32QUERYSYSTEMMEMINFO *         PK32QUERYSYSTEMMEMINFO; | 
|---|
|  | 424 |  | 
|---|
|  | 425 |  | 
|---|
|  | 426 | struct _k32QueryCallGate | 
|---|
|  | 427 | { | 
|---|
|  | 428 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 429 | PUSHORT     pusCGSelector;          /* Pointer to variable where the callgate selector */ | 
|---|
|  | 430 | /* is to be stored. */ | 
|---|
|  | 431 | }; | 
|---|
|  | 432 | typedef struct _k32QueryCallGate        K32QUERYCALLGATE; | 
|---|
|  | 433 | typedef struct _k32QueryCallGate *      PK32QUERYCALLGATE; | 
|---|
|  | 434 |  | 
|---|
|  | 435 |  | 
|---|
|  | 436 | struct _k32SetEnvironment | 
|---|
|  | 437 | { | 
|---|
|  | 438 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 439 | PSZ         pszzEnvironment;        /* Pointer to current odin32 environment block for a process. */ | 
|---|
|  | 440 | ULONG       cchEnvironment;         /* Pointer to current odin32 environment block for a process. */ | 
|---|
|  | 441 | PID         pid;                    /* The process to set invironment for. */ | 
|---|
|  | 442 | }; | 
|---|
|  | 443 | typedef struct _k32SetEnvironment       K32SETENVIRONMENT; | 
|---|
|  | 444 | typedef struct _k32SetEnvironment *     PK32SETENVIRONMENT; | 
|---|
|  | 445 |  | 
|---|
|  | 446 |  | 
|---|
|  | 447 | struct _k32KillProcessEx | 
|---|
|  | 448 | { | 
|---|
|  | 449 | K32HDR      hdr;                    /* Common parameter header */ | 
|---|
|  | 450 | ULONG       flAction;               /* Action flags. (see k32KillProcessEx for details.) */ | 
|---|
|  | 451 | PID         pid;                    /* The identity of the process or root in process tree to be killed. */ | 
|---|
|  | 452 | }; | 
|---|
|  | 453 | typedef struct _k32KillProcessEx        K32KILLPROCESSEX; | 
|---|
|  | 454 | typedef struct _k32KillProcessEx *      PK32KILLPROCESSEX; | 
|---|
|  | 455 |  | 
|---|
|  | 456 | #pragma pack() | 
|---|
|  | 457 |  | 
|---|
|  | 458 | /* NOINC */ | 
|---|
|  | 459 | #ifndef NO_WIN32K_LIB_FUNCTIONS | 
|---|
|  | 460 | /******************************************************************************* | 
|---|
|  | 461 | *   External Functions                                                         * | 
|---|
|  | 462 | *******************************************************************************/ | 
|---|
|  | 463 | /* Win32k APIs */ | 
|---|
|  | 464 | APIRET APIENTRY  libWin32kInit(void); | 
|---|
|  | 465 | APIRET APIENTRY  libWin32kTerm(void); | 
|---|
|  | 466 | BOOL   APIENTRY  libWin32kInstalled(void); | 
|---|
|  | 467 | APIRET APIENTRY  libWin32kSetEnvironment(PSZ pszzEnvironment, ULONG cchEnvironment, PID pid); | 
|---|
|  | 468 | APIRET APIENTRY  libWin32kQueryOptionsStatus(PK32OPTIONS pOptions, PK32STATUS pStatus); | 
|---|
|  | 469 | APIRET APIENTRY  libWin32kSetOptions(PK32OPTIONS pOptions); | 
|---|
|  | 470 |  | 
|---|
|  | 471 | /* "Extra OS2 APIs" */ | 
|---|
|  | 472 | APIRET APIENTRY  DosAllocMemEx(PPVOID ppv, ULONG cb, ULONG flag); | 
|---|
|  | 473 | APIRET APIENTRY  DosKillProcessEx(ULONG flAction, PID pid); | 
|---|
|  | 474 | APIRET APIENTRY  W32kQueryOTEs(HMODULE hMTE, PQOTEBUFFER pQOte, ULONG cbQOte); | 
|---|
|  | 475 | APIRET APIENTRY  W32kQuerySystemMemInfo(PK32SYSTEMMEMINFO pMemInfo); | 
|---|
|  | 476 | APIRET APIENTRY  W32kProcessReadWrite(PID pid, ULONG cb, PVOID pvSource, PVOID pvTarget, BOOL fRead); | 
|---|
|  | 477 | APIRET APIENTRY  W32kHandleSystemEvent(ULONG ulEvent, HEV hev, BOOL fHandle); | 
|---|
|  | 478 |  | 
|---|
|  | 479 | /* Helper function */ | 
|---|
|  | 480 | USHORT APIENTRY  libHelperGetCS(void); | 
|---|
|  | 481 |  | 
|---|
|  | 482 | #endif | 
|---|
|  | 483 | /* INC */ | 
|---|
|  | 484 |  | 
|---|
|  | 485 | /* NOINC */ | 
|---|
|  | 486 | #endif /* !defined(INCL_16) */ | 
|---|
|  | 487 | #endif | 
|---|
|  | 488 | /* INC */ | 
|---|