home *** CD-ROM | disk | FTP | other *** search
/ Mac Easy 2010 May / Mac Life Ubuntu.iso / casper / filesystem.squashfs / usr / src / linux-headers-2.6.28-15 / arch / mips / include / asm / sgi / gio.h next >
Encoding:
C/C++ Source or Header  |  2008-12-24  |  2.6 KB  |  87 lines

  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.
  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 */
  87.