1 /*++ NDK Version: 0098 2 3 Copyright (c) Alex Ionescu. All rights reserved. 4 5 Header Name: 6 7 haltypes.h 8 9 Abstract: 10 11 Type definitions for the HAL. 12 13 Author: 14 15 Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 16 17 --*/ 18 19 #ifndef _HALTYPES_H 20 #define _HALTYPES_H 21 22 // 23 // Dependencies 24 // 25 #include <umtypes.h> 26 27 #ifndef NTOS_MODE_USER 28 29 // 30 // HalShutdownSystem Types 31 // 32 typedef enum _FIRMWARE_REENTRY 33 { 34 HalHaltRoutine, 35 HalPowerDownRoutine, 36 HalRestartRoutine, 37 HalRebootRoutine, 38 HalInteractiveModeRoutine, 39 HalMaximumRoutine 40 } FIRMWARE_REENTRY, *PFIRMWARE_REENTRY; 41 42 // 43 // HAL Private function Types 44 // 45 typedef 46 PBUS_HANDLER 47 (FASTCALL *pHalHandlerForConfigSpace)( 48 _In_ BUS_DATA_TYPE ConfigSpace, 49 _In_ ULONG BusNumber 50 ); 51 52 typedef 53 NTSTATUS 54 (NTAPI *PINSTALL_BUS_HANDLER)( 55 _In_ PBUS_HANDLER Bus 56 ); 57 58 typedef 59 NTSTATUS 60 (NTAPI *pHalRegisterBusHandler)( 61 _In_ INTERFACE_TYPE InterfaceType, 62 _In_ BUS_DATA_TYPE ConfigSpace, 63 _In_ ULONG BusNumber, 64 _In_ INTERFACE_TYPE ParentInterfaceType, 65 _In_ ULONG ParentBusNumber, 66 _In_ ULONG ContextSize, 67 _In_ PINSTALL_BUS_HANDLER InstallCallback, 68 _Out_ PBUS_HANDLER *BusHandler 69 ); 70 71 typedef 72 VOID 73 (NTAPI *pHalSetWakeEnable)( 74 _In_ BOOLEAN Enable 75 ); 76 77 typedef 78 VOID 79 (NTAPI *pHalSetWakeAlarm)( 80 _In_ ULONGLONG AlartTime, 81 _In_ PTIME_FIELDS TimeFields 82 ); 83 84 typedef 85 VOID 86 (NTAPI *pHalLocateHiberRanges)( 87 _In_ PVOID MemoryMap 88 ); 89 90 typedef 91 NTSTATUS 92 (NTAPI *pHalAllocateMapRegisters)( 93 _In_ PADAPTER_OBJECT AdapterObject, 94 _In_ ULONG Unknown, 95 _In_ ULONG Unknown2, 96 PMAP_REGISTER_ENTRY Registers 97 ); 98 99 // 100 // HAL Bus Handler Callback Types 101 // 102 typedef 103 NTSTATUS 104 (NTAPI *PADJUSTRESOURCELIST)( 105 _In_ PBUS_HANDLER BusHandler, 106 _In_ PBUS_HANDLER RootHandler, 107 _Inout_ PIO_RESOURCE_REQUIREMENTS_LIST *Resources 108 ); 109 110 typedef 111 NTSTATUS 112 (NTAPI *PASSIGNSLOTRESOURCES)( 113 _In_ PBUS_HANDLER BusHandler, 114 _In_ PBUS_HANDLER RootHandler, 115 _In_ PUNICODE_STRING RegistryPath, 116 _In_ PUNICODE_STRING DriverClassName, 117 _In_ PDRIVER_OBJECT DriverObject, 118 _In_ PDEVICE_OBJECT DeviceObject, 119 _In_ ULONG SlotNumber, 120 _Inout_ PCM_RESOURCE_LIST *AllocatedResources 121 ); 122 123 typedef 124 ULONG 125 (NTAPI *PGETSETBUSDATA)( 126 _In_ PBUS_HANDLER BusHandler, 127 _In_ PBUS_HANDLER RootHandler, 128 _In_ ULONG SlotNumber, 129 _Out_ PVOID Buffer, 130 _In_ ULONG Offset, 131 _In_ ULONG Length 132 ); 133 134 typedef 135 ULONG 136 (NTAPI *PGETINTERRUPTVECTOR)( 137 _In_ PBUS_HANDLER BusHandler, 138 _In_ PBUS_HANDLER RootHandler, 139 _In_ ULONG BusInterruptLevel, 140 _In_ ULONG BusInterruptVector, 141 _Out_ PKIRQL Irql, 142 _Out_ PKAFFINITY Affinity 143 ); 144 145 typedef 146 BOOLEAN 147 (NTAPI *PTRANSLATEBUSADDRESS)( 148 _In_ PBUS_HANDLER BusHandler, 149 _In_ PBUS_HANDLER RootHandler, 150 _In_ PHYSICAL_ADDRESS BusAddress, 151 _Inout_ PULONG AddressSpace, 152 _Out_ PPHYSICAL_ADDRESS TranslatedAddress 153 ); 154 155 // 156 // HAL Private dispatch Table 157 // 158 // See Version table at: 159 // https://www.geoffchappell.com/studies/windows/km/ntoskrnl/inc/ntos/hal/hal_private_dispatch.htm 160 // 161 #if (NTDDI_VERSION < NTDDI_WINXP) 162 #define HAL_PRIVATE_DISPATCH_VERSION 1 163 #elif (NTDDI_VERSION < NTDDI_LONGHORN) 164 #define HAL_PRIVATE_DISPATCH_VERSION 2 165 #elif (NTDDI_VERSION >= NTDDI_LONGHORN) 166 #define HAL_PRIVATE_DISPATCH_VERSION 5 167 #else 168 /* Not yet defined */ 169 #endif 170 typedef struct _HAL_PRIVATE_DISPATCH 171 { 172 ULONG Version; 173 pHalHandlerForBus HalHandlerForBus; 174 pHalHandlerForConfigSpace HalHandlerForConfigSpace; 175 pHalLocateHiberRanges HalLocateHiberRanges; 176 pHalRegisterBusHandler HalRegisterBusHandler; 177 pHalSetWakeEnable HalSetWakeEnable; 178 pHalSetWakeAlarm HalSetWakeAlarm; 179 pHalTranslateBusAddress HalPciTranslateBusAddress; 180 pHalAssignSlotResources HalPciAssignSlotResources; 181 pHalHaltSystem HalHaltSystem; 182 pHalFindBusAddressTranslation HalFindBusAddressTranslation; 183 pHalResetDisplay HalResetDisplay; 184 pHalAllocateMapRegisters HalAllocateMapRegisters; 185 pKdSetupPciDeviceForDebugging KdSetupPciDeviceForDebugging; 186 pKdReleasePciDeviceForDebugging KdReleasePciDeviceforDebugging; 187 pKdGetAcpiTablePhase0 KdGetAcpiTablePhase0; 188 pKdCheckPowerButton KdCheckPowerButton; 189 pHalVectorToIDTEntry HalVectorToIDTEntry; 190 pKdMapPhysicalMemory64 KdMapPhysicalMemory64; 191 pKdUnmapVirtualAddress KdUnmapVirtualAddress; 192 #if (NTDDI_VERSION >= NTDDI_LONGHORN) 193 pKdGetPciDataByOffset KdGetPciDataByOffset; 194 pKdSetPciDataByOffset KdSetPciDataByOffset; 195 PVOID HalGetInterruptVectorOverride; 196 PVOID HalGetVectorInputOverride; 197 #endif 198 } HAL_PRIVATE_DISPATCH, *PHAL_PRIVATE_DISPATCH; 199 200 // 201 // HAL Supported Range 202 // 203 #define HAL_SUPPORTED_RANGE_VERSION 1 204 typedef struct _SUPPORTED_RANGE 205 { 206 struct _SUPPORTED_RANGE *Next; 207 ULONG SystemAddressSpace; 208 LONGLONG SystemBase; 209 LONGLONG Base; 210 LONGLONG Limit; 211 } SUPPORTED_RANGE, *PSUPPORTED_RANGE; 212 213 typedef struct _SUPPORTED_RANGES 214 { 215 USHORT Version; 216 BOOLEAN Sorted; 217 UCHAR Reserved; 218 ULONG NoIO; 219 SUPPORTED_RANGE IO; 220 ULONG NoMemory; 221 SUPPORTED_RANGE Memory; 222 ULONG NoPrefetchMemory; 223 SUPPORTED_RANGE PrefetchMemory; 224 ULONG NoDma; 225 SUPPORTED_RANGE Dma; 226 } SUPPORTED_RANGES, *PSUPPORTED_RANGES; 227 228 // 229 // HAL Bus Handler 230 // 231 #define HAL_BUS_HANDLER_VERSION 1 232 typedef struct _BUS_HANDLER 233 { 234 ULONG Version; 235 INTERFACE_TYPE InterfaceType; 236 BUS_DATA_TYPE ConfigurationType; 237 ULONG BusNumber; 238 PDEVICE_OBJECT DeviceObject; 239 struct _BUS_HANDLER *ParentHandler; 240 PVOID BusData; 241 ULONG DeviceControlExtensionSize; 242 PSUPPORTED_RANGES BusAddresses; 243 ULONG Reserved[4]; 244 PGETSETBUSDATA GetBusData; 245 PGETSETBUSDATA SetBusData; 246 PADJUSTRESOURCELIST AdjustResourceList; 247 PASSIGNSLOTRESOURCES AssignSlotResources; 248 PGETINTERRUPTVECTOR GetInterruptVector; 249 PTRANSLATEBUSADDRESS TranslateBusAddress; 250 PVOID Spare1; 251 PVOID Spare2; 252 PVOID Spare3; 253 PVOID Spare4; 254 PVOID Spare5; 255 PVOID Spare6; 256 PVOID Spare7; 257 PVOID Spare8; 258 } BUS_HANDLER; 259 260 // 261 // HAL Chip Hacks 262 // 263 #define HAL_PCI_CHIP_HACK_BROKEN_ACPI_TIMER 0x01 264 #define HAL_PCI_CHIP_HACK_DISABLE_HIBERNATE 0x02 265 #define HAL_PCI_CHIP_HACK_DISABLE_ACPI_IRQ_ROUTING 0x04 266 #define HAL_PCI_CHIP_HACK_USB_SMI_DISABLE 0x08 267 268 // 269 // Kernel Exports 270 // 271 #if !defined(_NTSYSTEM_) && (defined(_NTDRIVER_) || defined(_NTDDK_) || defined(_NTIFS_) || defined(_NTHAL_)) 272 extern NTSYSAPI PHAL_PRIVATE_DISPATCH HalPrivateDispatchTable; 273 #define HALPRIVATEDISPATCH ((PHAL_PRIVATE_DISPATCH)&HalPrivateDispatchTable) 274 #else 275 extern NTSYSAPI HAL_PRIVATE_DISPATCH HalPrivateDispatchTable; 276 #define HALPRIVATEDISPATCH (&HalPrivateDispatchTable) 277 #endif 278 279 // 280 // HAL Exports 281 // 282 extern NTHALAPI PUCHAR KdComPortInUse; 283 284 // 285 // HAL Constants 286 // 287 #define HAL_IRQ_TRANSLATOR_VERSION 0x0 288 289 // 290 // BIOS call structure 291 // 292 #ifdef _M_AMD64 293 294 typedef struct _X86_BIOS_REGISTERS 295 { 296 ULONG Eax; 297 ULONG Ecx; 298 ULONG Edx; 299 ULONG Ebx; 300 ULONG Ebp; 301 ULONG Esi; 302 ULONG Edi; 303 USHORT SegDs; 304 USHORT SegEs; 305 } X86_BIOS_REGISTERS, *PX86_BIOS_REGISTERS; 306 307 #endif // _M_AMD64 308 309 #endif 310 #endif 311 312 313 314