summaryrefslogtreecommitdiffstats
path: root/sys/i386/include/pio.h
diff options
context:
space:
mode:
Diffstat (limited to 'sys/i386/include/pio.h')
-rw-r--r--sys/i386/include/pio.h75
1 files changed, 75 insertions, 0 deletions
diff --git a/sys/i386/include/pio.h b/sys/i386/include/pio.h
new file mode 100644
index 0000000..553a97a
--- /dev/null
+++ b/sys/i386/include/pio.h
@@ -0,0 +1,75 @@
+/*
+ * Mach Operating System
+ * Copyright (c) 1990 Carnegie-Mellon University
+ * All rights reserved. The CMU software License Agreement specifies
+ * the terms and conditions for use and redistribution.
+ */
+/*
+ *
+ * PATCHES MAGIC LEVEL PATCH THAT GOT US HERE
+ * -------------------- ----- ----------------------
+ * CURRENT PATCH LEVEL: 1 00158
+ * -------------------- ----- ----------------------
+ *
+ * 27 May 93 Rodney W. Grimes Added #ifndef around inb so that the
+ * clash with cpufunc.h does not cause
+ * a compile warning.. this is a hack.
+ * All of this needs cleaned up at 0.1.5
+ *
+ * HISTORY
+ * $Log: pio.h,v $
+ * Revision 1.1 1992/05/27 00:48:30 balsup
+ * machkern/cor merge
+ *
+ * Revision 1.1 1991/10/10 20:11:39 balsup
+ * Initial revision
+ *
+ * Revision 2.2 91/04/02 11:52:29 mbj
+ * [90/08/14 mg32]
+ *
+ * Now we know how types are factor in.
+ * Cleaned up a bunch: eliminated ({ for output and flushed unused
+ * output variables.
+ * [90/08/14 rvb]
+ *
+ * This is how its done in gcc:
+ * Created.
+ * [90/03/26 rvb]
+ *
+ */
+
+
+#define inl(y) \
+({ unsigned long _tmp__; \
+ asm volatile("inl %1, %0" : "=a" (_tmp__) : "d" ((unsigned short)(y))); \
+ _tmp__; })
+
+#define inw(y) \
+({ unsigned short _tmp__; \
+ asm volatile(".byte 0x66; inl %1, %0" : "=a" (_tmp__) : "d" ((unsigned short)(y))); \
+ _tmp__; })
+
+/*
+ * only do this if it has not already be defined.. this is a crock for the
+ * patch kit for right now. Need to clean up all the inx, outx stuff for
+ * 0.1.5 to use 1 common header file, that has Bruces fast mode inb/outb
+ * stuff in it. Rgrimes 5/27/93
+ */
+#ifndef inb
+#define inb(y) \
+({ unsigned char _tmp__; \
+ asm volatile("inb %1, %0" : "=a" (_tmp__) : "d" ((unsigned short)(y))); \
+ _tmp__; })
+#endif
+
+
+#define outl(x, y) \
+{ asm volatile("outl %0, %1" : : "a" (y) , "d" ((unsigned short)(x))); }
+
+
+#define outw(x, y) \
+{asm volatile(".byte 0x66; outl %0, %1" : : "a" ((unsigned short)(y)) , "d" ((unsigned short)(x))); }
+
+
+#define outb(x, y) \
+{ asm volatile("outb %0, %1" : : "a" ((unsigned char)(y)) , "d" ((unsigned short)(x))); }
OpenPOWER on IntegriCloud