2007-09-10 12:54:02 +02:00
|
|
|
--- hw/xfree86/os-support/bus/linuxPci.c
|
|
|
|
+++ hw/xfree86/os-support/bus/linuxPci.c
|
|
|
|
@@ -550,7 +550,7 @@ xf86GetPciDomain(PCITAG Tag)
|
|
|
|
return result;
|
2006-12-18 17:55:05 +01:00
|
|
|
|
2006-12-19 17:31:36 +01:00
|
|
|
if (!pPCI || pPCI->fakeDevice)
|
2007-09-10 12:54:02 +02:00
|
|
|
- return 1; /* Domain 0 is reserved */
|
|
|
|
+ return 0;
|
|
|
|
|
|
|
|
if ((fd = linuxPciOpenFile(pPCI ? pPCI->tag : 0,FALSE)) < 0)
|
|
|
|
return 0;
|
|
|
|
@@ -558,7 +558,7 @@ xf86GetPciDomain(PCITAG Tag)
|
|
|
|
if ((result = ioctl(fd, PCIIOC_CONTROLLER, 0)) < 0)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
- return result + 1; /* Domain 0 is reserved */
|
|
|
|
+ return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static pointer
|
|
|
|
@@ -628,7 +628,7 @@ linuxMapPci(int ScreenNum, int Flags, PC
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
-#define MAX_DOMAINS 257
|
|
|
|
+#define MAX_DOMAINS 256
|
|
|
|
static pointer DomainMmappedIO[MAX_DOMAINS];
|
|
|
|
|
|
|
|
static int
|
|
|
|
@@ -649,11 +649,10 @@ linuxOpenLegacy(PCITAG Tag, char *name)
|
|
|
|
domain = xf86GetPciDomain(Tag);
|
|
|
|
bus = PCI_BUS_NO_DOMAIN(PCI_BUS_FROM_TAG(Tag));
|
|
|
|
|
|
|
|
- /* Domain 0 is reserved -- see xf86GetPciDomain() */
|
|
|
|
- if ((domain <= 0) || (domain >= MAX_DOMAINS))
|
|
|
|
+ if ((domain < 0) || (domain >= MAX_DOMAINS))
|
|
|
|
FatalError("linuxOpenLegacy(): domain out of range\n");
|
|
|
|
|
|
|
|
- sprintf(path, PREFIX, domain - 1, bus, name);
|
|
|
|
+ sprintf(path, PREFIX, domain, bus, name);
|
|
|
|
fd = open(path, O_RDWR);
|
|
|
|
if (fd >= 0) {
|
|
|
|
xfree(path);
|
|
|
|
@@ -685,7 +684,6 @@ _X_EXPORT pointer
|
|
|
|
xf86MapDomainMemory(int ScreenNum, int Flags, PCITAG Tag,
|
|
|
|
ADDRESS Base, unsigned long Size)
|
|
|
|
{
|
|
|
|
- int domain = xf86GetPciDomain(Tag);
|
|
|
|
int fd;
|
|
|
|
pointer addr;
|
|
|
|
|
|
|
|
@@ -733,7 +731,7 @@ xf86MapDomainIO(int ScreenNum, int Flags
|
|
|
|
int domain = xf86GetPciDomain(Tag);
|
|
|
|
int fd;
|
|
|
|
|
|
|
|
- if ((domain <= 0) || (domain >= MAX_DOMAINS))
|
|
|
|
+ if ((domain < 0) || (domain >= MAX_DOMAINS))
|
|
|
|
FatalError("xf86MapDomainIO(): domain out of range\n");
|
|
|
|
|
|
|
|
if (DomainMmappedIO[domain])
|