/*++ Copyright (c) Microsoft Corporation. All rights reserved. Module Name: video.h Abstract: Contains all structure and routine definitions common to the video port driver and the video miniport drivers. Notes: Revision History: --*/ #ifndef __VIDEO_H__ #define __VIDEO_H__ #include // // Define port driver status code. // The values for these are the Win32 error codes // typedef LONG VP_STATUS; typedef VP_STATUS *PVP_STATUS; // // Defines for registry information and synchronization. // typedef enum VIDEO_SYNCHRONIZE_PRIORITY { VpLowPriority, VpMediumPriority, VpHighPriority } VIDEO_SYNCHRONIZE_PRIORITY, *PVIDEO_SYNCHRONIZE_PRIORITY; // // Opaque pointer type for miniport to be used to type PEVENTs received from // display driver. // typedef struct _VIDEO_PORT_EVENT *PEVENT; typedef struct _VIDEO_PORT_SPIN_LOCK *PSPIN_LOCK; // // Type of information requested with GetDeviceData // typedef enum _VIDEO_DEVICE_DATA_TYPE { VpMachineData, VpCmosData, VpBusData, VpControllerData, VpMonitorData } VIDEO_DEVICE_DATA_TYPE, *PVIDEO_DEVICE_DATA_TYPE; typedef enum _VP_POOL_TYPE { VpNonPagedPool, VpPagedPool, VpNonPagedPoolCacheAligned = 4, VpPagedPoolCacheAligned } VP_POOL_TYPE, *PVP_POOL_TYPE; // // Data returned with VpControllerData // typedef struct _VIDEO_HARDWARE_CONFIGURATION_DATA { INTERFACE_TYPE InterfaceType; ULONG BusNumber; USHORT Version; USHORT Revision; USHORT Irql; USHORT Vector; ULONG ControlBase; ULONG ControlSize; ULONG CursorBase; ULONG CursorSize; ULONG FrameBase; ULONG FrameSize; } VIDEO_HARDWARE_CONFIGURATION_DATA, *PVIDEO_HARDWARE_CONFIGURATION_DATA; // // Define structure used to call the BIOS int 10 function // typedef struct _VIDEO_X86_BIOS_ARGUMENTS { ULONG Eax; ULONG Ebx; ULONG Ecx; ULONG Edx; ULONG Esi; ULONG Edi; ULONG Ebp; } VIDEO_X86_BIOS_ARGUMENTS, *PVIDEO_X86_BIOS_ARGUMENTS; typedef struct _INT10_BIOS_ARGUMENTS { ULONG Eax; ULONG Ebx; ULONG Ecx; ULONG Edx; ULONG Esi; ULONG Edi; ULONG Ebp; USHORT SegDs; USHORT SegEs; } INT10_BIOS_ARGUMENTS, *PINT10_BIOS_ARGUMENTS; #define SIZE_OF_NT4_VIDEO_PORT_CONFIG_INFO 0x42 #define SIZE_OF_NT4_VIDEO_HW_INITIALIZATION_DATA 0x28 #define SIZE_OF_W2K_VIDEO_HW_INITIALIZATION_DATA 0x50 // // Debugging statements. This will remove all the debug information from the // "free" version. // #if DBG #define VideoDebugPrint(arg) VideoPortDebugPrint arg #else #define VideoDebugPrint(arg) #endif typedef enum VIDEO_DEBUG_LEVEL { Error = 0, Warn, Trace, Info } VIDEO_DEBUG_LEVEL, *PVIDEO_DEBUG_LEVEL; // // Allows us to remove lots of unused code. // #ifndef _NTOSDEF_ //don't pickup ntosp version #ifdef PAGED_CODE #undef PAGED_CODE #endif #define ALLOC_PRAGMA 1 #define VIDEOPORT_API __declspec(dllimport) #if DBG #define PAGED_CODE() \ if (VideoPortGetCurrentIrql() > 1 /*APC_LEVEL*/) { \ VideoPortDebugPrint(0, "Video: Pageable code called at IRQL %d\n", VideoPortGetCurrentIrql() ); \ ASSERT(FALSE); \ } #else #define PAGED_CODE() #endif ULONG DriverEntry( PVOID Context1, PVOID Context2 ); #else #define VIDEOPORT_API #endif #ifndef _NTOS_ // // These are the various function prototypes of the routines that are // provided by the kernel driver to hook out access to io ports. // typedef VP_STATUS (*PDRIVER_IO_PORT_UCHAR ) ( ULONG_PTR Context, ULONG Port, UCHAR AccessMode, PUCHAR Data ); typedef VP_STATUS (*PDRIVER_IO_PORT_UCHAR_STRING ) ( ULONG_PTR Context, ULONG Port, UCHAR AccessMode, PUCHAR Data, ULONG DataLength ); typedef VP_STATUS (*PDRIVER_IO_PORT_USHORT ) ( ULONG_PTR Context, ULONG Port, UCHAR AccessMode, PUSHORT Data ); typedef VP_STATUS (*PDRIVER_IO_PORT_USHORT_STRING ) ( ULONG_PTR Context, ULONG Port, UCHAR AccessMode, PUSHORT Data, ULONG DataLength // number of words ); typedef VP_STATUS (*PDRIVER_IO_PORT_ULONG ) ( ULONG_PTR Context, ULONG Port, UCHAR AccessMode, PULONG Data ); typedef VP_STATUS (*PDRIVER_IO_PORT_ULONG_STRING ) ( ULONG_PTR Context, ULONG Port, UCHAR AccessMode, PULONG Data, ULONG DataLength // number of dwords ); #endif // _NTOS_ // // Definition of the request packet sent from the port driver to the // miniport driver. It reflects the parameters passed from the // DeviceIOControl call made by the windows display driver. // // N.B. The definition of the STATUS_BLOCK must be the same as the // the definition of IO_STATUS_BLOCK defined in ntioapi.h. // typedef struct _STATUS_BLOCK { // // Contains the status code of the operation. // This value in one of the Win32 error codes that are defined for use // in the video miniport drivers. // union { VP_STATUS Status; PVOID Pointer; }; // // Information returned to the callee. // The meaning of the information varies from function to function. It // is generally used to return the minimum size for the input buffer if // the function takes an input buffer, or the amount of data transfered // back to the caller if the operation returns output. // ULONG_PTR Information; } STATUS_BLOCK, *PSTATUS_BLOCK; typedef struct _VIDEO_REQUEST_PACKET { // // The IO control code passed to the DeviceIoControl function by the // caller. // ULONG IoControlCode; // // Pointer to a status block provided by the caller. This should be // filled out by the callee with the appropriate information. // PSTATUS_BLOCK StatusBlock; // // Pointer to an input buffer which contains the information passed in // by the caller. // PVOID InputBuffer; // // Size of the input buffer // ULONG InputBufferLength; // // Pointer to an output buffer into which the data returned to the caller // should be stored. // PVOID OutputBuffer; // // Length of the output buffer. This buffer can not be grown by the // callee. // ULONG OutputBufferLength; } VIDEO_REQUEST_PACKET, *PVIDEO_REQUEST_PACKET; // // typedef for scattergather array available via GET_VIDEO_SCATTERGATHER(). // typedef struct __VRB_SG { __int64 PhysicalAddress; ULONG Length; } VRB_SG, *PVRB_SG; // // Opaque type for dma handle // typedef struct __DMA_PARAMETERS * PDMA; // // The following macro returns in Address the 32 bit physical address of // the VirtualAddress lying within the InputBuffer passed into EngDevIo // #define GET_VIDEO_PHYSICAL_ADDRESS(scatterList, VirtualAddress, InputBuffer, pLength, Address) \ \ do { \ ULONG_PTR byteOffset; \ \ byteOffset = (PCHAR) VirtualAddress - (PCHAR)InputBuffer; \ \ while (byteOffset >= scatterList->Length) { \ \ byteOffset -= scatterList->Length; \ scatterList++; \ } \ \ *pLength = scatterList->Length - byteOffset; \ \ Address = (ULONG_PTR) (scatterList->PhysicalAddress + byteOffset); \ \ } while (0) #define GET_VIDEO_SCATTERGATHER(ppDma) (**(PVRB_SG **)ppDma) // // Opaque type for PVP_DMA_ADAPTER // typedef struct __VP_DMA_ADAPTER *PVP_DMA_ADAPTER; typedef enum _VP_LOCK_OPERATION { VpReadAccess, VpWriteAccess, VpModifyAccess } VP_LOCK_OPERATION; typedef struct _VP_DEVICE_DESCRIPTION { BOOLEAN ScatterGather; BOOLEAN Dma32BitAddresses; BOOLEAN Dma64BitAddresses; ULONG MaximumLength; } VP_DEVICE_DESCRIPTION, *PVP_DEVICE_DESCRIPTION; typedef struct _VP_SCATTER_GATHER_ELEMENT { PHYSICAL_ADDRESS Address; ULONG Length; ULONG_PTR Reserved; } VP_SCATTER_GATHER_ELEMENT, *PVP_SCATTER_GATHER_ELEMENT; #pragma warning(disable:4200) typedef struct _VP_SCATTER_GATHER_LIST { ULONG NumberOfElements; ULONG_PTR Reserved; VP_SCATTER_GATHER_ELEMENT Elements[]; } VP_SCATTER_GATHER_LIST, *PVP_SCATTER_GATHER_LIST; #pragma warning(default:4200) #define VIDEO_RANGE_PASSIVE_DECODE 0x1 #define VIDEO_RANGE_10_BIT_DECODE 0x2 // // The following structure is used to define access ranges. The ranges are // used to indicate which ports and memory adresses are being used by the // card. // typedef struct _VIDEO_ACCESS_RANGE { // // Indicates the starting memory address or port number of the range. // This values should be stored before being transformed by // VideoPortGetDeviceBase() which returns the logical address that must // be used by the miniport driver when referencing physical addresses. // PHYSICAL_ADDRESS RangeStart; // // Indicates the length in bytes, or number of ports in the range. This // value should indicate the range actually decoded by the adapter. For // example, if the adapter uses 7 registers but responds to eight, the // RangeLength should be set to 8. ULONG RangeLength; // // Indicates if the range is in IO space (TRUE) or in memory space (FALSE). // UCHAR RangeInIoSpace; // // Indicates if the range should be visible by the Windows display driver. // This is done so that a Windows display driver can access certain // video ports directly. This will only be allowed if the caller has the // required privileges (is a trusted subsystem) to access the range. // // Synchronization of access to ports or memory in the range must be // done explicitly by the miniport driver and the user mode process so // that they both don't try to program the device simultaneously. // // Non visible ranges should include video memory, ROM addresses, etc. // which are not required to program the device for output purposes. // // UCHAR RangeVisible; // // This field determines if the range can be shared with another device. // The rule should be applied as follow. // // - If the range of memory or IO ports should be "owned" by this driver, // and that any other driver trying to access this range may cause // a problem, FALSE should be returned. // // - If the range can be shared with another co-operating device driver, // then the share field should be set to TRUE. // // As a guideline, the VGA miniport driver will claim all of its resources // as shareable so that it can be used as a VGA compatible device with // any other driver (such as an S3 or XGA. // // Super VGA miniport drivers that implement all the VGA functionality // (declared in the Registry as VGACOMPATIBLE=1) should claim the range // as non-shareable since they don't want the VGA to run at the same time. // // Miniports for cards such as an S3 or XGA that have an XGA on the board // but do not implement the VGA functionality will run with the VGA // miniport loaded and should therefore claim all the resources shared // with the VGA as shareable. // // Miniports for cards that work with a pass-through and that can be // connected to any VGA/SVGA card should not be using any VGA ports or // memory ranges ! ... but if they do they should not claim those // resources since they will cause a conflict in the system because the // SVGA cards will have claimed them as non-shareable ... // UCHAR RangeShareable; // // Indicates that the range is decoded by the hardware, but that the // driver will never access this port. // UCHAR RangePassive; } VIDEO_ACCESS_RANGE, *PVIDEO_ACCESS_RANGE; typedef PVOID (*PVIDEO_PORT_GET_PROC_ADDRESS)( IN PVOID HwDeviceExtension, IN PUCHAR FunctionName ); // // This structure contains the specific configuration information about the // device. The information is initialized by the port driver and it should // be completed by the miniport driver. // The information is used to setup the device, as weel as providing // information to the port driver so it can perform some of the requests on // behalf of the miniport driver. // typedef struct _VIDEO_PORT_CONFIG_INFO { // // Specifies the length of the PVIDEO_PORT_CONFIG_INFO structure as // returned by sizeof(). Since this structure may grow in later // releases, the miniport driver should check that the length of the // structure is greater than or equal to the length it expects (since // it is guaranteed that defined fields will not change). // // This field is always initialized by the port driver. // ULONG Length; // // Specifies which IO bus is tp be scanned. This field is used as a // parameter to some VideoPortXXX calls. // // This field is always initialized by the port driver. // ULONG SystemIoBusNumber; // // Specifies the type of bus being scanned. This field is equal to the // value being passed into VideoPortInitialize in the // VIDEO_HW_INITIALIZATION_DATA structure. // // This field is always initialized by the port driver. // INTERFACE_TYPE AdapterInterfaceType; // // Specifies the bus interrupt request level. This level corresponds to // the IRQL on ISA and MCA buses. // This value is only used if the device supports interrupts, which is // determined by the presence of an interrupt service routine in the // VIDEO_HW_INITIALIZATION_DATA structure. // // The preset default value for this field is zero. Otherwise, it is the // value found in the device configuration information. // ULONG BusInterruptLevel; // // Specifies the bus vector returned by the adapter. This is used for // systems which have IO buses that use interrupt vectors. For ISA, MCA // and EISA buses, this field is unused. // // The preset default value for this field is zero. // ULONG BusInterruptVector; // // Specifies whether this adapter uses latched or edge-triggered type // interrupts. // // This field is always initialized by the port driver. // KINTERRUPT_MODE InterruptMode; // // Specifies the number of emulator access entries that the adapter // uses. It indicates the number of array elements in the following field. // // This field can be reinitialized with the number of entries in the // EmulatorAccessEntries structure if the structure is statically // defined in the miniport driver. The EmulatorAccessEntries fields // should also be updated. // ULONG NumEmulatorAccessEntries; // // Supplies a pointer to an array of EMULATOR_ACCESS_ENTRY structures. // The number of elements in the array is indicated by the // NumEmulatorAccessEntries field. The driver should fill out each entry // for the adapter. // // The uninitialized value for the structure is NULL. // EmulatorAccessEntries will be NULL if NumEmulatorAccessEntries is // zero. // // A poiner to an array of emulator access entries can be passed back // if such a structure is defined statically in the miniport driver. The // NumEmulatorAccessEntries field should also be updated. // PEMULATOR_ACCESS_ENTRY EmulatorAccessEntries; // // This is a context values that is passed with each call to the // emulator/validator functions defined in the EmulatorAccessEntries // defined above. // This parameter should in general be a pointer to the miniports // device extension or other such storage location. // // This pointer will allow the miniport to save some state temporarily // to allow for the batching of IO requests. // ULONG_PTR EmulatorAccessEntriesContext; // // Physical address of the video memory that must be mapped into a VDM's // address space for proper BIOS support // PHYSICAL_ADDRESS VdmPhysicalVideoMemoryAddress; // // Length of the video memory that must be mapped into a VDM's addres // space for proper BIOS support. // ULONG VdmPhysicalVideoMemoryLength; // // Determines the minimum size required to store the hardware state // information returned by IOCTL_VIDEO_SAVE_HARDWARE_STATE. // // The uninitialized value for this field is zero. // // If the field is left to zero, SAVE_HARDWARE_STATE will return an // ERROR_INVALID_FUNCTION status code. // ULONG HardwareStateSize; // // New for version 3.5 // // // Optional DMA channel, if required by the device. // 0 for the Channel and Port indicates DMA is not used by the device. // ULONG DmaChannel; // // Optional DMA channel, if required by the device. // 0 for the Channel and Port indicates DMA is not used by the device. // ULONG DmaPort; // // Set to 1 if the DMA channel can be shared with another device. // Set to 0 if the DMA channel must be owned exclusively by the driver. // UCHAR DmaShareable; // // Set to 1 if the interrupt can be shared with another device. // Set to 0 if the interrupt must be owned exclusively by the driver. // UCHAR InterruptShareable; // // Start new dma stuff // // // Set to TRUE if the DMA device is a busmaster, FALSE otherwise. // BOOLEAN Master; // // Set to number of bits wide. Consistent with DEVICE_DESCRIPTION. // See ntioapi.h // DMA_WIDTH DmaWidth; // // Set to speed so miniport can set DEVICE_DESCRIPTION field. // See ntioapi.h // DMA_SPEED DmaSpeed; // // Set to TRUE if the DMA device requires mapped buffers. Also // a DEVICE_DESCRIPTION field. // BOOLEAN bMapBuffers; // // Set to TRUE if the DMA device requires physical addresses. // BOOLEAN NeedPhysicalAddresses; // // Set to TRUE if the DMA device supports demand mode, FALSE otherwise. // Also DEVICE_DESCRIPTION support. // BOOLEAN DemandMode; // // Set to max transfer length the DMA device supports. // ULONG MaximumTransferLength; // // Set to max number of Physical breaks the DMA device supports. // ULONG NumberOfPhysicalBreaks; // // Set to TRUE if the DMA device supports scatter gather, FALSE otherwise. // BOOLEAN ScatterGather; // // Maximal Length in PVRB_SG returned measured in bytes. If the device // has no maximum size, zero should be entered. // ULONG MaximumScatterGatherChunkSize; // // Allow for 4.0/5.0 compatibilty // PVIDEO_PORT_GET_PROC_ADDRESS VideoPortGetProcAddress; // // Provide a pointer to the device's registry path // PWSTR DriverRegistryPath; // // Indicates to a driver the amount of physical memory in the system // ULONGLONG SystemMemorySize; } VIDEO_PORT_CONFIG_INFO, *PVIDEO_PORT_CONFIG_INFO; // // Video Adapter Dependent Routines. // typedef VP_STATUS (*PVIDEO_HW_FIND_ADAPTER) ( PVOID HwDeviceExtension, PVOID HwContext, PWSTR ArgumentString, PVIDEO_PORT_CONFIG_INFO ConfigInfo, PUCHAR Again ); typedef BOOLEAN (*PVIDEO_HW_INITIALIZE) ( PVOID HwDeviceExtension ); typedef BOOLEAN (*PVIDEO_HW_INTERRUPT) ( PVOID HwDeviceExtension ); typedef VOID (*PVIDEO_HW_LEGACYRESOURCES) ( IN ULONG VendorId, IN ULONG DeviceId, IN OUT PVIDEO_ACCESS_RANGE *LegacyResourceList, IN OUT PULONG LegacyResourceCount ); // // type to be returned by HwStartDma(). // typedef enum _HW_DMA_RETURN { DmaAsyncReturn, DmaSyncReturn } HW_DMA_RETURN, *PHW_DMA_RETURN; typedef HW_DMA_RETURN (*PVIDEO_HW_START_DMA) ( PVOID HwDeviceExtension, PDMA pDma ); typedef VOID (*PEXECUTE_DMA)( PVOID HwDeviceExtension, PVP_DMA_ADAPTER VpDmaAdapter, PVP_SCATTER_GATHER_LIST SGList, PVOID Context ); // // Flags to be passed into VideoPortLockPages() or VideoPortDoDma(). // // // The flag VideoPortUnlockAfterDma tells the video port to unlock the pages // after the miniport signals that the dma is complete via the // pDmaCompletionEvent in HwStartDma. Failure to set this event at // dma completion may cause the memory to be unlocked at randon times. // This flag is best used when one wants to do one dma transfer which // occurs infrequently. It allows locking, dmaing and unlocking to be performed // in the context of 1 IOCTL. // // // The flag VideoPortKeepPagesLocked tells the video port to leave the pages // locked if possible. // // // The flag VideoPortDmaInitOnly tells the Video Port to lock the pages, but don't // call HwStartDma. Not applicable to VideoPortDoDma(). // typedef enum { VideoPortUnlockAfterDma = 1, VideoPortKeepPagesLocked, VideoPortDmaInitOnly } DMA_FLAGS; // // Event flags // typedef ULONG DMA_EVENT_FLAGS; #define SET_USER_EVENT 0x01 #define SET_DISPLAY_EVENT 0x02 #define EVENT_TYPE_MASK 1 #define SYNCHRONIZATION_EVENT 0 #define NOTIFICATION_EVENT 1 #define INITIAL_EVENT_STATE_MASK 2 #define INITIAL_EVENT_NOT_SIGNALED 0 #define INITIAL_EVENT_SIGNALED 2 // // Child Enumeration structure passed in to the PVIDEO_HW_GET_CHILD_DESCRIPTOR // function. // // All these parameters are input parameters and must not be modified by the // callee // // Size - Size of the structure. It can be used by the calle for versioning. // // ChildDescriptorSize - Size of the pChildDescriptor buffer passed in as the // third parameter to PVIDEO_HW_GET_CHILD_DESCRIPTOR. // // ChildIndex - Index of the device to be enumerated. This field should be // used to enumerate devices not enumerated by ACPI or other operating // system components. If this field is set to 0 it indicates the ACPIHwId // field. // // ACPIHwId - ID returned by the ACPI BIOS that represent the device being // queried. The ACPIHwId returned by the firmware must match the HwIds // returned by the driver. The System BIOS manufacturer and the graphics // IHV must synchronize these IDs. // // ChildHwDeviceExtension - Pointer to a device extension specific to this // child device. This field will only be filled in if the miniport driver // filled the ChildHwDeviceExtensionSize to be non-NULL. // typedef struct _VIDEO_CHILD_ENUM_INFO { ULONG Size; ULONG ChildDescriptorSize; ULONG ChildIndex; ULONG ACPIHwId; PVOID ChildHwDeviceExtension; } VIDEO_CHILD_ENUM_INFO, *PVIDEO_CHILD_ENUM_INFO; // // VIDEO_CHILD_TYPE enum: // // 'Monitor' identifies a device which may have a DDC2 compliant EDID data // structure. If the video miniport detects such a device, it is to extract // the edid from the monitor and put that in the paged buffer provided by // videoprt.sys in the callback to PVIDEO_HW_GET_CHILD_DESCRIPTOR and return // this type in the the OUT PVIDEO_CHILD_TYPE parameter of that call. This // EDID, if available, will be written to the registry. If the EDID is not // available, nothing should be put in the buffer. // // 'NonPrimaryChip' identifies another VGA chip on the video board which // is not the primary VGA chip. This type is to be used if and only if the // miniport detects more than one VGA chip on the board. Such an identifier // will cause the videoprt to create another DEVICE_EXTENSION and associated // HW_DEVICE_EXTENSION to be associated with the chip so identified. // // 'Other' identifies some other video device attached to the video card. If // the miniport detects such a device, it is to put a wide char string // (WSTR) into the paged buffer provided by the videoprt.sys which is the // PNP hardware identifier of the device. This string will be used to create // a value of that name in the registry. // typedef enum { Monitor = 1, NonPrimaryChip, VideoChip, Other } VIDEO_CHILD_TYPE, *PVIDEO_CHILD_TYPE; // // define a constant that represents the display adapter self query. // #define DISPLAY_ADAPTER_HW_ID 0xFFFFFFFF // // Define invalid child device id (needed for failure return value). // #define VIDEO_INVALID_CHILD_ID 0xFFFFFFFF typedef struct _VIDEO_CHILD_STATE { ULONG Id; ULONG State; } VIDEO_CHILD_STATE, *PVIDEO_CHILD_STATE; typedef struct _VIDEO_CHILD_STATE_CONFIGURATION { ULONG Count; VIDEO_CHILD_STATE ChildStateArray[ANYSIZE_ARRAY]; } VIDEO_CHILD_STATE_CONFIGURATION, *PVIDEO_CHILD_STATE_CONFIGURATION; // // The following routine should return TRUE if successful. It should: // 1) put the type of the child device in VideoChildType. // 2) put the information from the device in Buffer. This // buffer is of size 256 bytes. If the type returned in // PVideoChildType is Monitor, this buffer must contain the // EDID of the monitor if readable. If the type returned in // PVideoChildType is Other, a wide character string representing // the PNP Device Id must be put in the buffer. This string will // be used to create a key for the device if the buffer contains // an EDID. Otherwise, it is used to obtain a PNP ID for the // device. // 3) Put a miniport determined HANDLE in HwId. This value will be // passed back to the miniport for Power management operations, // as well as other operations. This allows the miniport to define // the contract between the system and the miniport which defines a // particular device. // // It should only return FALSE if there are no devices attached to that // display adapter connector. // typedef VP_STATUS (*PVIDEO_HW_GET_CHILD_DESCRIPTOR) ( IN PVOID HwDeviceExtension, IN PVIDEO_CHILD_ENUM_INFO ChildEnumInfo, OUT PVIDEO_CHILD_TYPE VideoChildType, OUT PUCHAR pChildDescriptor, OUT PULONG UId, OUT PULONG pUnused ); // // This routine is used to set the power on the graphics devices. // These include all the Children enumerated by GET_CHILD_DESCRIPTOR callback // as well as the graphics adapter itself. // // The HwDevice extension represent the adapter instance of the device. // // The HwId parameter is the unique ID as returned by the enumeration routine. // The miniport will only be called to set the power on the devices it // enumerated, as well as the graphics adapter itself. A HwId of 0xFFFFFFFF // will be passed in to identify the graphics adapter itself. // The miniport driver should never turn off the power to the graphics adapter // unless specifically request to. // // The VideoPowerControl is the level to which the device shold be set. // The videoport driver will manage these states. // typedef VP_STATUS (*PVIDEO_HW_POWER_SET) ( PVOID HwDeviceExtension, ULONG HwId, PVIDEO_POWER_MANAGEMENT VideoPowerControl ); // // This routine simply returns whether or not the device can support the // requested state. // // See HW_POWER_SET for a description of the parameters. // typedef VP_STATUS (*PVIDEO_HW_POWER_GET) ( PVOID HwDeviceExtension, ULONG HwId, PVIDEO_POWER_MANAGEMENT VideoPowerControl ); // // This structure should match the QueryInterface struct defined // in io.h. // typedef struct _QUERY_INTERFACE { CONST GUID *InterfaceType; USHORT Size; USHORT Version; PINTERFACE Interface; PVOID InterfaceSpecificData; } QUERY_INTERFACE, *PQUERY_INTERFACE; typedef VP_STATUS (*PVIDEO_HW_QUERY_INTERFACE) ( PVOID HwDeviceExtension, PQUERY_INTERFACE QueryInterface ); typedef VP_STATUS (*PVIDEO_HW_CHILD_CALLBACK) ( PVOID HwDeviceExtension, PVOID ChildDeviceExtension ); // // Entry point for all IOCTL calls made to the miniport driver. // typedef BOOLEAN (*PVIDEO_HW_START_IO) ( PVOID HwDeviceExtension, PVIDEO_REQUEST_PACKET RequestPacket ); // // The return value determines if the mode was completely programmed (TRUE) // or if an int10 should be done by the HAL to complete the modeset (FALSE). // typedef BOOLEAN (*PVIDEO_HW_RESET_HW) ( PVOID HwDeviceExtension, ULONG Columns, ULONG Rows ); // // Timer routine called every second. // typedef VOID (*PVIDEO_HW_TIMER) ( PVOID HwDeviceExtension ); // // Structure passed by the miniport entry point to the video port // initialization routine. // typedef struct _VIDEO_HW_INITIALIZATION_DATA { // // Supplies the size of the structure in bytes as determined by sizeof(). // ULONG HwInitDataSize; // // Indicates the bus type the adapter works with, such as Eisa, Isa, MCA. // INTERFACE_TYPE AdapterInterfaceType; // // Supplies a pointer to the miniport driver's find adapter routine. // PVIDEO_HW_FIND_ADAPTER HwFindAdapter; // // Supplies a pointer to the miniport driver's initialization routine. // PVIDEO_HW_INITIALIZE HwInitialize; // // Supplies a pointer to the miniport driver's interrupt service routine. // PVIDEO_HW_INTERRUPT HwInterrupt; // // Supplies a pointer to the miniport driver's start io routine. // PVIDEO_HW_START_IO HwStartIO; // // Supplies the size in bytes required for the miniport driver's private // device extension. This storage is used by the miniport driver to hold // per-adapter information. A pointer to this storage is provided with // every call made to the miniport driver. This data storage is // initialized to zero by the port driver. // ULONG HwDeviceExtensionSize; // // Supplies the number with which device numbering should be started. // The device numbering is used to determine which \DeviceX entry under // the \Parameters section in the registry should be used for parameters // to the miniport driver. // The number is *automatically* incremented when the miniport is called // back in it's FindAdapter routine due to an appropriate _Again_ // parameter. // ULONG StartingDeviceNumber; // // New for version 3.5 // // // Supplies a pointer to the miniport driver's HwResetHw routine. // // This function is called when the machine needs to bugchecks (go back // to the blue screen). // // This function should reset the video adapter to a character mode, // or at least to a state from which an int 10 can reset the card to // a character mode. // // This routine CAN NOT call int10. // It can only call Read\Write Port\Register functions from the port driver. // // The function must also be completely in non-paged pool since the IO\MM // subsystems may have crashed. // PVIDEO_HW_RESET_HW HwResetHw; // // Pointer to a timer routine to be called every second. // PVIDEO_HW_TIMER HwTimer; // // Start of 5.0 stuff. // // // Supplies a pointer to the miniport driver's start dma routine. This routine must // return a HW_DMA_RETURN consistent with it's return behavior. // PVIDEO_HW_START_DMA HwStartDma; // // HW dependent Power management routines. // PVIDEO_HW_POWER_SET HwSetPowerState; PVIDEO_HW_POWER_GET HwGetPowerState; // // Supplies a pointer to a miniport driver routine which can be called to // enumerate devices physically attached to the graphics adapter. // PVIDEO_HW_GET_CHILD_DESCRIPTOR HwGetVideoChildDescriptor; // // Supplies a pointer to a miniport driver routine which can be called to // query external programming interfaces supported in the miniport // driver. // PVIDEO_HW_QUERY_INTERFACE HwQueryInterface; // // Obselete. Don't set it. // ULONG HwChildDeviceExtensionSize; // // Allows the device to report legacy resources that should be // associated with the Plug and Play device. // PVIDEO_ACCESS_RANGE HwLegacyResourceList; // // Number of elements in the legacy resource list. // ULONG HwLegacyResourceCount; // // Call this routine to allow a driver to specify it's // legacy resources based on its device/vendor id. // PVIDEO_HW_LEGACYRESOURCES HwGetLegacyResources; // // Can HwGetVideoChildDescriptor be called before HwInitialize? // BOOLEAN AllowEarlyEnumeration; // // Start of 5.1 stuff. // ULONG Reserved; } VIDEO_HW_INITIALIZATION_DATA, *PVIDEO_HW_INITIALIZATION_DATA; // // DDC help routines. // typedef VOID (*PVIDEO_WRITE_CLOCK_LINE)( PVOID HwDeviceExtension, UCHAR Data ); typedef VOID (*PVIDEO_WRITE_DATA_LINE)( PVOID HwDeviceExtension, UCHAR Data ); typedef BOOLEAN (*PVIDEO_READ_CLOCK_LINE)( PVOID HwDeviceExtension ); typedef BOOLEAN (*PVIDEO_READ_DATA_LINE)( PVOID HwDeviceExtension ); typedef VOID (*PVIDEO_WAIT_VSYNC_ACTIVE)( PVOID HwDeviceExtension ); // // Data structures used I2C and DDC helper functions. // typedef struct _I2C_FNC_TABLE { IN ULONG Size; IN PVIDEO_WRITE_CLOCK_LINE WriteClockLine; IN PVIDEO_WRITE_DATA_LINE WriteDataLine; IN PVIDEO_READ_CLOCK_LINE ReadClockLine; IN PVIDEO_READ_DATA_LINE ReadDataLine; IN PVIDEO_WAIT_VSYNC_ACTIVE WaitVsync; PVOID Reserved; } I2C_FNC_TABLE, *PI2C_FNC_TABLE; typedef struct _I2C_CALLBACKS { IN PVIDEO_WRITE_CLOCK_LINE WriteClockLine; IN PVIDEO_WRITE_DATA_LINE WriteDataLine; IN PVIDEO_READ_CLOCK_LINE ReadClockLine; IN PVIDEO_READ_DATA_LINE ReadDataLine; } I2C_CALLBACKS, *PI2C_CALLBACKS; typedef struct _DDC_CONTROL { IN ULONG Size; IN I2C_CALLBACKS I2CCallbacks; IN UCHAR EdidSegment; } DDC_CONTROL, *PDDC_CONTROL; typedef struct _VIDEO_I2C_CONTROL { IN PVIDEO_WRITE_CLOCK_LINE WriteClockLine; IN PVIDEO_WRITE_DATA_LINE WriteDataLine; IN PVIDEO_READ_CLOCK_LINE ReadClockLine; IN PVIDEO_READ_DATA_LINE ReadDataLine; IN ULONG I2CDelay; // 100ns units } VIDEO_I2C_CONTROL, *PVIDEO_I2C_CONTROL; // // Types of services exported by the VideoPortQueryServices(). // typedef enum { VideoPortServicesAGP = 1, VideoPortServicesI2C, VideoPortServicesHeadless, VideoPortServicesInt10 } VIDEO_PORT_SERVICES; // // AGP services interface. // #define VIDEO_PORT_AGP_INTERFACE_VERSION_1 1 typedef struct _VIDEO_PORT_AGP_INTERFACE { IN USHORT Size; IN USHORT Version; OUT PVOID Context; OUT PINTERFACE_REFERENCE InterfaceReference; OUT PINTERFACE_DEREFERENCE InterfaceDereference; OUT PAGP_RESERVE_PHYSICAL AgpReservePhysical; OUT PAGP_RELEASE_PHYSICAL AgpReleasePhysical; OUT PAGP_COMMIT_PHYSICAL AgpCommitPhysical; OUT PAGP_FREE_PHYSICAL AgpFreePhysical; OUT PAGP_RESERVE_VIRTUAL AgpReserveVirtual; OUT PAGP_RELEASE_VIRTUAL AgpReleaseVirtual; OUT PAGP_COMMIT_VIRTUAL AgpCommitVirtual; OUT PAGP_FREE_VIRTUAL AgpFreeVirtual; OUT ULONGLONG AgpAllocationLimit; } VIDEO_PORT_AGP_INTERFACE, *PVIDEO_PORT_AGP_INTERFACE; #define VIDEO_PORT_AGP_INTERFACE_VERSION_2 2 typedef struct _VIDEO_PORT_AGP_INTERFACE_2 { IN USHORT Size; IN USHORT Version; OUT PVOID Context; OUT PINTERFACE_REFERENCE InterfaceReference; OUT PINTERFACE_DEREFERENCE InterfaceDereference; OUT PAGP_RESERVE_PHYSICAL AgpReservePhysical; OUT PAGP_RELEASE_PHYSICAL AgpReleasePhysical; OUT PAGP_COMMIT_PHYSICAL AgpCommitPhysical; OUT PAGP_FREE_PHYSICAL AgpFreePhysical; OUT PAGP_RESERVE_VIRTUAL AgpReserveVirtual; OUT PAGP_RELEASE_VIRTUAL AgpReleaseVirtual; OUT PAGP_COMMIT_VIRTUAL AgpCommitVirtual; OUT PAGP_FREE_VIRTUAL AgpFreeVirtual; OUT ULONGLONG AgpAllocationLimit; OUT PAGP_SET_RATE AgpSetRate; } VIDEO_PORT_AGP_INTERFACE_2, *PVIDEO_PORT_AGP_INTERFACE_2; // // I2C helper routines exported via VideoPortQueryServices(). // typedef BOOLEAN (*PI2C_START)( IN PVOID HwDeviceExtension, IN PI2C_CALLBACKS I2CCallbacks ); typedef BOOLEAN (*PI2C_STOP)( IN PVOID HwDeviceExtension, IN PI2C_CALLBACKS I2CCallbacks ); typedef BOOLEAN (*PI2C_WRITE)( IN PVOID HwDeviceExtension, IN PI2C_CALLBACKS I2CCallbacks, IN PUCHAR Buffer, IN ULONG Length ); typedef BOOLEAN (*PI2C_READ)( IN PVOID HwDeviceExtension, IN PI2C_CALLBACKS I2CCallbacks, OUT PUCHAR Buffer, IN ULONG Length ); // // I2C services interface. // #define VIDEO_PORT_I2C_INTERFACE_VERSION_1 1 typedef struct _VIDEO_PORT_I2C_INTERFACE { IN USHORT Size; IN USHORT Version; OUT PVOID Context; OUT PINTERFACE_REFERENCE InterfaceReference; OUT PINTERFACE_DEREFERENCE InterfaceDereference; OUT PI2C_START I2CStart; OUT PI2C_STOP I2CStop; OUT PI2C_WRITE I2CWrite; OUT PI2C_READ I2CRead; } VIDEO_PORT_I2C_INTERFACE, *PVIDEO_PORT_I2C_INTERFACE; // // I2C helper routines exported via VideoPortQueryServices() // for I2C interface version 2. // typedef BOOLEAN (*PI2C_START_2)( IN PVOID HwDeviceExtension, IN PVIDEO_I2C_CONTROL I2CControl ); typedef BOOLEAN (*PI2C_STOP_2)( IN PVOID HwDeviceExtension, IN PVIDEO_I2C_CONTROL I2CControl ); typedef BOOLEAN (*PI2C_WRITE_2)( IN PVOID HwDeviceExtension, IN PVIDEO_I2C_CONTROL I2CControl, IN PUCHAR Buffer, IN ULONG Length ); typedef BOOLEAN (*PI2C_READ_2)( IN PVOID HwDeviceExtension, IN PVIDEO_I2C_CONTROL I2CControl, OUT PUCHAR Buffer, IN ULONG Length, IN BOOLEAN EndOfRead ); // // I2C services interface version 2. // #define VIDEO_PORT_I2C_INTERFACE_VERSION_2 2 typedef struct _VIDEO_PORT_I2C_INTERFACE_2 { IN USHORT Size; IN USHORT Version; OUT PVOID Context; OUT PINTERFACE_REFERENCE InterfaceReference; OUT PINTERFACE_DEREFERENCE InterfaceDereference; OUT PI2C_START_2 I2CStart; OUT PI2C_STOP_2 I2CStop; OUT PI2C_WRITE_2 I2CWrite; OUT PI2C_READ_2 I2CRead; } VIDEO_PORT_I2C_INTERFACE_2, *PVIDEO_PORT_I2C_INTERFACE_2; typedef VP_STATUS (*PINT10_ALLOCATE_BUFFER)( IN PVOID Context, OUT PUSHORT Seg, OUT PUSHORT Off, IN OUT PULONG Length ); typedef VP_STATUS (*PINT10_FREE_BUFFER)( IN PVOID Context, IN USHORT Seg, IN USHORT Off ); typedef VP_STATUS (*PINT10_READ_MEMORY)( IN PVOID Context, IN USHORT Seg, IN USHORT Off, OUT PVOID Buffer, IN ULONG Length ); typedef VP_STATUS (*PINT10_WRITE_MEMORY)( IN PVOID Context, IN USHORT Seg, IN USHORT Off, IN PVOID Buffer, IN ULONG Length ); typedef VP_STATUS (*PINT10_CALL_BIOS)( PVOID Context, PINT10_BIOS_ARGUMENTS BiosArguments ); #define VIDEO_PORT_INT10_INTERFACE_VERSION_1 1 typedef struct _VIDEO_PORT_INT10_INTERFACE { IN USHORT Size; IN USHORT Version; OUT PVOID Context; OUT PINTERFACE_REFERENCE InterfaceReference; OUT PINTERFACE_DEREFERENCE InterfaceDereference; OUT PINT10_ALLOCATE_BUFFER Int10AllocateBuffer; OUT PINT10_FREE_BUFFER Int10FreeBuffer; OUT PINT10_READ_MEMORY Int10ReadMemory; OUT PINT10_WRITE_MEMORY Int10WriteMemory; OUT PINT10_CALL_BIOS Int10CallBios; } VIDEO_PORT_INT10_INTERFACE, *PVIDEO_PORT_INT10_INTERFACE; typedef struct _VPOSVERSIONINFO { IN ULONG Size; OUT ULONG MajorVersion; OUT ULONG MinorVersion; OUT ULONG BuildNumber; OUT USHORT ServicePackMajor; OUT USHORT ServicePackMinor; } VPOSVERSIONINFO, *PVPOSVERSIONINFO; // // Flags that can be passed to VideoPortGetDeviceBase or VideoPortMapMemory. // #define VIDEO_MEMORY_SPACE_MEMORY 0x00 // Should not be set by display driver #define VIDEO_MEMORY_SPACE_IO 0x01 // Should not be set by display driver #define VIDEO_MEMORY_SPACE_USER_MODE 0x02 // Memory pointer for application use #define VIDEO_MEMORY_SPACE_DENSE 0x04 // Mapped dense, linearly (ALPHA) #define VIDEO_MEMORY_SPACE_P6CACHE 0x08 // P6 MTRR caching (kernel and user) // // Define status codes returned by HwGetVideoChildDescriptor() // miniport enumaration routine. // // Note: For backword compatibility reasons these values match // existing WINERROR codes. // // // Call again (ACPI and non-ACPI devices will be enumerated). // #define VIDEO_ENUM_MORE_DEVICES ERROR_CONTINUE // // Stop enumeration. // #define VIDEO_ENUM_NO_MORE_DEVICES ERROR_NO_MORE_DEVICES // // Call again, device could not be enumerated. // #define VIDEO_ENUM_INVALID_DEVICE ERROR_INVALID_NAME // // Define the bits in VgaStatus. // #define DEVICE_VGA_ENABLED 1 // // Port driver routines called by miniport driver and callbacks. // VIDEOPORT_API VP_STATUS VideoPortAllocateBuffer( IN PVOID HwDeviceExtension, IN ULONG Size, OUT PVOID *Buffer ); VIDEOPORT_API VOID VideoPortAcquireDeviceLock( IN PVOID HwDeviceExtension ); VIDEOPORT_API ULONG VideoPortCompareMemory( PVOID Source1, PVOID Source2, ULONG Length ); VIDEOPORT_API BOOLEAN VideoPortDDCMonitorHelper( IN PVOID HwDeviceExtension, IN PVOID DDCControl, IN OUT PUCHAR EdidBuffer, IN ULONG EdidBufferSize ); VIDEOPORT_API VOID VideoPortDebugPrint( VIDEO_DEBUG_LEVEL DebugPrintLevel, PCHAR DebugMessage, ... ); VIDEOPORT_API VP_STATUS VideoPortDisableInterrupt( PVOID HwDeviceExtension ); VIDEOPORT_API VP_STATUS VideoPortEnableInterrupt( PVOID HwDeviceExtension ); VIDEOPORT_API VP_STATUS VideoPortEnumerateChildren( IN PVOID HwDeviceExtension, IN PVOID Reserved ); VIDEOPORT_API VOID VideoPortFreeDeviceBase( PVOID HwDeviceExtension, PVOID MappedAddress ); typedef VP_STATUS (*PMINIPORT_QUERY_DEVICE_ROUTINE)( PVOID HwDeviceExtension, PVOID Context, VIDEO_DEVICE_DATA_TYPE DeviceDataType, PVOID Identifier, ULONG IdentiferLength, PVOID ConfigurationData, ULONG ConfigurationDataLength, PVOID ComponentInformation, ULONG ComponentInformationLength ); VIDEOPORT_API VP_STATUS VideoPortGetAccessRanges( PVOID HwDeviceExtension, ULONG NumRequestedResources, PIO_RESOURCE_DESCRIPTOR RequestedResources OPTIONAL, ULONG NumAccessRanges, PVIDEO_ACCESS_RANGE AccessRanges, PVOID VendorId, PVOID DeviceId, PULONG Slot ); VIDEOPORT_API PVOID VideoPortGetAssociatedDeviceExtension( IN PVOID DeviceObject ); VIDEOPORT_API ULONG VideoPortGetBusData( PVOID HwDeviceExtension, BUS_DATA_TYPE BusDataType, ULONG SlotNumber, PVOID Buffer, ULONG Offset, ULONG Length ); VIDEOPORT_API UCHAR VideoPortGetCurrentIrql(); VIDEOPORT_API PVOID VideoPortGetDeviceBase( PVOID HwDeviceExtension, PHYSICAL_ADDRESS IoAddress, ULONG NumberOfUchars, UCHAR InIoSpace ); VIDEOPORT_API VP_STATUS VideoPortGetDeviceData( PVOID HwDeviceExtension, VIDEO_DEVICE_DATA_TYPE DeviceDataType, PMINIPORT_QUERY_DEVICE_ROUTINE CallbackRoutine, PVOID Context ); typedef VP_STATUS (*PMINIPORT_GET_REGISTRY_ROUTINE)( PVOID HwDeviceExtension, PVOID Context, PWSTR ValueName, PVOID ValueData, ULONG ValueLength ); VIDEOPORT_API VP_STATUS VideoPortGetRegistryParameters( PVOID HwDeviceExtension, PWSTR ParameterName, UCHAR IsParameterFileName, PMINIPORT_GET_REGISTRY_ROUTINE GetRegistryRoutine, PVOID Context ); VIDEOPORT_API PVOID VideoPortGetRomImage( IN PVOID HwDeviceExtension, IN PVOID Unused1, IN ULONG Unused2, IN ULONG Length ); VIDEOPORT_API VP_STATUS VideoPortGetVgaStatus( PVOID HwDeviceExtension, OUT PULONG VgaStatus ); VIDEOPORT_API LONG FASTCALL VideoPortInterlockedDecrement( IN PLONG Addend ); VIDEOPORT_API LONG FASTCALL VideoPortInterlockedIncrement( IN PLONG Addend ); VIDEOPORT_API LONG FASTCALL VideoPortInterlockedExchange( IN OUT PLONG Target, IN LONG Value ); VIDEOPORT_API ULONG VideoPortInitialize( PVOID Argument1, PVOID Argument2, PVIDEO_HW_INITIALIZATION_DATA HwInitializationData, PVOID HwContext ); VIDEOPORT_API VP_STATUS VideoPortInt10( PVOID HwDeviceExtension, PVIDEO_X86_BIOS_ARGUMENTS BiosArguments ); VIDEOPORT_API VOID VideoPortLogError( PVOID HwDeviceExtension, PVIDEO_REQUEST_PACKET Vrp OPTIONAL, VP_STATUS ErrorCode, ULONG UniqueId ); VIDEOPORT_API VP_STATUS VideoPortMapBankedMemory( PVOID HwDeviceExtension, PHYSICAL_ADDRESS PhysicalAddress, PULONG Length, PULONG InIoSpace, PVOID *VirtualAddress, ULONG BankLength, UCHAR ReadWriteBank, PBANKED_SECTION_ROUTINE BankRoutine, PVOID Context ); VIDEOPORT_API VP_STATUS VideoPortMapMemory( PVOID HwDeviceExtension, PHYSICAL_ADDRESS PhysicalAddress, PULONG Length, PULONG InIoSpace, PVOID *VirtualAddress ); VIDEOPORT_API VOID VideoPortMoveMemory( PVOID Destination, PVOID Source, ULONG Length ); VIDEOPORT_API LONGLONG VideoPortQueryPerformanceCounter( IN PVOID HwDeviceExtension, OUT PLONGLONG PerformanceFrequency OPTIONAL ); VIDEOPORT_API VP_STATUS VideoPortQueryServices( IN PVOID HwDeviceExtension, IN VIDEO_PORT_SERVICES ServicesType, IN OUT PINTERFACE Interface ); typedef VOID (*PMINIPORT_DPC_ROUTINE)( IN PVOID HwDeviceExtension, IN PVOID Context ); VIDEOPORT_API BOOLEAN VideoPortQueueDpc( IN PVOID HwDeviceExtension, IN PMINIPORT_DPC_ROUTINE CallbackRoutine, IN PVOID Context ); VIDEOPORT_API UCHAR VideoPortReadPortUchar( PUCHAR Port ); VIDEOPORT_API USHORT VideoPortReadPortUshort( PUSHORT Port ); VIDEOPORT_API ULONG VideoPortReadPortUlong( PULONG Port ); VIDEOPORT_API VOID VideoPortReadPortBufferUchar( PUCHAR Port, PUCHAR Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortReadPortBufferUshort( PUSHORT Port, PUSHORT Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortReadPortBufferUlong( PULONG Port, PULONG Buffer, ULONG Count ); VIDEOPORT_API UCHAR VideoPortReadRegisterUchar( PUCHAR Register ); VIDEOPORT_API USHORT VideoPortReadRegisterUshort( PUSHORT Register ); VIDEOPORT_API ULONG VideoPortReadRegisterUlong( PULONG Register ); VIDEOPORT_API VOID VideoPortReadRegisterBufferUchar( PUCHAR Register, PUCHAR Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortReadRegisterBufferUshort( PUSHORT Register, PUSHORT Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortReadRegisterBufferUlong( PULONG Register, PULONG Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortReleaseBuffer( IN PVOID HwDeviceExtension, IN PVOID Buffer ); VIDEOPORT_API VOID VideoPortReleaseDeviceLock( IN PVOID HwDeviceExtension ); VIDEOPORT_API BOOLEAN VideoPortScanRom( PVOID HwDeviceExtension, PUCHAR RomBase, ULONG RomLength, PUCHAR String ); VIDEOPORT_API ULONG VideoPortSetBusData( PVOID HwDeviceExtension, BUS_DATA_TYPE BusDataType, ULONG SlotNumber, PVOID Buffer, ULONG Offset, ULONG Length ); VIDEOPORT_API VP_STATUS VideoPortSetRegistryParameters( PVOID HwDeviceExtension, PWSTR ValueName, PVOID ValueData, ULONG ValueLength ); VIDEOPORT_API VP_STATUS VideoPortSetTrappedEmulatorPorts( PVOID HwDeviceExtension, ULONG NumAccessRanges, PVIDEO_ACCESS_RANGE AccessRange ); VIDEOPORT_API VOID VideoPortStallExecution( ULONG Microseconds ); VIDEOPORT_API VOID VideoPortStartTimer( PVOID HwDeviceExtension ); VIDEOPORT_API VOID VideoPortStopTimer( PVOID HwDeviceExtension ); typedef BOOLEAN (*PMINIPORT_SYNCHRONIZE_ROUTINE)( PVOID Context ); BOOLEAN VIDEOPORT_API VideoPortSynchronizeExecution( PVOID HwDeviceExtension, VIDEO_SYNCHRONIZE_PRIORITY Priority, PMINIPORT_SYNCHRONIZE_ROUTINE SynchronizeRoutine, PVOID Context ); VIDEOPORT_API VP_STATUS VideoPortUnmapMemory( PVOID HwDeviceExtension, PVOID VirtualAddress, HANDLE ProcessHandle ); VIDEOPORT_API VP_STATUS VideoPortVerifyAccessRanges( PVOID HwDeviceExtension, ULONG NumAccessRanges, PVIDEO_ACCESS_RANGE AccessRanges ); VIDEOPORT_API VOID VideoPortWritePortUchar( PUCHAR Port, UCHAR Value ); VIDEOPORT_API VOID VideoPortWritePortUshort( PUSHORT Port, USHORT Value ); VIDEOPORT_API VOID VideoPortWritePortUlong( PULONG Port, ULONG Value ); VIDEOPORT_API VOID VideoPortWritePortBufferUchar( PUCHAR Port, PUCHAR Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortWritePortBufferUshort( PUSHORT Port, PUSHORT Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortWritePortBufferUlong( PULONG Port, PULONG Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortWriteRegisterUchar( PUCHAR Register, UCHAR Value ); VIDEOPORT_API VOID VideoPortWriteRegisterUshort( PUSHORT Register, USHORT Value ); VIDEOPORT_API VOID VideoPortWriteRegisterUlong( PULONG Register, ULONG Value ); VIDEOPORT_API VOID VideoPortWriteRegisterBufferUchar( PUCHAR Register, PUCHAR Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortWriteRegisterBufferUshort( PUSHORT Register, PUSHORT Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortWriteRegisterBufferUlong( PULONG Register, PULONG Buffer, ULONG Count ); VIDEOPORT_API VOID VideoPortZeroDeviceMemory( PVOID Destination, ULONG Length ); VIDEOPORT_API VOID VideoPortZeroMemory( PVOID Destination, ULONG Length ); // // DMA support. // TODO: Move to the separate module -- will be obsolete. // VIDEOPORT_API PVOID VideoPortAllocateContiguousMemory( IN PVOID HwDeviceExtension, IN ULONG NumberOfBytes, IN PHYSICAL_ADDRESS HighestAcceptableAddress ); VIDEOPORT_API PVOID VideoPortGetCommonBuffer( IN PVOID HwDeviceExtension, IN ULONG DesiredLength, IN ULONG Alignment, OUT PPHYSICAL_ADDRESS LogicalAddress, OUT PULONG pActualLength, IN BOOLEAN CacheEnabled ); VIDEOPORT_API VOID VideoPortFreeCommonBuffer( IN PVOID HwDeviceExtension, IN ULONG Length, IN PVOID VirtualAddress, IN PHYSICAL_ADDRESS LogicalAddress, IN BOOLEAN CacheEnabled ); VIDEOPORT_API PDMA VideoPortDoDma( IN PVOID HwDeviceExtension, IN PDMA pDma, IN DMA_FLAGS DmaFlags ); VIDEOPORT_API BOOLEAN VideoPortLockPages( IN PVOID HwDeviceExtension, IN OUT PVIDEO_REQUEST_PACKET pVrp, IN PEVENT pUEvent, IN PEVENT pDisplayEvent, IN DMA_FLAGS DmaFlags ); VIDEOPORT_API BOOLEAN VideoPortUnlockPages( PVOID hwDeviceExtension, PDMA pDma ); VIDEOPORT_API BOOLEAN VideoPortSignalDmaComplete( IN PVOID HwDeviceExtension, IN PDMA pDmaHandle ); VIDEOPORT_API PVOID VideoPortGetMdl( IN PVOID HwDeviceExtension, IN PDMA pDma ); VIDEOPORT_API PVOID VideoPortGetDmaContext( IN PVOID HwDeviceExtension, IN PDMA pDma ); VIDEOPORT_API VOID VideoPortSetDmaContext( IN PVOID HwDeviceExtension, OUT PDMA pDma, IN PVOID InstanceContext ); VIDEOPORT_API ULONG VideoPortGetBytesUsed( IN PVOID HwDeviceExtension, IN PDMA pDma ); VIDEOPORT_API VOID VideoPortSetBytesUsed( IN PVOID HwDeviceExtension, IN OUT PDMA pDma, IN ULONG BytesUsed ); VIDEOPORT_API PDMA VideoPortAssociateEventsWithDmaHandle( IN PVOID HwDeviceExtension, IN OUT PVIDEO_REQUEST_PACKET pVrp, IN PVOID MappedUserEvent, IN PVOID DisplayDriverEvent ); VIDEOPORT_API PDMA VideoPortMapDmaMemory( IN PVOID HwDeviceExtension, IN PVIDEO_REQUEST_PACKET pVrp, IN PHYSICAL_ADDRESS BoardAddress, IN PULONG Length, IN PULONG InIoSpace, IN PVOID MappedUserEvent, IN PVOID DisplayDriverEvent, IN OUT PVOID * VirtualAddress ); VIDEOPORT_API BOOLEAN VideoPortUnmapDmaMemory( PVOID HwDeviceExtension, PVOID VirtualAddress, HANDLE ProcessHandle, PDMA BoardMemoryHandle ); VIDEOPORT_API VP_STATUS VideoPortCreateSecondaryDisplay( IN PVOID HwDeviceExtension, IN OUT PVOID *SecondaryDeviceExtension, IN ULONG ulFlag ); VIDEOPORT_API PVP_DMA_ADAPTER VideoPortGetDmaAdapter( IN PVOID HwDeviceExtension, IN PVP_DEVICE_DESCRIPTION VpDeviceDescription ); VIDEOPORT_API VOID VideoPortPutDmaAdapter( IN PVOID HwDeviceExtension, IN PVP_DMA_ADAPTER VpDmaAdapter ); VIDEOPORT_API PVOID VideoPortAllocateCommonBuffer( IN PVOID HwDeviceExtension, IN PVP_DMA_ADAPTER VpDmaAdapter, IN ULONG DesiredLength, OUT PPHYSICAL_ADDRESS LogicalAddress, IN BOOLEAN CacheEnabled, OUT PVOID Reserved ); VIDEOPORT_API VOID VideoPortReleaseCommonBuffer( IN PVOID HwDeviceExtension, IN PVP_DMA_ADAPTER VpDmaAdapter, IN ULONG Length, IN PHYSICAL_ADDRESS LogicalAddress, IN PVOID VirtualAddress, IN BOOLEAN CacheEnabled ); VIDEOPORT_API PVOID VideoPortLockBuffer( IN PVOID HwDeviceExtension, IN PVOID BaseAddress, IN ULONG Length, IN VP_LOCK_OPERATION Operation ); VIDEOPORT_API VOID VideoPortUnlockBuffer( IN PVOID HwDeviceExtension, IN PVOID Mdl ); VIDEOPORT_API VP_STATUS VideoPortStartDma( IN PVOID HwDeviceExtension, IN PVP_DMA_ADAPTER VpDmaAdapter, IN PVOID Mdl, IN ULONG Offset, IN OUT PULONG pLength, IN PEXECUTE_DMA ExecuteDmaRoutine, IN PVOID Context, IN BOOLEAN WriteToDevice ); VIDEOPORT_API VP_STATUS VideoPortCompleteDma( IN PVOID HwDeviceExtension, IN PVP_DMA_ADAPTER VpDmaAdapter, IN PVP_SCATTER_GATHER_LIST VpScatterGather, IN BOOLEAN WriteToDevice ); VIDEOPORT_API VP_STATUS VideoPortCreateEvent( IN PVOID HwDeviceExtension, IN ULONG EventFlag, IN PVOID Unused, OUT PEVENT *ppEvent ); VIDEOPORT_API VP_STATUS VideoPortDeleteEvent( IN PVOID HwDeviceExtension, IN PEVENT pEvent ); VIDEOPORT_API LONG VideoPortSetEvent( IN PVOID HwDeviceExtension, IN PEVENT pEvent ); VIDEOPORT_API VOID VideoPortClearEvent( IN PVOID HwDeviceExtension, IN PEVENT pEvent ); VIDEOPORT_API LONG VideoPortReadStateEvent( IN PVOID HwDeviceExtension, IN PEVENT pEvent ); VIDEOPORT_API VP_STATUS VideoPortWaitForSingleObject( IN PVOID HwDeviceExtension, IN PVOID Object, IN PLARGE_INTEGER Timeout ); VIDEOPORT_API PVOID VideoPortAllocatePool( IN PVOID HwDeviceExtension, IN VP_POOL_TYPE PoolType, IN SIZE_T NumberOfBytes, IN ULONG Tag ); VIDEOPORT_API VOID VideoPortFreePool( IN PVOID HwDeviceExtension, IN PVOID Ptr ); VIDEOPORT_API VP_STATUS VideoPortCreateSpinLock( IN PVOID HwDeviceExtension, OUT PSPIN_LOCK *SpinLock ); VIDEOPORT_API VP_STATUS VideoPortDeleteSpinLock( IN PVOID HwDeviceExtension, IN PSPIN_LOCK SpinLock ); VIDEOPORT_API VOID VideoPortAcquireSpinLock( IN PVOID HwDeviceExtension, IN PSPIN_LOCK SpinLock, OUT PUCHAR OldIrql ); VIDEOPORT_API VOID VideoPortAcquireSpinLockAtDpcLevel( IN PVOID HwDeviceExtension, IN PSPIN_LOCK SpinLock ); VIDEOPORT_API VOID VideoPortReleaseSpinLock( IN PVOID HwDeviceExtension, IN PSPIN_LOCK SpinLock, IN UCHAR NewIrql ); VIDEOPORT_API VOID VideoPortReleaseSpinLockFromDpcLevel( IN PVOID HwDeviceExtension, IN PSPIN_LOCK SpinLock ); VIDEOPORT_API VOID VideoPortQuerySystemTime( OUT PLARGE_INTEGER CurrentTime ); #define CDE_USE_SUBSYSTEM_IDS 0x00000001 #define CDE_USE_REVISION 0x00000002 VIDEOPORT_API BOOLEAN VideoPortCheckForDeviceExistence( IN PVOID HwDeviceExtension, IN USHORT VendorId, IN USHORT DeviceId, IN UCHAR RevisionId, IN USHORT SubVendorId, IN USHORT SubSystemId, IN ULONG Flags ); VIDEOPORT_API ULONG VideoPortGetAssociatedDeviceID( IN PVOID DeviceObject ); VIDEOPORT_API VP_STATUS VideoPortFlushRegistry( PVOID HwDeviceExtension ); VIDEOPORT_API VP_STATUS VideoPortGetVersion( IN PVOID HwDeviceExtension, IN OUT PVPOSVERSIONINFO pVpOsVersionInfo ); // // TODO: End of move block. // // // Support for bugcheck reason callbacks // typedef VOID (*PVIDEO_BUGCHECK_CALLBACK) ( IN PVOID HwDeviceExtension, IN ULONG BugcheckCode, IN PUCHAR Buffer, IN ULONG BufferSize ); VIDEOPORT_API VP_STATUS VideoPortRegisterBugcheckCallback( IN PVOID HwDeviceExtension, IN ULONG BugcheckCode, IN PVIDEO_BUGCHECK_CALLBACK Callback, IN ULONG BugcheckDataSize ); #endif // ifndef __VIDEO_H__