/* libgha.c - Library for direct hardware access Copyrights: 1996/10/27 - Robin Cutshaw (robin@xfree86.org) XFree86 3.3.3 implementation 1999 - Øyvind Aabling. Modified for GATOS/win/gfxdump. 2002 - library implementation by Nick Kurshev - dhahelper and some changes by Alex Beregszaszi supported O/S's: SVR4, UnixWare, SCO, Solaris, FreeBSD, NetBSD, 386BSD, BSDI BSD/386, Linux, Mach/386, ISC DOS (WATCOM 9.5 compiler), Win9x (with mapdev.vxd) Licence: GPL Original location: www.linuxvideo.org/gatos */ #include "config.h" #include "libdha.h" #include "AsmMacros.h" #include #include #include #include #include #include #ifdef ARCH_ALPHA #include #endif #include #if defined(WIN32) #include "sysdep/libdha_win32.c" #elif defined (__EMX__) #include "sysdep/libdha_os2.c" #else #if defined(SVR4) || defined(SCO325) # if !(defined(sun) && defined (i386) && defined (SVR4)) # define DEV_MEM "/dev/pmem" # elif defined(PowerMAX_OS) # define DEV_MEM "/dev/iomem" # endif # ifdef SCO325 # undef DEV_MEM # define DEV_MEM "/dev/mem" # endif # endif /* SVR4 */ #if defined(__OpenBSD__) #define DEV_APERTURE "/dev/xf86" #endif /* Generic version */ #include #ifndef DEV_MEM #define DEV_MEM "/dev/mem" #endif #ifdef CONFIG_DHAHELPER #include "kernelhelper/dhahelper.h" #endif #ifdef CONFIG_SVGAHELPER #include #endif static int mem_fd = -1; void *map_phys_mem(unsigned long base, unsigned long size) { #ifdef ARCH_ALPHA /* TODO: move it into sysdep */ base += bus_base(); #endif #ifdef CONFIG_SVGAHELPER if ( (mem_fd = open(DEV_SVGA,O_RDWR)) == -1) { perror("libdha: SVGAlib kernelhelper failed"); #ifdef CONFIG_DHAHELPER goto dha_helper_way; #else goto dev_mem_way; #endif } else goto mmap; #endif #ifdef CONFIG_DHAHELPER #ifdef CONFIG_SVGAHELPER dha_helper_way: #endif if ( (mem_fd = open("/dev/dhahelper",O_RDWR)) < 0) { perror("libdha: DHA kernelhelper failed"); goto dev_mem_way; } else { dhahelper_memory_t mem_req; mem_req.operation = MEMORY_OP_MAP; mem_req.start = base; mem_req.offset = 0; mem_req.size = size; if (ioctl(mem_fd, DHAHELPER_MEMORY, &mem_req) < 0) { perror("libdha: DHA kernelhelper failed"); close(mem_fd); goto dev_mem_way; } else goto mmap; } #endif dev_mem_way: #ifdef DEV_APERTURE if ((mem_fd = open(DEV_APERTURE, O_RDWR)) == -1) perror("libdha: opening aperture failed"); else { void *p = mmap(0,size,PROT_READ|PROT_WRITE,MAP_SHARED,mem_fd,base); if (p == MAP_FAILED) { perror("libdha: mapping aperture failed"); close(mem_fd); } else return p; } #endif if ( (mem_fd = open(DEV_MEM,O_RDWR)) == -1) { perror("libdha: opening /dev/mem failed"); return MAP_FAILED; } mmap: return mmap(0,size,PROT_READ|PROT_WRITE,MAP_SHARED,mem_fd,base); } void unmap_phys_mem(void *ptr, unsigned long size) { int res = munmap(ptr,size); if (res == (int)MAP_FAILED) { perror("libdha: unmapping memory failed"); return; } close(mem_fd); mem_fd = -1; return; } #endif /* Generic mmap (not win32, nor os2) */ unsigned char INPORT8(unsigned idx) { return inb(idx); } unsigned short INPORT16(unsigned idx) { return inw(idx); } unsigned INPORT32(unsigned idx) { return inl(idx); } void OUTPORT8(unsigned idx,unsigned char val) { outb(idx,val); } void OUTPORT16(unsigned idx,unsigned short val) { outw(idx,val); } void OUTPORT32(unsigned idx,unsigned val) { outl(idx,val); }