summaryrefslogtreecommitdiffstats
path: root/sys/dev
diff options
context:
space:
mode:
authorcokane <cokane@FreeBSD.org>2000-08-28 04:28:53 +0000
committercokane <cokane@FreeBSD.org>2000-08-28 04:28:53 +0000
commitc851ea05b476be9ac84f29b54bd98fd69be99560 (patch)
tree653af965e7b682df417a4a10d92addbda6fb6643 /sys/dev
parent4b7e05714e32500ba6e3dd109b293bbf3ae292d2 (diff)
downloadFreeBSD-src-c851ea05b476be9ac84f29b54bd98fd69be99560.zip
FreeBSD-src-c851ea05b476be9ac84f29b54bd98fd69be99560.tar.gz
Removed detection for Voodoo Banshee and Voodoo3 cards. I forsee certain
possible complications with the forthcoming DRI code, and feel that DRI should handle the device-level interaction. Read http://people.FreeBSD.org/~cokane/3dfx.html to find out more. Basically want to move toward using OpenGL and DRI for everything on these cards. Added a few defines and spacing style fixes in tdfx_vars.h
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/tdfx/tdfx_pci.c38
-rw-r--r--sys/dev/tdfx/tdfx_vars.h21
2 files changed, 43 insertions, 16 deletions
diff --git a/sys/dev/tdfx/tdfx_pci.c b/sys/dev/tdfx/tdfx_pci.c
index ba7ff84..6214094 100644
--- a/sys/dev/tdfx/tdfx_pci.c
+++ b/sys/dev/tdfx/tdfx_pci.c
@@ -142,12 +142,12 @@ tdfx_probe(device_t dev)
case PCI_DEVICE_3DFX_VOODOO2:
device_set_desc(dev, "3DFX Voodoo II 3D Accelerator");
return 0;
- case PCI_DEVICE_3DFX_BANSHEE:
+ /*case PCI_DEVICE_3DFX_BANSHEE:
device_set_desc(dev, "3DFX Voodoo Banshee 2D/3D Graphics Accelerator");
return 0;
case PCI_DEVICE_3DFX_VOODOO3:
device_set_desc(dev, "3DFX Voodoo3 2D/3D Graphics Accelerator");
- return 0;
+ return 0;*/
case PCI_DEVICE_3DFX_VOODOO1:
device_set_desc(dev, "3DFX Voodoo Graphics 3D Accelerator");
return 0;;
@@ -238,7 +238,9 @@ tdfx_attach(device_t dev) {
tdfx_info->memrid2 = rid;
}
/* Now to map the PIO stuff */
-/* rid = 0;
+ rid = PCIR_IOBASE0_2;
+ tdfx_info->pio0 = pci_read_config(dev, 0x2c, 2);
+ tdfx_info->pio0max = pci_read_config(dev, 0x30, 2) + tdfx_info->pio0;
tdfx_info->piorange = bus_alloc_resource(dev, SYS_RES_IOPORT, &rid,
0, ~0, 1, RF_ACTIVE | RF_SHAREABLE);
if(tdfx_info->piorange == NULL) {
@@ -249,7 +251,7 @@ tdfx_attach(device_t dev) {
}
else {
tdfx_info->piorid = rid;
- }*/
+ }
} else {
tdfx_info->addr1 = 0;
tdfx_info->memrange2 = NULL;
@@ -544,6 +546,19 @@ tdfx_query_fetch(u_int cmd, struct tdfx_pio_data *piod)
if(piod->size != 4) return -EINVAL;
copyout(&tdfx_info->addr0, piod->value, piod->size);
return 0;
+ case PCI_BASE_ADDRESS_1_FREEBSD:
+ if(piod->size != 4) return -EINVAL;
+ copyout(&tdfx_info->addr1, piod->value, piod->size);
+ return 0;
+ case PCI_PRIBUS_FREEBSD:
+ if(piod->size != 1) return -EINVAL;
+ break;
+ case PCI_IOBASE_0_FREEBSD:
+ if(piod->size != 2) return -EINVAL;
+ break;
+ case PCI_IOLIMIT_0_FREEBSD:
+ if(piod->size != 2) return -EINVAL;
+ break;
case SST1_PCI_SPECIAL1_FREEBSD:
if(piod->size != 4) return -EINVAL;
break;
@@ -672,9 +687,13 @@ tdfx_do_pio_rd(struct tdfx_pio_data *piod)
/* Return val */
u_int8_t ret_byte;
u_int workport;
+ struct tdfx_softc *tdfx_info =
+ (struct tdfx_softc*)devclass_get_softc(tdfx_devclass, piod->device);
+
/* Restricts the access of ports other than those we use */
- if((piod->port != VGA_INPUT_STATUS_1C) || (piod->port != SC_INDEX) ||
- (piod->port != SC_DATA) || (piod->port != VGA_MISC_OUTPUT_READ))
+ if(((piod->port != VGA_INPUT_STATUS_1C) || (piod->port != SC_INDEX) ||
+ (piod->port != SC_DATA) || (piod->port != VGA_MISC_OUTPUT_READ)) &&
+ (piod->port < tdfx_info->pio0) && (piod->port > tdfx_info->pio0max))
return -EPERM;
/* All VGA STATUS REGS are byte registers, size should never be > 1 */
@@ -695,10 +714,13 @@ tdfx_do_pio_wt(struct tdfx_pio_data *piod)
/* return val */
u_int8_t ret_byte;
u_int workport;
+ struct tdfx_softc *tdfx_info = (struct
+ tdfx_softc*)devclass_get_softc(tdfx_devclass, piod->device);
/* Replace old switch w/ massive if(...) */
/* Restricts the access of ports other than those we use */
- if((piod->port != SC_INDEX) && (piod->port != SC_DATA) &&
- (piod->port != VGA_MISC_OUTPUT_READ)) /* Can't write VGA_ST_1C */
+ if(((piod->port != SC_INDEX) && (piod->port != SC_DATA) &&
+ (piod->port != VGA_MISC_OUTPUT_READ)) /* Can't write VGA_ST_1C */ &&
+ (piod->port < tdfx_info->pio0) && (piod->port > tdfx_info->pio0max))
return -EPERM;
/* All VGA STATUS REGS are byte registers, size should never be > 1 */
diff --git a/sys/dev/tdfx/tdfx_vars.h b/sys/dev/tdfx/tdfx_vars.h
index 7af036f..f9a8660 100644
--- a/sys/dev/tdfx/tdfx_vars.h
+++ b/sys/dev/tdfx/tdfx_vars.h
@@ -50,15 +50,19 @@
#define PCI_DEVICE_3DFX_BANSHEE 0x0003121a
#define PCI_DEVICE_3DFX_VOODOO3 0x0005121a
-#define PCI_VENDOR_ID_FREEBSD 0x0
-#define PCI_DEVICE_ID_FREEBSD 0x2
-#define PCI_COMMAND_FREEBSD 0x4
-#define PCI_REVISION_ID_FREEBSD 0x8
+#define PCI_VENDOR_ID_FREEBSD 0x0
+#define PCI_DEVICE_ID_FREEBSD 0x2
+#define PCI_COMMAND_FREEBSD 0x4
+#define PCI_REVISION_ID_FREEBSD 0x8
#define PCI_BASE_ADDRESS_0_FREEBSD 0x10
-#define SST1_PCI_SPECIAL1_FREEBSD 0x40
-#define SST1_PCI_SPECIAL2_FREEBSD 0x44
-#define SST1_PCI_SPECIAL3_FREEBSD 0x48
-#define SST1_PCI_SPECIAL4_FREEBSD 0x54
+#define PCI_BASE_ADDRESS_1_FREEBSD 0x14
+#define PCI_PRIBUS_FREEBSD 0x18
+#define PCI_IOBASE_0_FREEBSD 0x2c
+#define PCI_IOLIMIT_0_FREEBSD 0x30
+#define SST1_PCI_SPECIAL1_FREEBSD 0x40
+#define SST1_PCI_SPECIAL2_FREEBSD 0x44
+#define SST1_PCI_SPECIAL3_FREEBSD 0x48
+#define SST1_PCI_SPECIAL4_FREEBSD 0x54
#define VGA_INPUT_STATUS_1C 0x3DA
#define VGA_MISC_OUTPUT_READ 0x3cc
@@ -85,6 +89,7 @@ struct tdfx_softc {
int vendor;
int type;
int addr0, addr1;
+ short pio0, pio0max;
unsigned char bus;
unsigned char dv;
struct file *curFile;
OpenPOWER on IntegriCloud