pio.h revision 1.1 1 1.1 briggs /*
2 1.1 briggs * Mach Operating System
3 1.1 briggs * Copyright (c) 1990 Carnegie-Mellon University
4 1.1 briggs * All rights reserved. The CMU software License Agreement specifies
5 1.1 briggs * the terms and conditions for use and redistribution.
6 1.1 briggs */
7 1.1 briggs /*
8 1.1 briggs * HISTORY
9 1.1 briggs * pio.h,v
10 1.1 briggs * Revision 1.1 1993/03/21 18:09:48 cgd
11 1.1 briggs * after 0.2.2 "stable" patches applied
12 1.1 briggs *
13 1.1 briggs * Revision 1.1 1992/05/27 00:48:30 balsup
14 1.1 briggs * machkern/cor merge
15 1.1 briggs *
16 1.1 briggs * Revision 1.1 1991/10/10 20:11:39 balsup
17 1.1 briggs * Initial revision
18 1.1 briggs *
19 1.1 briggs * Revision 2.2 91/04/02 11:52:29 mbj
20 1.1 briggs * [90/08/14 mg32]
21 1.1 briggs *
22 1.1 briggs * Now we know how types are factor in.
23 1.1 briggs * Cleaned up a bunch: eliminated ({ for output and flushed unused
24 1.1 briggs * output variables.
25 1.1 briggs * [90/08/14 rvb]
26 1.1 briggs *
27 1.1 briggs * This is how its done in gcc:
28 1.1 briggs * Created.
29 1.1 briggs * [90/03/26 rvb]
30 1.1 briggs *
31 1.1 briggs */
32 1.1 briggs #ident "$Id: pio.h,v 1.1 1993/09/29 06:09:21 briggs Exp $"
33 1.1 briggs
34 1.1 briggs
35 1.1 briggs #define inl(y) \
36 1.1 briggs ({ unsigned long _tmp__; \
37 1.1 briggs asm volatile("inl %1, %0" : "=a" (_tmp__) : "d" ((unsigned short)(y))); \
38 1.1 briggs _tmp__; })
39 1.1 briggs
40 1.1 briggs #define inw(y) \
41 1.1 briggs ({ unsigned short _tmp__; \
42 1.1 briggs asm volatile(".byte 0x66; inl %1, %0" : "=a" (_tmp__) : "d" ((unsigned short)(y))); \
43 1.1 briggs _tmp__; })
44 1.1 briggs
45 1.1 briggs #define inb(y) \
46 1.1 briggs ({ unsigned char _tmp__; \
47 1.1 briggs asm volatile("inb %1, %0" : "=a" (_tmp__) : "d" ((unsigned short)(y))); \
48 1.1 briggs _tmp__; })
49 1.1 briggs
50 1.1 briggs
51 1.1 briggs #define outl(x, y) \
52 1.1 briggs { asm volatile("outl %0, %1" : : "a" (y) , "d" ((unsigned short)(x))); }
53 1.1 briggs
54 1.1 briggs
55 1.1 briggs #define outw(x, y) \
56 1.1 briggs {asm volatile(".byte 0x66; outl %0, %1" : : "a" ((unsigned short)(y)) , "d" ((unsigned short)(x))); }
57 1.1 briggs
58 1.1 briggs
59 1.1 briggs #define outb(x, y) \
60 1.1 briggs { asm volatile("outb %0, %1" : : "a" ((unsigned char)(y)) , "d" ((unsigned short)(x))); }
61