NAME¶
outb, outw, outl, outsb, outsw, outsl, inb, inw, inl, insb, insw, insl, outb_p,
  outw_p, outl_p, inb_p, inw_p, inl_p - port I/O
DESCRIPTION¶
This family of functions is used to do low-level port input and output. The out*
  functions do port output, the in* functions do port input; the b-suffix
  functions are byte-width and the w-suffix functions word-width; the _p-suffix
  functions pause until the I/O completes.
They are primarily designed for internal kernel use, but can be used from user
  space.
 
You compile with 
-O or 
-O2 or similar. The functions are defined
  as inline macros, and will not be substituted in without optimization enabled,
  causing unresolved references at link time.
 
You use 
ioperm(2) or alternatively 
iopl(2) to tell the kernel to
  allow the user space application to access the I/O ports in question. Failure
  to do this will cause the application to receive a segmentation fault.
outb() and friends are hardware-specific. The 
value argument is
  passed first and the 
port argument is passed second, which is the
  opposite order from most DOS implementations.
SEE ALSO¶
ioperm(2), 
iopl(2)
COLOPHON¶
This page is part of release 3.44 of the Linux 
man-pages project. A
  description of the project, and information about reporting bugs, can be found
  at 
http://www.kernel.org/doc/man-pages/.