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
|
|
|
|
* Copyright 2019 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 *******************************************************************/
|
|
|
|
|
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"
|
|
|
|
#include "video.h"
|
|
|
|
|
|
|
|
/* FIXME: NDK not compatible with miniport drivers */
|
|
|
|
#define SystemBasicInformation 0
|
|
|
|
typedef struct _SYSTEM_BASIC_INFORMATION
|
|
|
|
{
|
|
|
|
ULONG Reserved;
|
|
|
|
ULONG TimerResolution;
|
|
|
|
ULONG PageSize;
|
|
|
|
ULONG NumberOfPhysicalPages;
|
|
|
|
ULONG LowestPhysicalPageNumber;
|
|
|
|
ULONG HighestPhysicalPageNumber;
|
|
|
|
ULONG AllocationGranularity;
|
|
|
|
ULONG MinimumUserModeAddress;
|
|
|
|
ULONG MaximumUserModeAddress;
|
|
|
|
KAFFINITY ActiveProcessorsAffinityMask;
|
|
|
|
CCHAR NumberOfProcessors;
|
|
|
|
} SYSTEM_BASIC_INFORMATION, *PSYSTEM_BASIC_INFORMATION;
|
2004-12-10 17:11:35 +00:00
|
|
|
|
2006-01-08 01:24:27 +00:00
|
|
|
LONG
|
|
|
|
__stdcall
|
|
|
|
ZwQuerySystemInformation(
|
|
|
|
IN ULONG SystemInformationClass,
|
|
|
|
OUT PVOID SystemInformation,
|
|
|
|
IN ULONG Length,
|
|
|
|
OUT PULONG ResultLength
|
|
|
|
);
|
|
|
|
|
2019-09-01 19:44:24 +00:00
|
|
|
#define I2C_IO_BASE 0xC000
|
|
|
|
#define NV2A_CONTROL_FRAMEBUFFER_ADDRESS_OFFSET 0x600800
|
|
|
|
|
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 */
|