#include <output.h>
#include "vga-overlay.h"
#include <smram.h>
+#include "3c905.h"
extern int _bss, _bssend;
extern void kbc_handler(smi_event_t ev);
extern void gbl_rls_handler(smi_event_t ev);
-static int found = 0, _bus, _dev, _fn;
-
-void do_bother()
-{
- int bar;
-
- if (!found)
- return;
-
- pci_write16(_bus, _dev, _fn, 0x04, 0x00);
- for (bar = 0; bar < 6; bar++)
- pci_write32(_bus, _dev, _fn, 0x10 + bar*4, 0x1FFFFFFF);
-}
-
-int bother_3c905(pci_dev_t *dev)
-{
- if (dev->vid == 0x10B7 || dev->did == 0x9200)
- {
- outputf("Found a 3c905 to bother");
-
- _bus = dev->bus;
- _dev = dev->dev;
- _fn = dev->fn;
- found = 1;
-
- do_bother();
-
- return 1;
- }
- return 0;
-}
-
void __firstrun_start() {
unsigned char *bp;
smram_state_t smram;
/* Turn on the SMIs we want */
smi_disable();
- pci_probe(bother_3c905);
+ eth_init();
smi_register_handler(SMI_EVENT_FAST_TIMER, timer_handler);
smi_enable_event(SMI_EVENT_FAST_TIMER);
#include <pci.h>
#include <output.h>
-int pci_probe(pci_probe_fn_t probe)
+int pci_probe(pci_probe_fn_t probe, void *data)
{
int devsfound = 0;
pci_dev_t pdev;
for (bus = 0; bus < 0x100; bus++)
for (dev = 0; dev < 0x20; dev++)
- if (pci_read32(bus, dev, 0, 0) != 0xFFFFFFFF)
- for (fn = 0; fn < 8; fn++)
+ {
+ if (pci_read32(bus, dev, 0, 0) == 0xFFFFFFFF)
+ continue;
+ for (fn = 0; fn < 8; fn++)
+ {
+ int bar;
+
+ if (pci_read32(bus, dev, fn, 0) == 0xFFFFFFFF)
+ continue;
+
+ if ((fn != 0) && !(pci_read8(bus, dev, 0, 0x0E) & 0x80))
+ continue;
+
+ pdev.bus = bus;
+ pdev.dev = dev;
+ pdev.fn = fn;
+ pdev.vid = pci_read16(bus, dev, fn, 0);
+ pdev.did = pci_read16(bus, dev, fn, 2);
+
+ for (bar = 0; bar < 6; bar++)
{
- int bar;
-
- if (pci_read32(bus, dev, fn, 0) == 0xFFFFFFFF)
- continue;
-
- if ((fn != 0) && !(pci_read8(bus, dev, 0, 0x0E) & 0x80))
+ unsigned long bardat = pci_read32(bus, dev, fn, 0x10 + bar*4);
+ if (bardat == 0)
+ {
+ pdev.bars[bar].type = PCI_BAR_NONE;
continue;
-
- pdev.bus = bus;
- pdev.dev = dev;
- pdev.fn = fn;
- pdev.vid = pci_read16(bus, dev, fn, 0);
- pdev.did = pci_read16(bus, dev, fn, 2);
-
- for (bar = 0; bar < 6; bar++)
+ }
+ if (bardat & 1)
{
- unsigned long bardat = pci_read32(bus, dev, fn, 0x10 + bar*4);
- if (bardat == 0)
+ pdev.bars[bar].type = PCI_BAR_IO;
+ pdev.bars[bar].addr = bardat & ~0x3;
+ } else {
+ pdev.bars[bar].prefetchable = (bardat >> 3) & 1;
+ switch ((bardat >> 1) & 0x3)
{
+ case 0:
+ pdev.bars[bar].type = PCI_BAR_MEMORY32;
+ pdev.bars[bar].addr = bardat & ~0xF;
+ break;
+ case 2:
+ pdev.bars[bar].type = PCI_BAR_MEMORY64;
+ bar++;
+ pdev.bars[bar].type = PCI_BAR_NONE;
+ break;
+ default:
pdev.bars[bar].type = PCI_BAR_NONE;
continue;
}
- if (bardat & 1)
- {
- pdev.bars[bar].type = PCI_BAR_IO;
- pdev.bars[bar].addr = bardat & ~0x3;
- } else {
- pdev.bars[bar].prefetchable = (bardat >> 3) & 1;
- switch ((bardat >> 1) & 0x3)
- {
- case 0:
- pdev.bars[bar].type = PCI_BAR_MEMORY32;
- pdev.bars[bar].addr = bardat & ~0xF;
- break;
- case 2:
- pdev.bars[bar].type = PCI_BAR_MEMORY64;
- bar++;
- pdev.bars[bar].type = PCI_BAR_NONE;
- break;
- default:
- pdev.bars[bar].type = PCI_BAR_NONE;
- continue;
- }
- }
}
-
- devsfound += probe(&pdev);
}
+
+ devsfound += probe(&pdev, data);
+ }
+ }
return devsfound;
}
-static int _enumfn(pci_dev_t *pdev)
+static int _enumfn(pci_dev_t *pdev, void *data)
{
int bar;
void pci_bus_enum()
{
- pci_probe(_enumfn);
+ pci_probe(_enumfn, 0x0);
}
+static int _probefn(pci_dev_t *dev, void *d)
+{
+ pci_driver_t *driver = d;
+ int i;
+
+ for (i = 0; i < driver->id_count; i++)
+ if ((dev->vid == driver->ids[i].vid) && (dev->did == driver->ids[i].did))
+ {
+ outputf("Probing PCI device: %s (%s)", driver->ids[i].name ? driver->ids[i].name : driver->name, driver->ids[i].friendlyname ? driver->ids[i].friendlyname : "no friendly name");
+ return driver->probe(dev, d);
+ }
+ return 0;
+}
+
+int pci_probe_driver(pci_driver_t driver)
+{
+ return pci_probe(_probefn, &driver);
+}