Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* |
| 2 | * This file is subject to the terms and conditions of the GNU General Public |
| 3 | * License. See the file "COPYING" in the main directory of this archive |
| 4 | * for more details. |
| 5 | * |
| 6 | * gio.h: Definitions for SGI GIO bus |
| 7 | * |
| 8 | * Copyright (C) 2002 Ladislav Michl |
| 9 | */ |
| 10 | |
| 11 | #ifndef _SGI_GIO_H |
| 12 | #define _SGI_GIO_H |
| 13 | |
| 14 | /* |
| 15 | * GIO bus addresses |
| 16 | * |
| 17 | * The Indigo and Indy have two GIO bus connectors. Indigo2 (all models) have |
| 18 | * three physical connectors, but only two slots, GFX and EXP0. |
Ralf Baechle | 42a3b4f | 2005-09-03 15:56:17 -0700 | [diff] [blame] | 19 | * |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 20 | * There is 10MB of GIO address space for GIO64 slot devices |
| 21 | * slot# slot type address range size |
| 22 | * ----- --------- ----------------------- ----- |
| 23 | * 0 GFX 0x1f000000 - 0x1f3fffff 4MB |
| 24 | * 1 EXP0 0x1f400000 - 0x1f5fffff 2MB |
| 25 | * 2 EXP1 0x1f600000 - 0x1f9fffff 4MB |
| 26 | * |
| 27 | * There are un-slotted devices, HPC, I/O and misc devices, which are grouped |
| 28 | * into the HPC address space. |
| 29 | * - MISC 0x1fb00000 - 0x1fbfffff 1MB |
| 30 | * |
| 31 | * Following space is reserved and unused |
| 32 | * - RESERVED 0x18000000 - 0x1effffff 112MB |
| 33 | * |
| 34 | * GIO bus IDs |
| 35 | * |
| 36 | * Each GIO bus device identifies itself to the system by answering a |
| 37 | * read with an "ID" value. IDs are either 8 or 32 bits long. IDs less |
| 38 | * than 128 are 8 bits long, with the most significant 24 bits read from |
| 39 | * the slot undefined. |
| 40 | * |
| 41 | * 32-bit IDs are divided into |
| 42 | * bits 0:6 the product ID; ranges from 0x00 to 0x7F. |
| 43 | * bit 7 0=GIO Product ID is 8 bits wide |
| 44 | * 1=GIO Product ID is 32 bits wide. |
| 45 | * bits 8:15 manufacturer version for the product. |
| 46 | * bit 16 0=GIO32 and GIO32-bis, 1=GIO64. |
| 47 | * bit 17 0=no ROM present |
| 48 | * 1=ROM present on this board AND next three words |
| 49 | * space define the ROM. |
| 50 | * bits 18:31 up to manufacturer. |
| 51 | * |
| 52 | * IDs above 0x50/0xd0 are of 3rd party boards. |
| 53 | * |
| 54 | * 8-bit IDs |
| 55 | * 0x01 XPI low cost FDDI |
| 56 | * 0x02 GTR TokenRing |
| 57 | * 0x04 Synchronous ISDN |
| 58 | * 0x05 ATM board [*] |
| 59 | * 0x06 Canon Interface |
| 60 | * 0x07 16 bit SCSI Card [*] |
| 61 | * 0x08 JPEG (Double Wide) |
| 62 | * 0x09 JPEG (Single Wide) |
| 63 | * 0x0a XPI mez. FDDI device 0 |
| 64 | * 0x0b XPI mez. FDDI device 1 |
| 65 | * 0x0c SMPTE 259M Video [*] |
| 66 | * 0x0d Babblefish Compression [*] |
| 67 | * 0x0e E-Plex 8-port Ethernet |
| 68 | * 0x30 Lyon Lamb IVAS |
| 69 | * 0xb8 GIO 100BaseTX Fast Ethernet (gfe) |
| 70 | * |
| 71 | * [*] Device provide 32-bit ID. |
| 72 | * |
| 73 | */ |
| 74 | |
| 75 | #define GIO_ID(x) (x & 0x7f) |
| 76 | #define GIO_32BIT_ID 0x80 |
| 77 | #define GIO_REV(x) ((x >> 8) & 0xff) |
| 78 | #define GIO_64BIT_IFACE 0x10000 |
| 79 | #define GIO_ROM_PRESENT 0x20000 |
| 80 | #define GIO_VENDOR_CODE(x) ((x >> 18) & 0x3fff) |
| 81 | |
| 82 | #define GIO_SLOT_GFX_BASE 0x1f000000 |
| 83 | #define GIO_SLOT_EXP0_BASE 0x1f400000 |
| 84 | #define GIO_SLOT_EXP1_BASE 0x1f600000 |
| 85 | |
| 86 | #endif /* _SGI_GIO_H */ |