269 lines
4.1 KiB
C
269 lines
4.1 KiB
C
/*++
|
|
|
|
Copyright (c) 1993 Weitek Corporation
|
|
|
|
Module Name:
|
|
|
|
p9gbl.h
|
|
|
|
Abstract:
|
|
|
|
This module contains external definitions of the global data used by the
|
|
Weitek P9 miniport device driver.
|
|
|
|
Environment:
|
|
|
|
Kernel mode
|
|
|
|
Revision History may be found at the end of this file.
|
|
|
|
--*/
|
|
|
|
//
|
|
// Number of adapter types that this driver supports.
|
|
//
|
|
|
|
#define NUM_OEM_ADAPTERS 8
|
|
|
|
//
|
|
// DAC data structures for all DACs supported by this driver.
|
|
//
|
|
|
|
extern DAC Bt485;
|
|
extern DAC P91Bt485;
|
|
extern DAC P91Bt489;
|
|
extern DAC Ibm525;
|
|
|
|
//
|
|
// P9 Coprocessor Info structures for all P9 family coprocessors supported
|
|
// by this driver.
|
|
//
|
|
|
|
extern P9_COPROC P9000Info;
|
|
extern P9_COPROC P9100Info;
|
|
|
|
//
|
|
// DriverAccessRanges are used to verify access to the P9 coprocessor and
|
|
// VGA registers.
|
|
//
|
|
|
|
#define NUM_DRIVER_ACCESS_RANGES 2
|
|
#define NUM_DAC_ACCESS_RANGES 16
|
|
#define NUM_MISC_ACCESS_RANGES 1
|
|
|
|
extern VIDEO_ACCESS_RANGE DriverAccessRanges[NUM_DRIVER_ACCESS_RANGES +
|
|
NUM_DAC_ACCESS_RANGES +
|
|
NUM_MISC_ACCESS_RANGES];
|
|
|
|
//
|
|
// P9 mode information Tables.
|
|
//
|
|
|
|
extern P9INITDATA P9Modes[mP9ModeCount];
|
|
|
|
//
|
|
// The structure containing Access Ranges for the DAC registers.
|
|
//
|
|
|
|
extern VIDEO_ACCESS_RANGE DACRegisterAccessRange[];
|
|
|
|
//
|
|
// List of P9 adapters.
|
|
//
|
|
|
|
extern P9ADAPTER OEMAdapter[NUM_OEM_ADAPTERS];
|
|
|
|
//
|
|
// Global data defined in P9GBL.C.
|
|
//
|
|
|
|
extern ULONG ulStrtScan;
|
|
extern ULONG ulCurScan;
|
|
|
|
|
|
//
|
|
// Global Function Prototypes.
|
|
//
|
|
|
|
//
|
|
// Misc. function prototypes defined in P9GBL.C.
|
|
//
|
|
|
|
long mul32(
|
|
short op1,
|
|
short op2
|
|
);
|
|
|
|
int div32(
|
|
long op1,
|
|
short op2
|
|
);
|
|
|
|
//
|
|
// P9000 specific function prototypes defined in P9000.C.
|
|
//
|
|
|
|
VOID
|
|
Init8720(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
VOID
|
|
WriteTiming(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
VOID
|
|
SysConf(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
VOID
|
|
P9000SizeMem(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
//
|
|
// P9100 specific function prototypes defined in P91supp.c
|
|
//
|
|
|
|
VOID
|
|
P91SizeVideoMemory(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
|
|
//
|
|
// VGA specific function prototypes defined in VGA.C.
|
|
//
|
|
|
|
VOID
|
|
LockVGARegs(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
VOID
|
|
UnlockVGARegs(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
//
|
|
// Clock generator function prototype.
|
|
//
|
|
|
|
VOID
|
|
DevSetClock(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension,
|
|
USHORT usFrequency,
|
|
BOOLEAN bSetMemclk,
|
|
BOOLEAN bUseClockDoubler
|
|
);
|
|
|
|
//
|
|
// PCI function prototypes defined in PCI.C.
|
|
//
|
|
|
|
BOOLEAN
|
|
PciGetBaseAddr(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
BOOLEAN
|
|
PciP9MemEnable(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
VOID
|
|
ViperPciP9Enable(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
BOOLEAN
|
|
ViperPciP9Disable(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
//
|
|
// Weitek P9000 VL specific function prototypes defined in WTKP90VL.C
|
|
//
|
|
|
|
BOOLEAN
|
|
VLGetBaseAddr(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
VOID
|
|
VLEnableP9(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
BOOLEAN
|
|
VLDisableP9(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
VOID
|
|
VLSetMode(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
BOOLEAN
|
|
VLP90CoprocDetect(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension,
|
|
ULONG ulCoprocPhyAddr
|
|
);
|
|
|
|
//
|
|
// Diamond Viper specific function prototypes defined in WTKP90VL.C
|
|
//
|
|
|
|
BOOLEAN
|
|
ViperGetBaseAddr(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
VOID
|
|
ViperSetMode(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
VOID
|
|
ViperEnableP9(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
BOOLEAN
|
|
ViperDisableP9(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
BOOLEAN
|
|
ViperEnableMem(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
//
|
|
// Weitek P9100 VL specific function prototypes defined in WTKP91VL.C
|
|
//
|
|
|
|
VOID
|
|
VLSetModeP91(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
|
|
VOID VLEnableP91(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
BOOLEAN
|
|
VLDisableP91(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|
|
|
|
|
|
BOOLEAN
|
|
VLGetBaseAddrP91(
|
|
PHW_DEVICE_EXTENSION HwDeviceExtension
|
|
);
|