2004-12-10 17:11:35 +00:00
|
|
|
/*
|
2019-09-01 19:30:09 +00:00
|
|
|
* PROJECT: ReactOS Xbox miniport video driver
|
|
|
|
* LICENSE: GPL-2.0-or-later (https://spdx.org/licenses/GPL-2.0-or-later)
|
|
|
|
* PURPOSE: Simple framebuffer driver for NVIDIA NV2A XGPU
|
|
|
|
* COPYRIGHT: Copyright 2004 Ge van Geldorp
|
|
|
|
* Copyright 2004 Filip Navara
|
2020-05-02 20:18:34 +00:00
|
|
|
* Copyright 2019-2020 Stanislav Motylkov (x86corez@gmail.com)
|
2004-12-10 17:11:35 +00:00
|
|
|
*/
|
|
|
|
|
2010-02-26 11:43:19 +00:00
|
|
|
#pragma once
|
2004-12-10 17:11:35 +00:00
|
|
|
|
|
|
|
/* INCLUDES *******************************************************************/
|
|
|
|
|
2019-10-08 15:08:44 +00:00
|
|
|
/*
|
|
|
|
* FIXME: specify headers properly in the triangle brackets and rearrange them
|
|
|
|
* in a way so it would be simpler to add NDK and other headers for debugging.
|
|
|
|
*/
|
2010-03-03 07:09:09 +00:00
|
|
|
#include "ntdef.h"
|
2006-01-07 22:49:41 +00:00
|
|
|
#define PAGE_SIZE 4096
|
2008-11-27 20:05:12 +00:00
|
|
|
#include "dderror.h"
|
2010-03-03 07:09:09 +00:00
|
|
|
#include "devioctl.h"
|
2006-01-07 22:49:41 +00:00
|
|
|
#include "miniport.h"
|
2020-05-02 20:18:34 +00:00
|
|
|
#include "ioaccess.h"
|
2006-01-07 22:49:41 +00:00
|
|
|
#include "video.h"
|
|
|
|
|
2004-12-10 17:11:35 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
2019-09-01 19:30:09 +00:00
|
|
|
PHYSICAL_ADDRESS PhysControlStart;
|
|
|
|
ULONG ControlLength;
|
|
|
|
PVOID VirtControlStart;
|
|
|
|
PHYSICAL_ADDRESS PhysFrameBufferStart;
|
2004-12-10 17:11:35 +00:00
|
|
|
} XBOXVMP_DEVICE_EXTENSION, *PXBOXVMP_DEVICE_EXTENSION;
|
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
VP_STATUS
|
|
|
|
NTAPI
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpFindAdapter(
|
2019-09-01 19:30:09 +00:00
|
|
|
IN PVOID HwDeviceExtension,
|
|
|
|
IN PVOID HwContext,
|
|
|
|
IN PWSTR ArgumentString,
|
|
|
|
IN OUT PVIDEO_PORT_CONFIG_INFO ConfigInfo,
|
|
|
|
OUT PUCHAR Again);
|
|
|
|
|
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
XboxVmpInitialize(
|
|
|
|
PVOID HwDeviceExtension);
|
|
|
|
|
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpStartIO(
|
2019-09-01 19:30:09 +00:00
|
|
|
PVOID HwDeviceExtension,
|
|
|
|
PVIDEO_REQUEST_PACKET RequestPacket);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpResetHw(
|
2019-09-01 19:30:09 +00:00
|
|
|
PVOID DeviceExtension,
|
|
|
|
ULONG Columns,
|
|
|
|
ULONG Rows);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
VP_STATUS
|
|
|
|
NTAPI
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpGetPowerState(
|
2019-09-01 19:30:09 +00:00
|
|
|
PVOID HwDeviceExtension,
|
|
|
|
ULONG HwId,
|
|
|
|
PVIDEO_POWER_MANAGEMENT VideoPowerControl);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
VP_STATUS
|
|
|
|
NTAPI
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpSetPowerState(
|
2019-09-01 19:30:09 +00:00
|
|
|
PVOID HwDeviceExtension,
|
|
|
|
ULONG HwId,
|
|
|
|
PVIDEO_POWER_MANAGEMENT VideoPowerControl);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
BOOLEAN
|
|
|
|
FASTCALL
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpSetCurrentMode(
|
2019-09-01 19:30:09 +00:00
|
|
|
PXBOXVMP_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
PVIDEO_MODE RequestedMode,
|
|
|
|
PSTATUS_BLOCK StatusBlock);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
BOOLEAN
|
|
|
|
FASTCALL
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpResetDevice(
|
2019-09-01 19:30:09 +00:00
|
|
|
PXBOXVMP_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
PSTATUS_BLOCK StatusBlock);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
BOOLEAN
|
|
|
|
FASTCALL
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpMapVideoMemory(
|
2019-09-01 19:30:09 +00:00
|
|
|
PXBOXVMP_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
PVIDEO_MEMORY RequestedAddress,
|
|
|
|
PVIDEO_MEMORY_INFORMATION MapInformation,
|
|
|
|
PSTATUS_BLOCK StatusBlock);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
BOOLEAN
|
|
|
|
FASTCALL
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpUnmapVideoMemory(
|
2019-09-01 19:30:09 +00:00
|
|
|
PXBOXVMP_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
PVIDEO_MEMORY VideoMemory,
|
|
|
|
PSTATUS_BLOCK StatusBlock);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
BOOLEAN
|
|
|
|
FASTCALL
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpQueryNumAvailModes(
|
2019-09-01 19:30:09 +00:00
|
|
|
PXBOXVMP_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
PVIDEO_NUM_MODES Modes,
|
|
|
|
PSTATUS_BLOCK StatusBlock);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
BOOLEAN
|
|
|
|
FASTCALL
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpQueryAvailModes(
|
2019-09-01 19:30:09 +00:00
|
|
|
PXBOXVMP_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
PVIDEO_MODE_INFORMATION ReturnedModes,
|
|
|
|
PSTATUS_BLOCK StatusBlock);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
BOOLEAN
|
|
|
|
FASTCALL
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpQueryCurrentMode(
|
2019-09-01 19:30:09 +00:00
|
|
|
PXBOXVMP_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
PVIDEO_MODE_INFORMATION VideoModeInfo,
|
|
|
|
PSTATUS_BLOCK StatusBlock);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2019-09-01 19:30:09 +00:00
|
|
|
BOOLEAN
|
|
|
|
FASTCALL
|
2004-12-10 17:11:35 +00:00
|
|
|
XboxVmpSetColorRegisters(
|
2019-09-01 19:30:09 +00:00
|
|
|
PXBOXVMP_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
PVIDEO_CLUT ColorLookUpTable,
|
|
|
|
PSTATUS_BLOCK StatusBlock);
|
2004-12-10 17:11:35 +00:00
|
|
|
|
|
|
|
/* EOF */
|