ARCH(3) (x86) ARCH(3)
NAME
arch - x86 architecture-specific information and control
SYNOPSIS
bind -a #P /dev
/dev/cputype
/dev/ioalloc
/dev/iob
/dev/iol
/dev/iow
/dev/irqalloc
DESCRIPTION
This device presents textual information about PC hardware
and allows user-level control of the I/O ports on x86-class
machines.
Reads from cputype recover the processor type and clock
rate.
Reads from ioalloc return I/O ranges used by each device,
one line per range. Each line contains three fields sepa-
rated by white space: first address in hexadecimal, last
address, name of device.
Reads from irqalloc return the enabled interrupts, one line
per interrupt. Each line contains three fields separated by
white space: the trap number, the IRQ it is assigned to, and
the name of the device using it.
Reads and writes to iob, iow, and iol cause 8-bit wide, 16-
bit wide, and 32-bit wide requests to I/O ports. The port
accessed is determined by the byte offset of the file
descriptor.
EXAMPLE
The following Limbo code reads from an x86 byte I/O port.
inportb(port: int): byte
{
data := array[1] of byte;
if(iobfd == nil)
iobfd = sys->open("#P/iob", Sys->ORDWR);
sys->seek(iobfd, port, 0);
if(sys->read(iobfd, data, len data) != len data)
fatal(sys->sprint("inportb(16r%4.4x): %r\n", port));
return data[0];
Page 1 Plan 9 (printed 10/26/25)
ARCH(3) (x86) ARCH(3)
}
SOURCE
/os/pc/devarch.c
Page 2 Plan 9 (printed 10/26/25)