Some people confuse vidix with kernel drivers, so let's add a note about it
[mplayer/glamo.git] / libdha / libdha.c
blob328df4d87a217c409e16162ea045553938096238
1 /*
2 libgha.c - Library for direct hardware access
3 Copyrights:
4 1996/10/27 - Robin Cutshaw (robin@xfree86.org)
5 XFree86 3.3.3 implementation
6 1999 - Øyvind Aabling.
7 Modified for GATOS/win/gfxdump.
9 2002 - library implementation by Nick Kurshev
10 - dhahelper and some changes by Alex Beregszaszi
12 supported O/S's: SVR4, UnixWare, SCO, Solaris,
13 FreeBSD, NetBSD, 386BSD, BSDI BSD/386,
14 Linux, Mach/386, ISC
15 DOS (WATCOM 9.5 compiler), Win9x (with mapdev.vxd)
16 Licence: GPL
17 Original location: www.linuxvideo.org/gatos
20 #include "config.h"
22 #include "libdha.h"
23 #include "AsmMacros.h"
24 #include <stdio.h>
25 #include <stdlib.h>
26 #include <string.h>
27 #include <fcntl.h>
28 #include <sys/stat.h>
29 #include <sys/types.h>
30 #ifdef ARCH_ALPHA
31 #include <sys/io.h>
32 #endif
33 #include <unistd.h>
35 #if defined(WIN32)
36 #include "sysdep/libdha_win32.c"
37 #elif defined (__EMX__)
38 #include "sysdep/libdha_os2.c"
39 #else
41 #if defined(SVR4) || defined(SCO325)
42 # if !(defined(sun) && defined (i386) && defined (SVR4))
43 # define DEV_MEM "/dev/pmem"
44 # elif defined(PowerMAX_OS)
45 # define DEV_MEM "/dev/iomem"
46 # endif
47 # ifdef SCO325
48 # undef DEV_MEM
49 # define DEV_MEM "/dev/mem"
50 # endif
51 # endif /* SVR4 */
53 #if defined(__OpenBSD__)
54 #define DEV_APERTURE "/dev/xf86"
55 #endif
57 /* Generic version */
58 #include <sys/mman.h>
60 #ifndef DEV_MEM
61 #define DEV_MEM "/dev/mem"
62 #endif
64 #ifdef CONFIG_DHAHELPER
65 #include "kernelhelper/dhahelper.h"
66 #endif
68 #ifdef CONFIG_SVGAHELPER
69 #include <svgalib_helper.h>
70 #endif
72 static int mem_fd = -1;
74 void *map_phys_mem(unsigned long base, unsigned long size)
76 #ifdef ARCH_ALPHA
77 /* TODO: move it into sysdep */
78 base += bus_base();
79 #endif
81 #ifdef CONFIG_SVGAHELPER
82 if ( (mem_fd = open(DEV_SVGA,O_RDWR)) == -1) {
83 perror("libdha: SVGAlib kernelhelper failed");
84 #ifdef CONFIG_DHAHELPER
85 goto dha_helper_way;
86 #else
87 goto dev_mem_way;
88 #endif
90 else
91 goto mmap;
92 #endif
94 #ifdef CONFIG_DHAHELPER
95 #ifdef CONFIG_SVGAHELPER
96 dha_helper_way:
97 #endif
98 if ( (mem_fd = open("/dev/dhahelper",O_RDWR)) < 0)
100 perror("libdha: DHA kernelhelper failed");
101 goto dev_mem_way;
103 else
105 dhahelper_memory_t mem_req;
107 mem_req.operation = MEMORY_OP_MAP;
108 mem_req.start = base;
109 mem_req.offset = 0;
110 mem_req.size = size;
112 if (ioctl(mem_fd, DHAHELPER_MEMORY, &mem_req) < 0)
114 perror("libdha: DHA kernelhelper failed");
115 close(mem_fd);
116 goto dev_mem_way;
118 else
119 goto mmap;
121 #endif
123 dev_mem_way:
124 #ifdef DEV_APERTURE
125 if ((mem_fd = open(DEV_APERTURE, O_RDWR)) == -1)
126 perror("libdha: opening aperture failed");
127 else {
128 void *p = mmap(0,size,PROT_READ|PROT_WRITE,MAP_SHARED,mem_fd,base);
130 if (p == MAP_FAILED) {
131 perror("libdha: mapping aperture failed");
132 close(mem_fd);
133 } else
134 return p;
136 #endif
138 if ( (mem_fd = open(DEV_MEM,O_RDWR)) == -1)
140 perror("libdha: opening /dev/mem failed");
141 return MAP_FAILED;
144 mmap:
145 return mmap(0,size,PROT_READ|PROT_WRITE,MAP_SHARED,mem_fd,base);
148 void unmap_phys_mem(void *ptr, unsigned long size)
150 int res = munmap(ptr,size);
152 if (res == (int)MAP_FAILED)
154 perror("libdha: unmapping memory failed");
155 return;
158 close(mem_fd);
159 mem_fd = -1;
161 return;
164 #endif /* Generic mmap (not win32, nor os2) */
166 unsigned char INPORT8(unsigned idx)
168 return inb(idx);
171 unsigned short INPORT16(unsigned idx)
173 return inw(idx);
176 unsigned INPORT32(unsigned idx)
178 return inl(idx);
181 void OUTPORT8(unsigned idx,unsigned char val)
183 outb(idx,val);
186 void OUTPORT16(unsigned idx,unsigned short val)
188 outw(idx,val);
191 void OUTPORT32(unsigned idx,unsigned val)
193 outl(idx,val);