OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [include/] [asm-mips64/] [sgi/] [gio.h] - Blame information for rev 1275

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1275 phoenix
/*
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.
19
 *
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 */

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.