| GIO(4) | Kernel Interfaces Manual (SGIMIPS) | GIO(4) | 
NAME
 gio — SGI's Graphics I/O (GIO) bus (an early PCI-like bus)
SYNOPSIS
 gio0 at imc0
gio0 at pic0
DESCRIPTION
 The 
gio bus is a bus for connecting high-speed peripherals to the main memory and CPU. The devices themselves are typically (but not necessarily) connected to the 
hpc(4) peripheral controller, and memory and CPU are accessed through the 
imc(4) (Indy Memory Controller) or 
pic(4) (Processor Interface Controller). The 
gio bus is found on the Personal Iris 4D/3x, Indigo, Indy, Challenge S, Challenge M, and Indigo2 machines and exists in three incarnations: GIO32, GIO32-bis, and GIO64.
 
HISTORY
 The gio driver first appeared in NetBSD 1.5.
CAVEATS
 Challenge S systems may use only one 
gio DMA-capable expansion card, despite having two slots. Cards based on the 
hpc(4) controller, such as the GIO32 scsi and E++ Ethernet adapters, must be placed in slot 1 (closest to the side of the case). All other cards must be placed in slot 0 (adjacent to the memory banks).
Indigo2 and Challenge M systems contain either three or four GIO64 connectors, depending on the model. However, in both cases only two electrically distinct slots are present. Therefore, distinct expansion cards may not share physical connectors associated with the same slot. Refer to the PCB stencils to determine the association between physical connectors and slots.
 
BUGS
 Systems employing the 
imc(4) may experience spurious SysAD bus parity errors when using expansion cards, which do not drive all data lines during a CPU PIO read. The only workaround is to disable SysAD parity checking when using such cards.