2004-07-08 19:18:27 +02:00
|
|
|
#include <stdio.h>
|
2015-09-28 22:12:04 +02:00
|
|
|
#include "pci-userspace.h"
|
2004-07-08 19:18:27 +02:00
|
|
|
|
2009-05-27 13:39:16 +02:00
|
|
|
#ifdef PCI_LIB_VERSION
|
|
|
|
#define LIBPCI_CHECK_VERSION(major,minor,micro) \
|
|
|
|
((((major) << 16) | ((minor) << 8) | (micro)) <= PCI_LIB_VERSION)
|
|
|
|
#else
|
2005-01-17 12:08:08 +01:00
|
|
|
#define LIBPCI_CHECK_VERSION(major,minor,micro) \
|
|
|
|
( (LIBPCI_MAJOR_VERSION > (major)) || \
|
|
|
|
(LIBPCI_MAJOR_VERSION == (major) && LIBPCI_MINOR_VERSION > (minor)) || \
|
|
|
|
(LIBPCI_MAJOR_VERSION == (major) && LIBPCI_MINOR_VERSION == (minor)) && \
|
|
|
|
LIBPCI_MICRO_VERSION >= (micro) )
|
2009-05-27 13:39:16 +02:00
|
|
|
#endif
|
2005-01-17 12:08:08 +01:00
|
|
|
|
2004-07-08 19:18:27 +02:00
|
|
|
#define PCITAG struct pci_filter *
|
|
|
|
|
|
|
|
#define DEBUG_PCI 1
|
|
|
|
|
|
|
|
struct pci_access *pacc;
|
|
|
|
struct pci_dev *dev;
|
|
|
|
|
|
|
|
struct pci_filter ltag;
|
|
|
|
|
|
|
|
|
|
|
|
int pciNumBuses = 0;
|
|
|
|
|
|
|
|
int pciInit(void)
|
|
|
|
{
|
|
|
|
pacc = pci_alloc();
|
|
|
|
|
|
|
|
pci_init(pacc);
|
|
|
|
pci_scan_bus(pacc);
|
|
|
|
for (dev = pacc->devices; dev; dev = dev->next) {
|
|
|
|
pci_fill_info(dev, PCI_FILL_IDENT | PCI_FILL_BASES);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int pciExit(void)
|
|
|
|
{
|
|
|
|
pci_cleanup(pacc);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
PCITAG findPci(unsigned short bx)
|
|
|
|
{
|
|
|
|
PCITAG tag = <ag;
|
|
|
|
|
|
|
|
int bus = (bx >> 8) & 0xFF;
|
|
|
|
int slot = (bx >> 3) & 0x1F;
|
|
|
|
int func = bx & 0x7;
|
|
|
|
|
|
|
|
tag->bus = bus;
|
|
|
|
tag->slot = slot;
|
|
|
|
tag->func = func;
|
|
|
|
|
2005-01-17 12:08:08 +01:00
|
|
|
#if LIBPCI_CHECK_VERSION(2,1,99)
|
2005-01-11 04:18:39 +01:00
|
|
|
if (pci_get_dev(pacc, 0, bus, slot, func))
|
2005-01-17 12:08:08 +01:00
|
|
|
#else
|
|
|
|
if (pci_get_dev(pacc, bus, slot, func))
|
|
|
|
#endif
|
2004-07-08 19:18:27 +02:00
|
|
|
return tag;
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
u32 pciSlotBX(PCITAG tag)
|
|
|
|
{
|
|
|
|
return (tag->bus << 8) | (tag->slot << 3) | (tag->func);
|
|
|
|
}
|
|
|
|
|
|
|
|
u8 pciReadByte(PCITAG tag, u32 idx)
|
|
|
|
{
|
|
|
|
struct pci_dev *d;
|
2005-01-17 12:08:08 +01:00
|
|
|
#if LIBPCI_CHECK_VERSION(2,1,99)
|
2005-01-11 04:18:39 +01:00
|
|
|
if ((d = pci_get_dev(pacc, 0, tag->bus, tag->slot, tag->func)))
|
2005-01-17 12:08:08 +01:00
|
|
|
#else
|
|
|
|
if ((d = pci_get_dev(pacc, tag->bus, tag->slot, tag->func)))
|
|
|
|
#endif
|
2004-07-08 19:18:27 +02:00
|
|
|
return pci_read_byte(d, idx);
|
|
|
|
#ifdef DEBUG_PCI
|
|
|
|
printf("PCI: device not found while read byte (%x:%x.%x)\n",
|
|
|
|
tag->bus, tag->slot, tag->func);
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
u16 pciReadWord(PCITAG tag, u32 idx)
|
|
|
|
{
|
|
|
|
struct pci_dev *d;
|
2005-01-17 12:08:08 +01:00
|
|
|
#if LIBPCI_CHECK_VERSION(2,1,99)
|
2005-01-11 04:18:39 +01:00
|
|
|
if ((d = pci_get_dev(pacc, 0, tag->bus, tag->slot, tag->func)))
|
2005-01-17 12:08:08 +01:00
|
|
|
#else
|
|
|
|
if ((d = pci_get_dev(pacc, tag->bus, tag->slot, tag->func)))
|
|
|
|
#endif
|
2004-07-08 19:18:27 +02:00
|
|
|
return pci_read_word(d, idx);
|
|
|
|
#ifdef DEBUG_PCI
|
|
|
|
printf("PCI: device not found while read word (%x:%x.%x)\n",
|
|
|
|
tag->bus, tag->slot, tag->func);
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
u32 pciReadLong(PCITAG tag, u32 idx)
|
|
|
|
{
|
|
|
|
struct pci_dev *d;
|
2005-01-17 12:08:08 +01:00
|
|
|
#if LIBPCI_CHECK_VERSION(2,1,99)
|
2005-01-11 04:18:39 +01:00
|
|
|
if ((d = pci_get_dev(pacc, 0, tag->bus, tag->slot, tag->func)))
|
2005-01-17 12:08:08 +01:00
|
|
|
#else
|
|
|
|
if ((d = pci_get_dev(pacc, tag->bus, tag->slot, tag->func)))
|
|
|
|
#endif
|
2004-07-08 19:18:27 +02:00
|
|
|
return pci_read_long(d, idx);
|
|
|
|
#ifdef DEBUG_PCI
|
|
|
|
printf("PCI: device not found while read long (%x:%x.%x)\n",
|
|
|
|
tag->bus, tag->slot, tag->func);
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void pciWriteLong(PCITAG tag, u32 idx, u32 data)
|
|
|
|
{
|
|
|
|
struct pci_dev *d;
|
2005-01-17 12:08:08 +01:00
|
|
|
#if LIBPCI_CHECK_VERSION(2,1,99)
|
2005-01-11 04:18:39 +01:00
|
|
|
if ((d = pci_get_dev(pacc, 0, tag->bus, tag->slot, tag->func)))
|
2005-01-17 12:08:08 +01:00
|
|
|
#else
|
|
|
|
if ((d = pci_get_dev(pacc, tag->bus, tag->slot, tag->func)))
|
|
|
|
#endif
|
2004-07-08 19:18:27 +02:00
|
|
|
pci_write_long(d, idx, data);
|
|
|
|
#ifdef DEBUG_PCI
|
|
|
|
else
|
|
|
|
printf("PCI: device not found while write long (%x:%x.%x)\n",
|
|
|
|
tag->bus, tag->slot, tag->func);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void pciWriteWord(PCITAG tag, u32 idx, u16 data)
|
|
|
|
{
|
|
|
|
struct pci_dev *d;
|
2005-01-17 12:08:08 +01:00
|
|
|
#if LIBPCI_CHECK_VERSION(2,1,99)
|
2005-01-11 04:18:39 +01:00
|
|
|
if ((d = pci_get_dev(pacc, 0, tag->bus, tag->slot, tag->func)))
|
2005-01-17 12:08:08 +01:00
|
|
|
#else
|
|
|
|
if ((d = pci_get_dev(pacc, tag->bus, tag->slot, tag->func)))
|
|
|
|
#endif
|
2004-07-08 19:18:27 +02:00
|
|
|
pci_write_word(d, idx, data);
|
|
|
|
#ifdef DEBUG_PCI
|
|
|
|
else
|
|
|
|
printf("PCI: device not found while write word (%x:%x.%x)\n",
|
|
|
|
tag->bus, tag->slot, tag->func);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void pciWriteByte(PCITAG tag, u32 idx, u8 data)
|
|
|
|
{
|
|
|
|
struct pci_dev *d;
|
2005-01-17 12:08:08 +01:00
|
|
|
#if LIBPCI_CHECK_VERSION(2,1,99)
|
2005-01-11 04:18:39 +01:00
|
|
|
if ((d = pci_get_dev(pacc, 0, tag->bus, tag->slot, tag->func)))
|
2005-01-17 12:08:08 +01:00
|
|
|
#else
|
|
|
|
if ((d = pci_get_dev(pacc, tag->bus, tag->slot, tag->func)))
|
|
|
|
#endif
|
2004-07-08 19:18:27 +02:00
|
|
|
pci_write_long(d, idx, data);
|
|
|
|
#ifdef DEBUG_PCI
|
|
|
|
else
|
|
|
|
printf("PCI: device not found while write long (%x:%x.%x)\n",
|
|
|
|
tag->bus, tag->slot, tag->func);
|
|
|
|
#endif
|
|
|
|
}
|