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