/* <:copyright-gpl Copyright 2004 Broadcom Corp. All Rights Reserved. This program is free software; you can distribute it and/or modify it under the terms of the GNU General Public License (Version 2) as published by the Free Software Foundation. This program is distributed in the hope it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. :> */ #ifndef __BCM6338_MAP_H #define __BCM6338_MAP_H #include "bcmtypes.h" #define PERF_BASE 0xfffe0000 #define TIMR_BASE 0xfffe0200 #define UART_BASE 0xfffe0300 #define GPIO_BASE 0xfffe0400 #define SPI_BASE 0xfffe0c00 typedef struct PerfControl { uint32 RevID; uint16 testControl; uint16 blkEnables; #define EMAC_CLK_EN 0x0010 #define USBS_CLK_EN 0x0010 #define SAR_CLK_EN 0x0020 #define SPI_CLK_EN 0x0200 uint32 pll_control; #define SOFT_RESET 0x00000001 uint32 IrqMask; uint32 IrqStatus; uint32 ExtIrqCfg; #define EI_SENSE_SHFT 0 #define EI_STATUS_SHFT 5 #define EI_CLEAR_SHFT 10 #define EI_MASK_SHFT 15 #define EI_INSENS_SHFT 20 #define EI_LEVEL_SHFT 25 uint32 unused[4]; /* (18) */ uint32 BlockSoftReset; /* (28) */ #define BSR_SPI 0x00000001 #define BSR_EMAC 0x00000004 #define BSR_USBH 0x00000008 #define BSR_USBS 0x00000010 #define BSR_ADSL 0x00000020 #define BSR_DMAMEM 0x00000040 #define BSR_SAR 0x00000080 #define BSR_ACLC 0x00000100 #define BSR_ADSL_MIPS_PLL 0x00000400 #define BSR_ALL_BLOCKS \ (BSR_SPI | BSR_EMAC | BSR_USBH | BSR_USBS | BSR_ADSL | BSR_DMAMEM | \ BSR_SAR | BSR_ACLC | BSR_ADSL_MIPS_PLL) } PerfControl; #define PERF ((volatile PerfControl * const) PERF_BASE) typedef struct Timer { uint16 unused0; byte TimerMask; #define TIMER0EN 0x01 #define TIMER1EN 0x02 #define TIMER2EN 0x04 byte TimerInts; #define TIMER0 0x01 #define TIMER1 0x02 #define TIMER2 0x04 #define WATCHDOG 0x08 uint32 TimerCtl0; uint32 TimerCtl1; uint32 TimerCtl2; #define TIMERENABLE 0x80000000 #define RSTCNTCLR 0x40000000 uint32 TimerCnt0; uint32 TimerCnt1; uint32 TimerCnt2; uint32 WatchDogDefCount; /* Write 0xff00 0x00ff to Start timer * Write 0xee00 0x00ee to Stop and re-load default count * Read from this register returns current watch dog count */ uint32 WatchDogCtl; /* Number of 40-MHz ticks for WD Reset pulse to last */ uint32 WDResetCount; } Timer; #define TIMER ((volatile Timer * const) TIMR_BASE) typedef struct UartChannel { byte unused0; byte control; #define BRGEN 0x80 /* Control register bit defs */ #define TXEN 0x40 #define RXEN 0x20 #define LOOPBK 0x10 #define TXPARITYEN 0x08 #define TXPARITYEVEN 0x04 #define RXPARITYEN 0x02 #define RXPARITYEVEN 0x01 byte config; #define XMITBREAK 0x40 #define BITS5SYM 0x00 #define BITS6SYM 0x10 #define BITS7SYM 0x20 #define BITS8SYM 0x30 #define ONESTOP 0x07 #define TWOSTOP 0x0f /* 4-LSBS represent STOP bits/char * in 1/8 bit-time intervals. Zero * represents 1/8 stop bit interval. * Fifteen represents 2 stop bits. */ byte fifoctl; #define RSTTXFIFOS 0x80 #define RSTRXFIFOS 0x40 /* 5-bit TimeoutCnt is in low bits of this register. * This count represents the number of characters * idle times before setting receive Irq when below threshold */ uint32 baudword; /* When divide SysClk/2/(1+baudword) we should get 32*bit-rate */ byte txf_levl; /* Read-only fifo depth */ byte rxf_levl; /* Read-only fifo depth */ byte fifocfg; /* Upper 4-bits are TxThresh, Lower are * RxThreshold. Irq can be asserted * when rx fifo> thresh, txfifo