2005-04-16 15:20:36 -07:00
/*
* This file is subject to the terms and conditions of the GNU General Public
* License . See the file " COPYING " in the main directory of this archive
* for more details .
*
* gio . h : Definitions for SGI GIO bus
*
* Copyright ( C ) 2002 Ladislav Michl
*/
# ifndef _SGI_GIO_H
# define _SGI_GIO_H
/*
* GIO bus addresses
*
* The Indigo and Indy have two GIO bus connectors . Indigo2 ( all models ) have
* three physical connectors , but only two slots , GFX and EXP0 .
2005-09-03 15:56:17 -07:00
*
2005-04-16 15:20:36 -07:00
* There is 10 MB of GIO address space for GIO64 slot devices
* slot # slot type address range size
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
* 0 GFX 0x1f000000 - 0x1f3fffff 4 MB
* 1 EXP0 0x1f400000 - 0x1f5fffff 2 MB
* 2 EXP1 0x1f600000 - 0x1f9fffff 4 MB
*
* There are un - slotted devices , HPC , I / O and misc devices , which are grouped
* into the HPC address space .
* - MISC 0x1fb00000 - 0x1fbfffff 1 MB
*
* Following space is reserved and unused
* - RESERVED 0x18000000 - 0x1effffff 112 MB
*
* GIO bus IDs
*
* Each GIO bus device identifies itself to the system by answering a
* read with an " ID " value . IDs are either 8 or 32 bits long . IDs less
* than 128 are 8 bits long , with the most significant 24 bits read from
* the slot undefined .
*
* 32 - bit IDs are divided into
* bits 0 : 6 the product ID ; ranges from 0x00 to 0x7F .
* bit 7 0 = GIO Product ID is 8 bits wide
* 1 = GIO Product ID is 32 bits wide .
* bits 8 : 15 manufacturer version for the product .
* bit 16 0 = GIO32 and GIO32 - bis , 1 = GIO64 .
* bit 17 0 = no ROM present
* 1 = ROM present on this board AND next three words
* space define the ROM .
* bits 18 : 31 up to manufacturer .
*
* IDs above 0x50 / 0xd0 are of 3 rd party boards .
*
* 8 - bit IDs
* 0x01 XPI low cost FDDI
* 0x02 GTR TokenRing
* 0x04 Synchronous ISDN
* 0x05 ATM board [ * ]
* 0x06 Canon Interface
* 0x07 16 bit SCSI Card [ * ]
* 0x08 JPEG ( Double Wide )
* 0x09 JPEG ( Single Wide )
* 0x0a XPI mez . FDDI device 0
* 0x0b XPI mez . FDDI device 1
* 0x0c SMPTE 259 M Video [ * ]
* 0x0d Babblefish Compression [ * ]
* 0x0e E - Plex 8 - port Ethernet
* 0x30 Lyon Lamb IVAS
* 0xb8 GIO 100 BaseTX Fast Ethernet ( gfe )
*
* [ * ] Device provide 32 - bit ID .
*
*/
# define GIO_ID(x) (x & 0x7f)
# define GIO_32BIT_ID 0x80
# define GIO_REV(x) ((x >> 8) & 0xff)
# define GIO_64BIT_IFACE 0x10000
# define GIO_ROM_PRESENT 0x20000
# define GIO_VENDOR_CODE(x) ((x >> 18) & 0x3fff)
# define GIO_SLOT_GFX_BASE 0x1f000000
# define GIO_SLOT_EXP0_BASE 0x1f400000
# define GIO_SLOT_EXP1_BASE 0x1f600000
# endif /* _SGI_GIO_H */