348 lines
6.8 KiB
C
348 lines
6.8 KiB
C
/*++ BUILD Version: 0001
|
|
|
|
Copyright (c) 1994 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
haldisp.h
|
|
|
|
Abstract:
|
|
|
|
This module contains the private structure definitions and APIs used by
|
|
the NT haldisp
|
|
|
|
Author:
|
|
|
|
|
|
Revision History:
|
|
|
|
|
|
--*/
|
|
|
|
#pragma warning(push)
|
|
#pragma warning(disable:4200)
|
|
|
|
//
|
|
// Strcuture definitions.
|
|
//
|
|
|
|
typedef struct _ADAPTER_OBJECT {
|
|
DMA_ADAPTER DmaAdapter;
|
|
PADAPTER_OBJECT RealAdapterObject;
|
|
}ADAPTER_OBJECT;
|
|
|
|
typedef struct _XHAL_WAIT_CONTEXT_BLOCK {
|
|
PMDL Mdl;
|
|
PVOID CurrentVa;
|
|
ULONG Length;
|
|
PADAPTER_OBJECT RealAdapterObject;
|
|
PDRIVER_LIST_CONTROL DriverExecutionRoutine;
|
|
PVOID DriverContext;
|
|
PIRP CurrentIrp;
|
|
ULONG MapRegisterLock;
|
|
UCHAR WriteToDevice;
|
|
UCHAR MdlCount;
|
|
PVOID MapRegisterBase[];
|
|
} XHAL_WAIT_CONTEXT_BLOCK, *PXHAL_WAIT_CONTEXT_BLOCK;
|
|
|
|
//
|
|
// Function prototypes
|
|
//
|
|
|
|
NTSTATUS
|
|
xHalQuerySystemInformation(
|
|
IN HAL_QUERY_INFORMATION_CLASS InformationClass,
|
|
IN ULONG BufferSize,
|
|
OUT PVOID Buffer,
|
|
OUT PULONG ReturnedLength
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalSetSystemInformation(
|
|
IN HAL_SET_INFORMATION_CLASS InformationClass,
|
|
IN ULONG BufferSize,
|
|
OUT PVOID Buffer
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalQueryBusSlots(
|
|
IN PBUS_HANDLER BusHandler,
|
|
IN ULONG BufferSize,
|
|
OUT PULONG SlotNumbers,
|
|
OUT PULONG ReturnedLength
|
|
);
|
|
|
|
VOID
|
|
xHalSetWakeEnable(
|
|
IN BOOLEAN Enable
|
|
);
|
|
|
|
VOID
|
|
xHalSetWakeAlarm(
|
|
IN ULONGLONG WakeTime,
|
|
IN PTIME_FIELDS WakeTimeFields
|
|
);
|
|
|
|
VOID
|
|
xHalLocateHiberRanges(
|
|
IN PVOID MemoryMap
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalRegisterBusHandler(
|
|
IN INTERFACE_TYPE InterfaceType,
|
|
IN BUS_DATA_TYPE ConfigurationSpace,
|
|
IN ULONG BusNumber,
|
|
IN INTERFACE_TYPE ParentBusType,
|
|
IN ULONG ParentBusNumber,
|
|
IN ULONG SizeofBusExtensionData,
|
|
IN PINSTALL_BUS_HANDLER InstallBusHandlers,
|
|
OUT PBUS_HANDLER *BusHandler
|
|
);
|
|
|
|
PBUS_HANDLER
|
|
FASTCALL
|
|
xHalHandlerForBus (
|
|
IN INTERFACE_TYPE InterfaceType,
|
|
IN ULONG BusNumber
|
|
);
|
|
|
|
VOID
|
|
FASTCALL
|
|
xHalReferenceHandler (
|
|
IN PBUS_HANDLER Handler
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalInitPnpDriver(
|
|
VOID
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalInitPowerManagement(
|
|
IN PPM_DISPATCH_TABLE PmDriverDispatchTable,
|
|
IN OUT PPM_DISPATCH_TABLE *PmHalDispatchTable
|
|
);
|
|
|
|
PDMA_ADAPTER
|
|
xHalGetDmaAdapter (
|
|
IN PVOID Context,
|
|
IN struct _DEVICE_DESCRIPTION *DeviceDescriptor,
|
|
OUT PULONG NumberOfMapRegisters
|
|
);
|
|
|
|
VOID
|
|
xHalPutDmaAdapter (
|
|
PDMA_ADAPTER DmaAdapter
|
|
);
|
|
|
|
PVOID
|
|
xHalAllocateCommonBuffer (
|
|
IN PDMA_ADAPTER DmaAdapter,
|
|
IN ULONG Length,
|
|
OUT PPHYSICAL_ADDRESS LogicalAddress,
|
|
IN BOOLEAN CacheEnabled
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalAllocateMapRegisters(
|
|
IN PADAPTER_OBJECT DmaAdapter,
|
|
IN ULONG NumberOfMapRegisters,
|
|
IN ULONG BaseAddressCount,
|
|
OUT PMAP_REGISTER_ENTRY MapRegisterArray
|
|
);
|
|
|
|
VOID
|
|
xHalFreeCommonBuffer (
|
|
IN PDMA_ADAPTER DmaAdapter,
|
|
IN ULONG Length,
|
|
IN PHYSICAL_ADDRESS LogicalAddress,
|
|
IN PVOID VirtualAddress,
|
|
IN BOOLEAN CacheEnabled
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalAllocateAdapterChannel (
|
|
IN PDMA_ADAPTER DmaAdapter,
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
IN ULONG NumberOfMapRegisters,
|
|
IN PDRIVER_CONTROL ExecutionRoutine,
|
|
IN PVOID Context
|
|
);
|
|
|
|
BOOLEAN
|
|
xHalFlushAdapterBuffers (
|
|
IN PDMA_ADAPTER DmaAdapter,
|
|
IN PMDL Mdl,
|
|
IN PVOID MapRegisterBase,
|
|
IN PVOID CurrentVa,
|
|
IN ULONG Length,
|
|
IN BOOLEAN WriteToDevice
|
|
);
|
|
|
|
VOID
|
|
xHalFreeAdapterChannel (
|
|
IN PDMA_ADAPTER DmaAdapter
|
|
);
|
|
|
|
VOID
|
|
xHalFreeMapRegisters (
|
|
IN PDMA_ADAPTER DmaAdapter,
|
|
PVOID MapRegisterBase,
|
|
ULONG NumberOfMapRegisters
|
|
);
|
|
|
|
PHYSICAL_ADDRESS
|
|
xHalMapTransfer (
|
|
IN PDMA_ADAPTER DmaAdapter,
|
|
IN PMDL Mdl,
|
|
IN PVOID MapRegisterBase,
|
|
IN PVOID CurrentVa,
|
|
IN OUT PULONG Length,
|
|
IN BOOLEAN WriteToDevice
|
|
);
|
|
|
|
ULONG
|
|
xHalGetDmaAlignment (
|
|
IN PDMA_ADAPTER DmaAdapter
|
|
);
|
|
|
|
ULONG
|
|
xHalReadDmaCounter (
|
|
IN PDMA_ADAPTER DmaAdapter
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalGetScatterGatherList (
|
|
IN PDMA_ADAPTER DmaAdapter,
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
IN PMDL Mdl,
|
|
IN PVOID CurrentVa,
|
|
IN ULONG Length,
|
|
IN PDRIVER_LIST_CONTROL ExecutionRoutine,
|
|
IN PVOID Context,
|
|
IN BOOLEAN WriteToDevice
|
|
);
|
|
|
|
|
|
VOID
|
|
xHalPutScatterGatherList (
|
|
IN PDMA_ADAPTER DmaAdapter,
|
|
IN PSCATTER_GATHER_LIST ScatterGather,
|
|
IN BOOLEAN WriteToDevice
|
|
);
|
|
|
|
IO_ALLOCATION_ACTION
|
|
xHalpAllocateAdapterCallback (
|
|
IN struct _DEVICE_OBJECT *DeviceObject,
|
|
IN struct _IRP *Irp,
|
|
IN PVOID MapRegisterBase,
|
|
IN PVOID Context
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalGetInterruptTranslator(
|
|
IN INTERFACE_TYPE ParentInterfaceType,
|
|
IN ULONG ParentBusNumber,
|
|
IN INTERFACE_TYPE BridgeInterfaceType,
|
|
IN USHORT Size,
|
|
IN USHORT Version,
|
|
OUT PTRANSLATOR_INTERFACE Translator,
|
|
OUT PULONG BridgeBusNumber
|
|
);
|
|
|
|
BOOLEAN
|
|
xHalTranslateBusAddress(
|
|
IN INTERFACE_TYPE InterfaceType,
|
|
IN ULONG BusNumber,
|
|
IN PHYSICAL_ADDRESS BusAddress,
|
|
IN OUT PULONG AddressSpace,
|
|
OUT PPHYSICAL_ADDRESS TranslatedAddress
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalAssignSlotResources (
|
|
IN PUNICODE_STRING RegistryPath,
|
|
IN PUNICODE_STRING DriverClassName OPTIONAL,
|
|
IN PDRIVER_OBJECT DriverObject,
|
|
IN PDEVICE_OBJECT DeviceObject OPTIONAL,
|
|
IN INTERFACE_TYPE BusType,
|
|
IN ULONG BusNumber,
|
|
IN ULONG SlotNumber,
|
|
IN OUT PCM_RESOURCE_LIST *AllocatedResources
|
|
);
|
|
|
|
VOID
|
|
xHalHaltSystem(
|
|
VOID
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalStartMirroring(
|
|
VOID
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalEndMirroring(
|
|
IN ULONG PassNumber
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalMirrorPhysicalMemory(
|
|
IN PHYSICAL_ADDRESS PhysicalAddress,
|
|
IN LARGE_INTEGER NumberOfBytes
|
|
);
|
|
|
|
NTSTATUS
|
|
xHalMirrorVerify(
|
|
IN PHYSICAL_ADDRESS PhysicalAddress,
|
|
IN LARGE_INTEGER NumberOfBytes
|
|
);
|
|
|
|
NTSTATUS
|
|
xKdSetupPciDeviceForDebugging(
|
|
IN PVOID LoaderBlock, OPTIONAL
|
|
IN OUT PDEBUG_DEVICE_DESCRIPTOR PciDevice
|
|
);
|
|
|
|
NTSTATUS
|
|
xKdReleasePciDeviceForDebugging(
|
|
IN OUT PDEBUG_DEVICE_DESCRIPTOR PciDevice
|
|
);
|
|
|
|
PVOID
|
|
xKdGetAcpiTablePhase0(
|
|
IN PLOADER_PARAMETER_BLOCK LoaderBlock,
|
|
IN ULONG Signature
|
|
);
|
|
|
|
VOID
|
|
xKdCheckPowerButton(
|
|
VOID
|
|
);
|
|
|
|
VOID
|
|
xHalEndOfBoot(
|
|
VOID
|
|
);
|
|
|
|
UCHAR
|
|
xHalVectorToIDTEntry(
|
|
ULONG Vector
|
|
);
|
|
|
|
PVOID
|
|
xKdMapPhysicalMemory64(
|
|
IN PHYSICAL_ADDRESS PhysicalAddress,
|
|
IN ULONG NumberPages
|
|
);
|
|
|
|
VOID
|
|
xKdUnmapVirtualAddress(
|
|
IN PVOID VirtualAddress,
|
|
IN ULONG NumberPages
|
|
);
|
|
|
|
#pragma warning(pop)
|
|
|