www.pudn.com > PlxSdk.rar > Reg8311.h


#ifndef __REG8311_H
#define __REG8311_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:
 *
 *      Reg8311.h
 *
 * Description:
 *
 *      This file defines all the PLX 8311 chip registers.
 *
 * Revision:
 *
 *      11-01-06 : PLX SDK v5.00
 *
 ******************************************************************************/


#include "PciRegs.h"


#ifdef __cplusplus
extern "C" {
#endif


#if defined(PLX_LOCAL_CODE)
    #define PCI8311_REG_BASE         0x080
    #define PCI8311_REG_BASE_1       0x0a0
    #define PCI8311_NEW_CAP_BASE     0x140
#else
    #define PCI8311_REG_BASE         0x000
    #define PCI8311_REG_BASE_1       0x000
    #define PCI8311_NEW_CAP_BASE     0x000
#endif


// Additional defintions
#define PCI8311_MAX_REG_OFFSET       (PCI8311_REG_BASE_1 + 0x108)
#define PCI8311_EEPROM_SIZE          0x064          // EEPROM size (bytes) used by PLX Chip
#define PCI8311_DMA_CHANNELS         2              // Number of DMA channels supported by PLX Chip


// PCI Configuration Registers
#define PCI8311_VENDOR_ID            CFG_VENDOR_ID
#define PCI8311_COMMAND              CFG_COMMAND
#define PCI8311_REV_ID               CFG_REV_ID
#define PCI8311_CACHE_SIZE           CFG_CACHE_SIZE
#define PCI8311_RTR_BASE             CFG_BAR0
#define PCI8311_RTR_IO_BASE          CFG_BAR1
#define PCI8311_LOCAL_BASE0          CFG_BAR2
#define PCI8311_LOCAL_BASE1          CFG_BAR3
#define PCI8311_UNUSED_BASE1         CFG_BAR4
#define PCI8311_UNUSED_BASE2         CFG_BAR5
#define PCI8311_CIS_PTR              CFG_CIS_PTR
#define PCI8311_SUB_ID               CFG_SUB_VENDOR_ID
#define PCI8311_EXP_ROM_BASE         CFG_EXP_ROM_BASE
#define PCI8311_CAP_PTR              CFG_CAP_PTR
#define PCI8311_RESERVED2            CFG_RESERVED1
#define PCI8311_INT_LINE             CFG_INT_LINE
#define PCI8311_PM_CAP_ID            (PCI8311_NEW_CAP_BASE + 0x040)
#define PCI8311_PM_CSR               (PCI8311_NEW_CAP_BASE + 0x044)
#define PCI8311_HS_CAP_ID            (PCI8311_NEW_CAP_BASE + 0x048)
#define PCI8311_VPD_CAP_ID           (PCI8311_NEW_CAP_BASE + 0x04c)
#define PCI8311_VPD_DATA             (PCI8311_NEW_CAP_BASE + 0x050)


// Local Configuration Registers
#define PCI8311_SPACE0_RANGE         (PCI8311_REG_BASE   + 0x000)
#define PCI8311_SPACE0_REMAP         (PCI8311_REG_BASE   + 0x004)
#define PCI8311_LOCAL_DMA_ARBIT      (PCI8311_REG_BASE   + 0x008)
#define PCI8311_ENDIAN_DESC          (PCI8311_REG_BASE   + 0x00c)
#define PCI8311_EXP_ROM_RANGE        (PCI8311_REG_BASE   + 0x010)
#define PCI8311_EXP_ROM_REMAP        (PCI8311_REG_BASE   + 0x014)
#define PCI8311_SPACE0_ROM_DESC      (PCI8311_REG_BASE   + 0x018)
#define PCI8311_DM_RANGE             (PCI8311_REG_BASE   + 0x01c)
#define PCI8311_DM_MEM_BASE          (PCI8311_REG_BASE   + 0x020)
#define PCI8311_DM_IO_BASE           (PCI8311_REG_BASE   + 0x024)
#define PCI8311_DM_PCI_MEM_REMAP     (PCI8311_REG_BASE   + 0x028)
#define PCI8311_DM_PCI_IO_CONFIG     (PCI8311_REG_BASE   + 0x02c)
#define PCI8311_SPACE1_RANGE         (PCI8311_REG_BASE   + 0x0f0)
#define PCI8311_SPACE1_REMAP         (PCI8311_REG_BASE   + 0x0f4)
#define PCI8311_SPACE1_DESC          (PCI8311_REG_BASE   + 0x0f8)
#define PCI8311_DM_DAC               (PCI8311_REG_BASE   + 0x0fc)
#define PCI8311_ARBITER_CTRL         (PCI8311_REG_BASE_1 + 0x100)
#define PCI8311_ABORT_ADDRESS        (PCI8311_REG_BASE_1 + 0x104)


// Runtime Registers
#if defined(PLX_LOCAL_CODE)
    #define PCI8311_MAILBOX0         0x0c0
    #define PCI8311_MAILBOX1         0x0c4
#else
    #define PCI8311_MAILBOX0         0x078
    #define PCI8311_MAILBOX1         0x07c
#endif

#define PCI8311_MAILBOX2             (PCI8311_REG_BASE + 0x048)
#define PCI8311_MAILBOX3             (PCI8311_REG_BASE + 0x04c)
#define PCI8311_MAILBOX4             (PCI8311_REG_BASE + 0x050)
#define PCI8311_MAILBOX5             (PCI8311_REG_BASE + 0x054)
#define PCI8311_MAILBOX6             (PCI8311_REG_BASE + 0x058)
#define PCI8311_MAILBOX7             (PCI8311_REG_BASE + 0x05c)
#define PCI8311_LOCAL_DOORBELL       (PCI8311_REG_BASE + 0x060)
#define PCI8311_PCI_DOORBELL         (PCI8311_REG_BASE + 0x064)
#define PCI8311_INT_CTRL_STAT        (PCI8311_REG_BASE + 0x068)
#define PCI8311_EEPROM_CTRL_STAT     (PCI8311_REG_BASE + 0x06c)
#define PCI8311_PERM_VENDOR_ID       (PCI8311_REG_BASE + 0x070)
#define PCI8311_REVISION_ID          (PCI8311_REG_BASE + 0x074)


// DMA Registers
#define PCI8311_DMA0_MODE            (PCI8311_REG_BASE + 0x080)
#define PCI8311_DMA0_PCI_ADDR        (PCI8311_REG_BASE + 0x084)
#define PCI8311_DMA0_LOCAL_ADDR      (PCI8311_REG_BASE + 0x088)
#define PCI8311_DMA0_COUNT           (PCI8311_REG_BASE + 0x08c)
#define PCI8311_DMA0_DESC_PTR        (PCI8311_REG_BASE + 0x090)
#define PCI8311_DMA1_MODE            (PCI8311_REG_BASE + 0x094)
#define PCI8311_DMA1_PCI_ADDR        (PCI8311_REG_BASE + 0x098)
#define PCI8311_DMA1_LOCAL_ADDR      (PCI8311_REG_BASE + 0x09c)
#define PCI8311_DMA1_COUNT           (PCI8311_REG_BASE + 0x0a0)
#define PCI8311_DMA1_DESC_PTR        (PCI8311_REG_BASE + 0x0a4)
#define PCI8311_DMA_COMMAND_STAT     (PCI8311_REG_BASE + 0x0a8)
#define PCI8311_DMA_ARBIT            (PCI8311_REG_BASE + 0x0ac)
#define PCI8311_DMA_THRESHOLD        (PCI8311_REG_BASE + 0x0b0)
#define PCI8311_DMA0_PCI_DAC         (PCI8311_REG_BASE + 0x0b4)
#define PCI8311_DMA1_PCI_DAC         (PCI8311_REG_BASE + 0x0b8)


// Messaging Unit Registers
#define PCI8311_OUTPOST_INT_STAT     (PCI8311_REG_BASE + 0x030)
#define PCI8311_OUTPOST_INT_MASK     (PCI8311_REG_BASE + 0x034)
#define PCI8311_MU_CONFIG            (PCI8311_REG_BASE + 0x0c0)
#define PCI8311_FIFO_BASE_ADDR       (PCI8311_REG_BASE + 0x0c4)
#define PCI8311_INFREE_HEAD_PTR      (PCI8311_REG_BASE + 0x0c8)
#define PCI8311_INFREE_TAIL_PTR      (PCI8311_REG_BASE + 0x0cc)
#define PCI8311_INPOST_HEAD_PTR      (PCI8311_REG_BASE + 0x0d0)
#define PCI8311_INPOST_TAIL_PTR      (PCI8311_REG_BASE + 0x0d4)
#define PCI8311_OUTFREE_HEAD_PTR     (PCI8311_REG_BASE + 0x0d8)
#define PCI8311_OUTFREE_TAIL_PTR     (PCI8311_REG_BASE + 0x0dc)
#define PCI8311_OUTPOST_HEAD_PTR     (PCI8311_REG_BASE + 0x0e0)
#define PCI8311_OUTPOST_TAIL_PTR     (PCI8311_REG_BASE + 0x0e4)
#define PCI8311_FIFO_CTRL_STAT       (PCI8311_REG_BASE + 0x0e8)




#ifdef __cplusplus
}
#endif

#endif