tech-x11 archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
xf86-video-sis changes for mips
[ I'm not subscribed to tech-x11, so please keep either me or port-mips in Cc ]
Hello,
attached is a change against the netbsd-6 xf86-video-sis, which allows me
to run X11 accelerated on a lemote fuloong.
This device has a loongson2 CPU and uses a sis 315Pro as graphic controller.
But here the controller is not in VGA-compatible mode but in framebuffer
mode. We have sisfb(4) in our kernel to use it as text console.
Recently I added support to sisfb(4) for wsfb (this was easy), and
also got xf86-video-sis working (which gives us highter resolutions,
support for the second video output, etc ...). For this, I added
support to sisfb to mmap the video memory, but also the I/O and memory-mapped
registers. The attached patch changes xf86-video-sis to use the services
provided by sisfb for registers access (I couldn't get it working
using the libpciaccess, because our pci(4) doesn't support mmap'ing the
I/O space, and chaning this would be quite intrusive).
Would anyone see a problem with this approach ? I don't think xf86-video-sis
has ever worked on mips hardware on NetBSD so this shouldn't break anything ...
--
Manuel Bouyer <bouyer%antioche.eu.org@localhost>
NetBSD: 26 ans d'experience feront toujours la difference
--
Index: xf86-video-sis/dist/src/sis.h
===================================================================
RCS file: /cvsroot/xsrc/external/mit/xf86-video-sis/dist/src/sis.h,v
retrieving revision 1.1.1.3
diff -u -p -u -r1.1.1.3 sis.h
--- xf86-video-sis/dist/src/sis.h 22 Aug 2009 00:04:41 -0000 1.1.1.3
+++ xf86-video-sis/dist/src/sis.h 26 Jan 2014 21:26:49 -0000
@@ -149,7 +149,7 @@
/* List of architectures likely to be incomplete */
/* This is BROKEN, see comment in sis_driver.c */
#undef SIS_NEED_MAP_IOP
-#if 0
+#if defined(__NetBSD__)
#if defined(__arm32__) || defined(__mips__)
#define SIS_NEED_MAP_IOP
#endif
Index: xf86-video-sis/dist/src/sis_driver.c
===================================================================
RCS file: /cvsroot/xsrc/external/mit/xf86-video-sis/dist/src/sis_driver.c,v
retrieving revision 1.1.1.4
diff -u -p -u -r1.1.1.4 sis_driver.c
--- xf86-video-sis/dist/src/sis_driver.c 17 Jul 2010 06:32:06 -0000
1.1.1.4
+++ xf86-video-sis/dist/src/sis_driver.c 26 Jan 2014 21:26:49 -0000
@@ -118,6 +118,10 @@ static int SiSSProcXineramaDispatch(Clie
#endif
#endif
+#if defined(__NetBSD__) && defined(__mips__)
+#define SIS_USEMAPVIDMEM
+#endif
+
/*
* This is intentionally screen-independent. It indicates the binding
* choice made in the first PreInit.
@@ -3271,16 +3275,16 @@ SISPreInit(ScrnInfoPtr pScrn, int flags)
/* we have our own vgaHW routines. However, */
/* we use /dev/port for now instead.) */
/********************************************/
- pSiS->IOPAddress = pSiS->IODBase + pSiS->PciInfo->ioBase[2];
+ pSiS->IOPAddress = pSiS->IODBase + PCI_REGION_BASE(pSiS->PciInfo, 2,
REGION_IO);
if(!SISMapIOPMem(pScrn)) {
SISErrorLog(pScrn, "Could not map I/O port area at 0x%x\n",
pSiS->IOPAddress);
goto my_error_0;
} else {
- xf86DrvMsg(pScrn->scrnIndex, X_INFO, "I/O port area mapped to %p, size
128\n", pSiS->IOPBase);
+ xf86DrvMsg(pScrn->scrnIndex, X_INFO, "I/O port area 0x%x mapped to %p,
size 128\n", pSiS->IOPAddress, pSiS->IOPBase);
#if defined(__mips__) || defined(__arm32__)
/* inX/outX macros on these use IOPortBase as offset */
/* This is entirely skrewed. */
- IOPortBase = (unsigned int)pSiS->IOPBase;
+ IOPortBase = (unsigned int)pSiS->IOPBase - pSiS->IOPAddress;
#endif
}
#endif
@@ -7011,7 +7015,10 @@ SISMapIOPMem(ScrnInfoPtr pScrn)
pSiSEnt->MapCountIOPBase++;
if(!(pSiSEnt->IOPBase)) {
/* Only map if not mapped previously */
-#ifndef XSERVER_LIBPCIACCESS
+#ifdef SIS_USEMAPVIDMEM
+ pSiSEnt->IOPBase = xf86MapVidMem(pScrn->scrnIndex, VIDMEM_MMIO,
+ pSiS->IOPAddress, 128);
+#elif !defined(XSERVER_LIBPCIACCESS)
pSiSEnt->IOPBase = xf86MapPciMem(pScrn->scrnIndex, VIDMEM_MMIO,
pSiS->PciTag, pSiS->IOPAddress, 128);
#else
@@ -7034,7 +7041,10 @@ SISMapIOPMem(ScrnInfoPtr pScrn)
pSiS->IOPBase = pSiSEnt->IOPBase;
} else
#endif
-#ifndef XSERVER_LIBPCIACCESS
+#ifdef SIS_USEMAPVIDMEM
+ pSiS->IOPBase = xf86MapVidMem(pScrn->scrnIndex, VIDMEM_MMIO,
+ pSiS->IOPAddress, 128);
+#elif !defined(XSERVER_LIBPCIACCESS)
pSiS->IOPBase = xf86MapPciMem(pScrn->scrnIndex, VIDMEM_MMIO,
pSiS->PciTag, pSiS->IOPAddress, 128);
#else
@@ -7122,7 +7132,10 @@ SISMapMem(ScrnInfoPtr pScrn)
pSiSEnt->MapCountIOBase++;
if(!(pSiSEnt->IOBase)) {
/* Only map if not mapped previously */
-#ifndef XSERVER_LIBPCIACCESS
+#ifdef SIS_USEMAPVIDMEM
+ pSiSEnt->IOBase = xf86MapVidMem(pScrn->scrnIndex, mmioFlags,
+ pSiS->IOAddress, (pSiS->mmioSize * 1024));
+#elif !defined(XSERVER_LIBPCIACCESS)
pSiSEnt->IOBase = xf86MapPciMem(pScrn->scrnIndex, mmioFlags,
pSiS->PciTag, pSiS->IOAddress, (pSiS->mmioSize *
1024));
#else
@@ -7143,7 +7156,10 @@ SISMapMem(ScrnInfoPtr pScrn)
pSiS->IOBase = pSiSEnt->IOBase;
} else
#endif
-#ifndef XSERVER_LIBPCIACCESS
+#ifdef SIS_USEMAPVIDMEM
+ pSiS->IOBase = xf86MapVidMem(pScrn->scrnIndex, mmioFlags,
+ pSiS->IOAddress, (pSiS->mmioSize * 1024));
+#elif !defined(XSERVER_LIBPCIACCESS)
pSiS->IOBase = xf86MapPciMem(pScrn->scrnIndex, mmioFlags,
pSiS->PciTag, pSiS->IOAddress, (pSiS->mmioSize *
1024));
#else
@@ -7178,7 +7194,10 @@ SISMapMem(ScrnInfoPtr pScrn)
pSiSEnt->MapCountIOBaseDense++;
if(!(pSiSEnt->IOBaseDense)) {
/* Only map if not mapped previously */
-#ifndef XSERVER_LIBPCIACCESS
+#ifdef SIS_USEMAPVIDMEM
+ pSiSEnt->IOBaseDense = xf86MapVidMem(pScrn->scrnIndex, VIDMEM_MMIO,
+ pSiS->IOAddress, (pSiS->mmioSize * 1024));
+#elif !defined(XSERVER_LIBPCIACCESS)
pSiSEnt->IOBaseDense = xf86MapPciMem(pScrn->scrnIndex, VIDMEM_MMIO,
pSiS->PciTag, pSiS->IOAddress, (pSiS->mmioSize * 1024));
#else
@@ -7199,7 +7218,10 @@ SISMapMem(ScrnInfoPtr pScrn)
pSiS->IOBaseDense = pSiSEnt->IOBaseDense;
} else {
#endif /* SISDUALHEAD */
-#ifndef XSERVER_LIBPCIACCESS
+#ifdef SIS_USEMAPVIDMEM
+ pSiS->IOBaseDense = xf86MapVidMem(pScrn->scrnIndex, VIDMEM_MMIO,
+ pSiS->IOAddress, (pSiS->mmioSize * 1024));
+#elif !defined(XSERVER_LIBPCIACCESS)
pSiS->IOBaseDense = xf86MapPciMem(pScrn->scrnIndex, VIDMEM_MMIO,
pSiS->PciTag, pSiS->IOAddress, (pSiS->mmioSize * 1024));
#else
@@ -7230,7 +7252,11 @@ SISMapMem(ScrnInfoPtr pScrn)
pSiSEnt->MapCountFbBase++;
if(!(pSiSEnt->FbBase)) {
/* Only map if not mapped previously */
-#ifndef XSERVER_LIBPCIACCESS
+#ifdef SIS_USEMAPVIDMEM
+ pSiSEnt->FbBase = pSiSEnt->RealFbBase =
+ xf86MapVidMem(pScrn->scrnIndex, VIDMEM_FRAMEBUFFER,
+ pSiS->realFbAddress, pSiS->FbMapSize);
+#elif !defined(XSERVER_LIBPCIACCESS)
pSiSEnt->FbBase = pSiSEnt->RealFbBase =
xf86MapPciMem(pScrn->scrnIndex, VIDMEM_FRAMEBUFFER,
pSiS->PciTag, (ULong)pSiS->realFbAddress,
@@ -7257,7 +7283,11 @@ SISMapMem(ScrnInfoPtr pScrn)
} else {
#endif
-#ifndef XSERVER_LIBPCIACCESS
+#ifdef SIS_USEMAPVIDMEM
+ pSiS->FbBase = pSiS->RealFbBase =
+ xf86MapVidMem(pScrn->scrnIndex, VIDMEM_FRAMEBUFFER,
+ pSiS->realFbAddress, pSiS->FbMapSize);
+#elif !defined(XSERVER_LIBPCIACCESS)
pSiS->FbBase = pSiS->RealFbBase =
xf86MapPciMem(pScrn->scrnIndex, VIDMEM_FRAMEBUFFER,
pSiS->PciTag, (ULong)pSiS->realFbAddress,
Home |
Main Index |
Thread Index |
Old Index