X-Git-Url: http://git.joshuawise.com/netwatch.git/blobdiff_plain/d6f56afa7470cf4c29f4f9fa4bf2dd1bd0ba9193..047916ed37a8497d26e5e09345385651feaeebe5:/net/net.c?ds=inline diff --git a/net/net.c b/net/net.c index 18eaddf..04eaff5 100644 --- a/net/net.c +++ b/net/net.c @@ -3,26 +3,51 @@ #include #include "net.h" -struct nic nic; +static struct nic *_nic = 0x0; -static int bother_3c905(pci_dev_t *dev, void *nutrinus) +extern struct pci_driver a3c90x_driver; + +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"); - - pci_bother_add(dev); - 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 (_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!"); }