2007-11-24 10:55:21 -07:00
|
|
|
/* This file has to be built with -mcpu=ev56 */
|
2006-11-26 11:13:41 -07:00
|
|
|
#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;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef INCLUDE_XF86_NO_DOMAIN
|
|
|
|
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* !INCLUDE_XF86_NO_DOMAIN */
|
|
|
|
|