www.pudn.com > PlxSdk.rar > Reg9054.h
#ifndef __REG9054_H
#define __REG9054_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:
*
* Reg9054.h
*
* Description:
*
* This file defines all the PLX 9054 chip Registers.
*
* Revision:
*
* 11-01-06 : PLX SDK v5.00
*
******************************************************************************/
#include "PciRegs.h"
#ifdef __cplusplus
extern "C" {
#endif
#if defined(PLX_LOCAL_CODE)
#define PCI9054_REG_BASE 0x080
#define PCI9054_NEW_CAP_BASE 0x140
#define PCI9054_MAX_REG_OFFSET 0x194
#else
#define PCI9054_REG_BASE 0x000
#define PCI9054_NEW_CAP_BASE 0x000
#define PCI9054_MAX_REG_OFFSET 0x100
#endif
// Additional defintions
#define PCI9054_EEPROM_SIZE 0x058 // EEPROM size (bytes) used by PLX Chip
#define PCI9054_DMA_CHANNELS 2 // Number of DMA channels supported by PLX Chip
// PCI Configuration Registers
#define PCI9054_VENDOR_ID CFG_VENDOR_ID
#define PCI9054_COMMAND CFG_COMMAND
#define PCI9054_REV_ID CFG_REV_ID
#define PCI9054_CACHE_SIZE CFG_CACHE_SIZE
#define PCI9054_RTR_BASE CFG_BAR0
#define PCI9054_RTR_IO_BASE CFG_BAR1
#define PCI9054_LOCAL_BASE0 CFG_BAR2
#define PCI9054_LOCAL_BASE1 CFG_BAR3
#define PCI9054_UNUSED_BASE1 CFG_BAR4
#define PCI9054_UNUSED_BASE2 CFG_BAR5
#define PCI9054_CIS_PTR CFG_CIS_PTR
#define PCI9054_SUB_ID CFG_SUB_VENDOR_ID
#define PCI9054_EXP_ROM_BASE CFG_EXP_ROM_BASE
#define PCI9054_CAP_PTR CFG_CAP_PTR
#define PCI9054_RESERVED2 CFG_RESERVED1
#define PCI9054_INT_LINE CFG_INT_LINE
#define PCI9054_PM_CAP_ID (PCI9054_NEW_CAP_BASE + 0x040)
#define PCI9054_PM_CSR (PCI9054_NEW_CAP_BASE + 0x044)
#define PCI9054_HS_CAP_ID (PCI9054_NEW_CAP_BASE + 0x048)
#define PCI9054_VPD_CAP_ID (PCI9054_NEW_CAP_BASE + 0x04c)
#define PCI9054_VPD_DATA (PCI9054_NEW_CAP_BASE + 0x050)
// Local Configuration Registers
#define PCI9054_SPACE0_RANGE (PCI9054_REG_BASE + 0x000)
#define PCI9054_SPACE0_REMAP (PCI9054_REG_BASE + 0x004)
#define PCI9054_LOCAL_DMA_ARBIT (PCI9054_REG_BASE + 0x008)
#define PCI9054_ENDIAN_DESC (PCI9054_REG_BASE + 0x00c)
#define PCI9054_EXP_ROM_RANGE (PCI9054_REG_BASE + 0x010)
#define PCI9054_EXP_ROM_REMAP (PCI9054_REG_BASE + 0x014)
#define PCI9054_SPACE0_ROM_DESC (PCI9054_REG_BASE + 0x018)
#define PCI9054_DM_RANGE (PCI9054_REG_BASE + 0x01c)
#define PCI9054_DM_MEM_BASE (PCI9054_REG_BASE + 0x020)
#define PCI9054_DM_IO_BASE (PCI9054_REG_BASE + 0x024)
#define PCI9054_DM_PCI_MEM_REMAP (PCI9054_REG_BASE + 0x028)
#define PCI9054_DM_PCI_IO_CONFIG (PCI9054_REG_BASE + 0x02c)
#define PCI9054_SPACE1_RANGE (PCI9054_REG_BASE + 0x0f0)
#define PCI9054_SPACE1_REMAP (PCI9054_REG_BASE + 0x0f4)
#define PCI9054_SPACE1_DESC (PCI9054_REG_BASE + 0x0f8)
#define PCI9054_DM_DAC (PCI9054_REG_BASE + 0x0fc)
// Runtime Registers
#if defined(PLX_LOCAL_CODE)
#define PCI9054_MAILBOX0 0x0c0
#define PCI9054_MAILBOX1 0x0c4
#else
#define PCI9054_MAILBOX0 0x078
#define PCI9054_MAILBOX1 0x07c
#endif
#define PCI9054_MAILBOX2 (PCI9054_REG_BASE + 0x048)
#define PCI9054_MAILBOX3 (PCI9054_REG_BASE + 0x04c)
#define PCI9054_MAILBOX4 (PCI9054_REG_BASE + 0x050)
#define PCI9054_MAILBOX5 (PCI9054_REG_BASE + 0x054)
#define PCI9054_MAILBOX6 (PCI9054_REG_BASE + 0x058)
#define PCI9054_MAILBOX7 (PCI9054_REG_BASE + 0x05c)
#define PCI9054_LOCAL_DOORBELL (PCI9054_REG_BASE + 0x060)
#define PCI9054_PCI_DOORBELL (PCI9054_REG_BASE + 0x064)
#define PCI9054_INT_CTRL_STAT (PCI9054_REG_BASE + 0x068)
#define PCI9054_EEPROM_CTRL_STAT (PCI9054_REG_BASE + 0x06c)
#define PCI9054_PERM_VENDOR_ID (PCI9054_REG_BASE + 0x070)
#define PCI9054_REVISION_ID (PCI9054_REG_BASE + 0x074)
// DMA Registers
#define PCI9054_DMA0_MODE (PCI9054_REG_BASE + 0x080)
#define PCI9054_DMA0_PCI_ADDR (PCI9054_REG_BASE + 0x084)
#define PCI9054_DMA0_LOCAL_ADDR (PCI9054_REG_BASE + 0x088)
#define PCI9054_DMA0_COUNT (PCI9054_REG_BASE + 0x08c)
#define PCI9054_DMA0_DESC_PTR (PCI9054_REG_BASE + 0x090)
#define PCI9054_DMA1_MODE (PCI9054_REG_BASE + 0x094)
#define PCI9054_DMA1_PCI_ADDR (PCI9054_REG_BASE + 0x098)
#define PCI9054_DMA1_LOCAL_ADDR (PCI9054_REG_BASE + 0x09c)
#define PCI9054_DMA1_COUNT (PCI9054_REG_BASE + 0x0a0)
#define PCI9054_DMA1_DESC_PTR (PCI9054_REG_BASE + 0x0a4)
#define PCI9054_DMA_COMMAND_STAT (PCI9054_REG_BASE + 0x0a8)
#define PCI9054_DMA_ARBIT (PCI9054_REG_BASE + 0x0ac)
#define PCI9054_DMA_THRESHOLD (PCI9054_REG_BASE + 0x0b0)
#define PCI9054_DMA0_PCI_DAC (PCI9054_REG_BASE + 0x0b4)
#define PCI9054_DMA1_PCI_DAC (PCI9054_REG_BASE + 0x0b8)
// Messaging Unit Registers
#define PCI9054_OUTPOST_INT_STAT (PCI9054_REG_BASE + 0x030)
#define PCI9054_OUTPOST_INT_MASK (PCI9054_REG_BASE + 0x034)
#define PCI9054_MU_CONFIG (PCI9054_REG_BASE + 0x0c0)
#define PCI9054_FIFO_BASE_ADDR (PCI9054_REG_BASE + 0x0c4)
#define PCI9054_INFREE_HEAD_PTR (PCI9054_REG_BASE + 0x0c8)
#define PCI9054_INFREE_TAIL_PTR (PCI9054_REG_BASE + 0x0cc)
#define PCI9054_INPOST_HEAD_PTR (PCI9054_REG_BASE + 0x0d0)
#define PCI9054_INPOST_TAIL_PTR (PCI9054_REG_BASE + 0x0d4)
#define PCI9054_OUTFREE_HEAD_PTR (PCI9054_REG_BASE + 0x0d8)
#define PCI9054_OUTFREE_TAIL_PTR (PCI9054_REG_BASE + 0x0dc)
#define PCI9054_OUTPOST_HEAD_PTR (PCI9054_REG_BASE + 0x0e0)
#define PCI9054_OUTPOST_TAIL_PTR (PCI9054_REG_BASE + 0x0e4)
#define PCI9054_FIFO_CTRL_STAT (PCI9054_REG_BASE + 0x0e8)
#ifdef __cplusplus
}
#endif
#endif