Scroll to navigation

outb(2) System Calls Manual outb(2)

NOMBRE

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

BIBLIOTECA

Biblioteca Estándar C (libc, -lc)

SINOPSIS

#include <sys/io.h>
unsigned char inb(unsigned short puerto);
unsigned char inb_p(unsigned short puerto);
unsigned short inw(unsigned short puerto);
unsigned short inw_p(unsigned short puerto);
unsigned int inl(unsigned short puerto);
unsigned int inl_p(unsigned short puerto);
void outb(unsigned char value, unsigned short port);
void outb_p(unsigned char value, unsigned short port);
void outw(unsigned short value, unsigned short port);
void outw_p(unsigned short value, unsigned short port);
void outl(unsigned int value, unsigned short port);
void outl_p(unsigned int value, unsigned short port);
void insb(unsigned short port, void addr[.count],
           unsigned long count);
void insw(unsigned short port, void addr[.count],
           unsigned long count);
void insl(unsigned short port, void addr[.count],
           unsigned long count);
void outsb(unsigned short port, const void addr[.count],
           unsigned long count);
void outsw(unsigned short port, const void addr[.count],
           unsigned long count);
void outsl(unsigned short port, const void addr[.count],
           unsigned long count);

DESCRIPCIÓN

Esta familia de funciones se utiliza para la entrada y salida de puertos de bajo nivel. Las funciones out* realizan la salida de puertos mientras que las funciones in* realizan la entrada. Las funciones con sufijo b ocupan el ancho de byte y las funciones con sufijo w ocupan el ancho de palabra; las funciones con sufijo _p se pausan hasta que se completa la E/S.

Están diseñadas principalmente para uso interno del núcleo, pero pueden ser empleadas desde el espacio del usuario.

Debe compilarse con -O o -O2 o similar. Las funciones están definidas como macros en línea del preprocesador, y no serán sustituidas sin la opción de optimización activada, provocando referencias no resueltas durante el enlazado.

Debe emplearse ioperm(2) o alternativamente iopl(2) para decirle al núcleo que permita a la aplicación en el espacio de usuario el acceso a los puertos de E/S en cuestión. Si no hace esto la aplicación recibirá un error de segmentación.

VERSIONES

outb() y similares son específicas de cada hardware. El argumento value se pasa primero y el argumento port se pasa después, en el orden inverso al de la mayoría de las implementaciones de DOS.

ESTÁNDARES

Ninguna.

VÉASE TAMBIÉN

ioperm(2), iopl(2)

TRADUCCIÓN

La traducción al español de esta página del manual fue creada por Gerardo Aburruzaga García <gerardo.aburruzaga@uca.es> y Marcos Fouces <marcos@debian.org>

Esta traducción es documentación libre; lea la GNU General Public License Version 3 o posterior con respecto a las condiciones de copyright. No existe NINGUNA RESPONSABILIDAD.

Si encuentra algún error en la traducción de esta página del manual, envíe un correo electrónico a debian-l10n-spanish@lists.debian.org.

2 Mayo 2024 Páginas de Manual de Linux 6.9.1