|
|
/****************************************************************************
***************************************************************************** * * ****************************************** * * Copyright (c) 1995, Cirrus Logic, Inc. * * * All Rights Reserved * * ****************************************** * * PROJECT: Laguna I (CL-GD5462) - * * FILE: clioctl.h * * AUTHOR: Benny Ng * * DESCRIPTION: * This module contains the definitions of IOCTL commands * between the NT miniport and the display. * * MODULES: * * REVISION HISTORY: * $Log: X:/log/laguna/nt35/displays/cl546x/CLIOCTL.H $ * * Rev 1.14 Mar 25 1998 17:56:54 frido * Added IOCTL_STALL. * * Rev 1.13 Dec 10 1997 13:24:54 frido * Merged from 1.62 branch. * * Rev 1.12.1.0 Nov 10 1997 11:25:14 phyang * Added 5 IOCTL code for utilities to update registry values. * * Rev 1.12 Nov 03 1997 16:44:24 phyang * Added IOCTL_GET_AGPDATASTREAMING. * * Rev 1.11 28 Aug 1997 15:16:06 noelv * * Merged with miniport CLIOCTL.H. Now we only use this one. * * Rev 1.10 23 Jul 1997 09:18:30 bennyn * * Added IOCTL_GET_BIOS_VERSION * * Rev 1.9 21 Jul 1997 16:21:06 bennyn * Added IOCTL for getting EDID data * * Rev 1.8 20 Jun 1997 13:33:18 bennyn * * Added power manager data structure and #define * * Rev 1.7 23 Apr 1997 07:38:26 SueS * Added IOCTL for enabling memory-mapped I/O access to PCI * configuration registers. * * Rev 1.6 21 Mar 1997 13:41:20 noelv * Combined LOG_CALLS, LOG_WRITES and LOG_QFREE into ENABLE_LOG_FILE * * Rev 1.5 18 Mar 1997 09:28:58 bennyn * Added Intel DPMS support * * Rev 1.4 26 Nov 1996 10:15:24 SueS * Added IOCTL for closing the log file. * * Rev 1.3 13 Nov 1996 17:06:58 SueS * Added two IOCTL codes for notifying the miniport driver on * file logging functions. * 11/16/95 Benny Ng Initial version * **************************************************************************** ****************************************************************************/
//---------------------------------------------------------------------------
//
// The following macro(CTL_CODE) is defined in WINIOCTL.H. That file states
// that functions 2048-4095 are reserved for "customers". So I picked an
// arbitrary value of 0x900=2304.
//
#define CIRRUS_ESCAPE_FUNCTION 0x5000 // for Intel DPMS
#define IOCTL_CL_STRING_DISPLAY \
CTL_CODE(FILE_DEVICE_VIDEO, 0x900, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_CL_GET_COMMON_BUFFER \
CTL_CODE(FILE_DEVICE_VIDEO, 0x902, METHOD_BUFFERED, FILE_ANY_ACCESS)
#if ENABLE_LOG_FILE
#define IOCTL_CL_CREATE_LOG_FILE \
CTL_CODE(FILE_DEVICE_VIDEO, 0x903, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_CL_WRITE_LOG_FILE \
CTL_CODE(FILE_DEVICE_VIDEO, 0x904, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_CL_CLOSE_LOG_FILE \
CTL_CODE(FILE_DEVICE_VIDEO, 0x905, METHOD_BUFFERED, FILE_ANY_ACCESS) #endif
#define IOCTL_VIDEO_ENABLE_PCI_MMIO \
CTL_CODE(FILE_DEVICE_VIDEO, 0x906, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_SET_HW_MODULE_POWER_STATE \
CTL_CODE(FILE_DEVICE_VIDEO, 0x907, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_GET_HW_MODULE_POWER_STATE \
CTL_CODE(FILE_DEVICE_VIDEO, 0x908, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_GET_BIOS_VERSION \
CTL_CODE(FILE_DEVICE_VIDEO, 0x90A, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_GET_AGPDATASTREAMING \
CTL_CODE(FILE_DEVICE_VIDEO, 0x90B, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_STALL \
CTL_CODE(FILE_DEVICE_VIDEO, 0x911, METHOD_BUFFERED, FILE_ANY_ACCESS)
// =====================================================================
// Define structure used for power manager
// =====================================================================
#ifndef __LGPWRMGR_H__
#define __LGPWRMGR_H__
#define ENABLE 0x1
#define DISABLE 0x0
#define ACPI_D0 0x0
#define ACPI_D1 0x1
#define ACPI_D2 0x2
#define ACPI_D3 0x3
#define TOTAL_ACPI 4
#define MOD_2D 0x0
#define MOD_STRETCH 0x1
#define MOD_3D 0x2
#define MOD_EXTMODE 0x3
#define MOD_VGA 0x4
#define MOD_RAMDAC 0x5
#define MOD_VPORT 0x6
#define MOD_VW 0x7
#define MOD_TVOUT 0x8
#define TOTAL_MOD MOD_TVOUT+1
typedef struct _LGPM_IN_STRUCT { ULONG arg1; ULONG arg2; } LGPM_IN_STRUCT, *PLGPM_IN_STRUCT;
typedef struct _LGPM_OUT_STRUCT { BOOL status; ULONG retval; } LGPM_OUT_STRUCT, *PLGPM_OUT_STRUCT;
#endif // #ifndef __LGPWRMGR_H__
|