Commit | Line | Data |
---|---|---|
1da177e4 LT |
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. | |
42a3b4f2 | 19 | * |
1da177e4 | 20 | * There is 10MB of GIO address space for GIO64 slot devices |
70342287 | 21 | * slot# slot type address range size |
1da177e4 | 22 | * ----- --------- ----------------------- ----- |
70342287 RB |
23 | * 0 GFX 0x1f000000 - 0x1f3fffff 4MB |
24 | * 1 EXP0 0x1f400000 - 0x1f5fffff 2MB | |
25 | * 2 EXP1 0x1f600000 - 0x1f9fffff 4MB | |
1da177e4 LT |
26 | * |
27 | * There are un-slotted devices, HPC, I/O and misc devices, which are grouped | |
28 | * into the HPC address space. | |
70342287 | 29 | * - MISC 0x1fb00000 - 0x1fbfffff 1MB |
1da177e4 LT |
30 | * |
31 | * Following space is reserved and unused | |
70342287 | 32 | * - RESERVED 0x18000000 - 0x1effffff 112MB |
1da177e4 LT |
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 | |
70342287 | 42 | * bits 0:6 the product ID; ranges from 0x00 to 0x7F. |
1da177e4 LT |
43 | * bit 7 0=GIO Product ID is 8 bits wide |
44 | * 1=GIO Product ID is 32 bits wide. | |
70342287 | 45 | * bits 8:15 manufacturer version for the product. |
1da177e4 LT |
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 */ |