X-Git-Url: http://git.joshuawise.com/netwatch.git/blobdiff_plain/d6f56afa7470cf4c29f4f9fa4bf2dd1bd0ba9193..c25f3f39d2a544a91a8a96ea90bda1dc1d77b76a:/net/net.c diff --git a/net/net.c b/net/net.c index 18eaddf..01b4521 100644 --- a/net/net.c +++ b/net/net.c @@ -3,26 +3,50 @@ #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; + _nic->transmit("\x00\x03\x93\x87\x84\x8C", 0x1337, 1024, test); } -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); + /* Required for DMA to work. :( */ + smram_tseg_set_state(SMRAM_TSEG_OPEN); + pci_probe_driver(a3c90x_driver); }