summaryrefslogtreecommitdiffstats
path: root/libdha
diff options
context:
space:
mode:
authoralex <alex@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-01-20 12:12:58 +0000
committeralex <alex@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-01-20 12:12:58 +0000
commit3611dab34d4ab05e30e9ddcdf3e9ad9f8ee7c8c6 (patch)
treef182388743f2d99487b1d46f184e9b7dcb0e0d4e /libdha
parente016034afc0ee81765527ec850759b5902677d7d (diff)
downloadmpv-3611dab34d4ab05e30e9ddcdf3e9ad9f8ee7c8c6.tar.bz2
mpv-3611dab34d4ab05e30e9ddcdf3e9ad9f8ee7c8c6.tar.xz
pci_config_read working
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@4278 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libdha')
-rw-r--r--libdha/libdha.h5
-rw-r--r--libdha/pci.c16
2 files changed, 15 insertions, 6 deletions
diff --git a/libdha/libdha.h b/libdha/libdha.h
index 7456457a70..18c9770ee4 100644
--- a/libdha/libdha.h
+++ b/libdha/libdha.h
@@ -30,11 +30,12 @@ typedef struct pciinfo_s
int bus,card,func; /* PCI/AGP bus:card:func */
unsigned short vendor,device; /* Card vendor+device ID */
unsigned base0,base1,base2,baserom; /* Memory and I/O base addresses */
+// unsigned base0_limit, base1_limit, base2_limit, baserom_limit;
}pciinfo_t;
/* needed for mga_vid */
-extern int pci_config_read(unsigned char bus, unsigned char dev, unsigned char offset,
- int len, unsigned long *val);
+extern int pci_config_read(unsigned char bus, unsigned char dev, unsigned char func,
+ unsigned char cmd, int len, unsigned long *val);
/* Fill array pci_list which must have size MAX_PCI_DEVICES
and return 0 if sucessful */
extern int pci_scan(pciinfo_t *pci_list,unsigned *num_card);
diff --git a/libdha/pci.c b/libdha/pci.c
index 21ee1b749b..2b54bb2ff7 100644
--- a/libdha/pci.c
+++ b/libdha/pci.c
@@ -593,6 +593,7 @@ int pci_scan(pciinfo_t *pci_list,unsigned *num_pci)
pcr._cardnum,func,PCI_INTERRUPT_REG);
pcr._user_config = pci_config_read_long(pcr._pcibuses[pcr._pcibusidx],
pcr._cardnum,func,PCI_REG_USERCONFIG);
+ printf("user_config dword: %x\n", pcr._user_config);
/* check for pci-pci bridges */
#define PCI_CLASS_MASK 0xff000000
#define PCI_SUBCLASS_MASK 0x00ff0000
@@ -707,17 +708,24 @@ int pci_scan(pciinfo_t *pci_list,unsigned *num_pci)
#endif
#endif
-int pci_config_read(unsigned char bus, unsigned char dev,
- unsigned char offset, int len, unsigned long *val)
+int pci_config_read(unsigned char bus, unsigned char dev, unsigned char func,
+ unsigned char cmd, int len, unsigned long *val)
{
+ int ret;
+
if (len != 4)
{
printf("pci_config_read: reading non-dword not supported!\n");
return(ENOTSUP);
}
- *val = pci_config_read_long(bus, dev, offset, 0);
-
+ ret = enable_os_io();
+ if (ret != 0)
+ return(ret);
+ ret = pci_config_read_long(bus, dev, func, cmd);
+ disable_os_io();
+
+ *val = ret;
return(0);
}