+#if defined(__GNUC__) && (!MACH_ASSERT)
+extern __inline__ unsigned long inl(
+ i386_ioport_t port)
+{
+ unsigned long datum;
+ __asm__ volatile("inl %1, %0" : "=a" (datum) : "d" (port));
+ return(datum);
+}
+
+extern __inline__ unsigned short inw(
+ i386_ioport_t port)
+{
+ unsigned short datum;
+ __asm__ volatile(".byte 0x66; inl %1, %0" : "=a" (datum) : "d" (port));
+ return(datum);
+}
+
+extern __inline__ unsigned char inb(
+ i386_ioport_t port)
+{
+ unsigned char datum;
+ __asm__ volatile("inb %1, %0" : "=a" (datum) : "d" (port));
+ return(datum);
+}
+
+extern __inline__ void outl(
+ i386_ioport_t port,
+ unsigned long datum)
+{
+ __asm__ volatile("outl %0, %1" : : "a" (datum), "d" (port));
+}
+
+extern __inline__ void outw(
+ i386_ioport_t port,
+ unsigned short datum)
+{
+ __asm__ volatile(".byte 0x66; outl %0, %1" : : "a" (datum), "d" (port));
+}
+
+extern __inline__ void outb(
+ i386_ioport_t port,
+ unsigned char datum)
+{
+ __asm__ volatile("outb %0, %1" : : "a" (datum), "d" (port));
+}
+#endif /* defined(__GNUC__) && (!MACH_ASSERT) */