OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [hal/] [powerpc/] [fads/] [v2_0/] [src/] [ppc_860.h] - Rev 587

Go to most recent revision | Compare with Previous | Blame | View Log

#ifndef CYGONCE_HAL_PPC_FADS_PPC_860_H
#define CYGONCE_HAL_PPC_FADS_PPC_860_H
 
//=============================================================================
//####UNSUPPORTEDBEGIN####
//
// -------------------------------------------
// This source file has been contributed to eCos/Red Hat. It may have been
// changed slightly to provide an interface consistent with those of other 
// files.
//
// The functionality and contents of this file is supplied "AS IS"
// without any form of support and will not necessarily be kept up
// to date by Red Hat.
//
// The style of programming used in this file may not comply with the
// eCos programming guidelines. Please do not use as a base for other
// files.
//
// All inquiries about this file, or the functionality provided by it,
// should be directed to the 'ecos-discuss' mailing list (see
// http://sourceware.cygnus.com/ecos/intouch.html for details).
//
// Contributed by: Kevin Hester <khester@opticworks.com>
// Maintained by:  <Unmaintained>
// See also:
//   Motorola's "Example Software Initializing the SMC as a UART" package 
//   (smc2.zip) at:
//    http://www.mot.com/SPS/RISC/netcomm/tools/index.html#MPC860_table
// -------------------------------------------
//
//####UNSUPPORTEDEND####
//=============================================================================
 
#include <cyg/infra/cyg_type.h>
 
/******************************************************************************
*
* Definitions of Parameter RAM entries for each peripheral and mode
*
******************************************************************************/
 
/*---------------------------------------------------------------------------*/
/*      HDLC parameter RAM (SCC)                                             */
/*---------------------------------------------------------------------------*/
 
struct hdlc_pram 
 
{
 
   /*-------------------*/
   /* SCC parameter RAM */
   /*-------------------*/
 
   cyg_uint16   rbase;          /* RX BD base address */
   cyg_uint16   tbase;          /* TX BD base address */
   cyg_uint8       rfcr;                   /* Rx function code */
   cyg_uint8       tfcr;                   /* Tx function code */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rtemp;               /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32      ttemp;               /* Tx temp */
   cyg_uint32      rcrc;                   /* temp receive CRC */
   cyg_uint32      tcrc;                   /* temp transmit CRC */
 
   /*-----------------------------*/
   /* HDLC specific parameter RAM */
   /*-----------------------------*/
 
   cyg_uint8       RESERVED1[4];        /* Reserved area */
   cyg_uint32      c_mask;                      /* CRC constant */
   cyg_uint32      c_pres;                      /* CRC preset */
   cyg_uint16   disfc;                  /* discarded frame counter */
   cyg_uint16   crcec;                  /* CRC error counter */
   cyg_uint16   abtsc;                  /* abort sequence counter */
   cyg_uint16   nmarc;                  /* nonmatching address rx cnt */
   cyg_uint16   retrc;                  /* frame retransmission cnt */
   cyg_uint16   mflr;                      /* maximum frame length reg */
   cyg_uint16   max_cnt;                   /* maximum length counter */
   cyg_uint16   rfthr;                  /* received frames threshold */
   cyg_uint16   rfcnt;                  /* received frames count */
   cyg_uint16   hmask;                  /* user defined frm addr mask */
   cyg_uint16   haddr1;                 /* user defined frm address 1 */
   cyg_uint16   haddr2;                 /* user defined frm address 2 */
   cyg_uint16   haddr3;                 /* user defined frm address 3 */
   cyg_uint16   haddr4;                 /* user defined frm address 4 */
   cyg_uint16   tmp;                       /* temp */
   cyg_uint16   tmp_mb;                 /* temp */
};
 
 
/*-------------------------------------------------------------------------*/
/*                       ASYNC HDLC parameter RAM (SCC)                                                  */
/*-------------------------------------------------------------------------*/
 
struct async_hdlc_pram 
 
{
 
   /*-------------------*/
   /* SCC parameter RAM */
   /*-------------------*/
 
   cyg_uint16   rbase;          /* RX BD base address */
   cyg_uint16   tbase;          /* TX BD base address */
   cyg_uint8       rfcr;                   /* Rx function code */
   cyg_uint8       tfcr;                   /* Tx function code */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rtemp;               /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32   ttemp;          /* Tx temp */
   cyg_uint32      rcrc;                   /* temp receive CRC */
   cyg_uint32    tcrc;             /* temp transmit CRC */
 
   /*-----------------------------------*/
   /* ASYNC HDLC specific parameter RAM */
   /*-----------------------------------*/
 
   cyg_uint8       RESERVED2[4];        /* Reserved area */
   cyg_uint32      c_mask;                      /* CRC constant */
   cyg_uint32      c_pres;                      /* CRC preset */
   cyg_uint16   bof;                       /* begining of flag character */
   cyg_uint16   eof;                       /* end of flag character */
   cyg_uint16   esc;                       /* control escape character */
   cyg_uint8       RESERVED3[4];        /* Reserved area */
   cyg_uint16   zero;                      /* zero */
   cyg_uint8       RESERVED4[2];        /* Reserved area */
   cyg_uint16   rfthr;                  /* received frames threshold */
   cyg_uint8       RESERVED5[4];        /* Reserved area */
   cyg_uint32      txctl_tbl;           /* Tx ctl char mapping table */
   cyg_uint32      rxctl_tbl;           /* Rx ctl char mapping table */
   cyg_uint16   nof;                       /* Number of opening flags */
};
 
 
/*--------------------------------------------------------------------------*/
/*                    UART parameter RAM (SCC)                                                                 */
/*--------------------------------------------------------------------------*/
 
/*----------------------------------------*/
/* bits in uart control characters table  */
/*----------------------------------------*/
 
#define CC_INVALID      0x8000          /* control character is valid */
#define CC_REJ          0x4000          /* don't store char in buffer */
#define CC_CHAR         0x00ff          /* control character */
 
/*------*/
/* UART */
/*------*/
 
struct uart_pram 
 
{
   /*-------------------*/
   /* SCC parameter RAM */
   /*-------------------*/
 
   cyg_uint16   rbase;          /* RX BD base address */
   cyg_uint16   tbase;          /* TX BD base address */
   cyg_uint8       rfcr;                   /* Rx function code */
   cyg_uint8       tfcr;                   /* Tx function code */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rx_temp;        /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32      ttemp;               /* Tx temp */
   cyg_uint32      rcrc;                   /* temp receive CRC */
   cyg_uint32      tcrc;                   /* temp transmit CRC */
 
   /*------------------------------*/
   /*   UART specific parameter RAM  */
   /*------------------------------*/
 
   cyg_uint8       RESERVED6[8];        /* Reserved area */
   cyg_uint16   max_idl;                   /* maximum idle characters */
   cyg_uint16   idlc;                      /* rx idle counter (internal) */
   cyg_uint16   brkcr;                  /* break count register */
 
   cyg_uint16   parec;                  /* Rx parity error counter */
   cyg_uint16   frmec;                  /* Rx framing error counter */
   cyg_uint16   nosec;                  /* Rx noise counter */
   cyg_uint16   brkec;                  /* Rx break character counter */
   cyg_uint16   brkln;                  /* Reaceive break length */
 
   cyg_uint16   uaddr1;                 /* address character 1 */
   cyg_uint16   uaddr2;                 /* address character 2 */
   cyg_uint16   rtemp;                  /* temp storage */
   cyg_uint16   toseq;                  /* Tx out of sequence char */
   cyg_uint16   cc[8];                  /* Rx control characters */
   cyg_uint16   rccm;                      /* Rx control char mask */
   cyg_uint16   rccr;                      /* Rx control char register */
   cyg_uint16   rlbc;                      /* Receive last break char */
};
 
 
/*---------------------------------------------------------------------------
*                    BISYNC parameter RAM (SCC)
*--------------------------------------------------------------------------*/
 
struct bisync_pram 
 
{
   /*-------------------*/
   /* SCC parameter RAM */
   /*-------------------*/
 
   cyg_uint16   rbase;          /* RX BD base address */
   cyg_uint16   tbase;          /* TX BD base address */
   cyg_uint8       rfcr;                   /* Rx function code */
   cyg_uint8       tfcr;                   /* Tx function code */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rtemp;               /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32      ttemp;               /* Tx temp */
   cyg_uint32      rcrc;                   /* temp receive CRC */
   cyg_uint32      tcrc;                   /* temp transmit CRC */
 
   /*--------------------------------*/
   /*   BISYNC specific parameter RAM */
   /*--------------------------------*/
 
   cyg_uint8       RESERVED7[4];        /* Reserved area */
   cyg_uint32      crcc;                           /* CRC Constant Temp Value */
   cyg_uint16   prcrc;                  /* Preset Receiver CRC-16/LRC */
   cyg_uint16   ptcrc;                  /* Preset Transmitter CRC-16/LRC */
   cyg_uint16   parec;                  /* Receive Parity Error Counter */
   cyg_uint16   bsync;                  /* BISYNC SYNC Character */
   cyg_uint16   bdle;                      /* BISYNC DLE Character */
   cyg_uint16   cc[8];                  /* Rx control characters */
   cyg_uint16   rccm;                      /* Receive Control Character Mask */
};
 
 
/*-------------------------------------------------------------------------*/
/*             Transparent mode parameter RAM (SCC)                                                */
/*-------------------------------------------------------------------------*/
 
struct transparent_pram 
 
{
   /*--------------------*/
   /*   SCC parameter RAM */
   /*--------------------*/
 
   cyg_uint16   rbase;          /* RX BD base address */
   cyg_uint16   tbase;          /* TX BD base address */
   cyg_uint8       rfcr;                   /* Rx function code */
   cyg_uint8       tfcr;                   /* Tx function code */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rtemp;               /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32      ttemp;               /* Tx temp */
   cyg_uint32      rcrc;                   /* temp receive CRC */
   cyg_uint32      tcrc;                   /* temp transmit CRC */
 
   /*-------------------------------------*/
   /*   TRANSPARENT specific parameter RAM */
   /*-------------------------------------*/
 
   cyg_uint32   crc_p;          /* CRC Preset */
   cyg_uint32   crc_c;          /* CRC constant */
};
 
 
/*-------------------------------------------------------------------------*/ 
/*                    Ethernet parameter RAM (SCC)                                                       */
/*-------------------------------------------------------------------------*/
 
struct ethernet_pram 
 
{
   /*--------------------*/
   /*   SCC parameter RAM */
   /*--------------------*/
 
   cyg_uint16   rbase;          /* RX BD base address */
   cyg_uint16   tbase;          /* TX BD base address */
   cyg_uint8       rfcr;                   /* Rx function code */
   cyg_uint8       tfcr;                   /* Tx function code */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rtemp;               /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32      ttemp;               /* Tx temp */
   cyg_uint32      rcrc;                   /* temp receive CRC */
   cyg_uint32      tcrc;                   /* temp transmit CRC */
 
   /*---------------------------------*/
   /*   ETHERNET specific parameter RAM */
   /*---------------------------------*/
 
   cyg_uint32      c_pres;                      /* preset CRC */
   cyg_uint32      c_mask;                      /* constant mask for CRC */
   cyg_uint32      crcec;                       /* CRC error counter */
   cyg_uint32      alec;                           /* alighnment error counter */
   cyg_uint32      disfc;                       /* discard frame counter */
   cyg_uint16   pads;                      /* short frame PAD characters */
   cyg_uint16   ret_lim;                   /* retry limit threshold */
   cyg_uint16   ret_cnt;                   /* retry limit counter */
   cyg_uint16   mflr;                      /* maximum frame length reg */
   cyg_uint16   minflr;                 /* minimum frame length reg */
   cyg_uint16   maxd1;                  /* maximum DMA1 length reg */
   cyg_uint16   maxd2;                  /* maximum DMA2 length reg */
   cyg_uint16   maxd;                      /* rx max DMA */
   cyg_uint16   dma_cnt;                   /* rx dma counter */
   cyg_uint16   max_b;                  /* max bd byte count */
   cyg_uint16   gaddr1;                 /* group address filter 1 */
   cyg_uint16   gaddr2;                 /* group address filter 2 */
   cyg_uint16   gaddr3;                 /* group address filter 3 */
   cyg_uint16   gaddr4;                 /* group address filter 4 */
   cyg_uint32      tbuf0_data0; /* save area 0 - current frm */
   cyg_uint32      tbuf0_data1; /* save area 1 - current frm */
   cyg_uint32      tbuf0_rba0;
   cyg_uint32      tbuf0_crc;
   cyg_uint16   tbuf0_bcnt;
   cyg_uint16   paddr_h;                   /* physical address (MSB) */
   cyg_uint16   paddr_m;                   /* physical address */
   cyg_uint16   paddr_l;                   /* physical address (LSB) */
   cyg_uint16   p_per;                  /* persistence */
   cyg_uint16   rfbd_ptr;               /* rx first bd pointer */
   cyg_uint16   tfbd_ptr;               /* tx first bd pointer */
   cyg_uint16   tlbd_ptr;               /* tx last bd pointer */
   cyg_uint32      tbuf1_data0; /* save area 0 - next frame */
   cyg_uint32      tbuf1_data1; /* save area 1 - next frame */
   cyg_uint32      tbuf1_rba0;
   cyg_uint32      tbuf1_crc;
   cyg_uint16   tbuf1_bcnt;
   cyg_uint16   tx_len;                 /* tx frame length counter */
   cyg_uint16   iaddr1;                 /* individual address filter 1*/
   cyg_uint16   iaddr2;                 /* individual address filter 2*/
   cyg_uint16   iaddr3;                 /* individual address filter 3*/
   cyg_uint16   iaddr4;                 /* individual address filter 4*/
   cyg_uint16   boff_cnt;               /* back-off counter */
   cyg_uint16   taddr_h;                   /* temp address (MSB) */
   cyg_uint16   taddr_m;                   /* temp address */
   cyg_uint16   taddr_l;                   /* temp address (LSB) */
};
 
 
/*------------------------------------------------------------------*/
/*                          QMC  definitions                                       */
/*------------------------------------------------------------------*/
 
 
struct global_qmc_pram {
 
    cyg_uint32   mcbase;                /* Multichannel Base pointer */
    cyg_uint16  qmcstate;       /* Multichannel Controller state */
    cyg_uint16  mrblr;          /* Maximum Receive Buffer Length */
    cyg_uint16  tx_s_ptr;   /* TSATTx Pointer */
    cyg_uint16  rxptr;     /* Current Time slot entry in TSATRx */
    cyg_uint16  grfthr;         /* Global Receive frame threshold */
    cyg_uint16  grfcnt;         /* Global Receive Frame Count */
    cyg_uint32   intbase;               /* Multichannel Base address */
    cyg_uint32   intptr;                /* Pointer to interrupt queue */
    cyg_uint16  rx_s_ptr;   /* TSATRx Pointer */
    cyg_uint16  txptr;     /* Current Time slot entry in TSATTx */
    cyg_uint32   c_mask32;      /* CRC Constant (debb20e3) */
    cyg_uint16  tsatrx[32];     /* Time Slot Assignment Table Rx */
    cyg_uint16  tsattx[32];     /* Time Slot Assignment Table Tx */
    cyg_uint16  c_mask16;       /* CRC Constant (f0b8) */
 
};
 
 
   /*------------------------------------------*/
   /* QMC HDLC channel specific parameter RAM  */
   /*------------------------------------------*/
 
struct qmc_hdlc_pram {
 
    cyg_uint16  tbase;  /* Tx Buffer Descriptors Base Address */
    cyg_uint16  chamr;  /* Channel Mode Register */
    cyg_uint32   tstate;        /* Tx Internal State */
    cyg_uint32   txintr;        /* Tx Internal Data Pointer */
    cyg_uint16  tbptr;  /* Tx Buffer Descriptor Pointer */
    cyg_uint16  txcntr; /* Tx Internal Byte Count */
    cyg_uint32   tupack;        /* (Tx Temp) */
    cyg_uint32   zistate;       /* Zero Insertion machine state */
    cyg_uint32   tcrc;          /* Temp Transmit CRC */
    cyg_uint16  intmsk; /* Channel's interrupt mask flags */
    cyg_uint16  bdflags;                
    cyg_uint16  rbase;  /* Rx Buffer Descriptors Base Address */
    cyg_uint16  mflr;           /* Max Frame Length Register */
    cyg_uint32   rstate;        /* Rx Internal State */
    cyg_uint32   rxintr;        /* Rx Internal Data Pointer */
    cyg_uint16  rbptr;  /* Rx Buffer Descriptor Pointer */
    cyg_uint16  rxbyc;  /* Rx Internal Byte Count */
    cyg_uint32   rpack; /* (Rx Temp) */
    cyg_uint32   zdstate;       /* Zero Deletion machine state */
    cyg_uint32   rcrc;          /* Temp Transmit CRC */
    cyg_uint16  maxc;           /* Max_length counter */
    cyg_uint16  tmp_mb; /* Temp */
};
 
 
         /*-------------------------------------------------*/
         /* QMC Transparent channel specific parameter RAM  */
         /*-------------------------------------------------*/
 
struct qmc_tran_pram {
 
        cyg_uint16      tbase;          /* Tx Bufer Descriptors Base Address */
        cyg_uint16      chamr;          /* Channel Mode Register */
        cyg_uint32   tstate;            /* Tx Internal State */
    cyg_uint32   txintr;                /* Tx Internal Data Pointer */
    cyg_uint16  tbptr;          /* Tx Buffer Descriptor Pointer */
    cyg_uint16  txcntr;         /* Tx Internal Byte Count */
    cyg_uint32   tupack;                /* (Tx Temp) */
    cyg_uint32   zistate;               /* Zero Insertion machine state */
    cyg_uint32   RESERVED8;     
    cyg_uint16  intmsk;         /* Channel's interrupt mask flags */
    cyg_uint16  bdflags;                
    cyg_uint16  rbase;          /* Rx Buffer Descriptors Base Address */
    cyg_uint16  tmrblr;         /* Max receive buffer length */
    cyg_uint32   rstate;                /* Rx Internal State */
    cyg_uint32   rxintr;                /* Rx Internal Data Pointer */
    cyg_uint16  rbptr;          /* Rx Buffer Descriptor Pointer */
    cyg_uint16  rxbyc;          /* Rx Internal Byte Count */
    cyg_uint32   rpack;         /* (Rx Temp) */
    cyg_uint32   zdstate;               /* Zero Deletion machine state */
    cyg_uint32   RESERVED9;     /* Temp Transmit CRC */
    cyg_uint16  trnsync;                /* Max_length counter */
    cyg_uint16  RESERVED10;     /* Temp */
 
};
 
/*----------------------------------------------------------*/
/* allows multiprotocol array declaration in the memory map */
/*----------------------------------------------------------*/
 
struct qmc_chan_pram
{
        union
        {
                struct qmc_hdlc_pram h;
                struct qmc_tran_pram t;
        }h_or_t;
};
 
 
 
/*--------------------------------------------------------------------*/
/*                          SMC UART parameter RAM                            */
/*--------------------------------------------------------------------*/
 
struct smc_uart_pram 
 
{
   cyg_uint16   rbase;          /* Rx BD Base Address */
   cyg_uint16   tbase;          /* Tx BD Base Address */
   cyg_uint8       rfcr;                   /* Rx function code */
   cyg_uint8       tfcr;                   /* Tx function code */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rtemp;               /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32      ttemp;               /* Tx temp */
   cyg_uint16   max_idl;           /* Maximum IDLE Characters */
   cyg_uint16   idlc;              /* Temporary IDLE Counter */
   cyg_uint16   brkln;          /* Last Rx Break Length */
   cyg_uint16   brkec;          /* Rx Break Condition Counter */
   cyg_uint16   brkcr;          /* Break Count Register (Tx) */
   cyg_uint16   r_mask;         /* Temporary bit mask */
};
 
 
/*--------------------------------------------------------------------------*/
/*                  SMC Transparent mode parameter RAM                                              */
/*--------------------------------------------------------------------------*/
 
struct smc_trnsp_pram 
 
{
   cyg_uint16   rbase;                  /* Rx BD Base Address */
   cyg_uint16   tbase;                  /* Tx BD Base Address */
   cyg_uint8       rfcr;                           /* Rx function code */
   cyg_uint8       tfcr;                           /* Tx function code */
   cyg_uint16   mrblr;                  /* Rx buffer length */
   cyg_uint32      rstate;                      /* Rx internal state */
   cyg_uint32      rptr;                           /* Rx internal data pointer */
   cyg_uint16   rbptr;                  /* rb BD Pointer */
   cyg_uint16   rcount;                 /* Rx internal byte count */
   cyg_uint32      rtemp;                       /* Rx temp */
   cyg_uint32      tstate;                      /* Tx internal state */
   cyg_uint32      tptr;                           /* Tx internal data pointer */
   cyg_uint16   tbptr;                  /* Tx BD pointer */
   cyg_uint16   tcount;                 /* Tx byte count */
   cyg_uint32      ttemp;                       /* Tx temp */
   cyg_uint16   RESERVED11[5];  /* Reserved */
};
 
 
/*--------------------------------------------------------------------------*/
/*                      SPI parameter RAM                                                                                 */
/*--------------------------------------------------------------------------*/
 
#define SPI_R   0x8000          /* Ready bit in BD */
 
struct spi_pram 
 
{
   cyg_uint16   rbase;          /* Rx BD Base Address */
   cyg_uint16   tbase;          /* Tx BD Base Address */
   cyg_uint8       rfcr;                   /* Rx function code */
   cyg_uint8       tfcr;                   /* Tx function code */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rtemp;               /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32      ttemp;               /* Tx temp */
 
    cyg_uint8     RESERVED12[8]; /* Reserved */
};
 
 
/*--------------------------------------------------------------------------*/
/*                       I2C parameter RAM                                                                             */
/*--------------------------------------------------------------------------*/
 
struct i2c_pram 
 
{
   /*--------------------*/
   /*   I2C parameter RAM */
   /*--------------------*/
 
   cyg_uint16   rbase;          /* RX BD base address */
   cyg_uint16   tbase;          /* TX BD base address */
   cyg_uint8       rfcr;                   /* Rx function code */
   cyg_uint8       tfcr;                   /* Tx function code */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rtemp;               /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32      ttemp;               /* Tx temp */
 
    cyg_uint8     RESERVED13[8];    
};
 
/*--------------------------------------------------------------------------*/
/*                       MISC parameter RAM                                                                             */
/*--------------------------------------------------------------------------*/
 
struct misc_pram 
{
    cyg_uint8    RESERVED14[16];
};
 
 
 
/*--------------------------------------------------------------------------*/
/*                      PIP Centronics parameter RAM                                                   */
/*--------------------------------------------------------------------------*/
 
struct centronics_pram 
 
{
   cyg_uint16   rbase;          /* Rx BD Base Address */
   cyg_uint16   tbase;          /* Tx BD Base Address */
   cyg_uint8       fcr;            /* function code */
   cyg_uint8       smask;               /* Status Mask */
   cyg_uint16   mrblr;          /* Rx buffer length */
   cyg_uint32      rstate;              /* Rx internal state */
   cyg_uint32      rptr;                   /* Rx internal data pointer */
   cyg_uint16   rbptr;          /* rb BD Pointer */
   cyg_uint16   rcount;         /* Rx internal byte count */
   cyg_uint32      rtemp;               /* Rx temp */
   cyg_uint32      tstate;              /* Tx internal state */
   cyg_uint32      tptr;                   /* Tx internal data pointer */
   cyg_uint16   tbptr;          /* Tx BD pointer */
   cyg_uint16   tcount;         /* Tx byte count */
   cyg_uint32      ttemp;               /* Tx temp */
   cyg_uint16   max_sl;         /* Maximum Silence period */
   cyg_uint16   sl_cnt;         /* Silence Counter */
   cyg_uint16   char1;          /* CONTROL char 1 */
   cyg_uint16   char2;          /* CONTROL char 2 */
   cyg_uint16   char3;          /* CONTROL char 3 */
   cyg_uint16   char4;          /* CONTROL char 4 */
   cyg_uint16   char5;          /* CONTROL char 5 */
   cyg_uint16   char6;          /* CONTROL char 6 */
   cyg_uint16   char7;          /* CONTROL char 7 */
   cyg_uint16   char8;          /* CONTROL char 8 */
   cyg_uint16   rccm;              /* Rx Control Char Mask */
   cyg_uint16   rccr;              /* Rx Char Control Register */
};
 
 
/*--------------------------------------------------------------------------*/
/*                                                      IDMA parameter RAM                                                                           */
/*--------------------------------------------------------------------------*/
 
struct idma_pram 
 
{
   cyg_uint16 ibase;        /* IDMA BD Base Address */
   cyg_uint16 dcmr;       /* DMA Channel Mode Register */
   cyg_uint32  sapr;       /* Source Internal Data Pointer */
   cyg_uint32  dapr;       /* Destination Internal Data Pointer */
   cyg_uint16 ibptr;      /* Buffer Descriptor Pointer */
   cyg_uint16 write_sp;   /* No description given in manual */
   cyg_uint32  s_byte_c;   /* Internal Source Byte Count */
   cyg_uint32  d_byte_c;   /* Internal Destination Byte Count */
   cyg_uint32  s_state;    /* Internal State */
   cyg_uint32  itemp0;     /* Temp Data Storage */
   cyg_uint32  itemp1;     /* Temp Data Storage */
   cyg_uint32  itemp2;     /* Temp Data Storage */
   cyg_uint32  itemp3;     /* Temp Data Storage */
   cyg_uint32  sr_mem;     /* Data Storage for Peripherial Write */
   cyg_uint16 read_sp;    /* No description given in manual */
   cyg_uint16 nodesc0;    /* Diff Between Source and Destination Residue*/
   cyg_uint16 nodesc1;    /* Temp Storage Address Pointer */
   cyg_uint16 nodesc2;    /* SR_MEM Byte Count */
   cyg_uint32  d_state;    /* Internal State */
};
 
 
 
/*--------------------------------------------------------------------------*/
/*                                      RISC timer parameter RAM                                                                     */
/*--------------------------------------------------------------------------*/
 
struct timer_pram 
 
{
   /*----------------------------*/
   /*   RISC timers parameter RAM */
   /*----------------------------*/
 
   cyg_uint16   tm_base;           /* RISC timer table base adr */
   cyg_uint16   tm_ptr;         /* RISC timer table pointer */
   cyg_uint16   r_tmr;          /* RISC timer mode register */
   cyg_uint16   r_tmv;          /* RISC timer valid register */
   cyg_uint32      tm_cmd;              /* RISC timer cmd register */
   cyg_uint32      tm_cnt;              /* RISC timer internal cnt */
};
 
 
/*--------------------------------------------------------------------------*/
/*                                              ROM Microcode parameter RAM                                                               */
/*--------------------------------------------------------------------------*/
 
struct ucode_pram 
 
{
   /*---------------------------*/
   /*   RISC ucode parameter RAM */
   /*---------------------------*/
 
   cyg_uint16   rev_num;    /* Ucode Revision Number */
   cyg_uint16   d_ptr;          /* MISC Dump area pointer */
   cyg_uint32      temp1;               /* MISC Temp1 */
   cyg_uint32      temp2;               /* MISC Temp2 */
};
 
 
/*---------------------------------------------------------------------------*/
/* Example structuring of user data area of memory at 0x2000 (base of DPRAM) */
/* Note that this area can also be used by microcodes and the QMC channel        */
/* specific parameter ram.                                                                                                       */
/*---------------------------------------------------------------------------*/
 
struct user_data
 
{
 
   volatile cyg_uint8   udata_bd_ucode[0x200];  /* user data bd's or Ucode (small)  */
   volatile cyg_uint8   udata_bd_ucode2[0x200]; /* user data bd's or Ucode (medium) */
   volatile cyg_uint8   udata_bd_ucode3[0x400]; /* user data bd's or Ucode (large)  */
   volatile cyg_uint8   udata_bd[0x700];                        /* user data bd's*/
   volatile cyg_uint8   ucode_ext[0x100];                       /* Ucode Extension ram*/
   volatile cyg_uint8   RESERVED12[0x0c00];             /* Reserved area */
 
};
 
 
 
/***************************************************************************/
/*                                                                                                                                                                   */
/*      Definitions of Embedded PowerPC (EPPC) internal memory structures,         */
/*  including registers and dual-port RAM                                                                           */
/*                                                                                                                                                                   */
/***************************************************************************/
 
typedef struct eppc 
 
{
   /*-----------------------------------*/
   /* BASE + 0x0000: INTERNAL REGISTERS */
   /*-----------------------------------*/
 
   /*-----*/
   /* SIU */
   /*-----*/
 
   volatile cyg_uint32  siu_mcr;                      /* module configuration reg */
   volatile cyg_uint32  siu_sypcr;                 /* System protection cnt */
   cyg_uint8    RESERVED13[0x6];
   volatile cyg_uint16  siu_swsr;                  /* sw service */
   volatile cyg_uint32  siu_sipend;                /* Interrupt pend reg */
   volatile cyg_uint32  siu_simask;                /* Interrupt mask reg */
   volatile cyg_uint32  siu_siel;                  /* Interrupt edge level mask reg */
   volatile cyg_uint32  siu_sivec;                 /* Interrupt vector */
   volatile cyg_uint32  siu_tesr;                  /* Transfer error status */
   volatile cyg_uint8   RESERVED14[0xc];  /* Reserved area */
   volatile cyg_uint32  dma_sdcr;                  /* SDMA configuration reg */
   cyg_uint8    RESERVED15[0x4c];
 
   /*--------*/
   /* PCMCIA */
   /*--------*/
 
   volatile cyg_uint32  pcmcia_pbr0;      /* PCMCIA Base Reg: Window 0 */
   volatile cyg_uint32  pcmcia_por0;      /* PCMCIA Option Reg: Window 0 */
   volatile cyg_uint32  pcmcia_pbr1;      /* PCMCIA Base Reg: Window 1 */
   volatile cyg_uint32  pcmcia_por1;      /* PCMCIA Option Reg: Window 1 */
   volatile cyg_uint32  pcmcia_pbr2;      /* PCMCIA Base Reg: Window 2 */
   volatile cyg_uint32  pcmcia_por2;      /* PCMCIA Option Reg: Window 2 */
   volatile cyg_uint32  pcmcia_pbr3;      /* PCMCIA Base Reg: Window 3 */
   volatile cyg_uint32  pcmcia_por3;      /* PCMCIA Option Reg: Window 3 */
   volatile cyg_uint32  pcmcia_pbr4;      /* PCMCIA Base Reg: Window 4 */
   volatile cyg_uint32  pcmcia_por4;      /* PCMCIA Option Reg: Window 4 */
   volatile cyg_uint32  pcmcia_pbr5;      /* PCMCIA Base Reg: Window 5 */
   volatile cyg_uint32  pcmcia_por5;      /* PCMCIA Option Reg: Window 5 */
   volatile cyg_uint32  pcmcia_pbr6;      /* PCMCIA Base Reg: Window 6 */
   volatile cyg_uint32  pcmcia_por6;      /* PCMCIA Option Reg: Window 6 */
   volatile cyg_uint32  pcmcia_pbr7;      /* PCMCIA Base Reg: Window 7 */
   volatile cyg_uint32  pcmcia_por7;      /* PCMCIA Option Reg: Window 7 */
   volatile cyg_uint8  RESERVED16[0x20];  /* Reserved area */
   volatile cyg_uint32  pcmcia_pgcra;     /* PCMCIA Slot A Control  Reg */
   volatile cyg_uint32  pcmcia_pgcrb;     /* PCMCIA Slot B Control  Reg */
   volatile cyg_uint32  pcmcia_pscr;      /* PCMCIA Status Reg */
   volatile cyg_uint8  RESERVED17[0x4];  /* Reserved area */
   volatile cyg_uint32  pcmcia_pipr;      /* PCMCIA Pins Value Reg */
   volatile cyg_uint8  RESERVED18[0x4];  /* Reserved area */
   volatile cyg_uint32  pcmcia_per;       /* PCMCIA Enable Reg */
   volatile cyg_uint8  RESERVED19[0x4];  /* Reserved area */
 
   /*------*/
   /* MEMC */
   /*------*/
 
   volatile cyg_uint32  memc_br0;                       /* base register 0 */
   volatile cyg_uint32  memc_or0;                       /* option register 0 */
   volatile cyg_uint32  memc_br1;                       /* base register 1 */
   volatile cyg_uint32  memc_or1;                       /* option register 1 */
   volatile cyg_uint32  memc_br2;                       /* base register 2 */
   volatile cyg_uint32  memc_or2;                       /* option register 2 */
   volatile cyg_uint32  memc_br3;                       /* base register 3 */
   volatile cyg_uint32  memc_or3;                       /* option register 3 */
   volatile cyg_uint32  memc_br4;                       /* base register 3 */
   volatile cyg_uint32  memc_or4;                       /* option register 3 */
   volatile cyg_uint32  memc_br5;                       /* base register 3 */
   volatile cyg_uint32  memc_or5;                       /* option register 3 */
   volatile cyg_uint32  memc_br6;                       /* base register 3 */
   volatile cyg_uint32  memc_or6;                       /* option register 3 */
   volatile cyg_uint32  memc_br7;                       /* base register 3 */
   volatile cyg_uint32  memc_or7;                       /* option register 3 */
   volatile cyg_uint8   RESERVED20[0x24];       /* Reserved area */
   volatile cyg_uint32  memc_mar;                       /* Memory address */
   volatile cyg_uint32  memc_mcr;                       /* Memory command */
   volatile cyg_uint8   RESERVED21[0x4];        /* Reserved area */
   volatile cyg_uint32  memc_mamr;                      /* Machine A mode */
   volatile cyg_uint32  memc_mbmr;                      /* Machine B mode */
   volatile cyg_uint16  memc_mstat;                     /* Memory status */
   volatile cyg_uint16  memc_mptpr;                     /* Memory preidic timer prescalar */
   volatile cyg_uint32  memc_mdr;                       /* Memory data */
   volatile cyg_uint8   RESERVED22[0x80];       /* Reserved area */
 
   /*---------------------------*/
   /* SYSTEM INTEGRATION TIMERS */
   /*---------------------------*/
 
   volatile cyg_uint16  simt_tbscr;                     /* Time base stat&ctr */
   volatile cyg_uint8   RESERVED23[0x2];        /* Reserved area */
   volatile cyg_uint32  simt_tbreff0;           /* Time base reference 0 */
   volatile cyg_uint32  simt_tbreff1;           /* Time base reference 1 */
   volatile cyg_uint8   RESERVED24[0x14];       /* Reserved area */
   volatile cyg_uint16  simt_rtcsc;                     /* Realtime clk stat&cntr 1 */
   volatile cyg_uint8   RESERVED25[0x2];        /* Reserved area */
   volatile cyg_uint32  simt_rtc;                       /* Realtime clock */
   volatile cyg_uint32  simt_rtsec;                     /* Realtime alarm seconds */
   volatile cyg_uint32  simt_rtcal;                     /* Realtime alarm */
   volatile cyg_uint8   RESERVED26[0x10];       /* Reserved area */
   volatile cyg_uint32  simt_piscr;                     /* PIT stat&ctrl */
   volatile cyg_uint32  simt_pitc;                      /* PIT counter */
   volatile cyg_uint32  simt_pitr;                      /* PIT */
   volatile cyg_uint8   RESERVED27[0x34];       /* Reserved area */
 
   /*---------------*/
   /* CLOCKS, RESET */
   /*---------------*/
 
   volatile cyg_uint32  clkr_sccr;                      /* System clk cntrl */
   volatile cyg_uint32  clkr_plprcr;            /* PLL reset&ctrl */
   volatile cyg_uint32  clkr_rsr;                       /* reset status */
   cyg_uint8    RESERVED28[0x74];       /* Reserved area */
 
   /*--------------------------------*/
   /* System Integration Timers Keys */
   /*--------------------------------*/
 
   volatile cyg_uint32  simt_tbscrk;            /* Timebase Status&Ctrl Key */
   volatile cyg_uint32  simt_tbreff0k;          /* Timebase Reference 0 Key */
   volatile cyg_uint32  simt_tbreff1k;          /* Timebase Reference 1 Key */
   volatile cyg_uint32  simt_tbk;               /* Timebase and Decrementer Key */
   cyg_uint8   RESERVED29[0x10];        /* Reserved area */
   volatile cyg_uint32  simt_rtcsck;            /* Real-Time Clock Status&Ctrl Key */
 
   volatile cyg_uint32  simt_rtck;              /* Real-Time Clock Key */
   volatile cyg_uint32  simt_rtseck;            /* Real-Time Alarm Seconds Key */
   volatile cyg_uint32  simt_rtcalk;            /* Real-Time Alarm Key */
   cyg_uint8   RESERVED30[0x10];        /* Reserved area */
   volatile cyg_uint32  simt_piscrk;            /* Periodic Interrupt Status&Ctrl Key */
   volatile cyg_uint32  simt_pitck;             /* Periodic Interrupt Count Key */
   cyg_uint8   RESERVED31[0x38];        /* Reserved area */
 
   /*----------------------*/
   /* Clock and Reset Keys */
   /*----------------------*/
 
   volatile cyg_uint32  clkr_sccrk;           /* System Clock Control Key */
   volatile cyg_uint32  clkr_plprcrk;         /* PLL, Low Power and Reset Control Key */
   volatile cyg_uint32  clkr_rsrk;                 /* Reset Status Key */
   cyg_uint8      RESERVED32[0x4d4];    /* Reserved area */
 
   /*-----*/
   /* I2C */
   /*-----*/
 
   volatile cyg_uint8   i2c_i2mod;                      /* i2c mode */
   cyg_uint8            RESERVED33[3];
   volatile cyg_uint8   i2c_i2add;                      /* i2c address */
   cyg_uint8            RESERVED34[3];
   volatile cyg_uint8   i2c_i2brg;                      /* i2c brg */
   cyg_uint8            RESERVED35[3];
   volatile cyg_uint8   i2c_i2com;                      /* i2c command */
   cyg_uint8            RESERVED36[3];
   volatile cyg_uint8   i2c_i2cer;                      /* i2c event */
   cyg_uint8            RESERVED37[3];
   volatile cyg_uint8   i2c_i2cmr;                      /* i2c mask */
   volatile cyg_uint8   RESERVED38[0x8b];       /* Reserved area */
 
   /*-----*/
   /* DMA */
   /*-----*/
 
   volatile cyg_uint8   RESERVED39[0x4];        /* Reserved area */
   volatile cyg_uint32  dma_sdar;                       /* SDMA address reg */
   volatile cyg_uint8   RESERVED40[0x2];        /* Reserved area */
   volatile cyg_uint8   dma_sdsr;                       /* SDMA status reg */
   volatile cyg_uint8   RESERVED41[0x3];        /* Reserved area */
   volatile cyg_uint8   dma_sdmr;                       /* SDMA mask reg */
   volatile cyg_uint8   RESERVED42[0x1];        /* Reserved area */                        
   volatile cyg_uint8   dma_idsr1;                      /* IDMA1 status reg */
   volatile cyg_uint8   RESERVED43[0x3];        /* Reserved area */
   volatile cyg_uint8   dma_idmr1;                      /* IDMA1 mask reg */
   volatile cyg_uint8   RESERVED44[0x3];        /* Reserved area */
   volatile cyg_uint8   dma_idsr2;                      /* IDMA2 status reg */
   volatile cyg_uint8   RESERVED45[0x3];        /* Reserved area */
   volatile cyg_uint8   dma_idmr2;                      /* IDMA2 mask reg */
   volatile cyg_uint8   RESERVED46[0x13];       /* Reserved area */
 
   /*--------------------------*/
   /* CPM Interrupt Controller */
   /*--------------------------*/
 
   volatile cyg_uint16  cpmi_civr;                      /* CP interrupt vector reg */
   volatile cyg_uint8   RESERVED47[0xe];        /* Reserved area */
   volatile cyg_uint32  cpmi_cicr;                      /* CP interrupt configuration reg */
   volatile cyg_uint32  cpmi_cipr;                      /* CP interrupt pending reg */
   volatile cyg_uint32  cpmi_cimr;                      /* CP interrupt mask reg */
   volatile cyg_uint32  cpmi_cisr;                      /* CP interrupt in-service reg */
 
   /*----------*/
   /* I/O port */
   /*----------*/
 
   volatile cyg_uint16  pio_padir;                      /* port A data direction reg */
   volatile cyg_uint16  pio_papar;                      /* port A pin assignment reg */
   volatile cyg_uint16  pio_paodr;                      /* port A open drain reg */
   volatile cyg_uint16  pio_padat;                      /* port A data register */
   volatile cyg_uint8   RESERVED48[0x8];        /* Reserved area */
   volatile cyg_uint16  pio_pcdir;                      /* port C data direction reg */
   volatile cyg_uint16  pio_pcpar;                      /* port C pin assignment reg */
   volatile cyg_uint16  pio_pcso;                       /* port C special options */
   volatile cyg_uint16  pio_pcdat;                      /* port C data register */
   volatile cyg_uint16  pio_pcint;                      /* port C interrupt cntrl reg */
   cyg_uint8            RESERVED49[6];
   volatile cyg_uint16  pio_pddir;                      /* port D Data Direction reg */
   volatile cyg_uint16  pio_pdpar;                      /* port D pin assignment reg */
   cyg_uint8            RESERVED50[2];
   volatile cyg_uint16  pio_pddat;                      /* port D data reg */
   volatile cyg_uint8   RESERVED51[0x8];        /* Reserved area */
 
   /*-----------*/
   /* CPM Timer */
   /*-----------*/
 
   volatile cyg_uint16  timer_tgcr;                     /* timer global configuration reg */
   volatile cyg_uint8   RESERVED52[0xe];        /* Reserved area */
   volatile cyg_uint16  timer_tmr1;                     /* timer 1 mode reg */
   volatile cyg_uint16  timer_tmr2;                     /* timer 2 mode reg */
   volatile cyg_uint16  timer_trr1;                     /* timer 1 referance reg */
   volatile cyg_uint16  timer_trr2;                     /* timer 2 referance reg */
   volatile cyg_uint16  timer_tcr1;                     /* timer 1 capture reg */
   volatile cyg_uint16  timer_tcr2;                     /* timer 2 capture reg */
   volatile cyg_uint16  timer_tcn1;                     /* timer 1 counter reg */
   volatile cyg_uint16  timer_tcn2;                     /* timer 2 counter reg */
   volatile cyg_uint16  timer_tmr3;                     /* timer 3 mode reg */
   volatile cyg_uint16  timer_tmr4;                     /* timer 4 mode reg */
   volatile cyg_uint16  timer_trr3;                     /* timer 3 referance reg */
   volatile cyg_uint16  timer_trr4;                     /* timer 4 referance reg */
   volatile cyg_uint16  timer_tcr3;                     /* timer 3 capture reg */
   volatile cyg_uint16  timer_tcr4;                     /* timer 4 capture reg */
   volatile cyg_uint16  timer_tcn3;                     /* timer 3 counter reg */
   volatile cyg_uint16  timer_tcn4;                     /* timer 4 counter reg */
   volatile cyg_uint16  timer_ter1;                     /* timer 1 event reg */
   volatile cyg_uint16  timer_ter2;                     /* timer 2 event reg */
   volatile cyg_uint16  timer_ter3;                     /* timer 3 event reg */
   volatile cyg_uint16  timer_ter4;                     /* timer 4 event reg */
   volatile cyg_uint8   RESERVED53[0x8];        /* Reserved area */
 
   /*----*/
   /* CP */
   /*----*/
 
   volatile cyg_uint16  cp_cr;                          /* command register */
   volatile cyg_uint8   RESERVED54[0x2];        /* Reserved area */
   volatile cyg_uint16  cp_rccr;                                /* main configuration reg */
   volatile cyg_uint8   RESERVED55;                     /* Reserved area */
   volatile cyg_uint8   cp_resv1;                       /* Reserved reg */
   volatile cyg_uint32  cp_resv2;                       /* Reserved reg */
   volatile cyg_uint16  cp_rctr1;                       /* ram break register 1 */
   volatile cyg_uint16  cp_rctr2;                       /* ram break register 2 */
   volatile cyg_uint16  cp_rctr3;                       /* ram break register 3 */
   volatile cyg_uint16  cp_rctr4;                       /* ram break register 4 */
   volatile cyg_uint8   RESERVED56[0x2];        /* Reserved area */
   volatile cyg_uint16  cp_rter;                                /* RISC timers event reg */
   volatile cyg_uint8   RESERVED57[0x2];        /* Reserved area */
   volatile cyg_uint16  cp_rtmr;                                /* RISC timers mask reg */
   volatile cyg_uint8   RESERVED58[0x14];       /* Reserved area */
 
   /*-----*/
   /* BRG */
   /*-----*/
 
   volatile cyg_uint32  brgc1;          /* BRG1 configuration reg */
   volatile cyg_uint32  brgc2;          /* BRG2 configuration reg */
   volatile cyg_uint32  brgc3;          /* BRG3 configuration reg */
   volatile cyg_uint32  brgc4;          /* BRG4 configuration reg */
 
   /*---------------*/
   /* SCC registers */
   /*---------------*/
 
   struct scc_regs 
 
   {
       volatile cyg_uint32      scc_gsmr_l;             /* SCC Gen mode (LOW) */
       volatile cyg_uint32      scc_gsmr_h;             /* SCC Gen mode (HIGH) */
       volatile cyg_uint16      scc_psmr;                       /* protocol specific mode register */
       volatile cyg_uint8       RESERVED59[0x2];        /* Reserved area */
       volatile cyg_uint16      scc_todr;                       /* SCC transmit on demand */
       volatile cyg_uint16      scc_dsr;                                /* SCC data sync reg */
       volatile cyg_uint16      scc_scce;                       /* SCC event reg */
       volatile cyg_uint8       RESERVED60[0x2];        /* Reserved area */
       volatile cyg_uint16      scc_sccm;                       /* SCC mask reg */
       volatile cyg_uint8       RESERVED61[0x1];        /* Reserved area */
       volatile cyg_uint8       scc_sccs;                       /* SCC status reg */
       volatile cyg_uint8       RESERVED62[0x8];        /* Reserved area */
 
   } scc_regs[4];
 
 
   /*-----*/
   /* SMC */
   /*-----*/
 
   struct smc_regs 
 
   {
       volatile cyg_uint8       RESERVED63[0x2];        /* Reserved area */
       volatile cyg_uint16      smc_smcmr;                      /* SMC mode reg */
       volatile cyg_uint8       RESERVED64[0x2];        /* Reserved area */
       volatile cyg_uint8       smc_smce;                       /* SMC event reg */
       volatile cyg_uint8       RESERVED65[0x3];        /* Reserved area */
       volatile cyg_uint8       smc_smcm;                       /* SMC mask reg */
       volatile cyg_uint8       RESERVED66[0x5];        /* Reserved area */
 
   } smc_regs[2];
 
 
   /*-----*/
   /* SPI */
   /*-----*/
 
   volatile cyg_uint16  spi_spmode;                     /* SPI mode reg */
   volatile cyg_uint8   RESERVED67[0x4];        /* Reserved area */
   volatile cyg_uint8   spi_spie;                       /* SPI event reg */
   volatile cyg_uint8   RESERVED68[0x3];        /* Reserved area */
   volatile cyg_uint8   spi_spim;                       /* SPI mask reg */
   volatile cyg_uint8   RESERVED69[0x2];        /* Reserved area */
   volatile cyg_uint8   spi_spcom;                      /* SPI command reg */
   volatile cyg_uint8   RESERVED70[0x4];        /* Reserved area */
 
   /*-----*/
   /* PIP */
   /*-----*/
 
   volatile cyg_uint16  pip_pipc;                       /* pip configuration reg */
   volatile cyg_uint8   RESERVED71[0x2];        /* Reserved area */
   volatile cyg_uint16  pip_ptpr;                       /* pip timing parameters reg */
   volatile cyg_uint32  pip_pbdir;                      /* port b data direction reg */
   volatile cyg_uint32  pip_pbpar;                      /* port b pin assignment reg */
   volatile cyg_uint8   RESERVED72[0x2];        /* Reserved area */
   volatile cyg_uint16  pip_pbodr;                      /* port b open drain reg */
   volatile cyg_uint32  pip_pbdat;                      /* port b data reg */
   volatile cyg_uint8   RESERVED73[0x18];       /* Reserved area */
 
 
   /*------------------*/
   /* Serial Interface */
   /*------------------*/
 
   volatile cyg_uint32  si_simode;                              /* SI mode register */
   volatile cyg_uint8   si_sigmr;                               /* SI global mode register */
   volatile cyg_uint8   RESERVED74;                     /* Reserved area */
   volatile cyg_uint8   si_sistr;                               /* SI status register */
   volatile cyg_uint8   si_sicmr;                               /* SI command register */
   volatile cyg_uint8   RESERVED75[0x4];                /* Reserved area */
   volatile cyg_uint32  si_sicr;                                        /* SI clock routing */
   volatile cyg_uint32  si_sirp;                                        /* SI ram pointers */
   volatile cyg_uint8   RESERVED76[0x10c];      /* Reserved area */
   volatile cyg_uint8   si_siram[0x200];                /* SI routing ram */
   volatile cyg_uint8   RESERVED77[0x1200];     /* Reserved area */
 
   /*-----------------------------------------------------------------*/
   /* BASE + 0x2000: user data memory, microcode, or QMC channel PRAM */
   /*-----------------------------------------------------------------*/
 
        union
        {
                struct qmc_chan_pram qcp[64];
                struct user_data ud;
                cyg_uint8 RESERVED[0x1c00];
        } qcp_or_ud;
 
 
   /*-----------------------------------------------------------------------*/
   /* BASE + 0x3c00: PARAMETER RAM. This main union defines 4 memory blocks */
   /* of an identical size. See the Parameter RAM definition in the MPC860  */
   /* user's manual.                                                        */
   /*-----------------------------------------------------------------------*/
 
   /*------------------------*/
   /* Base + 0x3C00 (page 1) */
   /*      + 0x3D00 (page 2) */
   /*      + 0x3E00 (page 3) */
   /*      + 0x3F00 (page 4) */
   /*------------------------*/
 
   union 
 
   {
      struct page_of_pram 
 
      {
         /*------------------------------------------------------------*/
         /* scc parameter area - 1st memory block (protocol dependent) */
         /*------------------------------------------------------------*/
 
         union 
 
         {
            struct hdlc_pram          h;
            struct uart_pram          u;
            struct bisync_pram          b;
            struct transparent_pram     t;
            struct async_hdlc_pram      a;
            cyg_uint8   RESERVED78[0x80];
 
         } scc;         
 
         /*----------------------------------------------------------------*/
         /* Other protocol areas for the rest of the memory blocks in each */
         /* page.                                                          */
         /*----------------------------------------------------------------*/
 
         union 
 
         {
            /*---------------------------------------------------------------*/
            /* This structure defines the rest of the blocks on the 1st page */
            /*---------------------------------------------------------------*/ 
 
            struct 
 
            {
               struct i2c_pram  i2c;     /* I2C   */
               struct misc_pram misc;    /* MISC  */
               struct idma_pram idma1;   /* IDMA1 */
 
            } i2c_idma; 
 
            /*---------------------------------------------------------------*/
            /* This structure defines the rest of the blocks on the 2nd page */
            /*---------------------------------------------------------------*/
 
            struct 
 
            {
               struct spi_pram  spi;     /* SPI    */
               struct timer_pram        timer;   /* Timers */
               struct idma_pram idma2;   /* IDMA2  */
 
            } spi_timer_idma; 
 
            /*---------------------------------------------------------------*/
            /* This structure defines the rest of the blocks on the 3rd page */
            /*---------------------------------------------------------------*/
 
            struct 
 
            {
               union 
 
               {
                  struct smc_uart_pram u1;   /* SMC1 */
                  struct smc_trnsp_pram t1;  /* SMC1 */
                  cyg_uint8     RESERVED78[0x80];     /* declare full block */
 
               } psmc1; 
 
            } smc_dsp1;
 
 
            /*---------------------------------------------------------------*/
            /* This structure defines the rest of the blocks on the 4th page */
            /*---------------------------------------------------------------*/ 
 
            struct 
 
            {
               union 
 
               {
                  struct smc_uart_pram u2;   /* SMC2 */
                  struct smc_trnsp_pram t2;  /* SMC2 */
                  struct centronics_pram c;  /* Uses SM2's space */
                  cyg_uint8     RESERVED79[0x80];    /* declare full block */
 
               } psmc2;
 
            } smc_dsp2; 
 
            cyg_uint8   RESERVED80[0x80];    /* declare full block */
 
         } other;
 
      } pg;
 
      /*---------------------------------------------------------------*/
      /* When selecting Ethernet as protocol for an SCC, this protocol */
      /* uses a complete page of Parameter RAM memory.                 */
      /*---------------------------------------------------------------*/
 
      struct ethernet_pram      enet_scc;
 
        /*---------------------------------------------------------------*/
        /* When using QMC as a mode for an SCC, the QMC global parameter */
        /* ram uses from SCC BASE to BASE+AC.                            */
        /*---------------------------------------------------------------*/
 
      struct global_qmc_pram  gqp; 
 
      /*--------------------------------------------------------*/
      /* declaration to guarantee a page of memory is allocated */
      /*--------------------------------------------------------*/
 
      cyg_uint8   RESERVED83[0x100]; 
 
   } PRAM[4]; /* end of union */
 
} EPPC;
 
 
/***************************************************************************/
/*                   General Global Definitions                            */
/***************************************************************************/
 
 
#define PAGE1           0       /* SCC1 Index into SCC Param RAM Array */
#define PAGE2           1       /* SCC2 Index into SCC Param RAM Array */
#define PAGE3           2       /* SCC3 Index into SCC Param RAM Array */
#define PAGE4           3       /* SCC4 Index into SCC Param RAM Array */
 
#define SCC1_REG                0       /* SCC1 Index into SCC Regs Array  */                           
#define SCC2_REG                1       /* SCC2 Index into SCC Regs Array  */                           
#define SCC3_REG                2       /* SCC3 Index into SCC Regs Array  */                           
#define SCC4_REG                3       /* SCC4 Index into SCC Regs Array  */                           
 
 
/*--------------------------------*/
/* KEEP ALIVE POWER REGISTERS KEY */
/*--------------------------------*/
 
#define KEEP_ALIVE_KEY 0x55ccaa33
 
 
#define SMC2_REG 1          /* SMC Regs Array Index for SMC2 */
 
/*-------------------------*/
/* Single buffer component */
/*-------------------------*/
 
typedef struct BufferPool
 
{
   cyg_uint8  RxBuffer;
   cyg_uint8  TxBuffer;
 
} LB;
 
 
/*--------------------------*/
/* Buffer Descriptor Format */
/*--------------------------*/
 
typedef struct BufferDescriptor 
 
{
   cyg_uint16 bd_cstatus;     /* control and status */
   cyg_uint16 bd_length;      /* transfer length */
   cyg_uint8  *bd_addr;       /* buffer address */
 
} BD;
 
 
/*-------------------------------*/
/* Buffer Descriptor Ring format */
/*-------------------------------*/
 
typedef struct BufferDescRings 
 
{
    volatile BD RxBD;    /* Rx BD ring */
    volatile BD TxBD;    /* Tx BD ring */
 
} BDRINGS;
 
 
#endif /* CYGONCE_HAL_PPC_FADS_PPC_860_H */
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.