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