outb, outw, outl, outsb, outsw, outsl, inb, inw, inl, insb, insw, insl, outb_p,
outw_p, outl_p, inb_p, inw_p, inl_p - wejście/wyjście
portów
Standardowa biblioteka C (
libc,
-lc)
#include <sys/io.h>
unsigned char inb(unsigned short port);
unsigned char inb_p(unsigned short port);
unsigned short inw(unsigned short port);
unsigned short inw_p(unsigned short port);
unsigned int inl(unsigned short port);
unsigned int inl_p(unsigned short port);
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);
Ta rodzina funkcji jest używana do wykonywania niskopoziomowych
odczytów z portu i zapisów do portu. Funkcje "out*"
zapisują do portu, funkcje "in*" odczytują z portu;
funkcje z sufiksem "b" operują na bajtach, a z sufiksem
"w" — na słowach; funkcje z sufiksem "p"
czekają na zakończenie operacji wejścia/wyjścia.
Są przeznaczone głównie do użytku wewnątrz
jądra, lecz mogą być też używane w warstwie
użytkownika.
Trzeba je kompilować z
-O lub
-O2 lub z czymś
podobnym. Funkcje te są zdefiniowane jako makra inline i nie
będą podstawione bez włączonej optymalizacji,
powodując niezdefiniowane referencje podczas konsolidacji.
Aby przekazać jądru, że warstwa użytkownika chce
uzyskać dostęp do żądanych portów,
należy użyć
ioperm(2) lub
iopl(2).
Błąd podczas wykonywanie tej operacji spowoduje
błąd ochrony pamięci.
outb() i przyjaciele są zależne od sprzętu, na
którym działają. Pierwszym przekazywanym argumentem jest
value, a drugim —
port, czyli kolejność
argumentów jest odwrotna w stosunku do większości
implementacji DOS-owych.
ioperm(2),
iopl(2)
Autorami polskiego tłumaczenia niniejszej strony podręcznika
są: Przemek Borys <
[email protected]>, Andrzej Krzysztofowicz
<
[email protected]>, Robert Luberda <
[email protected]> i
Michał Kułach <
[email protected]>
Niniejsze tłumaczenie jest wolną dokumentacją.
Bliższe informacje o warunkach licencji można uzyskać
zapoznając się z
GNU
General Public License w wersji 3 lub nowszej. Nie przyjmuje się
ŻADNEJ ODPOWIEDZIALNOŚCI.
Błędy w tłumaczeniu strony podręcznika prosimy
zgłaszać na adres listy dyskusyjnej
[email protected]