[1046] | 1 | /*
|
---|
| 2 | * winnt4.h
|
---|
| 3 | *
|
---|
| 4 | * Definitions only used in Windows NT 4.0 and earlier versions
|
---|
| 5 | *
|
---|
| 6 | * This file is part of the w32api package.
|
---|
| 7 | *
|
---|
| 8 | * Contributors:
|
---|
| 9 | * Created by Casper S. Hornstrup <chorns@users.sourceforge.net>
|
---|
| 10 | *
|
---|
| 11 | * THIS SOFTWARE IS NOT COPYRIGHTED
|
---|
| 12 | *
|
---|
| 13 | * This source code is offered for use in the public domain. You may
|
---|
| 14 | * use, modify or distribute it freely.
|
---|
| 15 | *
|
---|
| 16 | * This code is distributed in the hope that it will be useful but
|
---|
| 17 | * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
|
---|
| 18 | * DISCLAIMED. This includes but is not limited to warranties of
|
---|
| 19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
---|
| 20 | *
|
---|
| 21 | */
|
---|
| 22 |
|
---|
| 23 | #ifndef __WINNT4_H
|
---|
| 24 | #define __WINNT4_H
|
---|
| 25 |
|
---|
| 26 | #if __GNUC__ >=3
|
---|
| 27 | #pragma GCC system_header
|
---|
| 28 | #endif
|
---|
| 29 |
|
---|
| 30 | #ifdef __cplusplus
|
---|
| 31 | extern "C" {
|
---|
| 32 | #endif
|
---|
| 33 |
|
---|
| 34 | typedef struct _ZONE_SEGMENT_HEADER {
|
---|
| 35 | SINGLE_LIST_ENTRY SegmentList;
|
---|
| 36 | PVOID Reserved;
|
---|
| 37 | } ZONE_SEGMENT_HEADER, *PZONE_SEGMENT_HEADER;
|
---|
| 38 |
|
---|
| 39 | typedef struct _ZONE_HEADER {
|
---|
| 40 | SINGLE_LIST_ENTRY FreeList;
|
---|
| 41 | SINGLE_LIST_ENTRY SegmentList;
|
---|
| 42 | ULONG BlockSize;
|
---|
| 43 | ULONG TotalSegmentSize;
|
---|
| 44 | } ZONE_HEADER, *PZONE_HEADER;
|
---|
| 45 |
|
---|
| 46 | static __inline PVOID
|
---|
| 47 | ExAllocateFromZone(
|
---|
| 48 | /*IN*/ PZONE_HEADER Zone)
|
---|
| 49 | {
|
---|
| 50 | if (Zone->FreeList.Next)
|
---|
| 51 | Zone->FreeList.Next = Zone->FreeList.Next->Next;
|
---|
| 52 | return (PVOID) Zone->FreeList.Next;
|
---|
| 53 | }
|
---|
| 54 |
|
---|
| 55 | NTOSAPI
|
---|
| 56 | NTSTATUS
|
---|
| 57 | DDKAPI
|
---|
| 58 | ExExtendZone(
|
---|
| 59 | /*IN*/ PZONE_HEADER Zone,
|
---|
| 60 | /*IN*/ PVOID Segment,
|
---|
| 61 | /*IN*/ ULONG SegmentSize);
|
---|
| 62 |
|
---|
| 63 | static __inline PVOID
|
---|
| 64 | ExFreeToZone(
|
---|
| 65 | /*IN*/ PZONE_HEADER Zone,
|
---|
| 66 | /*IN*/ PVOID Block)
|
---|
| 67 | {
|
---|
| 68 | ((PSINGLE_LIST_ENTRY) Block)->Next = Zone->FreeList.Next;
|
---|
| 69 | Zone->FreeList.Next = ((PSINGLE_LIST_ENTRY) Block);
|
---|
| 70 | return ((PSINGLE_LIST_ENTRY) Block)->Next;
|
---|
| 71 | }
|
---|
| 72 |
|
---|
| 73 | NTOSAPI
|
---|
| 74 | NTSTATUS
|
---|
| 75 | DDKAPI
|
---|
| 76 | ExInitializeZone(
|
---|
| 77 | /*IN*/ PZONE_HEADER Zone,
|
---|
| 78 | /*IN*/ ULONG BlockSize,
|
---|
| 79 | /*IN*/ PVOID InitialSegment,
|
---|
| 80 | /*IN*/ ULONG InitialSegmentSize);
|
---|
| 81 |
|
---|
| 82 | /*
|
---|
| 83 | * PVOID
|
---|
| 84 | * ExInterlockedAllocateFromZone(
|
---|
| 85 | * IN PZONE_HEADER Zone,
|
---|
| 86 | * IN PKSPIN_LOCK Lock)
|
---|
| 87 | */
|
---|
| 88 | #define ExInterlockedAllocateFromZone(Zone, \
|
---|
| 89 | Lock) \
|
---|
| 90 | ((PVOID) ExInterlockedPopEntryList(&Zone->FreeList, Lock))
|
---|
| 91 |
|
---|
| 92 | NTOSAPI
|
---|
| 93 | NTSTATUS
|
---|
| 94 | DDKAPI
|
---|
| 95 | ExInterlockedExtendZone(
|
---|
| 96 | /*IN*/ PZONE_HEADER Zone,
|
---|
| 97 | /*IN*/ PVOID Segment,
|
---|
| 98 | /*IN*/ ULONG SegmentSize,
|
---|
| 99 | /*IN*/ PKSPIN_LOCK Lock);
|
---|
| 100 |
|
---|
| 101 | NTOSAPI
|
---|
| 102 | PVOID
|
---|
| 103 | DDKAPI
|
---|
| 104 | ExInterlockedFreeToZone(
|
---|
| 105 | /*IN*/ PZONE_HEADER Zone,
|
---|
| 106 | /*IN*/ PVOID Block,
|
---|
| 107 | /*IN*/ PKSPIN_LOCK Lock);
|
---|
| 108 |
|
---|
| 109 | /*
|
---|
| 110 | * VOID
|
---|
| 111 | * ExInitializeWorkItem(
|
---|
| 112 | * IN PWORK_QUEUE_ITEM Item,
|
---|
| 113 | * IN PWORKER_THREAD_ROUTINE Routine,
|
---|
| 114 | * IN PVOID Context)
|
---|
| 115 | */
|
---|
| 116 | #define ExInitializeWorkItem(Item, \
|
---|
| 117 | Routine, \
|
---|
| 118 | Context) \
|
---|
| 119 | { \
|
---|
| 120 | (Item)->WorkerRoutine = Routine; \
|
---|
| 121 | (Item)->Parameter = Context; \
|
---|
| 122 | (Item)->List.Flink = NULL; \
|
---|
| 123 | }
|
---|
| 124 |
|
---|
| 125 | /*
|
---|
| 126 | * BOOLEAN
|
---|
| 127 | * ExIsFullZone(
|
---|
| 128 | * IN PZONE_HEADER Zone)
|
---|
| 129 | */
|
---|
| 130 | #define ExIsFullZone(Zone) \
|
---|
| 131 | ((Zone)->FreeList.Next == (PSINGLE_LIST_ENTRY) NULL)
|
---|
| 132 |
|
---|
| 133 | NTOSAPI
|
---|
| 134 | VOID
|
---|
| 135 | DDKAPI
|
---|
| 136 | ExQueueWorkItem(
|
---|
| 137 | /*IN*/ PWORK_QUEUE_ITEM WorkItem,
|
---|
| 138 | /*IN*/ WORK_QUEUE_TYPE QueueType);
|
---|
| 139 |
|
---|
| 140 | NTOSAPI
|
---|
| 141 | BOOLEAN
|
---|
| 142 | DDKAPI
|
---|
| 143 | ExIsObjectInFirstZoneSegment(
|
---|
| 144 | /*IN*/ PZONE_HEADER Zone,
|
---|
| 145 | /*IN*/ PVOID Object);
|
---|
| 146 |
|
---|
| 147 | NTOSAPI
|
---|
| 148 | VOID
|
---|
| 149 | DDKAPI
|
---|
| 150 | ExReleaseResource(
|
---|
| 151 | /*IN*/ PERESOURCE Resource);
|
---|
| 152 |
|
---|
| 153 | #define ExAcquireResourceExclusive ExAcquireResourceExclusiveLite
|
---|
| 154 | #define ExAcquireResourceShared ExAcquireResourceSharedLite
|
---|
| 155 | #define ExConvertExclusiveToShared ExConvertExclusiveToSharedLite
|
---|
| 156 | #define ExDeleteResource ExDeleteResourceLite
|
---|
| 157 | #define ExInitializeResource ExInitializeResourceLite
|
---|
| 158 | #define ExIsResourceAcquiredExclusive ExIsResourceAcquiredExclusiveLite
|
---|
| 159 | #define ExIsResourceAcquiredShared ExIsResourceAcquiredSharedLite
|
---|
| 160 | #define ExIsResourceAcquired ExIsResourceAcquiredSharedLite
|
---|
| 161 | #define ExReleaseResourceForThread ExReleaseResourceForThreadLite
|
---|
| 162 |
|
---|
| 163 | NTOSAPI
|
---|
| 164 | INTERLOCKED_RESULT
|
---|
| 165 | DDKAPI
|
---|
| 166 | ExInterlockedDecrementLong(
|
---|
| 167 | /*IN*/ PLONG Addend,
|
---|
| 168 | /*IN*/ PKSPIN_LOCK Lock);
|
---|
| 169 |
|
---|
| 170 | NTOSAPI
|
---|
| 171 | ULONG
|
---|
| 172 | DDKAPI
|
---|
| 173 | ExInterlockedExchangeUlong(
|
---|
| 174 | /*IN*/ PULONG Target,
|
---|
| 175 | /*IN*/ ULONG Value,
|
---|
| 176 | /*IN*/ PKSPIN_LOCK Lock);
|
---|
| 177 |
|
---|
| 178 | NTOSAPI
|
---|
| 179 | INTERLOCKED_RESULT
|
---|
| 180 | DDKAPI
|
---|
| 181 | ExInterlockedIncrementLong(
|
---|
| 182 | /*IN*/ PLONG Addend,
|
---|
| 183 | /*IN*/ PKSPIN_LOCK Lock);
|
---|
| 184 |
|
---|
| 185 | NTOSAPI
|
---|
| 186 | PVOID
|
---|
| 187 | DDKAPI
|
---|
| 188 | HalAllocateCommonBuffer(
|
---|
| 189 | /*IN*/ PADAPTER_OBJECT AdapterObject,
|
---|
| 190 | /*IN*/ ULONG Length,
|
---|
| 191 | /*OUT*/ PPHYSICAL_ADDRESS LogicalAddress,
|
---|
| 192 | /*IN*/ BOOLEAN CacheEnabled);
|
---|
| 193 |
|
---|
| 194 | NTOSAPI
|
---|
| 195 | NTSTATUS
|
---|
| 196 | DDKAPI
|
---|
| 197 | HalAssignSlotResources(
|
---|
| 198 | /*IN*/ PUNICODE_STRING RegistryPath,
|
---|
| 199 | /*IN*/ PUNICODE_STRING DriverClassName,
|
---|
| 200 | /*IN*/ PDRIVER_OBJECT DriverObject,
|
---|
| 201 | /*IN*/ PDEVICE_OBJECT DeviceObject,
|
---|
| 202 | /*IN*/ INTERFACE_TYPE BusType,
|
---|
| 203 | /*IN*/ ULONG BusNumber,
|
---|
| 204 | /*IN*/ ULONG SlotNumber,
|
---|
| 205 | /*IN OUT*/ PCM_RESOURCE_LIST *AllocatedResources);
|
---|
| 206 |
|
---|
| 207 | NTOSAPI
|
---|
| 208 | VOID
|
---|
| 209 | DDKAPI
|
---|
| 210 | HalFreeCommonBuffer(
|
---|
| 211 | /*IN*/ PADAPTER_OBJECT AdapterObject,
|
---|
| 212 | /*IN*/ ULONG Length,
|
---|
| 213 | /*IN*/ PHYSICAL_ADDRESS LogicalAddress,
|
---|
| 214 | /*IN*/ PVOID VirtualAddress,
|
---|
| 215 | /*IN*/ BOOLEAN CacheEnabled);
|
---|
| 216 |
|
---|
| 217 | NTOSAPI
|
---|
| 218 | PADAPTER_OBJECT
|
---|
| 219 | DDKAPI
|
---|
| 220 | HalGetAdapter(
|
---|
| 221 | /*IN*/ PDEVICE_DESCRIPTION DeviceDescription,
|
---|
| 222 | /*IN OUT*/ PULONG NumberOfMapRegisters);
|
---|
| 223 |
|
---|
| 224 | NTOSAPI
|
---|
| 225 | ULONG
|
---|
| 226 | DDKAPI
|
---|
| 227 | HalGetBusData(
|
---|
| 228 | /*IN*/ BUS_DATA_TYPE BusDataType,
|
---|
| 229 | /*IN*/ ULONG BusNumber,
|
---|
| 230 | /*IN*/ ULONG SlotNumber,
|
---|
| 231 | /*IN*/ PVOID Buffer,
|
---|
| 232 | /*IN*/ ULONG Length);
|
---|
| 233 |
|
---|
| 234 | NTOSAPI
|
---|
| 235 | ULONG
|
---|
| 236 | DDKAPI
|
---|
| 237 | HalGetBusDataByOffset(
|
---|
| 238 | /*IN*/ BUS_DATA_TYPE BusDataType,
|
---|
| 239 | /*IN*/ ULONG BusNumber,
|
---|
| 240 | /*IN*/ ULONG SlotNumber,
|
---|
| 241 | /*IN*/ PVOID Buffer,
|
---|
| 242 | /*IN*/ ULONG Offset,
|
---|
| 243 | /*IN*/ ULONG Length);
|
---|
| 244 |
|
---|
| 245 | NTOSAPI
|
---|
| 246 | ULONG
|
---|
| 247 | DDKAPI
|
---|
| 248 | HalGetDmaAlignmentRequirement(
|
---|
| 249 | VOID);
|
---|
| 250 |
|
---|
| 251 | NTOSAPI
|
---|
| 252 | ULONG
|
---|
| 253 | DDKAPI
|
---|
| 254 | HalGetInterruptVector(
|
---|
| 255 | /*IN*/ INTERFACE_TYPE InterfaceType,
|
---|
| 256 | /*IN*/ ULONG BusNumber,
|
---|
| 257 | /*IN*/ ULONG BusInterruptLevel,
|
---|
| 258 | /*IN*/ ULONG BusInterruptVector,
|
---|
| 259 | /*OUT*/ PKIRQL Irql,
|
---|
| 260 | /*OUT*/ PKAFFINITY Affinity);
|
---|
| 261 |
|
---|
| 262 | NTOSAPI
|
---|
| 263 | ULONG
|
---|
| 264 | DDKAPI
|
---|
| 265 | HalReadDmaCounter(
|
---|
| 266 | /*IN*/ PADAPTER_OBJECT AdapterObject);
|
---|
| 267 |
|
---|
| 268 | NTOSAPI
|
---|
| 269 | ULONG
|
---|
| 270 | DDKAPI
|
---|
| 271 | HalSetBusData(
|
---|
| 272 | /*IN*/ BUS_DATA_TYPE BusDataType,
|
---|
| 273 | /*IN*/ ULONG BusNumber,
|
---|
| 274 | /*IN*/ ULONG SlotNumber,
|
---|
| 275 | /*IN*/ PVOID Buffer,
|
---|
| 276 | /*IN*/ ULONG Length);
|
---|
| 277 |
|
---|
| 278 | NTOSAPI
|
---|
| 279 | ULONG
|
---|
| 280 | DDKAPI
|
---|
| 281 | HalSetBusDataByOffset(
|
---|
| 282 | /*IN*/ BUS_DATA_TYPE BusDataType,
|
---|
| 283 | /*IN*/ ULONG BusNumber,
|
---|
| 284 | /*IN*/ ULONG SlotNumber,
|
---|
| 285 | /*IN*/ PVOID Buffer,
|
---|
| 286 | /*IN*/ ULONG Offset,
|
---|
| 287 | /*IN*/ ULONG Length);
|
---|
| 288 |
|
---|
| 289 | NTOSAPI
|
---|
| 290 | BOOLEAN
|
---|
| 291 | DDKAPI
|
---|
| 292 | HalTranslateBusAddress(
|
---|
| 293 | /*IN*/ INTERFACE_TYPE InterfaceType,
|
---|
| 294 | /*IN*/ ULONG BusNumber,
|
---|
| 295 | /*IN*/ PHYSICAL_ADDRESS BusAddress,
|
---|
| 296 | /*IN OUT*/ PULONG AddressSpace,
|
---|
| 297 | /*OUT*/ PPHYSICAL_ADDRESS TranslatedAddress);
|
---|
| 298 |
|
---|
| 299 | NTOSAPI
|
---|
| 300 | NTSTATUS
|
---|
| 301 | DDKAPI
|
---|
| 302 | IoAllocateAdapterChannel(
|
---|
| 303 | /*IN*/ PADAPTER_OBJECT AdapterObject,
|
---|
| 304 | /*IN*/ PDEVICE_OBJECT DeviceObject,
|
---|
| 305 | /*IN*/ ULONG NumberOfMapRegisters,
|
---|
| 306 | /*IN*/ PDRIVER_CONTROL ExecutionRoutine,
|
---|
| 307 | /*IN*/ PVOID Context);
|
---|
| 308 |
|
---|
| 309 | NTOSAPI
|
---|
| 310 | NTSTATUS
|
---|
| 311 | DDKAPI
|
---|
| 312 | IoAssignResources(
|
---|
| 313 | /*IN*/ PUNICODE_STRING RegistryPath,
|
---|
| 314 | /*IN*/ PUNICODE_STRING DriverClassName /*OPTIONAL*/,
|
---|
| 315 | /*IN*/ PDRIVER_OBJECT DriverObject,
|
---|
| 316 | /*IN*/ PDEVICE_OBJECT DeviceObject /*OPTIONAL*/,
|
---|
| 317 | /*IN*/ PIO_RESOURCE_REQUIREMENTS_LIST RequestedResources,
|
---|
| 318 | /*IN OUT*/ PCM_RESOURCE_LIST *AllocatedResources);
|
---|
| 319 |
|
---|
| 320 | NTOSAPI
|
---|
| 321 | NTSTATUS
|
---|
| 322 | DDKAPI
|
---|
| 323 | IoAttachDeviceByPointer(
|
---|
| 324 | /*IN*/ PDEVICE_OBJECT SourceDevice,
|
---|
| 325 | /*IN*/ PDEVICE_OBJECT TargetDevice);
|
---|
| 326 |
|
---|
| 327 | NTOSAPI
|
---|
| 328 | BOOLEAN
|
---|
| 329 | DDKAPI
|
---|
| 330 | IoFlushAdapterBuffers(
|
---|
| 331 | /*IN*/ PADAPTER_OBJECT AdapterObject,
|
---|
| 332 | /*IN*/ PMDL Mdl,
|
---|
| 333 | /*IN*/ PVOID MapRegisterBase,
|
---|
| 334 | /*IN*/ PVOID CurrentVa,
|
---|
| 335 | /*IN*/ ULONG Length,
|
---|
| 336 | /*IN*/ BOOLEAN WriteToDevice);
|
---|
| 337 |
|
---|
| 338 | NTOSAPI
|
---|
| 339 | VOID
|
---|
| 340 | DDKAPI
|
---|
| 341 | IoFreeAdapterChannel(
|
---|
| 342 | /*IN*/ PADAPTER_OBJECT AdapterObject);
|
---|
| 343 |
|
---|
| 344 | NTOSAPI
|
---|
| 345 | VOID
|
---|
| 346 | DDKAPI
|
---|
| 347 | IoFreeMapRegisters(
|
---|
| 348 | /*IN*/ PADAPTER_OBJECT AdapterObject,
|
---|
| 349 | /*IN*/ PVOID MapRegisterBase,
|
---|
| 350 | /*IN*/ ULONG NumberOfMapRegisters);
|
---|
| 351 |
|
---|
| 352 | NTOSAPI
|
---|
| 353 | PHYSICAL_ADDRESS
|
---|
| 354 | DDKAPI
|
---|
| 355 | IoMapTransfer(
|
---|
| 356 | /*IN*/ PADAPTER_OBJECT AdapterObject,
|
---|
| 357 | /*IN*/ PMDL Mdl,
|
---|
| 358 | /*IN*/ PVOID MapRegisterBase,
|
---|
| 359 | /*IN*/ PVOID CurrentVa,
|
---|
| 360 | /*IN OUT*/ PULONG Length,
|
---|
| 361 | /*IN*/ BOOLEAN WriteToDevice);
|
---|
| 362 |
|
---|
| 363 | NTOSAPI
|
---|
| 364 | PMDL
|
---|
| 365 | DDKAPI
|
---|
| 366 | MmCreateMdl(
|
---|
| 367 | /*IN*/ PMDL MemoryDescriptorList /*OPTIONAL*/,
|
---|
| 368 | /*IN*/ PVOID Base,
|
---|
| 369 | /*IN*/ SIZE_T Length);
|
---|
| 370 |
|
---|
| 371 | NTOSAPI
|
---|
| 372 | BOOLEAN
|
---|
| 373 | DDKAPI
|
---|
| 374 | MmIsNonPagedSystemAddressValid(
|
---|
| 375 | /*IN*/ PVOID VirtualAddress);
|
---|
| 376 |
|
---|
| 377 | NTOSAPI
|
---|
| 378 | LARGE_INTEGER
|
---|
| 379 | DDKAPI
|
---|
| 380 | RtlEnlargedIntegerMultiply(
|
---|
| 381 | /*IN*/ LONG Multiplicand,
|
---|
| 382 | /*IN*/ LONG Multiplier);
|
---|
| 383 |
|
---|
| 384 | NTOSAPI
|
---|
| 385 | ULONG
|
---|
| 386 | DDKAPI
|
---|
| 387 | RtlEnlargedUnsignedDivide(
|
---|
| 388 | /*IN*/ ULARGE_INTEGER Dividend,
|
---|
| 389 | /*IN*/ ULONG Divisor,
|
---|
| 390 | /*IN OUT*/ PULONG Remainder);
|
---|
| 391 |
|
---|
| 392 | NTOSAPI
|
---|
| 393 | LARGE_INTEGER
|
---|
| 394 | DDKAPI
|
---|
| 395 | RtlEnlargedUnsignedMultiply(
|
---|
| 396 | /*IN*/ ULONG Multiplicand,
|
---|
| 397 | /*IN*/ ULONG Multiplier);
|
---|
| 398 |
|
---|
| 399 | NTOSAPI
|
---|
| 400 | LARGE_INTEGER
|
---|
| 401 | DDKAPI
|
---|
| 402 | RtlExtendedIntegerMultiply(
|
---|
| 403 | /*IN*/ LARGE_INTEGER Multiplicand,
|
---|
| 404 | /*IN*/ LONG Multiplier);
|
---|
| 405 |
|
---|
| 406 | NTOSAPI
|
---|
| 407 | LARGE_INTEGER
|
---|
| 408 | DDKAPI
|
---|
| 409 | RtlExtendedLargeIntegerDivide(
|
---|
| 410 | /*IN*/ LARGE_INTEGER Dividend,
|
---|
| 411 | /*IN*/ ULONG Divisor,
|
---|
| 412 | /*IN OUT*/ PULONG Remainder);
|
---|
| 413 |
|
---|
| 414 | NTOSAPI
|
---|
| 415 | LARGE_INTEGER
|
---|
| 416 | DDKAPI
|
---|
| 417 | RtlExtendedMagicDivide(
|
---|
| 418 | /*IN*/ LARGE_INTEGER Dividend,
|
---|
| 419 | /*IN*/ LARGE_INTEGER MagicDivisor,
|
---|
| 420 | /*IN*/ CCHAR ShiftCount);
|
---|
| 421 |
|
---|
| 422 | NTOSAPI
|
---|
| 423 | LARGE_INTEGER
|
---|
| 424 | DDKAPI
|
---|
| 425 | RtlLargeIntegerAdd(
|
---|
| 426 | /*IN*/ LARGE_INTEGER Addend1,
|
---|
| 427 | /*IN*/ LARGE_INTEGER Addend2);
|
---|
| 428 |
|
---|
| 429 | NTOSAPI
|
---|
| 430 | VOID
|
---|
| 431 | DDKAPI
|
---|
| 432 | RtlLargeIntegerAnd(
|
---|
| 433 | /*IN OUT*/ LARGE_INTEGER Result,
|
---|
| 434 | /*IN*/ LARGE_INTEGER Source,
|
---|
| 435 | /*IN*/ LARGE_INTEGER Mask);
|
---|
| 436 |
|
---|
| 437 | NTOSAPI
|
---|
| 438 | LARGE_INTEGER
|
---|
| 439 | DDKAPI
|
---|
| 440 | RtlLargeIntegerArithmeticShift(
|
---|
| 441 | /*IN*/ LARGE_INTEGER LargeInteger,
|
---|
| 442 | /*IN*/ CCHAR ShiftCount);
|
---|
| 443 |
|
---|
| 444 | NTOSAPI
|
---|
| 445 | LARGE_INTEGER
|
---|
| 446 | DDKAPI
|
---|
| 447 | RtlLargeIntegerDivide(
|
---|
| 448 | /*IN*/ LARGE_INTEGER Dividend,
|
---|
| 449 | /*IN*/ LARGE_INTEGER Divisor,
|
---|
| 450 | /*IN OUT*/ PLARGE_INTEGER Remainder);
|
---|
| 451 |
|
---|
| 452 | NTOSAPI
|
---|
| 453 | BOOLEAN
|
---|
| 454 | DDKAPI
|
---|
| 455 | RtlLargeIntegerEqualTo(
|
---|
| 456 | /*IN*/ LARGE_INTEGER Operand1,
|
---|
| 457 | /*IN*/ LARGE_INTEGER Operand2);
|
---|
| 458 |
|
---|
| 459 | NTOSAPI
|
---|
| 460 | BOOLEAN
|
---|
| 461 | DDKAPI
|
---|
| 462 | RtlLargeIntegerEqualToZero(
|
---|
| 463 | /*IN*/ LARGE_INTEGER Operand);
|
---|
| 464 |
|
---|
| 465 | NTOSAPI
|
---|
| 466 | BOOLEAN
|
---|
| 467 | DDKAPI
|
---|
| 468 | RtlLargeIntegerGreaterOrEqualToZero(
|
---|
| 469 | /*IN*/ LARGE_INTEGER Operand);
|
---|
| 470 |
|
---|
| 471 | NTOSAPI
|
---|
| 472 | BOOLEAN
|
---|
| 473 | DDKAPI
|
---|
| 474 | RtlLargeIntegerGreaterThan(
|
---|
| 475 | /*IN*/ LARGE_INTEGER Operand1,
|
---|
| 476 | /*IN*/ LARGE_INTEGER Operand2);
|
---|
| 477 |
|
---|
| 478 | NTOSAPI
|
---|
| 479 | BOOLEAN
|
---|
| 480 | DDKAPI
|
---|
| 481 | RtlLargeIntegerGreaterThanOrEqualTo(
|
---|
| 482 | /*IN*/ LARGE_INTEGER Operand1,
|
---|
| 483 | /*IN*/ LARGE_INTEGER Operand2);
|
---|
| 484 |
|
---|
| 485 | NTOSAPI
|
---|
| 486 | BOOLEAN
|
---|
| 487 | DDKAPI
|
---|
| 488 | RtlLargeIntegerGreaterThanZero(
|
---|
| 489 | /*IN*/ LARGE_INTEGER Operand);
|
---|
| 490 |
|
---|
| 491 | NTOSAPI
|
---|
| 492 | BOOLEAN
|
---|
| 493 | DDKAPI
|
---|
| 494 | RtlLargeIntegerLessOrEqualToZero(
|
---|
| 495 | /*IN*/ LARGE_INTEGER Operand);
|
---|
| 496 |
|
---|
| 497 | NTOSAPI
|
---|
| 498 | BOOLEAN
|
---|
| 499 | DDKAPI
|
---|
| 500 | RtlLargeIntegerLessThan(
|
---|
| 501 | /*IN*/ LARGE_INTEGER Operand1,
|
---|
| 502 | /*IN*/ LARGE_INTEGER Operand2);
|
---|
| 503 |
|
---|
| 504 | NTOSAPI
|
---|
| 505 | BOOLEAN
|
---|
| 506 | DDKAPI
|
---|
| 507 | RtlLargeIntegerLessThanOrEqualTo(
|
---|
| 508 | /*IN*/ LARGE_INTEGER Operand1,
|
---|
| 509 | /*IN*/ LARGE_INTEGER Operand2);
|
---|
| 510 |
|
---|
| 511 | NTOSAPI
|
---|
| 512 | BOOLEAN
|
---|
| 513 | DDKAPI
|
---|
| 514 | RtlLargeIntegerLessThanZero(
|
---|
| 515 | /*IN*/ LARGE_INTEGER Operand);
|
---|
| 516 |
|
---|
| 517 | NTOSAPI
|
---|
| 518 | LARGE_INTEGER
|
---|
| 519 | DDKAPI
|
---|
| 520 | RtlLargeIntegerNegate(
|
---|
| 521 | /*IN*/ LARGE_INTEGER Subtrahend);
|
---|
| 522 |
|
---|
| 523 | NTOSAPI
|
---|
| 524 | BOOLEAN
|
---|
| 525 | DDKAPI
|
---|
| 526 | RtlLargeIntegerNotEqualTo(
|
---|
| 527 | /*IN*/ LARGE_INTEGER Operand1,
|
---|
| 528 | /*IN*/ LARGE_INTEGER Operand2);
|
---|
| 529 |
|
---|
| 530 | NTOSAPI
|
---|
| 531 | BOOLEAN
|
---|
| 532 | DDKAPI
|
---|
| 533 | RtlLargeIntegerNotEqualToZero(
|
---|
| 534 | /*IN*/ LARGE_INTEGER Operand);
|
---|
| 535 |
|
---|
| 536 | NTOSAPI
|
---|
| 537 | LARGE_INTEGER
|
---|
| 538 | DDKAPI
|
---|
| 539 | RtlLargeIntegerShiftLeft(
|
---|
| 540 | /*IN*/ LARGE_INTEGER LargeInteger,
|
---|
| 541 | /*IN*/ CCHAR ShiftCount);
|
---|
| 542 |
|
---|
| 543 | NTOSAPI
|
---|
| 544 | LARGE_INTEGER
|
---|
| 545 | DDKAPI
|
---|
| 546 | RtlLargeIntegerShiftRight(
|
---|
| 547 | /*IN*/ LARGE_INTEGER LargeInteger,
|
---|
| 548 | /*IN*/ CCHAR ShiftCount);
|
---|
| 549 |
|
---|
| 550 | NTOSAPI
|
---|
| 551 | LARGE_INTEGER
|
---|
| 552 | DDKAPI
|
---|
| 553 | RtlLargeIntegerSubtract(
|
---|
| 554 | /*IN*/ LARGE_INTEGER Minuend,
|
---|
| 555 | /*IN*/ LARGE_INTEGER Subtrahend);
|
---|
| 556 |
|
---|
| 557 |
|
---|
| 558 | /*
|
---|
| 559 | * ULONG
|
---|
| 560 | * COMPUTE_PAGES_SPANNED(
|
---|
| 561 | * IN PVOID Va,
|
---|
| 562 | * IN ULONG Size)
|
---|
| 563 | */
|
---|
| 564 | #define COMPUTE_PAGES_SPANNED(Va, \
|
---|
| 565 | Size) \
|
---|
| 566 | (ADDRESS_AND_SIZE_TO_SPAN_PAGES(Va, Size))
|
---|
| 567 |
|
---|
| 568 |
|
---|
| 569 | /*
|
---|
| 570 | ** Architecture specific functions
|
---|
| 571 | */
|
---|
| 572 |
|
---|
| 573 | #ifdef _X86_
|
---|
| 574 |
|
---|
| 575 | NTOSAPI
|
---|
| 576 | INTERLOCKED_RESULT
|
---|
| 577 | DDKAPI
|
---|
| 578 | Exi386InterlockedIncrementLong(
|
---|
| 579 | /*IN*/ PLONG Addend);
|
---|
| 580 |
|
---|
| 581 | NTOSAPI
|
---|
| 582 | INTERLOCKED_RESULT
|
---|
| 583 | DDKFASTAPI
|
---|
| 584 | Exfi386InterlockedIncrementLong(
|
---|
| 585 | /*IN*/ PLONG Addend);
|
---|
| 586 |
|
---|
| 587 | NTOSAPI
|
---|
| 588 | INTERLOCKED_RESULT
|
---|
| 589 | DDKAPI
|
---|
| 590 | Exi386InterlockedDecrementLong(
|
---|
| 591 | /*IN*/ PLONG Addend);
|
---|
| 592 |
|
---|
| 593 | NTOSAPI
|
---|
| 594 | INTERLOCKED_RESULT
|
---|
| 595 | DDKFASTAPI
|
---|
| 596 | Exfi386InterlockedDecrementLong(
|
---|
| 597 | /*IN*/ PLONG Addend);
|
---|
| 598 |
|
---|
| 599 | NTOSAPI
|
---|
| 600 | ULONG
|
---|
| 601 | DDKAPI
|
---|
| 602 | Exi386InterlockedExchangeUlong(
|
---|
| 603 | /*IN*/ PULONG Target,
|
---|
| 604 | /*IN*/ ULONG Value);
|
---|
| 605 |
|
---|
| 606 | NTOSAPI
|
---|
| 607 | ULONG
|
---|
| 608 | DDKFASTAPI
|
---|
| 609 | Exfi386InterlockedExchangeUlong(
|
---|
| 610 | /*IN*/ PULONG Target,
|
---|
| 611 | /*IN*/ ULONG Value);
|
---|
| 612 |
|
---|
| 613 | #define ExInterlockedIncrementLong(Addend,Lock) Exfi386InterlockedIncrementLong(Addend)
|
---|
| 614 | #define ExInterlockedDecrementLong(Addend,Lock) Exfi386InterlockedDecrementLong(Addend)
|
---|
| 615 | #define ExInterlockedExchangeUlong(Target, Value, Lock) Exfi386InterlockedExchangeUlong(Target, Value)
|
---|
| 616 |
|
---|
| 617 | #endif /* _X86_ */
|
---|
| 618 |
|
---|
| 619 | #ifdef __cplusplus
|
---|
| 620 | }
|
---|
| 621 | #endif
|
---|
| 622 |
|
---|
| 623 | #endif /* __WINNT4_H */
|
---|