summaryrefslogtreecommitdiff
path: root/src/video_out/libdha/sysdep/AsmMacros_powerpc.h
diff options
context:
space:
mode:
authorDaniel Caujolle-Bert <f1rmb@users.sourceforge.net>2002-06-01 14:08:36 +0000
committerDaniel Caujolle-Bert <f1rmb@users.sourceforge.net>2002-06-01 14:08:36 +0000
commitbb7a31a69bac993ffb9cfb195b84c1e374308e08 (patch)
treedfa504dd8c27837562c4850308d668afef851dd2 /src/video_out/libdha/sysdep/AsmMacros_powerpc.h
parentc49645144f4d31c88610c449059d48493736b5b6 (diff)
downloadxine-lib-bb7a31a69bac993ffb9cfb195b84c1e374308e08.tar.gz
xine-lib-bb7a31a69bac993ffb9cfb195b84c1e374308e08.tar.bz2
Add vidix/libdha from mplayerxp and Miguel's video ouput vidix.
CVS patchset: 1976 CVS date: 2002/06/01 14:08:36
Diffstat (limited to 'src/video_out/libdha/sysdep/AsmMacros_powerpc.h')
-rw-r--r--src/video_out/libdha/sysdep/AsmMacros_powerpc.h62
1 files changed, 62 insertions, 0 deletions
diff --git a/src/video_out/libdha/sysdep/AsmMacros_powerpc.h b/src/video_out/libdha/sysdep/AsmMacros_powerpc.h
new file mode 100644
index 000000000..b17daddbd
--- /dev/null
+++ b/src/video_out/libdha/sysdep/AsmMacros_powerpc.h
@@ -0,0 +1,62 @@
+/*
+ This file is based on:
+ $XFree86: xc/programs/Xserver/hw/xfree86/drivers/chips/util/AsmMacros.h,v 1.1 2001/11/16 21:13:34 tsi Exp $
+ Modified for readability by Nick Kurshev
+*/
+
+#ifndef __ASM_MACROS_POWERPC_H
+#define __ASM_MACROS_POWERPC_H
+
+#if defined(Lynx)
+
+extern unsigned char *ioBase;
+
+static __inline__ volatile void eieio()
+{
+ __asm__ __volatile__ ("eieio");
+}
+
+static __inline__ void outb(short port, unsigned char value)
+{
+ *(uchar *)(ioBase + port) = value; eieio();
+}
+
+static __inline__ void outw(short port, unsigned short value)
+{
+ *(unsigned short *)(ioBase + port) = value; eieio();
+}
+
+static __inline__ void outl(short port, unsigned short value)
+{
+ *(unsigned long *)(ioBase + port) = value; eieio();
+}
+
+static __inline__ unsigned char inb(short port)
+{
+ unsigned char val;
+ val = *((unsigned char *)(ioBase + port)); eieio();
+ return(val);
+}
+
+static __inline__ unsigned short inw(short port)
+{
+ unsigned short val;
+ val = *((unsigned short *)(ioBase + port)); eieio();
+ return(val);
+}
+
+static __inline__ unsigned long inl(short port)
+{
+ unsigned long val;
+ val = *((unsigned long *)(ioBase + port)); eieio();
+ return(val);
+}
+
+#define intr_disable()
+#define intr_enable()
+
+#else
+#error This stuff is not ported on your system
+#endif
+
+#endif