2009-09-28 04:20:03 +02:00
|
|
|
/*******************************************************************************
|
|
|
|
for Alpha Linux
|
|
|
|
*******************************************************************************/
|
|
|
|
|
2003-11-14 17:48:57 +01:00
|
|
|
/*
|
|
|
|
* Create a dependency that should be immune from the effect of register
|
|
|
|
* renaming as is commonly seen in superscalar processors. This should
|
|
|
|
* insert a minimum of 100-ns delays between reads/writes at clock rates
|
|
|
|
* up to 100 MHz---GGL
|
2009-09-28 04:20:03 +02:00
|
|
|
*
|
|
|
|
* Slowbcopy(char *src, char *dst, int count)
|
|
|
|
*
|
2003-11-14 17:48:57 +01:00
|
|
|
*/
|
|
|
|
|
2005-07-03 09:02:09 +02:00
|
|
|
#ifdef HAVE_XORG_CONFIG_H
|
|
|
|
#include <xorg-config.h>
|
|
|
|
#endif
|
|
|
|
|
2005-04-20 14:25:48 +02:00
|
|
|
#include <X11/X.h>
|
2003-11-14 17:48:57 +01:00
|
|
|
#include "xf86.h"
|
|
|
|
#include "xf86Priv.h"
|
|
|
|
#include "xf86_OSlib.h"
|
|
|
|
#include "compiler.h"
|
|
|
|
|
2007-08-02 02:50:01 +02:00
|
|
|
static int really_slow_bcopy;
|
|
|
|
|
Rework symbol visibility for easier maintenance
Save in a few special cases, _X_EXPORT should not be used in C source
files. Instead, it should be used in headers, and the proper C source
include that header. Some special cases are symbols that need to be
shared between modules, but not expected to be used by external drivers,
and symbols that are accessible via LoaderSymbol/dlopen.
This patch also adds conditionally some new sdk header files, depending
on extensions enabled. These files were added to match pattern for
other extensions/modules, that is, have the headers "deciding" symbol
visibility in the sdk. These headers are:
o Xext/panoramiXsrv.h, Xext/panoramiX.h
o fbpict.h (unconditionally)
o vidmodeproc.h
o mioverlay.h (unconditionally, used only by xaa)
o xfixes.h (unconditionally, symbols required by dri2)
LoaderSymbol and similar functions now don't have different prototypes,
in loaderProcs.h and xf86Module.h, so that both headers can be included,
without the need of defining IN_LOADER.
xf86NewInputDevice() device prototype readded to xf86Xinput.h, but
not exported (and with a comment about it).
2008-12-03 08:43:34 +01:00
|
|
|
void
|
2007-08-02 02:50:01 +02:00
|
|
|
xf86SetReallySlowBcopy(void)
|
|
|
|
{
|
|
|
|
really_slow_bcopy = 1;
|
|
|
|
}
|
|
|
|
|
2008-06-24 20:37:06 +02:00
|
|
|
#if defined(__i386__) || defined(__amd64__)
|
2007-08-02 02:50:01 +02:00
|
|
|
static void xf86_really_slow_bcopy(unsigned char *src, unsigned char *dst, int len)
|
2003-11-14 17:48:57 +01:00
|
|
|
{
|
|
|
|
while(len--)
|
|
|
|
{
|
|
|
|
*dst++ = *src++;
|
|
|
|
outb(0x80, 0x00);
|
2007-08-02 02:50:01 +02:00
|
|
|
}
|
|
|
|
}
|
2003-11-14 17:48:57 +01:00
|
|
|
#endif
|
2007-08-02 02:50:01 +02:00
|
|
|
|
|
|
|
/* The outb() isn't needed on my machine, but who knows ... -- ost */
|
Rework symbol visibility for easier maintenance
Save in a few special cases, _X_EXPORT should not be used in C source
files. Instead, it should be used in headers, and the proper C source
include that header. Some special cases are symbols that need to be
shared between modules, but not expected to be used by external drivers,
and symbols that are accessible via LoaderSymbol/dlopen.
This patch also adds conditionally some new sdk header files, depending
on extensions enabled. These files were added to match pattern for
other extensions/modules, that is, have the headers "deciding" symbol
visibility in the sdk. These headers are:
o Xext/panoramiXsrv.h, Xext/panoramiX.h
o fbpict.h (unconditionally)
o vidmodeproc.h
o mioverlay.h (unconditionally, used only by xaa)
o xfixes.h (unconditionally, symbols required by dri2)
LoaderSymbol and similar functions now don't have different prototypes,
in loaderProcs.h and xf86Module.h, so that both headers can be included,
without the need of defining IN_LOADER.
xf86NewInputDevice() device prototype readded to xf86Xinput.h, but
not exported (and with a comment about it).
2008-12-03 08:43:34 +01:00
|
|
|
void
|
2007-08-02 02:50:01 +02:00
|
|
|
xf86SlowBcopy(unsigned char *src, unsigned char *dst, int len)
|
|
|
|
{
|
2008-06-24 20:37:06 +02:00
|
|
|
#if defined(__i386__) || defined(__amd64__)
|
2007-08-02 02:50:01 +02:00
|
|
|
if (really_slow_bcopy) {
|
|
|
|
xf86_really_slow_bcopy(src, dst, len);
|
|
|
|
return;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
2007-08-02 02:50:01 +02:00
|
|
|
#endif
|
|
|
|
while(len--)
|
|
|
|
*dst++ = *src++;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
2009-09-28 04:20:03 +02:00
|
|
|
|
|
|
|
#ifdef __alpha__
|
|
|
|
|
|
|
|
#ifdef linux
|
|
|
|
|
2009-10-07 02:58:30 +02:00
|
|
|
unsigned long _bus_base(void);
|
|
|
|
|
|
|
|
#define useSparse() (!_bus_base())
|
|
|
|
|
2009-09-28 04:20:03 +02:00
|
|
|
#define SPARSE (7)
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
2009-10-07 02:58:30 +02:00
|
|
|
#define useSparse() 0
|
|
|
|
|
2009-09-28 04:20:03 +02:00
|
|
|
#define SPARSE 0
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void
|
|
|
|
xf86SlowBCopyFromBus(unsigned char *src, unsigned char *dst, int count)
|
|
|
|
{
|
2009-10-07 02:58:30 +02:00
|
|
|
if (useSparse())
|
|
|
|
{
|
|
|
|
unsigned long addr;
|
|
|
|
long result;
|
|
|
|
|
|
|
|
addr = (unsigned long) src;
|
|
|
|
while (count) {
|
|
|
|
result = *(volatile int *) addr;
|
|
|
|
result >>= ((addr>>SPARSE) & 3) * 8;
|
|
|
|
*dst++ = (unsigned char) (0xffUL & result);
|
|
|
|
addr += 1<<SPARSE;
|
|
|
|
count--;
|
|
|
|
outb(0x80, 0x00);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
xf86SlowBcopy(src, dst, count);
|
2009-09-28 04:20:03 +02:00
|
|
|
}
|
2009-10-07 02:58:30 +02:00
|
|
|
|
2009-09-28 04:20:03 +02:00
|
|
|
void
|
|
|
|
xf86SlowBCopyToBus(unsigned char *src, unsigned char *dst, int count)
|
|
|
|
{
|
2009-10-07 02:58:30 +02:00
|
|
|
if (useSparse())
|
|
|
|
{
|
|
|
|
unsigned long addr;
|
|
|
|
|
|
|
|
addr = (unsigned long) dst;
|
|
|
|
while (count) {
|
|
|
|
*(volatile unsigned int *) addr = (unsigned short)(*src) * 0x01010101;
|
|
|
|
src++;
|
|
|
|
addr += 1<<SPARSE;
|
|
|
|
count--;
|
|
|
|
outb(0x80, 0x00);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
xf86SlowBcopy(src, dst, count);
|
2009-09-28 04:20:03 +02:00
|
|
|
}
|
|
|
|
#endif
|