Leaked source code of windows server 2003
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
/*--------------------------------------------------------------------------
* * Copyright (C) Cyclades Corporation, 1999-2001. * All rights reserved. * * Cyclom-Y Bus/Port Driver * * This file: cyyhw.h * * Description: This module contains the common hardware declarations * for the parent driver (cyclom-y) and child driver * (cyyport). * * Notes: This code supports Windows 2000 and Windows XP, * x86 and ia64 processors. * * Complies with Cyclades SW Coding Standard rev 1.3. * *-------------------------------------------------------------------------- */
/*-------------------------------------------------------------------------
* * Change History * *-------------------------------------------------------------------------- * * *-------------------------------------------------------------------------- */
#ifndef CYYHW_H
#define CYYHW_H
#define MAX_DEVICE_ID_LEN 200 // This definition was copied from NTDDK\inc\cfgmgr32.h
// Always check if this value was changed.
// This is the maximum length for the Hardware ID.
#define CYYPORT_PNP_ID_WSTR L"Cyclom-Y\\Port"
#define CYYPORT_PNP_ID_STR "Cyclom-Y\\Port"
#define CYYPORT_DEV_ID_STR "Cyclom-Y\\Port"
#define CYY_NUMBER_OF_RESOURCES 3 // Memory, PLX Memory, Interrupt
// Cyclom-Y hardware
#define CYY_RUNTIME_LENGTH 0x00000080
#define CYY_MAX_CHIPS 8
#define CYY_CHANNELS_PER_CHIP 4
#define CYY_MAX_PORTS (CYY_CHANNELS_PER_CHIP*CYY_MAX_CHIPS)
// Custom register offsets
#define CYY_CLEAR_INTR 0x1800 //Isa; for PCI, multiply by 2
#define CYY_RESET_16 0x1400 //Isa; for PCI, multiply by 2
#define CYY_PCI_TYPE 0x3400 //PCI (no need to multiply by 2)
// Values in CYY_PCI_TYPE register
#define CYY_PLX9050 (0x0b)
#define CYY_PLX9060 (0x0c)
#define CYY_PLX9080 (0x0d)
// Runtime registers (or Local Configuration registers)
#define PLX9050_INT_OFFSET (0x4c)
#define PLX9060_INT_OFFSET (0x68)
#define PLX9050_INT_ENABLE (0x00000043UL)
#define PLX9060_INT_ENABLE (0x00000900UL)
// Write to Custom registers
#define CYY_RESET_BOARD(BaseBoardAddress,IsPci) \
do \ { \ WRITE_REGISTER_UCHAR( \ (BaseBoardAddress)+(CYY_RESET_16 << IsPci), \ 0x00 \ ); \ } while (0);
#define CYY_CLEAR_INTERRUPT(BaseBoardAddress,IsPci) \
do \ { \ WRITE_REGISTER_UCHAR( \ (BaseBoardAddress)+(CYY_CLEAR_INTR << IsPci), \ 0x00 \ ); \ } while (0);
#define CYY_READ_PCI_TYPE(BaseBoardAddress) \
(READ_REGISTER_UCHAR((BaseBoardAddress)+CYY_PCI_TYPE))
#define PLX9050_READ_INTERRUPT_CONTROL(BaseBoardAddress) \
(READ_REGISTER_ULONG((PULONG)((BaseBoardAddress)+PLX9050_INT_OFFSET)))
#define PLX9050_WRITE_INTERRUPT_CONTROL(BaseBoardAddress,Value) \
do { \ WRITE_REGISTER_ULONG( \ (PULONG)((BaseBoardAddress)+PLX9050_INT_OFFSET), \ Value \ ); \ } while (0);
#define PLX9060_READ_INTERRUPT_CONTROL(BaseBoardAddress) \
(READ_REGISTER_ULONG((PULONG)((BaseBoardAddress)+PLX9060_INT_OFFSET)))
#define PLX9060_WRITE_INTERRUPT_CONTROL(BaseBoardAddress,Value) \
do { \ WRITE_REGISTER_ULONG( \ (PULONG)((BaseBoardAddress)+PLX9060_INT_OFFSET), \ Value \ ); \ } while (0);
#endif // ndef CYCOMMON_H
|