www.pudn.com > PlxSdk.rar > Reg9080.h
#ifndef __REG9080_H
#define __REG9080_H
/*******************************************************************************
* Copyright (c) 2006 PLX Technology, Inc.
*
* PLX Technology Inc. licenses this software under specific terms and
* conditions. Use of any of the software or derviatives thereof in any
* product without a PLX Technology chip is strictly prohibited.
*
* PLX Technology, Inc. provides this software AS IS, WITHOUT ANY WARRANTY,
* EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, ANY WARRANTY OF
* MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. PLX makes no guarantee
* or representations regarding the use of, or the results of the use of,
* the software and documentation in terms of correctness, accuracy,
* reliability, currentness, or otherwise; and you rely on the software,
* documentation and results solely at your own risk.
*
* IN NO EVENT SHALL PLX BE LIABLE FOR ANY LOSS OF USE, LOSS OF BUSINESS,
* LOSS OF PROFITS, INDIRECT, INCIDENTAL, SPECIAL OR CONSEQUENTIAL DAMAGES
* OF ANY KIND. IN NO EVENT SHALL PLX'S TOTAL LIABILITY EXCEED THE SUM
* PAID TO PLX FOR THE PRODUCT LICENSED HEREUNDER.
*
******************************************************************************/
/******************************************************************************
*
* File Name:
*
* Reg9080.h
*
* Description:
*
* This file defines all the PCI 9080 Registers.
*
* Revision:
*
* 11-01-06 : PLX SDK v5.00
*
******************************************************************************/
#include "PciRegs.h"
#ifdef __cplusplus
extern "C" {
#endif
#if defined(PLX_LOCAL_CODE)
#define PCI9080_REG_BASE 0x080
#else
#define PCI9080_REG_BASE 0x000
#endif
// Additional defintions
#define PCI9080_MAX_REG_OFFSET (PCI9080_REG_BASE + 0x100)
#define PCI9080_EEPROM_SIZE 0x058 // EEPROM size (bytes) used by PLX Chip
#define PCI9080_DMA_CHANNELS 2 // Number of DMA channels supported by PLX Chip
// PCI Configuration Registers
#define PCI9080_VENDOR_ID CFG_VENDOR_ID
#define PCI9080_COMMAND CFG_COMMAND
#define PCI9080_REV_ID CFG_REV_ID
#define PCI9080_CACHE_SIZE CFG_CACHE_SIZE
#define PCI9080_RTR_BASE CFG_BAR0
#define PCI9080_RTR_IO_BASE CFG_BAR1
#define PCI9080_LOCAL_BASE0 CFG_BAR2
#define PCI9080_LOCAL_BASE1 CFG_BAR3
#define PCI9080_UNUSED_BASE1 CFG_BAR4
#define PCI9080_UNUSED_BASE2 CFG_BAR5
#define PCI9080_CIS_PTR CFG_CIS_PTR
#define PCI9080_SUB_ID CFG_SUB_VENDOR_ID
#define PCI9080_EXP_ROM_BASE CFG_EXP_ROM_BASE
#define PCI9080_RESERVED1 CFG_CAP_PTR
#define PCI9080_RESERVED2 CFG_RESERVED1
#define PCI9080_INT_LINE CFG_INT_LINE
// Local Configuration Registers
#define PCI9080_SPACE0_RANGE (PCI9080_REG_BASE + 0x000)
#define PCI9080_SPACE0_REMAP (PCI9080_REG_BASE + 0x004)
#define PCI9080_LOCAL_DMA_ARBIT (PCI9080_REG_BASE + 0x008)
#define PCI9080_ENDIAN_DESC (PCI9080_REG_BASE + 0x00c)
#define PCI9080_EXP_ROM_RANGE (PCI9080_REG_BASE + 0x010)
#define PCI9080_EXP_ROM_REMAP (PCI9080_REG_BASE + 0x014)
#define PCI9080_SPACE0_ROM_DESC (PCI9080_REG_BASE + 0x018)
#define PCI9080_DM_RANGE (PCI9080_REG_BASE + 0x01c)
#define PCI9080_DM_MEM_BASE (PCI9080_REG_BASE + 0x020)
#define PCI9080_DM_IO_BASE (PCI9080_REG_BASE + 0x024)
#define PCI9080_DM_PCI_MEM_REMAP (PCI9080_REG_BASE + 0x028)
#define PCI9080_DM_PCI_IO_CONFIG (PCI9080_REG_BASE + 0x02c)
#define PCI9080_SPACE1_RANGE (PCI9080_REG_BASE + 0x0f0)
#define PCI9080_SPACE1_REMAP (PCI9080_REG_BASE + 0x0f4)
#define PCI9080_SPACE1_DESC (PCI9080_REG_BASE + 0x0f8)
// Runtime Registers
#if defined(PLX_LOCAL_CODE)
#define PCI9080_MAILBOX0 0x0c0
#define PCI9080_MAILBOX1 0x0c4
#else
#define PCI9080_MAILBOX0 0x078
#define PCI9080_MAILBOX1 0x07c
#endif
#define PCI9080_MAILBOX2 (PCI9080_REG_BASE + 0x048)
#define PCI9080_MAILBOX3 (PCI9080_REG_BASE + 0x04c)
#define PCI9080_MAILBOX4 (PCI9080_REG_BASE + 0x050)
#define PCI9080_MAILBOX5 (PCI9080_REG_BASE + 0x054)
#define PCI9080_MAILBOX6 (PCI9080_REG_BASE + 0x058)
#define PCI9080_MAILBOX7 (PCI9080_REG_BASE + 0x05c)
#define PCI9080_LOCAL_DOORBELL (PCI9080_REG_BASE + 0x060)
#define PCI9080_PCI_DOORBELL (PCI9080_REG_BASE + 0x064)
#define PCI9080_INT_CTRL_STAT (PCI9080_REG_BASE + 0x068)
#define PCI9080_EEPROM_CTRL_STAT (PCI9080_REG_BASE + 0x06c)
#define PCI9080_PERM_VENDOR_ID (PCI9080_REG_BASE + 0x070)
#define PCI9080_REVISION_ID (PCI9080_REG_BASE + 0x074)
// DMA Registers
#define PCI9080_DMA0_MODE (PCI9080_REG_BASE + 0x080)
#define PCI9080_DMA0_PCI_ADDR (PCI9080_REG_BASE + 0x084)
#define PCI9080_DMA0_LOCAL_ADDR (PCI9080_REG_BASE + 0x088)
#define PCI9080_DMA0_COUNT (PCI9080_REG_BASE + 0x08c)
#define PCI9080_DMA0_DESC_PTR (PCI9080_REG_BASE + 0x090)
#define PCI9080_DMA1_MODE (PCI9080_REG_BASE + 0x094)
#define PCI9080_DMA1_PCI_ADDR (PCI9080_REG_BASE + 0x098)
#define PCI9080_DMA1_LOCAL_ADDR (PCI9080_REG_BASE + 0x09c)
#define PCI9080_DMA1_COUNT (PCI9080_REG_BASE + 0x0a0)
#define PCI9080_DMA1_DESC_PTR (PCI9080_REG_BASE + 0x0a4)
#define PCI9080_DMA_COMMAND_STAT (PCI9080_REG_BASE + 0x0a8)
#define PCI9080_DMA_ARBIT (PCI9080_REG_BASE + 0x0ac)
#define PCI9080_DMA_THRESHOLD (PCI9080_REG_BASE + 0x0b0)
// Messaging FIFO Registers
#define PCI9080_OUTPOST_INT_STAT (PCI9080_REG_BASE + 0x030)
#define PCI9080_OUTPOST_INT_MASK (PCI9080_REG_BASE + 0x034)
#define PCI9080_MU_CONFIG (PCI9080_REG_BASE + 0x0c0)
#define PCI9080_FIFO_BASE_ADDR (PCI9080_REG_BASE + 0x0c4)
#define PCI9080_INFREE_HEAD_PTR (PCI9080_REG_BASE + 0x0c8)
#define PCI9080_INFREE_TAIL_PTR (PCI9080_REG_BASE + 0x0cc)
#define PCI9080_INPOST_HEAD_PTR (PCI9080_REG_BASE + 0x0d0)
#define PCI9080_INPOST_TAIL_PTR (PCI9080_REG_BASE + 0x0d4)
#define PCI9080_OUTFREE_HEAD_PTR (PCI9080_REG_BASE + 0x0d8)
#define PCI9080_OUTFREE_TAIL_PTR (PCI9080_REG_BASE + 0x0dc)
#define PCI9080_OUTPOST_HEAD_PTR (PCI9080_REG_BASE + 0x0e0)
#define PCI9080_OUTPOST_TAIL_PTR (PCI9080_REG_BASE + 0x0e4)
#define PCI9080_FIFO_CTRL_STAT (PCI9080_REG_BASE + 0x0e8)
#ifdef __cplusplus
}
#endif
#endif