xenocara/xserver/hw/xfree86/os-support/linux/lnx_ev56.c

149 lines
3.2 KiB
C

/* This file has to be built with -mcpu=ev56 */
#ifdef HAVE_XORG_CONFIG_H
#include <xorg-config.h>
#endif
#include <X11/X.h>
#include "input.h"
#include "scrnintstr.h"
#include "compiler.h"
#include "xf86.h"
#include "xf86Priv.h"
#include "xf86_OSlib.h"
#include "xf86OSpriv.h"
int readDense8(pointer Base, register unsigned long Offset);
int readDense16(pointer Base, register unsigned long Offset);
int readDense32(pointer Base, register unsigned long Offset);
void
writeDenseNB8(int Value, pointer Base, register unsigned long Offset);
void
writeDenseNB16(int Value, pointer Base, register unsigned long Offset);
void
writeDenseNB32(int Value, pointer Base, register unsigned long Offset);
void
writeDense8(int Value, pointer Base, register unsigned long Offset);
void
writeDense16(int Value, pointer Base, register unsigned long Offset);
void
writeDense32(int Value, pointer Base, register unsigned long Offset);
int
readDense8(pointer Base, register unsigned long Offset)
{
mem_barrier();
return *(volatile CARD8*) ((unsigned long)Base+(Offset));
}
int
readDense16(pointer Base, register unsigned long Offset)
{
mem_barrier();
return *(volatile CARD16*) ((unsigned long)Base+(Offset));
}
int
readDense32(pointer Base, register unsigned long Offset)
{
mem_barrier();
return *(volatile CARD32*)((unsigned long)Base+(Offset));
}
void
writeDenseNB8(int Value, pointer Base, register unsigned long Offset)
{
*(volatile CARD8*)((unsigned long)Base+(Offset)) = Value;
}
void
writeDenseNB16(int Value, pointer Base, register unsigned long Offset)
{
*(volatile CARD16*)((unsigned long)Base + (Offset)) = Value;
}
void
writeDenseNB32(int Value, pointer Base, register unsigned long Offset)
{
*(volatile CARD32*)((unsigned long)Base+(Offset)) = Value;
}
void
writeDense8(int Value, pointer Base, register unsigned long Offset)
{
write_mem_barrier();
*(volatile CARD8 *)((unsigned long)Base+(Offset)) = Value;
}
void
writeDense16(int Value, pointer Base, register unsigned long Offset)
{
write_mem_barrier();
*(volatile CARD16 *)((unsigned long)Base+(Offset)) = Value;
}
void
writeDense32(int Value, pointer Base, register unsigned long Offset)
{
write_mem_barrier();
*(volatile CARD32 *)((unsigned long)Base+(Offset)) = Value;
}
void
_dense_outb(char val, unsigned long port)
{
if ((port & ~0xffff) == 0) return _outb(val, port);
write_mem_barrier();
*(volatile CARD8 *)port = val;
}
void
_dense_outw(short val, unsigned long port)
{
if ((port & ~0xffff) == 0) return _outw(val, port);
write_mem_barrier();
*(volatile CARD16 *)port = val;
}
void
_dense_outl(int val, unsigned long port)
{
if ((port & ~0xffff) == 0) return _outl(val, port);
write_mem_barrier();
*(volatile CARD32 *)port = val;
}
unsigned int
_dense_inb(unsigned long port)
{
if ((port & ~0xffff) == 0) return _inb(port);
mem_barrier();
return *(volatile CARD8 *)port;
}
unsigned int
_dense_inw(unsigned long port)
{
if ((port & ~0xffff) == 0) return _inw(port);
mem_barrier();
return *(volatile CARD16 *)port;
}
unsigned int
_dense_inl(unsigned long port)
{
if ((port & ~0xffff) == 0) return _inl(port);
mem_barrier();
return *(volatile CARD32 *)port;
}