1 1.1 thorpej /* $NetBSD: bonitoreg.h,v 1.1 2001/06/01 20:29:33 thorpej Exp $ */ 2 1.1 thorpej 3 1.1 thorpej /* 4 1.1 thorpej * Bonito Register Map 5 1.1 thorpej * Copyright (c) 1999 Algorithmics Ltd 6 1.1 thorpej * 7 1.1 thorpej * Algorithmics gives permission for anyone to use and modify this file 8 1.1 thorpej * without any obligation or license condition except that you retain 9 1.1 thorpej * this copyright message in any source redistribution in whole or part. 10 1.1 thorpej * 11 1.1 thorpej * Updated copies of this and other files can be found at 12 1.1 thorpej * ftp://ftp.algor.co.uk/pub/bonito/ 13 1.1 thorpej * 14 1.1 thorpej * Users of the Bonito controller are warmly recommended to contribute 15 1.1 thorpej * any useful changes back to Algorithmics (mail to 16 1.1 thorpej * bonito (at) algor.co.uk). 17 1.1 thorpej */ 18 1.1 thorpej 19 1.1 thorpej /* Revision 1.40 autogenerated on 08/14/99 17:37:43 */ 20 1.1 thorpej 21 1.1 thorpej #ifndef _BONITO_H_ 22 1.1 thorpej 23 1.1 thorpej #ifdef __ASSEMBLER__ 24 1.1 thorpej 25 1.1 thorpej /* offsets from base register */ 26 1.1 thorpej #define BONITO(x) (x) 27 1.1 thorpej 28 1.1 thorpej #else /* !__ASSEMBLER */ 29 1.1 thorpej 30 1.1 thorpej /* offsets from base pointer, this construct allows optimisation */ 31 1.1 thorpej /* static char * const _bonito = PA_TO_KVA1(BONITO_BASE); */ 32 1.1 thorpej #define BONITO(x) *(volatile unsigned long *)(_bonito + (x)) 33 1.1 thorpej 34 1.1 thorpej #endif /* __ASSEMBLER__ */ 35 1.1 thorpej 36 1.1 thorpej 37 1.1 thorpej #define BONITO_BOOT_BASE 0x1fc00000 38 1.1 thorpej #define BONITO_BOOT_SIZE 0x00100000 39 1.1 thorpej #define BONITO_BOOT_TOP (BOOT_BASE+BOOT_SIZE-1) 40 1.1 thorpej #define BONITO_FLASH_BASE 0x1c000000 41 1.1 thorpej #define BONITO_FLASH_SIZE 0x03000000 42 1.1 thorpej #define BONITO_FLASH_TOP (FLASH_BASE+FLASH_SIZE-1) 43 1.1 thorpej #define BONITO_SOCKET_BASE 0x1f800000 44 1.1 thorpej #define BONITO_SOCKET_SIZE 0x00400000 45 1.1 thorpej #define BONITO_SOCKET_TOP (SOCKET_BASE+SOCKET_SIZE-1) 46 1.1 thorpej #define BONITO_REG_BASE 0x1fe00000 47 1.1 thorpej #define BONITO_REG_SIZE 0x00040000 48 1.1 thorpej #define BONITO_REG_TOP (REG_BASE+REG_SIZE-1) 49 1.1 thorpej #define BONITO_DEV_BASE 0x1ff00000 50 1.1 thorpej #define BONITO_DEV_SIZE 0x00100000 51 1.1 thorpej #define BONITO_DEV_TOP (DEV_BASE+DEV_SIZE-1) 52 1.1 thorpej #define BONITO_PCILO_BASE 0x10000000 53 1.1 thorpej #define BONITO_PCILO_SIZE 0x0c000000 54 1.1 thorpej #define BONITO_PCILO_TOP (PCILO_BASE+PCILO_SIZE-1) 55 1.1 thorpej #define BONITO_PCIHI_BASE 0x20000000 56 1.1 thorpej #define BONITO_PCIHI_SIZE 0x20000000 57 1.1 thorpej #define BONITO_PCIHI_TOP (PCIHI_BASE+PCIHI_SIZE-1) 58 1.1 thorpej #define BONITO_PCIIO_BASE 0x1fd00000 59 1.1 thorpej #define BONITO_PCIIO_SIZE 0x00100000 60 1.1 thorpej #define BONITO_PCIIO_TOP (PCIIO_BASE+PCIIO_SIZE-1) 61 1.1 thorpej #define BONITO_PCICFG_BASE 0x1fe80000 62 1.1 thorpej #define BONITO_PCICFG_SIZE 0x00080000 63 1.1 thorpej #define BONITO_PCICFG_TOP (PCICFG_BASE+PCICFG_SIZE-1) 64 1.1 thorpej 65 1.1 thorpej 66 1.1 thorpej /* Bonito Register Bases */ 67 1.1 thorpej 68 1.1 thorpej #define BONITO_PCICONFIGBASE 0x00 69 1.1 thorpej #define BONITO_REGBASE 0x100 70 1.1 thorpej 71 1.1 thorpej 72 1.1 thorpej /* PCI Configuration Registers */ 73 1.1 thorpej 74 1.1 thorpej #define BONITO_PCIDID BONITO(BONITO_PCICONFIGBASE + 0x00) 75 1.1 thorpej #define BONITO_PCICMD BONITO(BONITO_PCICONFIGBASE + 0x04) 76 1.1 thorpej #define BONITO_PCICLASS BONITO(BONITO_PCICONFIGBASE + 0x08) 77 1.1 thorpej #define BONITO_PCILTIMER BONITO(BONITO_PCICONFIGBASE + 0x0c) 78 1.1 thorpej #define BONITO_PCIBASE0 BONITO(BONITO_PCICONFIGBASE + 0x10) 79 1.1 thorpej #define BONITO_PCIBASE1 BONITO(BONITO_PCICONFIGBASE + 0x14) 80 1.1 thorpej #define BONITO_PCIBASE2 BONITO(BONITO_PCICONFIGBASE + 0x18) 81 1.1 thorpej #define BONITO_PCIEXPRBASE BONITO(BONITO_PCICONFIGBASE + 0x30) 82 1.1 thorpej #define BONITO_PCIINT BONITO(BONITO_PCICONFIGBASE + 0x3c) 83 1.1 thorpej 84 1.1 thorpej #define BONITO_PCICMD_PERR_CLR 0x80000000 85 1.1 thorpej #define BONITO_PCICMD_SERR_CLR 0x40000000 86 1.1 thorpej #define BONITO_PCICMD_MABORT_CLR 0x20000000 87 1.1 thorpej #define BONITO_PCICMD_MTABORT_CLR 0x10000000 88 1.1 thorpej #define BONITO_PCICMD_TABORT_CLR 0x08000000 89 1.1 thorpej #define BONITO_PCICMD_MPERR_CLR 0x01000000 90 1.1 thorpej #define BONITO_PCICMD_PERRRESPEN 0x00000040 91 1.1 thorpej #define BONITO_PCICMD_ASTEPEN 0x00000080 92 1.1 thorpej #define BONITO_PCICMD_SERREN 0x00000100 93 1.1 thorpej #define BONITO_PCILTIMER_BUSLATENCY 0x0000ff00 94 1.1 thorpej #define BONITO_PCILTIMER_BUSLATENCY_SHIFT 8 95 1.1 thorpej 96 1.1 thorpej 97 1.1 thorpej 98 1.1 thorpej 99 1.1 thorpej /* 1. Bonito h/w Configuration */ 100 1.1 thorpej /* Power on register */ 101 1.1 thorpej 102 1.1 thorpej #define BONITO_BONPONCFG BONITO(BONITO_REGBASE + 0x00) 103 1.1 thorpej 104 1.1 thorpej #define BONITO_BONPONCFG_SYSCONTROLLERRD 0x00040000 105 1.1 thorpej #define BONITO_BONPONCFG_ROMCS1SAMP 0x00020000 106 1.1 thorpej #define BONITO_BONPONCFG_ROMCS0SAMP 0x00010000 107 1.1 thorpej #define BONITO_BONPONCFG_CPUBIGEND 0x00004000 108 1.1 thorpej #define BONITO_BONPONCFG_CPUPARITY 0x00002000 109 1.1 thorpej #define BONITO_BONPONCFG_CPUTYPE 0x00000007 110 1.1 thorpej #define BONITO_BONPONCFG_CPUTYPE_SHIFT 0 111 1.1 thorpej #define BONITO_BONPONCFG_PCIRESET_OUT 0x00000008 112 1.1 thorpej #define BONITO_BONPONCFG_IS_ARBITER 0x00000010 113 1.1 thorpej #define BONITO_BONPONCFG_ROMBOOT 0x000000c0 114 1.1 thorpej #define BONITO_BONPONCFG_ROMBOOT_SHIFT 6 115 1.1 thorpej 116 1.1 thorpej #define BONITO_BONPONCFG_ROMBOOT_FLASH (0x0<<BONITO_BONPONCFG_ROMBOOT_SHIFT) 117 1.1 thorpej #define BONITO_BONPONCFG_ROMBOOT_SOCKET (0x1<<BONITO_BONPONCFG_ROMBOOT_SHIFT) 118 1.1 thorpej #define BONITO_BONPONCFG_ROMBOOT_SDRAM (0x2<<BONITO_BONPONCFG_ROMBOOT_SHIFT) 119 1.1 thorpej #define BONITO_BONPONCFG_ROMBOOT_CPURESET (0x3<<BONITO_BONPONCFG_ROMBOOT_SHIFT) 120 1.1 thorpej 121 1.1 thorpej #define BONITO_BONPONCFG_ROMCS0WIDTH 0x00000100 122 1.1 thorpej #define BONITO_BONPONCFG_ROMCS1WIDTH 0x00000200 123 1.1 thorpej #define BONITO_BONPONCFG_ROMCS0FAST 0x00000400 124 1.1 thorpej #define BONITO_BONPONCFG_ROMCS1FAST 0x00000800 125 1.1 thorpej #define BONITO_BONPONCFG_CONFIG_DIS 0x00000020 126 1.1 thorpej 127 1.1 thorpej 128 1.1 thorpej /* Other Bonito configuration */ 129 1.1 thorpej 130 1.1 thorpej #define BONITO_BONGENCFG BONITO(BONITO_REGBASE + 0x04) 131 1.1 thorpej 132 1.1 thorpej #define BONITO_BONGENCFG_DEBUGMODE 0x00000001 133 1.1 thorpej #define BONITO_BONGENCFG_SNOOPEN 0x00000002 134 1.1 thorpej #define BONITO_BONGENCFG_CPUSELFRESET 0x00000004 135 1.1 thorpej 136 1.1 thorpej #define BONITO_BONGENCFG_FORCE_IRQA 0x00000008 137 1.1 thorpej #define BONITO_BONGENCFG_IRQA_ISOUT 0x00000010 138 1.1 thorpej #define BONITO_BONGENCFG_IRQA_FROM_INT1 0x00000020 139 1.1 thorpej #define BONITO_BONGENCFG_BYTESWAP 0x00000040 140 1.1 thorpej 141 1.1 thorpej #define BONITO_BONGENCFG_UNCACHED 0x00000080 142 1.1 thorpej #define BONITO_BONGENCFG_PREFETCHEN 0x00000100 143 1.1 thorpej #define BONITO_BONGENCFG_WBEHINDEN 0x00000200 144 1.1 thorpej #define BONITO_BONGENCFG_CACHEALG 0x00000c00 145 1.1 thorpej #define BONITO_BONGENCFG_CACHEALG_SHIFT 10 146 1.1 thorpej #define BONITO_BONGENCFG_PCIQUEUE 0x00001000 147 1.1 thorpej #define BONITO_BONGENCFG_CACHESTOP 0x00002000 148 1.1 thorpej #define BONITO_BONGENCFG_MSTRBYTESWAP 0x00004000 149 1.1 thorpej #define BONITO_BONGENCFG_NOTIMEOUT 0x00008000 150 1.1 thorpej #define BONITO_BONGENCFG_NORETRYTIMEOUT 0x00010000 151 1.1 thorpej 152 1.1 thorpej /* 2. IO & IDE configuration */ 153 1.1 thorpej 154 1.1 thorpej #define BONITO_IODEVCFG BONITO(BONITO_REGBASE + 0x08) 155 1.1 thorpej 156 1.1 thorpej /* 3. IO & IDE configuration */ 157 1.1 thorpej 158 1.1 thorpej #define BONITO_SDCFG BONITO(BONITO_REGBASE + 0x0c) 159 1.1 thorpej 160 1.1 thorpej /* 4. PCI address map control */ 161 1.1 thorpej 162 1.1 thorpej #define BONITO_PCIMAP BONITO(BONITO_REGBASE + 0x10) 163 1.1 thorpej #define BONITO_PCIMEMBASECFG BONITO(BONITO_REGBASE + 0x14) 164 1.1 thorpej #define BONITO_PCIMAP_CFG BONITO(BONITO_REGBASE + 0x18) 165 1.1 thorpej 166 1.1 thorpej /* 5. ICU & GPIO regs */ 167 1.1 thorpej 168 1.1 thorpej /* GPIO Regs - r/w */ 169 1.1 thorpej 170 1.1 thorpej #define BONITO_GPIODATA BONITO(BONITO_REGBASE + 0x1c) 171 1.1 thorpej #define BONITO_GPIOIE BONITO(BONITO_REGBASE + 0x20) 172 1.1 thorpej 173 1.1 thorpej /* ICU Configuration Regs - r/w */ 174 1.1 thorpej 175 1.1 thorpej #define BONITO_INTEDGE BONITO(BONITO_REGBASE + 0x24) 176 1.1 thorpej #define BONITO_INTSTEER BONITO(BONITO_REGBASE + 0x28) 177 1.1 thorpej #define BONITO_INTPOL BONITO(BONITO_REGBASE + 0x2c) 178 1.1 thorpej 179 1.1 thorpej /* ICU Enable Regs - IntEn & IntISR are r/o. */ 180 1.1 thorpej 181 1.1 thorpej #define BONITO_INTENSET BONITO(BONITO_REGBASE + 0x30) 182 1.1 thorpej #define BONITO_INTENCLR BONITO(BONITO_REGBASE + 0x34) 183 1.1 thorpej #define BONITO_INTEN BONITO(BONITO_REGBASE + 0x38) 184 1.1 thorpej #define BONITO_INTISR BONITO(BONITO_REGBASE + 0x3c) 185 1.1 thorpej 186 1.1 thorpej /* PCI mail boxes */ 187 1.1 thorpej 188 1.1 thorpej #define BONITO_PCIMAIL0 BONITO(BONITO_REGBASE + 0x40) 189 1.1 thorpej #define BONITO_PCIMAIL1 BONITO(BONITO_REGBASE + 0x44) 190 1.1 thorpej #define BONITO_PCIMAIL2 BONITO(BONITO_REGBASE + 0x48) 191 1.1 thorpej #define BONITO_PCIMAIL3 BONITO(BONITO_REGBASE + 0x4c) 192 1.1 thorpej 193 1.1 thorpej 194 1.1 thorpej /* 6. PCI cache */ 195 1.1 thorpej 196 1.1 thorpej #define BONITO_PCICACHECTRL BONITO(BONITO_REGBASE + 0x50) 197 1.1 thorpej #define BONITO_PCICACHETAG BONITO(BONITO_REGBASE + 0x54) 198 1.1 thorpej 199 1.1 thorpej #define BONITO_PCIBADADDR BONITO(BONITO_REGBASE + 0x58) 200 1.1 thorpej #define BONITO_PCIMSTAT BONITO(BONITO_REGBASE + 0x5c) 201 1.1 thorpej 202 1.1 thorpej 203 1.1 thorpej /* 204 1.1 thorpej #define BONITO_PCIRDPOST BONITO(BONITO_REGBASE + 0x60) 205 1.1 thorpej #define BONITO_PCIDATA BONITO(BONITO_REGBASE + 0x64) 206 1.1 thorpej */ 207 1.1 thorpej 208 1.1 thorpej /* 7. IDE DMA & Copier */ 209 1.1 thorpej 210 1.1 thorpej #define BONITO_CONFIGBASE 0x000 211 1.1 thorpej #define BONITO_BONITOBASE 0x100 212 1.1 thorpej #define BONITO_LDMABASE 0x200 213 1.1 thorpej #define BONITO_COPBASE 0x300 214 1.1 thorpej #define BONITO_REG_BLOCKMASK 0x300 215 1.1 thorpej 216 1.1 thorpej #define BONITO_LDMACTRL BONITO(BONITO_LDMABASE + 0x0) 217 1.1 thorpej #define BONITO_LDMASTAT BONITO(BONITO_LDMABASE + 0x0) 218 1.1 thorpej #define BONITO_LDMAADDR BONITO(BONITO_LDMABASE + 0x4) 219 1.1 thorpej #define BONITO_LDMAGO BONITO(BONITO_LDMABASE + 0x8) 220 1.1 thorpej #define BONITO_LDMADATA BONITO(BONITO_LDMABASE + 0xc) 221 1.1 thorpej 222 1.1 thorpej #define BONITO_COPCTRL BONITO(BONITO_COPBASE + 0x0) 223 1.1 thorpej #define BONITO_COPSTAT BONITO(BONITO_COPBASE + 0x0) 224 1.1 thorpej #define BONITO_COPPADDR BONITO(BONITO_COPBASE + 0x4) 225 1.1 thorpej #define BONITO_COPDADDR BONITO(BONITO_COPBASE + 0x8) 226 1.1 thorpej #define BONITO_COPGO BONITO(BONITO_COPBASE + 0xc) 227 1.1 thorpej 228 1.1 thorpej 229 1.1 thorpej /* ###### Bit Definitions for individual Registers #### */ 230 1.1 thorpej 231 1.1 thorpej /* Gen DMA. */ 232 1.1 thorpej 233 1.1 thorpej #define BONITO_IDECOPDADDR_DMA_DADDR 0x0ffffffc 234 1.1 thorpej #define BONITO_IDECOPDADDR_DMA_DADDR_SHIFT 2 235 1.1 thorpej #define BONITO_IDECOPPADDR_DMA_PADDR 0xfffffffc 236 1.1 thorpej #define BONITO_IDECOPPADDR_DMA_PADDR_SHIFT 2 237 1.1 thorpej #define BONITO_IDECOPGO_DMA_SIZE 0x0000ffff 238 1.1 thorpej #define BONITO_IDECOPGO_DMA_SIZE_SHIFT 0 239 1.1 thorpej #define BONITO_IDECOPGO_DMA_WRITE 0x00010000 240 1.1 thorpej 241 1.1 thorpej #define BONITO_IDECOPCTRL_DMA_STARTBIT 0x80000000 242 1.1 thorpej #define BONITO_IDECOPCTRL_DMA_RSTBIT 0x40000000 243 1.1 thorpej 244 1.1 thorpej /* DRAM - sdCfg */ 245 1.1 thorpej 246 1.1 thorpej #define BONITO_SDCFG_AROWBITS 0x00000003 247 1.1 thorpej #define BONITO_SDCFG_AROWBITS_SHIFT 0 248 1.1 thorpej #define BONITO_SDCFG_ACOLBITS 0x0000000c 249 1.1 thorpej #define BONITO_SDCFG_ACOLBITS_SHIFT 2 250 1.1 thorpej #define BONITO_SDCFG_ABANKBIT 0x00000010 251 1.1 thorpej #define BONITO_SDCFG_ASIDES 0x00000020 252 1.1 thorpej #define BONITO_SDCFG_AABSENT 0x00000040 253 1.1 thorpej #define BONITO_SDCFG_AWIDTH64 0x00000080 254 1.1 thorpej 255 1.1 thorpej #define BONITO_SDCFG_BROWBITS 0x00000300 256 1.1 thorpej #define BONITO_SDCFG_BROWBITS_SHIFT 8 257 1.1 thorpej #define BONITO_SDCFG_BCOLBITS 0x00000c00 258 1.1 thorpej #define BONITO_SDCFG_BCOLBITS_SHIFT 10 259 1.1 thorpej #define BONITO_SDCFG_BBANKBIT 0x00001000 260 1.1 thorpej #define BONITO_SDCFG_BSIDES 0x00002000 261 1.1 thorpej #define BONITO_SDCFG_BABSENT 0x00004000 262 1.1 thorpej #define BONITO_SDCFG_BWIDTH64 0x00008000 263 1.1 thorpej 264 1.1 thorpej #define BONITO_SDCFG_EXTRDDATA 0x00010000 265 1.1 thorpej #define BONITO_SDCFG_EXTRASCAS 0x00020000 266 1.1 thorpej #define BONITO_SDCFG_EXTPRECH 0x00040000 267 1.1 thorpej #define BONITO_SDCFG_EXTRASWIDTH 0x00180000 268 1.1 thorpej #define BONITO_SDCFG_EXTRASWIDTH_SHIFT 19 269 1.1 thorpej #define BONITO_SDCFG_DRAMRESET 0x00200000 270 1.1 thorpej #define BONITO_SDCFG_DRAMEXTREGS 0x00400000 271 1.1 thorpej #define BONITO_SDCFG_DRAMCSFLIP 0x00800000 272 1.1 thorpej 273 1.1 thorpej /* PCI Cache - pciCacheCtrl */ 274 1.1 thorpej 275 1.1 thorpej #define BONITO_PCICACHECTRL_CACHECMD 0x00000007 276 1.1 thorpej #define BONITO_PCICACHECTRL_CACHECMD_SHIFT 0 277 1.1 thorpej #define BONITO_PCICACHECTRL_CACHECMDLINE 0x00000018 278 1.1 thorpej #define BONITO_PCICACHECTRL_CACHECMDLINE_SHIFT 3 279 1.1 thorpej #define BONITO_PCICACHECTRL_CMDEXEC 0x00000020 280 1.1 thorpej 281 1.1 thorpej #define BONITO_IODEVCFG_BUFFBIT_CS0 0x00000001 282 1.1 thorpej #define BONITO_IODEVCFG_SPEEDBIT_CS0 0x00000002 283 1.1 thorpej #define BONITO_IODEVCFG_MOREABITS_CS0 0x00000004 284 1.1 thorpej 285 1.1 thorpej #define BONITO_IODEVCFG_BUFFBIT_CS1 0x00000008 286 1.1 thorpej #define BONITO_IODEVCFG_SPEEDBIT_CS1 0x00000010 287 1.1 thorpej #define BONITO_IODEVCFG_MOREABITS_CS1 0x00000020 288 1.1 thorpej 289 1.1 thorpej #define BONITO_IODEVCFG_BUFFBIT_CS2 0x00000040 290 1.1 thorpej #define BONITO_IODEVCFG_SPEEDBIT_CS2 0x00000080 291 1.1 thorpej #define BONITO_IODEVCFG_MOREABITS_CS2 0x00000100 292 1.1 thorpej 293 1.1 thorpej #define BONITO_IODEVCFG_BUFFBIT_CS3 0x00000200 294 1.1 thorpej #define BONITO_IODEVCFG_SPEEDBIT_CS3 0x00000400 295 1.1 thorpej #define BONITO_IODEVCFG_MOREABITS_CS3 0x00000800 296 1.1 thorpej 297 1.1 thorpej #define BONITO_IODEVCFG_BUFFBIT_IDE 0x00001000 298 1.1 thorpej #define BONITO_IODEVCFG_SPEEDBIT_IDE 0x00002000 299 1.1 thorpej #define BONITO_IODEVCFG_WORDSWAPBIT_IDE 0x00004000 300 1.1 thorpej #define BONITO_IODEVCFG_MODEBIT_IDE 0x00008000 301 1.1 thorpej #define BONITO_IODEVCFG_DMAON_IDE 0x001f0000 302 1.1 thorpej #define BONITO_IODEVCFG_DMAON_IDE_SHIFT 16 303 1.1 thorpej #define BONITO_IODEVCFG_DMAOFF_IDE 0x01e00000 304 1.1 thorpej #define BONITO_IODEVCFG_DMAOFF_IDE_SHIFT 21 305 1.1 thorpej 306 1.1 thorpej /* gpio */ 307 1.1 thorpej #define BONITO_GPIO_GPIOW 0x000003ff 308 1.1 thorpej #define BONITO_GPIO_GPIOW_SHIFT 0 309 1.1 thorpej #define BONITO_GPIO_GPIOR 0x01ff0000 310 1.1 thorpej #define BONITO_GPIO_GPIOR_SHIFT 16 311 1.1 thorpej #define BONITO_GPIO_GPINR 0xfe000000 312 1.1 thorpej #define BONITO_GPIO_GPINR_SHIFT 25 313 1.1 thorpej #define BONITO_GPIO_IOW(N) (1<<(BONITO_GPIO_GPIOW_SHIFT+(N))) 314 1.1 thorpej #define BONITO_GPIO_IOR(N) (1<<(BONITO_GPIO_GPIOR_SHIFT+(N))) 315 1.1 thorpej #define BONITO_GPIO_INR(N) (1<<(BONITO_GPIO_GPINR_SHIFT+(N))) 316 1.1 thorpej 317 1.1 thorpej /* ICU */ 318 1.1 thorpej #define BONITO_ICU_MBOXES 0x0000000f 319 1.1 thorpej #define BONITO_ICU_MBOXES_SHIFT 0 320 1.1 thorpej #define BONITO_ICU_DMARDY 0x00000010 321 1.1 thorpej #define BONITO_ICU_DMAEMPTY 0x00000020 322 1.1 thorpej #define BONITO_ICU_COPYRDY 0x00000040 323 1.1 thorpej #define BONITO_ICU_COPYEMPTY 0x00000080 324 1.1 thorpej #define BONITO_ICU_COPYERR 0x00000100 325 1.1 thorpej #define BONITO_ICU_PCIIRQ 0x00000200 326 1.1 thorpej #define BONITO_ICU_MASTERERR 0x00000400 327 1.1 thorpej #define BONITO_ICU_SYSTEMERR 0x00000800 328 1.1 thorpej #define BONITO_ICU_DRAMPERR 0x00001000 329 1.1 thorpej #define BONITO_ICU_GPIOS 0x01ff0000 330 1.1 thorpej #define BONITO_ICU_GPIOS_SHIFT 16 331 1.1 thorpej #define BONITO_ICU_GPINS 0x7e000000 332 1.1 thorpej #define BONITO_ICU_GPINS_SHIFT 25 333 1.1 thorpej #define BONITO_ICU_MBOX(N) (1<<(BONITO_ICU_MBOXES_SHIFT+(N))) 334 1.1 thorpej #define BONITO_ICU_GPIO(N) (1<<(BONITO_ICU_GPIOS_SHIFT+(N))) 335 1.1 thorpej #define BONITO_ICU_GPIN(N) (1<<(BONITO_ICU_GPINS_SHIFT+(N))) 336 1.1 thorpej 337 1.1 thorpej /* pcimap */ 338 1.1 thorpej 339 1.1 thorpej #define BONITO_PCIMAP_PCIMAP_LO0 0x0000003f 340 1.1 thorpej #define BONITO_PCIMAP_PCIMAP_LO0_SHIFT 0 341 1.1 thorpej #define BONITO_PCIMAP_PCIMAP_LO1 0x00000fc0 342 1.1 thorpej #define BONITO_PCIMAP_PCIMAP_LO1_SHIFT 6 343 1.1 thorpej #define BONITO_PCIMAP_PCIMAP_LO2 0x0003f000 344 1.1 thorpej #define BONITO_PCIMAP_PCIMAP_LO2_SHIFT 12 345 1.1 thorpej #define BONITO_PCIMAP_PCIMAP_2 0x00040000 346 1.1 thorpej #define BONITO_PCIMAP_WIN(WIN,ADDR) ((((ADDR)>>26) & BONITO_PCIMAP_PCIMAP_LO0) << (WIN)*6) 347 1.1 thorpej 348 1.1 thorpej /* pcimembaseCfg */ 349 1.1 thorpej 350 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE0_MASK 0x0000001f 351 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE0_MASK_SHIFT 0 352 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE0_TRANS 0x000003e0 353 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE0_TRANS_SHIFT 5 354 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE0_CACHED 0x00000400 355 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE0_IO 0x00000800 356 1.1 thorpej 357 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE1_MASK 0x0001f000 358 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE1_MASK_SHIFT 12 359 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE1_TRANS 0x003e0000 360 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE1_TRANS_SHIFT 17 361 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE1_CACHED 0x00400000 362 1.1 thorpej #define BONITO_PCIMEMBASECFG_MEMBASE1_IO 0x00800000 363 1.1 thorpej 364 1.1 thorpej #define BONITO_PCIMEMBASECFG_ASHIFT 23 365 1.1 thorpej #define BONITO_PCIMEMBASECFGSIZE(WIN,SIZE) (((~((SIZE)-1))>>(BONITO_PCIMEMBASECFG_ASHIFT-BONITO_PCIMEMBASECFG_MEMBASE##WIN##_MASK_SHIFT)) & BONITO_PCIMEMBASECFG_MEMBASE##WIN##_MASK) 366 1.1 thorpej #define BONITO_PCIMEMBASECFGBASE(WIN,BASE) (((BASE)>>(BONITO_PCIMEMBASECFG_ASHIFT-BONITO_PCIMEMBASECFG_MEMBASE##WIN##_TRANS_SHIFT)) & BONITO_PCIMEMBASECFG_MEMBASE##WIN##_TRANS) 367 1.1 thorpej 368 1.1 thorpej /* PCICmd */ 369 1.1 thorpej 370 1.1 thorpej #define BONITO_PCICMD_MEMEN 0x00000002 371 1.1 thorpej #define BONITO_PCICMD_MSTREN 0x00000004 372 1.1 thorpej 373 1.1 thorpej 374 1.1 thorpej #endif /* _BONITO_H_ */ 375