## diffname pc/etherec2t.c 2000/0524 ## diff -e /dev/null /n/emeliedump/2000/0524/sys/src/9/pc/etherec2t.c 0a /* * Linksys Combo PCMCIA EthernetCard (EC2T). * Supposedly an NE2000 clone, see the comments in ether2000.c */ #include "u.h" #include "../port/lib.h" #include "mem.h" #include "dat.h" #include "fns.h" #include "io.h" #include "../port/error.h" #include "../port/netif.h" #include "etherif.h" #include "ether8390.h" enum { Data = 0x10, /* offset from I/O base of data port */ Reset = 0x1F, /* offset from I/O base of reset port */ }; static int reset(Ether* ether) { ushort buf[16]; ulong port; Dp8390 *ctlr; int i, slot; uchar ea[Eaddrlen]; /* * Set up the software configuration. * Use defaults for port, irq, mem and size * if not specified. * The manual says 16KB memory, the box * says 32KB. The manual seems to be correct. */ if(ether->port == 0) ether->port = 0x300; if(ether->irq == 0) ether->irq = 9; if(ether->mem == 0) ether->mem = 0x4000; if(ether->size == 0) ether->size = 16*1024; port = ether->port; if(ioalloc(ether->port, 0x20, 0, "ec2t") < 0) return -1; if((slot = pcmspecial(ether->type, ether)) < 0){ iofree(port); return -1; } ether->ctlr = malloc(sizeof(Dp8390)); ctlr = ether->ctlr; ctlr->width = 2; ctlr->ram = 0; ctlr->port = port; ctlr->data = port+Data; ctlr->tstart = HOWMANY(ether->mem, Dp8390BufSz); ctlr->pstart = ctlr->tstart + HOWMANY(sizeof(Etherpkt), Dp8390BufSz); ctlr->pstop = ctlr->tstart + HOWMANY(ether->size, Dp8390BufSz); ctlr->dummyrr = 1; for(i = 0; i < ether->nopt; i++){ if(strcmp(ether->opt[i], "nodummyrr")) continue; ctlr->dummyrr = 0; break; } /* * Reset the board. This is done by doing a read * followed by a write to the Reset address. */ buf[0] = inb(port+Reset); delay(2); outb(port+Reset, buf[0]); delay(2); /* * Init the (possible) chip, then use the (possible) * chip to read the (possible) PROM for ethernet address * and a marker byte. * Could just look at the DP8390 command register after * initialisation has been tried, but that wouldn't be * enough, there are other ethernet boards which could * match. */ dp8390reset(ether); memset(buf, 0, sizeof(buf)); dp8390read(ctlr, buf, 0, sizeof(buf)); if((buf[0x0E] & 0xFF) != 0x57 || (buf[0x0F] & 0xFF) != 0x57){ pcmspecialclose(slot); iofree(ether->port); free(ether->ctlr); return -1; } /* * Stupid machine. Shorts were asked for, * shorts were delivered, although the PROM is a byte array. * Set the ethernet address. */ memset(ea, 0, Eaddrlen); if(memcmp(ea, ether->ea, Eaddrlen) == 0){ for(i = 0; i < sizeof(ether->ea); i++) ether->ea[i] = buf[i]; } dp8390setea(ether); return 0; } void etherec2tlink(void) { addethercard("EC2T", reset); } . ## diffname pc/etherec2t.c 2000/0604 ## diff -e /n/emeliedump/2000/0524/sys/src/9/pc/etherec2t.c /n/emeliedump/2000/0604/sys/src/9/pc/etherec2t.c 93,95c sum = 0; if(strcmp(type, "PCMPC100")){ memset(buf, 0, sizeof(buf)); dp8390read(ctlr, buf, 0, sizeof(buf)); if((buf[0x0E] & 0xFF) == 0x57 && (buf[0x0F] & 0xFF) == 0x57) sum = 0xFF; } else{ /* * The PCMPC100 has the ethernet address in I/O space. * There's a checksum over 8 bytes which sums to 0xFF. */ for(i = 0; i < 8; i++){ x = inb(port+0x14+i); sum += x; buf[i] = (x<<8)|x; } } if(sum != 0xFF){ . 82c . 49c slot = -1; type = nil; for(i = 0; ec2tpcmcia[i] != nil; i++){ type = ec2tpcmcia[i]; if((slot = pcmspecial(type, ether)) >= 0) break; } if(slot < 0){ . 28c uchar ea[Eaddrlen], sum, x; char *type; . 20a static char* ec2tpcmcia[] = { "EC2T", "PCMPC100", nil, }; . 15a . 2,3c * Linksys Combo PCMCIA EthernetCard (EC2T) * and EtherFast 10/100 PC Card (PCMPC100). * Supposedly NE2000 clones, see the comments in ether2000.c . ## diffname pc/etherec2t.c 2000/0605 ## diff -e /n/emeliedump/2000/0604/sys/src/9/pc/etherec2t.c /n/emeliedump/2000/0605/sys/src/9/pc/etherec2t.c 82,88c ctlr->dummyrr = 0; . ## diffname pc/etherec2t.c 2000/0615 ## diff -e /n/emeliedump/2000/0605/sys/src/9/pc/etherec2t.c /n/emeliedump/2000/0615/sys/src/9/pc/etherec2t.c 119a } else{ memset(buf, 0, sizeof(buf)); dp8390read(ctlr, buf, 0, sizeof(buf)); if((buf[0x0E] & 0xFF) == 0x57 && (buf[0x0F] & 0xFF) == 0x57) sum = 0xFF; . 104,110c if(cistrcmp(type, "PCMPC100") == 0){ . 82a for(i = 0; i < ether->nopt; i++){ if(cistrcmp(ether->opt[i], "nodummyrr") == 0) ctlr->dummyrr = 0; else if(cistrncmp(ether->opt[i], "dummyrr=", 8) == 0) ctlr->dummyrr = strtol(ðer->opt[i][8], nil, 0); } . 64a if(ec2tpcmcia[i] == nil){ for(i = 0; i < ether->nopt; i++){ if(cistrncmp(ether->opt[i], "id=", 3)) continue; type = ðer->opt[i][3]; if((slot = pcmspecial(type, ether)) >= 0) break; } } . 24,25c "EC2T", /* Linksys Combo PCMCIA EthernetCard */ "PCMPC100", /* EtherFast 10/100 PC Card */ "EN2216", /* Accton EtherPair-PCMCIA */ . 2,4c * Supposed NE2000 PCMCIA clones, see the comments in ether2000.c . ## diffname pc/etherec2t.c 2000/0825 ## diff -e /n/emeliedump/2000/0615/sys/src/9/pc/etherec2t.c /n/emeliedump/2000/0825/sys/src/9/pc/etherec2t.c 118c if(cistrcmp(type, "PCMPC100") == 0 || cistrcmp(type, "FA410TX") == 0){ . 24a "FA410TX", /* Netgear FA410TX */ . ## diffname pc/etherec2t.c 2001/0503 ## diff -e /n/emeliedump/2000/0825/sys/src/9/pc/etherec2t.c /n/emeliedump/2001/0503/sys/src/9/pc/etherec2t.c 121c * These NICs have the ethernet address in I/O space. . 119c if(cistrcmp(type, "PCMPC100") == 0 || cistrcmp(type, "PCM100") == 0 || cistrcmp(type, "FA410TX") == 0){ . 23a "PCM100", /* EtherFast 10/100 Integrated PC Card */ . ## diffname pc/etherec2t.c 2001/0527 ## diff -e /n/emeliedump/2001/0503/sys/src/9/pc/etherec2t.c /n/emeliedump/2001/0527/sys/src/9/pc/etherec2t.c 122c * The PCMPC100 has the ethernet address in I/O space. . 120c if(cistrcmp(type, "PCMPC100") == 0 || cistrcmp(type, "FA410TX") == 0){ . 24d ## diffname pc/etherec2t.c 2001/0726 ## diff -e /n/emeliedump/2001/0527/sys/src/9/pc/etherec2t.c /n/emeliedump/2001/0726/sys/src/9/pc/etherec2t.c 25a "Network Everywhere", /* Linksys NP10T 10BaseT Card */ . ## diffname pc/etherec2t.c 2001/1005 ## diff -e /n/emeliedump/2001/0726/sys/src/9/pc/etherec2t.c /n/emeliedump/2001/1005/sys/src/9/pc/etherec2t.c 122c * These cards have the ethernet address in I/O space. . 120c if(ec2t->iochecksum){ . 68,72c if(cistrncmp(ether->opt[i], "id=", 3) == 0){ ec2t->name = ðer->opt[i][3]; slot = pcmspecial(ec2t->name, ether); } else if(cistrncmp(ether->opt[i], "iochecksum", 10) == 0) ec2t->iochecksum = 1; . 66c if(ec2t->name == nil){ ec2t = &tmpec2t; ec2t->name = nil; ec2t->iochecksum = 0; . 60,63c for(ec2t = ec2tpcmcia; ec2t->name != nil; ec2t++){ if((slot = pcmspecial(ec2t->name, ether)) >= 0) . 38c Ec2t *ec2t, tmpec2t; . 21,27c typedef struct Ec2t { char* name; int iochecksum; } Ec2t; static Ec2t ec2tpcmcia[] = { { "EC2T", 0, }, /* Linksys Combo PCMCIA EthernetCard */ { "PCMPC100", 1, }, /* EtherFast 10/100 PC Card */ { "EN2216", 0, }, /* Accton EtherPair-PCMCIA */ { "FA410TX", 1, }, /* Netgear FA410TX */ { "Network Everywhere", 0, }, /* Linksys NP10T 10BaseT Card */ { "10/100 Port Attached", 1, }, /* SMC 8040TX */ { nil, 0, }, . ## diffname pc/etherec2t.c 2001/1019 ## diff -e /n/emeliedump/2001/1005/sys/src/9/pc/etherec2t.c /n/emeliedump/2001/1019/sys/src/9/pc/etherec2t.c 32a { "FA411", 0 }, /* Netgear FA411 PCMCIA */ . ## diffname pc/etherec2t.c 2002/0429 ## diff -e /n/emeliedump/2001/1019/sys/src/9/pc/etherec2t.c /n/emeliedump/2002/0429/sys/src/9/pc/etherec2t.c 28a { "PCM100", 1, }, /* EtherFast PCM100 Card */ .