X-Git-Url: http://git.joshuawise.com/netwatch.git/blobdiff_plain/c61d5f405f2f7fcdcc0a883e18ae7873f4fcd9d7..31ddf9b375ddf1bd142750bc4762b3268e297619:/net/net.c diff --git a/net/net.c b/net/net.c index 7f1932f..04eaff5 100644 --- a/net/net.c +++ b/net/net.c @@ -1,38 +1,53 @@ #include +#include #include #include "net.h" -static int found = 0, _bus, _dev, _fn; +static struct nic *_nic = 0x0; -struct nic nic; +extern struct pci_driver a3c90x_driver; -static int bother_3c905(pci_dev_t *dev, void *nutrinus) +static char test[1024] = {0}; + +void eth_poll() { - if (dev->vid == 0x10B7 || dev->did == 0x9200) + int i; + static int c; + + if (!_nic) + return; + + _nic->poll(_nic, 0); + + if ((c++) % 30) + return; + + for (i = 0; i < 1024; i++) { - outputf("Found a 3c905 to bother"); - - _bus = dev->bus; - _dev = dev->dev; - _fn = dev->fn; - found = 1; - - return 1; + switch(i%5) + { + case 0: test[i] = 'H'; break; + case 1: test[i] = 'A'; break; + case 2: test[i] = 'R'; break; + case 3: test[i] = 'B'; break; + case 4: test[i] = 'L'; break; + } } - return 0; + outputf("eth_poll: Attempting to tx"); + _nic->transmit("\x00\x03\x93\x87\x84\x8C", 0x1337, 1024, test); + outputf("eth_poll: tx complete"); } -void eth_poll() +int eth_register(struct nic *nic) { - if (!found) - return; - - pci_write16(_bus, _dev, _fn, 0x04, 0xFF); - - pci_write16(_bus, _dev, _fn, 0x04, 0x00); + if (_nic) + return -1; + _nic = nic; + return 0; } void eth_init() { - pci_probe(bother_3c905, 0x0); + if (pci_probe_driver(a3c90x_driver)) + outputf("found 3c90x, hopefully!"); }