home *** CD-ROM | disk | FTP | other *** search
/ Danny Amor's Online Library / Danny Amor's Online Library - Volume 1.iso / html / faqs / faq / linux / howto.ethernet.part1 < prev    next >
Encoding:
Text File  |  1995-07-25  |  52.9 KB  |  1,513 lines

  1. Subject: Linux Ethernet HOWTO (part 1/2)
  2. Newsgroups: comp.os.linux.announce,comp.os.linux.admin,comp.answers,news.answers,comp.dcoms.lan.ethernet,comp.sys.ibm.pc.hardware.networking,aus.computers.linux
  3. From: Paul Gortmaker <gpg109@rsphysse.anu.edu.au>
  4. Date: Fri, 18 Nov 1994 17:03:01 GMT
  5.  
  6. Archive-Name: linux/howto/ethernet/part1
  7. Last-modified: 20 Oct 94
  8.  
  9.   Linux Ethernet-Howto
  10.   Paul Gortmaker, Editor.
  11.   v2.0, 18/10/94
  12.  
  13.   This is the Ethernet-Howto, which is a compilation of information
  14.   about which ethernet devices can be used for Linux, and how to set
  15.   them up. It hopefully answers all the frequently asked questions about
  16.   using ethernet cards with Linux. Note that this Howto is focused on
  17.   the hardware and low level driver aspect of the ethernet cards, and
  18.   does not cover the software end of things. See the NET2-Howto for that
  19.   stuff.
  20.  
  21.   1.  Introduction
  22.  
  23.  
  24.   The Ethernet-Howto covers what cards you should and shouldn't buy; how
  25.   to set them up, how to run more than one, and other common problems
  26.   and questions. It contains detailed information on the current level
  27.   of support for all of the most common ethernet cards available.  It
  28.   does *not* cover the software end of things, as that is covered in the
  29.   NET-2 Howto.
  30.  
  31.   The Ethernet-Howto is edited and maintained by:
  32.  
  33.        Paul Gortmaker, Paul.Gortmaker@anu.edu.au
  34.  
  35.  
  36.   The primary source of the information for the Ethernet-Howto is from:
  37.  
  38.        Donald J. Becker, becker@cesdis.gsfc.nasa.gov
  39.  
  40.  
  41.   who we have to thank for writing the vast majority of ethernet card
  42.   drivers that are presently available for Linux. He also is the
  43.   original author of the NFS server too. Thanks Donald! We we owe ya
  44.   one!  :-)
  45.  
  46.   Net-surfers may wish to check out the following URL:
  47.  
  48.   Donald Becker
  49.   (http://cesdis.gsfc.nasa.gov/pub/people/becker/whoiam.html)
  50.  
  51.  
  52.   1.1.  Using the Ethernet-Howto
  53.  
  54.  
  55.   As this guide is getting bigger and bigger, you probably don't want to
  56.   spend the rest of your afternoon reading the whole thing. And you
  57.   don't *have* to read it all. If you haven't got an ethernet card, then
  58.   you will want to start with ``What card should I buy...''  to see what
  59.   you should buy, and what you should avoid. If you have already got an
  60.   ethernet card, but are not sure if you can use it with Linux, then you
  61.   will want to read ``Vendor Specific...''  which contains specific
  62.   information on each manufacturer, and their cards. If you are having
  63.   trouble with your card, then you will want to read the specific
  64.   information about your card mentioned above, and the troubleshooting
  65.   information in ``the FAQ section''.  If you are interested in some of
  66.   the technical aspects of the device drivers, then you can find that
  67.   information in ``Technical Information''
  68.  
  69.  
  70.   1.2.  Disclaimer and Copyright
  71.  
  72.  
  73.   This document is *not* gospel. However, it is probably the most up to
  74.   date info that you will be able to find. Nobody is responsible for
  75.   what happens to your hardware but yourself. If your ethercard or any
  76.   other hardware goes up in smoke (...nearly impossible!)  we take no
  77.   responsibility. ie. THE AUTHORS ARE NOT RESPONSIBLE FOR ANY DAMAGES
  78.   INCURRED DUE TO ACTIONS TAKEN BASED ON THE INFORMATION INCLUDED IN
  79.   THIS DOCUMENT.
  80.  
  81.   This document is Copyright (c) 1994 by Donald Becker and Paul
  82.   Gortmaker. Permission is granted to make and distribute verbatim
  83.   copies of this manual provided the copyright notice and this
  84.   permission notice are preserved on all copies.
  85.  
  86.   Permission is granted to copy and distribute modified versions of this
  87.   document under the conditions for verbatim copying, provided that this
  88.   copyright notice is included exactly as in the original, and that the
  89.   entire resulting derived work is distributed under the terms of a
  90.   permission notice identical to this one.
  91.  
  92.   Permission is granted to copy and distribute translations of this
  93.   document into another language, under the above conditions for
  94.   modified versions.
  95.  
  96.   If you are intending to incorporate this document into a published
  97.   work, please contact me, and I will make an effort to ensure that you
  98.   have the most up to date information available. In the past, out of
  99.   date versions of the Linux howto documents have been published, which
  100.   caused the developers undue grief from being plagued with questions
  101.   that were already answered in the up to date versions.
  102.  
  103.  
  104.   1.3.  Mailing Lists and the Linux Newsgroups
  105.  
  106.  
  107.  
  108.   If you have questions about your ethernet card, please READ this
  109.   document first. You may also want to join the NET channel of the
  110.   Linux-activists mailing list by sending mail to
  111.  
  112.        linux-activists-request@niksula.hut.fi
  113.  
  114.  
  115.   with the line
  116.  
  117.        X-Mn-Admin: join NET
  118.  
  119.  
  120.   at the top of the message body (not the subject). If you want to learn
  121.   how to use the mailing channels, then send an empty message to the
  122.   above address, and you will get an instruction manual sent back to you
  123.   in a few hours. However, it is worth noting that the NET channel is
  124.   primarily used for discussion of the networking code, and you may not
  125.   see much discussion about a particular driver.  Furthermore keep in
  126.   mind that the NET channel is for development discussions only. General
  127.   questions on how to configure your system should be directed to
  128.   comp.os.linux.help unless you are actively involved in the development
  129.   of part of the networking for Linux.  We ask that you *please* respect
  130.   this general guideline for content.  Also, you can safely bet that
  131.   most people will not respond to any plea for help that *should* be
  132.   posted to c.o.l.help, but is inappropriately placed elsewhere.
  133.  
  134.  
  135.   1.4.  Related Documentation
  136.  
  137.  
  138.   Much of this info came from saved postings from the comp.os.linux
  139.   groups, which shows that it is a valuable resource of information.
  140.   Other useful information came from a bunch of small files by Donald
  141.   himself. Of course, if you are setting up an Ethernet card, then you
  142.   will want to read the NET-2 Howto so that you can actually configure
  143.   the software you will use.  And last but not least, the contributions
  144.   from the individuals and companies listed in ``Contributors'' is
  145.   greatly appreciated as well. Oh yeah, if you fancy yourself as a bit
  146.   of a hacker, you can always scrounge some additional info from the
  147.   driver source files as well. There is usually a paragraph in there
  148.   describing any important points.
  149.  
  150.  
  151.   1.5.  New Versions of this Document
  152.  
  153.  
  154.   New versions of this document can be retrieved via anonymous FTP from
  155.   sunsite.unc.edu, in /pub/Linux/docs/HOWTO/* and various Linux ftp
  156.   mirror sites. Updates will be made as new information / drivers
  157.   becomes available. If this copy that you are reading is more than 2
  158.   months old, it is either out of date, or it means that I have been
  159.   lazy and haven't updated it.  This document was produced by using the
  160.   SGML system that was specifically set up for the Linux Howto project,
  161.   and there are various output formats available, including, postscript,
  162.   dvi, ascii, html, and soon TeXinfo.
  163.  
  164.   I would recommend viewing it in the html (via Mosaic) or the
  165.   Postscript/dvi format. Both of these contain cross-references that are
  166.   lost in the ascii translation.
  167.  
  168.  
  169.   2.  What card should I buy for Linux?
  170.  
  171.  
  172.   For impatient users that just want a quick, cheap answer the summary
  173.   is: get 16 bit thinnet 8013 cards. For those who want the absolute
  174.   best performance, get an AMD PC-Net/Lance based card. For more detail
  175.   as to the who what where and why, read on.
  176.  
  177.  
  178.   2.1.  Eight bit vs 16 bit
  179.  
  180.  
  181.   Unless you are a light user, or are confined to using the smaller ISA
  182.   slot, the use of the 8 bit cards like the wd8003, the 3c503 and the
  183.   ne1000 is really not worth the cost savings. Get the 8013 or the
  184.   3c503/16, or the ne2000 instead.
  185.  
  186.  
  187.   2.2.  Low price Ethernet cards
  188.  
  189.  
  190.   The lowest price seen so far was in the March '94 edition of LAN
  191.   magazine. There was an ad for Addtron AE-200 cards (jumper settable
  192.   NE2000 clones) for a measly $19 ea! (limit 2). Unfortunately this
  193.   offer has since expired. However, you might want to check to see what
  194.   their everyday price is.
  195.  
  196.   You can also call AT-LAN-TEC at 301-948-7070. Ask for their technical
  197.   support person, Vincent Bono. As with all purchases, you should
  198.   indicate you are buying this for a Linux system.  NB: Their current
  199.   NE2000 clone is a model that `traps' other drivers that probe into
  200.   their address space. AT-LAN-TEC also carries a clone, non-EEPROM 8013
  201.   board for somewhat more, and a NE2100 clone.  Either is a better
  202.   choice if the very lowest price isn't essential.
  203.  
  204.   Also, SMC has been offering an evaluation deal on their new Ultra
  205.   cards, and the word is that you can get one for $50. You can ask them
  206.   yourself by calling the numbers listed in ``Western Digital / SMC''.
  207.   And a recent addition is the VLB and PCI cards offered by Boca
  208.   Research. These are selling for around the $70 mark, and these are
  209.   supported with the latest kernel. These use the new 32 bit versions of
  210.   the LANCE chip from AMD. See ``Boca Research'' for more info.
  211.  
  212.   If you require an ISA card, you can use the the Allied Telesis AT1500
  213.   which uses the ISA version of the LANCE chip from AMD.  It is offered
  214.   at a good price by many vendors.  Even Inmac, known for their premium
  215.   markup, has this card for under $100. See ``AT-1500'' for more info.
  216.  
  217.  
  218.  
  219.   2.3.  Vendors and Brands to Avoid
  220.  
  221.  
  222.   These vendors have decided *not* to release programming information
  223.   about their products, without signing a NDA (non-disclosure
  224.   agreement).  Hence it is strongly advised that you avoid buying
  225.   products offered from these companies.
  226.  
  227.   (1) Cabletron (see ``Cabletron'')
  228.  
  229.   (2) Xircom (see ``Xircom'')
  230.  
  231.   These particular cards should be avoided, as they are obsolete.  The
  232.   reasons as to why they have been classified as such can be found in
  233.   their respective sections.
  234.  
  235.   (1) 3c501 (see ``3Com 3c501'')
  236.  
  237.   (2) Arcnet based cards (see ``Arcnet'')
  238.  
  239.   (3) Any 8-bit cards (see ``Eight bit...'')
  240.  
  241.  
  242.   2.4.  Type of cable that your card should support
  243.  
  244.  
  245.   Unless you have to conform to an existing network, you will want to
  246.   use thinnet or thin ethernet cable. This is the style with the
  247.   standard BNC connectors. See ``cable info'' for other concerns with
  248.   different types of ethernet cable.
  249.  
  250.   Most ethercards also come in a `Combo' version for only $10-$20 more.
  251.   These have both twisted pair and thinnet transceiver built-in,
  252.   allowing you to change your mind later.
  253.  
  254.   The twisted pair cables, with the RJ-45 (giant phone jack) connectors
  255.   is technically called 10Base-T. You may also hear it called UTP
  256.   (Unsheilded Twisted Pair).
  257.  
  258.   The thinnet, or thin ethernet cabling, (RG-58 coaxial cable) with the
  259.   BNC (metal push and turn-to-lock) connectors is technically called
  260.   10Base-2.
  261.  
  262.   The older thick ethernet (10mm coaxial cable) which is only found in
  263.   older installations is called 10Base-5.
  264.  
  265.   Large corporate installations will most likely use 10Base-T instead of
  266.   10Base-2. 10Base-2 does not offer an easy upgrade path to the new
  267.   upcoming 100Base-whatever.
  268.  
  269.  
  270.  
  271.  
  272.  
  273.   3.  Vendor/Manufacturer/Model Specific Information
  274.  
  275.  
  276.   The only thing that one needs to use an ethernet card with Linux is
  277.   the appropriate driver. For this, it is essential that the
  278.   manufacturer will release the technical programming information to the
  279.   general public without you (or anyone) having to sign your life away.
  280.   A good guide for the likelihood of getting documentation (or, if you
  281.   aren't writing code, the likelihood that someone else will write that
  282.   driver you really, really need) is the availability of the Crynwr (nee
  283.   Clarkson) packet driver. Russ Nelson runs this operation, and has been
  284.   very helpful in supporting the development of drivers for Linux. Net-
  285.   surfers can try this URL to look up Russ' software.
  286.  
  287.   Russ Nelson's Packet Drivers (http://www.crynwr.com/crynwr/home.html)
  288.  
  289.   Given the documentation, you can write a driver for your card and use
  290.   it for Linux, at least in theory. Keep in mind that some old hardware
  291.   that was designed for XT type machines will not function very well in
  292.   a multitasking environment such as Linux. Use of these will lead to
  293.   major problems if your network sees a reasonable amount of traffic.
  294.  
  295.   Most cards come with drivers for MS-DOS interfaces such as NDIS and
  296.   ODI, but these are useless for Linux. Many people have suggested
  297.   directly linking them in or automatic translation, but this is nearly
  298.   impossible. The MS-DOS drivers expect to be in 16 bit mode and hook
  299.   into `software interrupts', both incompatible with the Linux kernel.
  300.   This incompatibility is actually a feature, as some Linux drivers are
  301.   considerably better than their MS-DOS counterparts. The `8390' series
  302.   drivers, for instance, use ping-pong transmit buffers, which are only
  303.   now being introduced in the MS-DOS world.
  304.  
  305.   Keep in mind that PC ethercards have the widest variety of interfaces
  306.   (shared memory, programmed I/O, bus-master, or slave DMA) of any
  307.   computer hardware for anything, and supporting a new ethercard
  308.   sometimes requires re-thinking most of the lower-level networking
  309.   code. (If you are interested in learning more about these different
  310.   forms of interfaces, see ``Programmed I/O vs. ...''.
  311.  
  312.   Also, similar product numbers don't always indicate similar products.
  313.   For instance, the 3c50* product line from 3Com varies wildly between
  314.   different members.
  315.  
  316.   Enough talk. Let's get down to the information you want.
  317.  
  318.  
  319.   3.1.  3Com
  320.  
  321.  
  322.   If you are not sure what your card is, but you think it is a 3Com
  323.   card, you can probably figure it out from the assembly number. 3Com
  324.   has a document `Identifying 3Com Adapters By Assembly Number' (ref
  325.   24500002) that would most likely clear things up. See ``Technical
  326.   Information from 3Com'' for info on how to get documents from 3Com.
  327.  
  328.  
  329.   3.1.1.  3c501
  330.  
  331.  
  332.   Status -- Semi-Supported
  333.  
  334.   Too brain-damaged to use. Available surplus from many places. Avoid it
  335.   like the plague. Again, do not purchase this card, even as a joke.
  336.   It's performance is horrible, and it breaks in many ways.
  337.  
  338.  
  339.   Cameron L. Spitzer of 3Com said: ``I'm speaking only for myself here,
  340.   of course, but I believe 3Com advises against installing a 3C501 in a
  341.   new system, mostly for the same reasons Donald has discussed. You
  342.   probably won't be happy with the 3C501 in your Linux box. The data
  343.   sheet is marked `(obsolete)' on 3Com's Developers' Order Form, and the
  344.   board is not part of 3Com's program for sending free Technical
  345.   Reference Manuals to people who need them. The decade-old things are
  346.   nearly indestructible, but that's about all they've got going for them
  347.   any more.''
  348.  
  349.   For those not yet convinced, the 3c501 can only do one thing at a time
  350.   -- while you are removing one packet from the single-packet buffer it
  351.   cannot receive another packet, nor can it receive a packet while are
  352.   loading a transmit packet. This was fine for a network between two
  353.   8088-based computers where processing each packet and replying took
  354.   10's of msecs, but modern networks send back-to-back packets for
  355.   almost every transaction.
  356.  
  357.   Donald writes: `The driver is now in the std. kernel, but under the
  358.   following conditions: This is unsupported code. I know the usual
  359.   copyright says all the code is unsupported, but this is _really_
  360.   unsupported. I DON'T want to see bug reports, and I'll accept bug
  361.   fixes only if I'm in a good mood that day.
  362.  
  363.   I don't want to be flamed later for putting out bad software. I don't
  364.   know all all of the 3c501 bugs, and I know this driver only handles a
  365.   few that I've been able to figure out. It has taken a long intense
  366.   effort just to get the driver working this well.'
  367.  
  368.   AutoIRQ works, DMA isn't used, the autoprobe only looks at 0x280 and
  369.   0x300, and the debug level is set with the third boot-time argument.
  370.  
  371.   Once again, THE USE OF A 3c501 IS STRONGLY DISCOURAGED!
  372.  
  373.  
  374.   3.1.2.  3c503, 3c503/16
  375.  
  376.  
  377.   Status -- Supported
  378.  
  379.   3Com shared-memory ethercards. They also have a programmed I/O mode
  380.   that doesn't use the 8390 facilities (their engineers found too many
  381.   bugs!)  It should be about the same speed as the same bus width
  382.   WD80x3, Unless you are a light user, spend the extra money and get the
  383.   16 bit model, as the price difference isn't significant. The 3c503
  384.   does not have ``EEPROM setup'', so the diagnostic/setup program isn't
  385.   needed before running the card with Linux. The shared memory address
  386.   of the 3c503 is set using jumpers that are shared with the boot PROM
  387.   address. This is confusing to people familiar with other ISA cards,
  388.   where you always leave the jumper set to ``disable'' unless you have a
  389.   boot PROM.
  390.  
  391.  
  392.   The Linux 3c503 driver can also work with the 3c503 programmed-I/O
  393.   mode, but this is slower and less reliable than shared memory mode.
  394.   Also, programmed-I/O mode is not tested when updating the drivers, the
  395.   deadman (deadcard?) check code may falsely timeout on some machines,
  396.   and the probe for a 3c503 in programmed-I/O mode is turned off by
  397.   default in some versions of the kernel. This was a panic reaction to
  398.   the general device driver probe explosion; the 3c503 shared memory
  399.   probe is a safe read from memory, rather than an extensive scan
  400.   through I/O space. As of pl13, the kernel has an I/O port registrar
  401.   that makes I/O space probes safer, and the programmed-I/O 3c503 probe
  402.   has been re-enabled.  You still shouldn't use the programmed-I/O mode
  403.   though, unless you need it for MS-DOS compatibility.
  404.  
  405.   The 3c503's IRQ line is set in software, with no hints from an EEPROM.
  406.   Unlike the MS-DOS drivers, the Linux driver has capability to autoIRQ:
  407.   it uses the first available IRQ line in {5,2/9,3,4}, selected each
  408.   time the card is ifconfig'ed. (Older driver versions selected the IRQ
  409.   at boot time.) The ioctl() call in `ifconfig' will return EAGAIN if no
  410.   IRQ line is available at that time.
  411.  
  412.   Some common problems that people have with the 503 are discussed in
  413.   ``Problems with...''.
  414.  
  415.  
  416.  
  417.   3.1.3.  3c505
  418.  
  419.  
  420.   Status -- Semi-Supported
  421.  
  422.   This is a driver that was written by Craig Southeren
  423.   geoffw@extro.ucc.su.oz.au -- It is an Intel based ethercard, but I
  424.   really haven't seen that much mention of them, and I don't think there
  425.   are that many of them about. It is included in the standard kernel,
  426.   but it is classed as an alpha driver. See ``Alpha Drivers'' for
  427.   important information on using alpha-test ethernet drivers with Linux.
  428.  
  429.   There is also the file /usr/src/linux/drivers/net/README.3c505 that
  430.   you should read if you are going to use one of these cards.  It
  431.   contains various options that you can enable/disable.
  432.  
  433.  
  434.   3.1.4.  3c507
  435.  
  436.   Status -- Semi-Supported
  437.  
  438.   This card uses one of the Intel chips, and the development of the
  439.   driver is closely related to the development of the Intel Ether
  440.   Express driver.  The driver is included in the standard kernel
  441.   release, but as an alpha driver. See ``Alpha Drivers'' for important
  442.   information on using alpha-test ethernet drivers with Linux.
  443.  
  444.  
  445.   Technical information is available in ``Programming the Intel chips''
  446.   and if you have experience in writing drivers, see ``Skeleton driver''
  447.   as well.
  448.  
  449.  
  450.   3.1.5.  3c509
  451.  
  452.  
  453.   Status -- Supported
  454.  
  455.   A fairly new card from 3Com. It's inexpensive and has excellent
  456.   performance for a non-bus-master design. The drawbacks are that it
  457.   _requires_ very low interrupt latency, and it isn't rated for bus
  458.   speeds greater than 8Mhz.
  459.  
  460.   A working 3c509 driver was first included as an alpha-test version in
  461.   the 0.99pl13 kernel sources.  It is now in the standard kernel.
  462.  
  463.   The 3c509 has a tiny Rx buffer, causing the driver to occasionally
  464.   drop a packet if interrupts are masked for too long. To minimize this
  465.   problem, the driver should be completely rewritten to use predictive
  466.   interrupts.  (Note: performance re-writes of working drivers are low
  467.   priority unless there is some particular incentive or need.)
  468.  
  469.  
  470.  
  471.   There is also an alpha version of a Linux 3c509 diagnostic and EEPROM
  472.   setup program, but for now users that don't like the defaults should
  473.   use the MS-DOS EEPROM setup program.
  474.  
  475.   Cameron Spitzer writes: ``Beware that if you put a '509 in EISA
  476.   addressing mode by mistake and save that in the EEPROM, you'll have to
  477.   use an EISA machine or the infamous Test Via to get it back to normal,
  478.   and it will conflict at IO location 0 which may hang your ISA machine.
  479.   It's not my job to say whether this is a bug or feature, but I have
  480.   heard loud and clear that customers don't like it and I don't think
  481.   we'll do it that way again.''
  482.  
  483.  
  484.   3.1.6.  3c52*
  485.  
  486.  
  487.   Status -- Not Supported
  488.  
  489.   I am not sure of this, but I think all the 3c52* cards are MCA
  490.   equivalents of their 3c50* counterparts. I'd appreciate it if someone
  491.   could verify this. Some people are actually running Linux on MCA bus
  492.   machines, and are playing with MCA ethercards.  With a little bit of
  493.   luck, MCA cards could use a lot of code from the ISA drivers, with the
  494.   major change being i/o ports and the like. Don't hold your breath
  495.   though.
  496.  
  497.  
  498.   3.1.7.  3c579
  499.  
  500.  
  501.   Status -- Supported
  502.  
  503.   The EISA version of the 509. The current EISA version uses the same 16
  504.   bit wide chip rather than a 32 bit interface, so the performance
  505.   increase isn't stunning.  The EISA probe code was added to 3c509.c for
  506.   pl14.  We would be interested in hearing progress reports from any
  507.   3c579 users. (Read the above 3c509 section for info on the driver.)
  508.  
  509.   Cameron Spitzer writes: ``The 3C579 (Etherlink III EISA) should be
  510.   configured as an EISA card. The IO Base Address (window 0 register 6
  511.   bits 4:0) should be 1f, which selects EISA addressing mode. Logic
  512.   outside the ASIC decodes the IO address s000, where s is the slot
  513.   number. I don't think it was documented real well. Except for its IO
  514.   Base Address, the '579 should behave EXACTLY like the'509 (EL3 ISA),
  515.   and if it doesn't, I want to hear about it (at my work address).''
  516.  
  517.  
  518.  
  519.   3.1.8.  3c589
  520.  
  521.  
  522.   Status -- Semi-Supported
  523.  
  524.   Many people have been using this card for quite some time now. Note
  525.   that support for it is not (at present) included in the default kernel
  526.   source tree. Note that you will need a supported PCMCIA controller
  527.   chipset. There are drivers available on Donald's ftp site:
  528.  
  529.  
  530.        cesdis.gsfc.nasa.gov:/pub/linux/pcmcia/README.3c589 ces-
  531.        dis.gsfc.nasa.gov:/pub/linux/pcmcia/3c589.c ces-
  532.        dis.gsfc.nasa.gov:/pub/linux/pcmcia/dbether.c
  533.  
  534.  
  535.   Or for those that are net-surfing you can try:
  536.  
  537.   Don's PCMCIA Stuff (http://cesdis.gsfc.nasa.gov/linux/pcmcia.html)
  538.  
  539.   You will still need a PCMCIA socket enabler as well.
  540.  
  541.   See ``PCMCIA Support'' for more info on PCMCIA chipsets, socket
  542.   enablers, etc.
  543.  
  544.  
  545.   3.2.  Allied Telesis
  546.  
  547.  
  548.  
  549.   3.2.1.  AT1500
  550.  
  551.  
  552.   Status --Supported
  553.  
  554.   These are a series of low-cost ethercards using the 79C960 version of
  555.   the AMD LANCE. These are bus-master cards, and thus probably the
  556.   fastest ISA bus ethercards available (although the 3c509 has lower
  557.   latency thanks to predictive interrupts).
  558.  
  559.   DMA selection and chip numbering information can be found in ``AMD
  560.   LANCE''.
  561.  
  562.   More technical information on AMD LANCE based Ethernet cards can be
  563.   found in ``Notes on AMD...''.
  564.  
  565.  
  566.   3.2.2.  AT1700
  567.  
  568.  
  569.   Status -- Supported
  570.  
  571.   The Allied Telesis AT1700 series ethercards are based on the Fujitsu
  572.   MB86965. This chip uses a programmed I/O interface, and a pair of
  573.   fixed-size transmit buffers. This allows small groups of packets to
  574.   sent be sent back-to-back, with a short pause while switching buffers.
  575.  
  576.   A unique feature is the ability to drive 150ohm STP (Shielded Twisted
  577.   Pair) cable commonly installed for Token Ring, in addition to 10baseT
  578.   100ohm UTP (unshielded twisted pair).
  579.  
  580.   The Fujitsu chip used on the AT1700 has a design flaw: it can only be
  581.   fully reset by doing a power cycle of the machine.  Pressing the reset
  582.   button doesn't reset the bus interface. This wouldn't be so bad,
  583.   except that it can only be reliably detected when it has been freshly
  584.   reset. The solution/work-around is to power-cycle the machine if the
  585.   kernel has a problem detecting the AT1700.
  586.  
  587.   Some production runs of the AT1700 had another problem: they are
  588.   permanently wired to DMA channel 5.  This is undocumented, there are
  589.   no jumpers to disable the "feature", and no driver dares use the DMA
  590.   capability because of compatibility problems. No device driver will be
  591.   written using DMA if installing a second card into the machine breaks
  592.   both, and the only way to disable the DMA is with a knife.
  593.  
  594.   The at1700 driver is included in the standard kernel source tree.
  595.  
  596.  
  597.   3.3.  AMD / Advanced Micro Devices
  598.  
  599.  
  600.  
  601.  
  602.  
  603.   3.3.1.  AMD LANCE (7990, 79C960, PCnet-ISA)
  604.  
  605.  
  606.   Status -- Supported
  607.  
  608.   There really is no AMD ethernet card. You are probably reading this
  609.   because the only markings you could find on your card said AMD and the
  610.   above number. The 7990 is the original `LANCE' chip, but most stuff
  611.   (including this document) refer to all these similar chips as `LANCE'
  612.   chips. (...incorrectly, I might add.)
  613.  
  614.   These above numbers refer to chips from AMD that are the heart of many
  615.   ethernet cards.  For example, the Allied Telesis AT1500 (see
  616.   ``AT1500'') the NE1500/2100 (see ``NE1500'') and the Boca-VLB/PCI
  617.   cards (see ``Boca-VLB/PCI'')
  618.  
  619.   The 79C960 (a.k.a. PCnet-ISA) contains enhancements and bug fixes over
  620.   the original 7990 LANCE design.
  621.  
  622.   Chances are that the existing LANCE driver will work with all AMD
  623.   LANCE based cards. (except perhaps the NI65XX - see ``NI65XX'' for
  624.   more info on that one.)  This driver should also work with NE1500 and
  625.   NE2100 clones.
  626.  
  627.   For the ISA bus master mode all structures used directly by the LANCE,
  628.   the initialization block, Rx and Tx rings, and data buffers, must be
  629.   accessible from the ISA bus, i.e. in the lower 16M of real memory.
  630.   This is a problem for current Linux kernels on >16M machines. The
  631.   network devices are initialized after memory initialization, and the
  632.   kernel doles out memory from the top of memory downward. The current
  633.   solution is to have a special network initialization routine that's
  634.   called before memory initialization; this will eventually be
  635.   generalized for all network devices.  Low-memory `bounce-buffers' are
  636.   used when needed.
  637.  
  638.   The DMA channel can be set with the low bits of the otherwise-unused
  639.   dev->mem_start value (aka PARAM_1).  (see ``PARAM_1'') If unset it is
  640.   probed for by enabling each free DMA channel in turn and checking if
  641.   initialization succeeds.
  642.  
  643.   The HP-J2405A board is an exception: with this board it's easy to read
  644.   the EEPROM-set values for the IRQ, and DMA.
  645.  
  646.   See ``Notes on AMD...''  for more info on these chips.
  647.  
  648.  
  649.   3.3.2.  AMD 79C961 (PCnet-ISA+)
  650.  
  651.  
  652.   Status -- Supported
  653.  
  654.   This is the PCnet-ISA+  -- an enhanced version of the 79C960.  It has
  655.   support for jumper-less configuration and Plug and Play.  See the info
  656.   in the above section.
  657.  
  658.  
  659.   3.3.3.  AMD 79C965 (PCnet-32)
  660.  
  661.  
  662.   Status -- Supported
  663.  
  664.   This is the PCnet-32 -- a 32 bit bus-master version of the original
  665.   LANCE chip for VL-bus and local bus systems.  Minor cleanups were
  666.   added to the original lance driver around v1.1.50 to support these 32
  667.   bit versions of the LANCE chip.  The main problem was that the current
  668.   versions of the '965 and '970 chips have a minor bug.  They clear the
  669.   Rx buffer length field in the Rx ring when they are explicitly
  670.   documented not to. Again, see the above info.
  671.  
  672.  
  673.   3.3.4.  AMD 79C970 (PCnet-PCI)
  674.  
  675.  
  676.   Status -- Supported
  677.  
  678.   This is the PCnet-PCI -- similar to the PCnet-32, but designed for PCI
  679.   bus based systems. Again, see the above info.
  680.  
  681.  
  682.   3.3.5.  AMD 79C974 (PCnet-SCSI)
  683.  
  684.  
  685.   Status -- Supported
  686.  
  687.   This is the PCnet-SCSI -- treated like a '970 from Linux's point of
  688.   view. Again, see the above info.
  689.  
  690.  
  691.   3.4.  Ansel Communications
  692.  
  693.  
  694.  
  695.   3.4.1.  AC3200 EISA
  696.  
  697.  
  698.   Status -- Semi-Supported
  699.  
  700.   This driver is included in the present kernel as an alpha test driver.
  701.   Please see ``Alpha Drivers'' in this document for important
  702.   information regarding alpha drivers.  If you use it, let Donald know
  703.   how things work out, as not too many people have this card and
  704.   feedback has been low.
  705.  
  706.  
  707.   3.5.  Apricot
  708.  
  709.  
  710.  
  711.   3.5.1.  Apricot Xen-II On Board Ethernet
  712.  
  713.  
  714.   Status -- Supported
  715.  
  716.   This on board ethernet uses an i82596 bus-master chip.  It can only be
  717.   at i/o address 0x300. The author of this driver is Mark Evans. By
  718.   looking at the driver source, it appears that the IRQ is hardwired to
  719.   10.
  720.  
  721.  
  722.   3.6.  Arcnet
  723.  
  724.  
  725.   Status -- Not Really Supported
  726.  
  727.   At present, there is no stable Arcnet driver for Linux. With the very
  728.   low cost and better performance of ethernet, chances are that most
  729.   places will be giving away their Arcnet hardware for free, resulting
  730.   in a lot of home systems with Arcnet.
  731.  
  732.   An advantage of Arcnet is that all of the cards have identical
  733.   interfaces, so once a driver is available it will work for everyone.
  734.  
  735.   If you are feeling brave, there is `arcnet.c' in the usual place (see
  736.   ``Alpha Drivers'' if you don't know where that is) that you can play
  737.   with. Don't expect to just plug in this file and have everything work.
  738.   However it may prove to be a good starting point for a bored driver-
  739.   hacker. Also look at Russ Nelson's `arcether' packet driver.
  740.  
  741.   Recent interest in getting Arcnet going has picked up again and Avery
  742.   Pennarun has put an alpha driver up on sunsite.  Look for:
  743.  
  744.   /pub/Linux/system/Network/drivers/arcnet-0.12.tar.gz
  745.  
  746.   The `0.12' is likely to have changed by the time you read this, so
  747.   look around and find the newest one. Bug reports and success stories
  748.   can be mailed to:
  749.  
  750.   apenwarr@tourism.807-city.on.ca
  751.  
  752.  
  753.   3.7.  AT-Lan-Tec / RealTek
  754.  
  755.  
  756.  
  757.   3.7.1.  AT-Lan-Tec / RealTek Pocket adaptor
  758.  
  759.  
  760.   Status -- Supported
  761.  
  762.   This is a generic, low-cost OEM pocket adaptor being sold by AT-Lan-
  763.   Tec, and (likely) a number of other suppliers. A driver for it is
  764.   included in the standard kernel.  Note that there is substantial
  765.   information contained in the driver source file `atp.c' which
  766.   presently lives in ./drivers/net/ BTW, the adaptor (AEP-100L) has both
  767.   10baseT and BNC connections!  You can reach AT-Lan-Tec at
  768.   1-301-948-7070. Ask for the model that works with Linux, or ask for
  769.   `Vincent Bono' in tech support.  In the Netherlands a compatible
  770.   adaptor is sold under the name SHI-TEC PE-NET/CT, and sells for about
  771.   $125. The vendor was Megasellers.  They state that they do not sell to
  772.   private persons, but this doesn't appear to be strictly adhered to.
  773.   They are: Megasellers, Vianen, The Netherlands. They always advertise
  774.   in Dutch computer magazines. In Germany, a similar adaptor comes as a
  775.   no-brand-name product. Prolan 890b, no brand on the casing, only a
  776.   roman II. Resellers can get a price of about $130, including a small
  777.   wall transformer for the power.
  778.  
  779.   The adaptor is `normal size' for the product class, about 57mm wide,
  780.   22mm high tapering to 15mm high at the DB25 connector, and 105mm long
  781.   (120mm including the BNC socket). It's switchable between the RJ45 and
  782.   BNC jacks with a small slide switch positioned between the two: a very
  783.   intuitive design.
  784.  
  785.   Donald performed some power draw measurements, and determined that the
  786.   average current draw was only about 100mA @ 5V.  This power draw is
  787.   low enough that you could buy or build a cable to take the 5V directly
  788.   from the keyboard/mouse port available on many laptops. (Bonus points
  789.   here for using a standardized power connector instead of proprietary
  790.   one.)
  791.  
  792.  
  793.  
  794.   3.8.  Boca Research
  795.  
  796.  
  797.   Yes, they make more than just multi-port serial cards.  :-)
  798.  
  799.  
  800.  
  801.   3.8.1.  Boca PCI, Boca VLB
  802.  
  803.  
  804.   Status -- Supported
  805.  
  806.   These cards are based on AMD's PCnet chips, used in the AT1500 and the
  807.   like. You can pick up a combo (10Base-T and 10Base-2) PCI card for
  808.   under $70 at the moment.
  809.  
  810.   Chip numbering information can be found in ``AMD LANCE''.
  811.  
  812.   More technical information on AMD LANCE based Ethernet cards can be
  813.   found in ``Notes on AMD...''.
  814.  
  815.  
  816.   3.9.  Cabletron
  817.  
  818.  
  819.   Donald writes: `Yes, another one of these companies that won't release
  820.   its programming information. They waited for months before actually
  821.   confirming that all their information was proprietary, deliberately
  822.   wasting my time. Avoid their cards like the plague if you can.  Also
  823.   note that some people have phoned Cabletron, and have been told things
  824.   like `a D. Becker is working on a driver for linux' -- making it sound
  825.   like I work for them. This is NOT the case.'
  826.  
  827.   If you feel like asking them why they don't want to release their info
  828.   so that people can use their cards, write to support@ctron.com Tell
  829.   them that you are using Linux, and are disappointed that they don't
  830.   support open systems.
  831.  
  832.  
  833.   3.9.1.  E10**, E10**-x, E20**, E20**-x
  834.  
  835.  
  836.   Status -- Semi-Supported
  837.  
  838.   These are NEx000 almost-clones that are reported to work with the
  839.   standard NEx000 drivers, thanks to a ctron-specific check during the
  840.   probe. If there are any problems, they are unlikely to be fixed, as
  841.   the programming information is unavailable.
  842.  
  843.  
  844.   3.9.2.  E2100
  845.  
  846.  
  847.   Status -- Semi-Supported
  848.  
  849.   Again, there is not much one can do when the programming information
  850.   is proprietary.  The E2100 is a poor design. Whenever it maps its
  851.   shared memory in during a packet transfer, it maps it into the whole
  852.   128K region! That means you can't safely use another interrupt-driven
  853.   shared memory device in that region, including another E2100.  It will
  854.   work most of the time, but every once in a while it will bite you.
  855.   (Yes, this problem can be avoided by turning off interrupts while
  856.   transferring packets, but that will almost certainly lose clock
  857.   ticks.)
  858.  
  859.   Also, don't confuse the E2100 for a NE2100 clone.  The E2100 is a
  860.   shared memory NatSemi DP8390 design, roughly similar to a brain-
  861.   damaged WD8013, whereas the NE2100 (and NE1500) use a bus-mastering
  862.   AMD LANCE design.
  863.  
  864.   There is an E2100 driver included in the standard kernel.  However,
  865.   seeing as programming info isn't available, don't expect bug-fixes. I
  866.   wouldn't recommend using one unless I was already stuck with the card.
  867.   3.10.  D-Link
  868.  
  869.  
  870.  
  871.   3.10.1.  DE-100, DE-200, DE-220-T
  872.  
  873.  
  874.   Status -- Supported
  875.  
  876.   The manual says that it is 100 % compatible with the NE2000. This is
  877.   not true. You should call them and tell them you are using their card
  878.   with Linux, and they should correct their documentation. Some
  879.   pre-0.99pl12 driver versions may have trouble recognizing the DE2**
  880.   series as 16 bit cards, and these cards are the most widely reported
  881.   as having the spurious transfer address mismatch errors. Note that
  882.   there are cards from Digital (DEC) that are also named DE100 and
  883.   DE200, but the similarity stops there.
  884.  
  885.  
  886.  
  887.   3.10.2.  DE-600
  888.  
  889.  
  890.   Status -- Supported
  891.  
  892.   Laptop users and other folk who might want a quick way to put their
  893.   computer onto the ethernet may want to use this. The driver is
  894.   included with the default kernel source tree.  Bjorn Ekwall
  895.   bj0rn@blox.se wrote the original.  Expect about 80kb/s transfer speed
  896.   from this via the parallel port. You should read the README.DLINK file
  897.   in the kernel source tree.
  898.  
  899.   Note that the device name that you pass to ifconfig is not eth0 but
  900.   dl0 for the this device.
  901.  
  902.   Supposedly, a no-name ethernet pocket adaptor marketed under the name
  903.   `PE-1200' is DE-600 compatible.  It is available in Europe from:
  904.  
  905.  
  906.           SEMCON Handels Ges.m.b.h
  907.           Favoritenstrasse 20
  908.           A-1040 WIEN
  909.           Telephone: (+43) 222 50 41 708
  910.           Fax      : (+43) 222 50 41 706
  911.  
  912.  
  913.  
  914.  
  915.  
  916.   3.10.3.  DE-620
  917.  
  918.  
  919.   Status -- Supported
  920.  
  921.   Same as the DE-600, only with two output formats.  Bjorn has written a
  922.   driver for this model, for kernel versions 1.1 and above. See the
  923.   above information on the DE-600.
  924.  
  925.   Note that the device name that you pass to ifconfig is not eth0 but
  926.   dl0 for the this device.
  927.  
  928.  
  929.  
  930.  
  931.  
  932.  
  933.   3.10.4.  DE-650
  934.  
  935.  
  936.   Status -- Semi-Supported
  937.  
  938.   Some people have been using this PCMCIA card for some time now with
  939.   their notebooks. It is a basic 8390 design, much like a NE2000. The
  940.   LinkSys PCMCIA card and the IC-Card Ethernet (available from Midwest
  941.   Micro) are supposedly DE-650 clones as well.  Note that at present,
  942.   this driver is not part of the standard kernel, and so you will have
  943.   to do some patching.
  944.  
  945.   See ``PCMCIA Support'' in this document, and if you can, have a look
  946.   at:
  947.  
  948.   Don's PCMCIA Stuff (http://cesdis.gsfc.nasa.gov/linux/pcmcia.html)
  949.  
  950.  
  951.   3.11.  DFI
  952.  
  953.  
  954.  
  955.   3.11.1.  DFINET-300 and DFINET-400
  956.  
  957.  
  958.   Status -- Supported
  959.  
  960.   These cards are now detected (as of pl15) thanks to Eberhard
  961.   Moenkeberg emoenke@gwdg.de who noted that they use `DFI' in the first
  962.   3 bytes of the prom, instead of using 0x57 in bytes 14 and 15, which
  963.   is what all the NE1000 and NE2000 cards use. (The 300 is an 8 bit
  964.   pseudo NE1000 clone, and the 400 is a pseudo NE2000 clone.)
  965.  
  966.  
  967.  
  968.   3.12.  Digital / DEC
  969.  
  970.  
  971.  
  972.   3.12.1.  DE200, DE210, DE202, DE100, DEPCA rev E
  973.  
  974.  
  975.   Status -- Supported
  976.  
  977.   As of linux v1.0, there is a driver included as standard for these
  978.   cards. It was written by David C. Davies.  There is documentation
  979.   included in the source file `depca.c', which includes info on how to
  980.   use more than one of these cards in a machine.
  981.  
  982.   If you have / want to use the pl15 kernel or older, then you will have
  983.   to use Peter Bauer's driver.  It can be found as a separate patch
  984.   called depca-0.8.tar.gz.  You will have to un-comment the DEPCA line
  985.   in `config.in' after installing the patch. You can find the patch on
  986.   ftp.funet.fi, /pub/OS/Linux/BETA/depca/depca-0.8.tar.gz This version
  987.   resets the card upon close so that you can use it with broken DOS
  988.   drivers after a warm boot.
  989.  
  990.  
  991.   3.12.2.  Digital Etherlink III
  992.  
  993.  
  994.   Status -- Not Supported
  995.  
  996.   Peter Bauer said that `the new etherlink III seems to be a break: No
  997.   official docu from DEC as far as today, other (incompatible??)
  998.   hardware used, and (no joke) (at least for the first delivered cards)
  999.   also a sharp knife necessary to get the card working (needs cut of
  1000.   some irq lines ...)  As far as I know, lots of DEC Employees use Linux
  1001.   (at least for hobby purposes) and the depca-driver, because its a de-
  1002.   facto standard in DEC, so I encourage any DEC-employee reading this to
  1003.   check whether my writing is true, and to support sources of
  1004.   information about the etherworks-III.'
  1005.  
  1006.  
  1007.   3.12.3.  DEC 21040, 21140
  1008.  
  1009.  
  1010.   Status -- Not Supported
  1011.  
  1012.   These are new chips from DEC, designed for PCI ethernet cards, with
  1013.   the newer 21140 supporting 100Base-? I don't have any other info at
  1014.   the moment. Donald mentioned that he might work on a driver for the
  1015.   21040 at one stage or another.
  1016.  
  1017.  
  1018.   3.13.  Falleron
  1019.  
  1020.   Falleron sells EtherWave adaptors and transceivers. This device allows
  1021.   multiple 10baseT devices to be daisy-chained.
  1022.  
  1023.  
  1024.   3.13.1.  Falleron Etherwave
  1025.  
  1026.  
  1027.   Status -- Supported
  1028.  
  1029.   This is reported to be a 3c509 clone that includes the EtherWave
  1030.   transceiver. People have used these successfully with Linux and the
  1031.   present 3c509 driver. They are too expensive for general use, but are
  1032.   a great option for special cases.  Hublet prices start at $125, and
  1033.   Etherwave adds $75-$100 to the price of the board -- worth it if you
  1034.   have pulled one wire too few, but not if you are two network drops
  1035.   short.
  1036.  
  1037.  
  1038.   3.14.  Hewlett Packard
  1039.  
  1040.  
  1041.   The 272** cards use programmed I/O, similar to the NE*000 boards, but
  1042.   the data transfer port can be `turned off' when you aren't accessing
  1043.   it, avoiding problems with autoprobing drivers.
  1044.  
  1045.   Thanks to Glenn Talbott for helping clean up the confusion in this
  1046.   section regarding the version numbers of the HP hardware.
  1047.  
  1048.  
  1049.   3.14.1.  27245A
  1050.  
  1051.  
  1052.   Status -- Supported
  1053.  
  1054.   8 Bit 8390 based 10BaseT, not recommended for all the 8 bit reasons.
  1055.   It was re-designed a couple years ago to be highly integrated which
  1056.   caused some changes in initialization timing which only affected
  1057.   testing programs, not LAN drivers. (The new card is not `ready' as
  1058.   soon after switching into and out of loopback mode.)
  1059.  
  1060.  
  1061.   3.14.2.  HP PC Lan+ (27247A, 27247B, 27252A)
  1062.  
  1063.  
  1064.  
  1065.   Status -- Supported
  1066.  
  1067.   The HP PC Lan+ is different to the standard HP PC Lan card. This
  1068.   driver was added to the list of drivers in the standard kernel at
  1069.   about v1.1.3X. Note that even though the driver is included, the entry
  1070.   in `config.in' seems to have been omitted. If you want to use it, and
  1071.   it doesn't come up in `config.in' then add the following line to
  1072.   `config.in' under the  `HP PCLAN support' line:
  1073.  
  1074.  
  1075.           bool 'HP PCLAN Plus support' CONFIG_HPLAN_PLUS n
  1076.  
  1077.  
  1078.  
  1079.   Then run `make config;make dep;make zlilo' or whatever.
  1080.  
  1081.   The 47B is a 16 Bit 8390 based 10BaseT w/AUI, and the 52A is a 16 Bit
  1082.   8390 based ThinLAN w/AUI.  These cards are high performers (3c509
  1083.   speed) without the interrupt latency problems (32K onboard RAM for TX
  1084.   or RX packet buffering). They both offer LAN connector autosense, data
  1085.   I/O in I/O space (simpler) or memory mapped (faster), and soft
  1086.   configuration.
  1087.  
  1088.   The 47A is the older model that existed before the `B'.  Two versions
  1089.   27247-60001 or 27247-60002 have part numbers marked on the card.
  1090.   Functionally the same to the LAN driver, except bits in ROM to
  1091.   identify boards differ. -60002 has a jumper to allow operation in non-
  1092.   standard ISA busses (chipsets that expect IOCHRDY early.)
  1093.  
  1094.  
  1095.  
  1096.   3.14.3.  HP-J2405A
  1097.  
  1098.  
  1099.   Status -- Supported
  1100.  
  1101.   These are lower priced, and slightly faster than the 27247B/27252A,
  1102.   but are missing some features, such as AUI, ThinLAN connectivity, and
  1103.   boot PROM socket.  This is a fairly generic LANCE design, but a minor
  1104.   design decision makes it incompatible with a generic `NE2100' driver.
  1105.   Special support for it (including reading the DMA channel from the
  1106.   board) is included thanks to information provided by HP's Glenn
  1107.   Talbott.
  1108.  
  1109.   More technical information on LANCE based cards can be found in
  1110.   ``Notes on AMD...''
  1111.  
  1112.  
  1113.   3.14.4.  HP-Vectra On Board Ethernet
  1114.  
  1115.  
  1116.   Status -- Supported
  1117.  
  1118.   The HP-Vectra has an AMD PCnet chip on the motherboard.  Earlier
  1119.   kernel versions would detect it as the HP-J2405A but that would fail,
  1120.   as the Vectra doesn't report the IRQ and DMA channel like the J2405A.
  1121.   Get a kernel newer than v1.1.53 to avoid this problem.
  1122.  
  1123.   DMA selection and chip numbering information can be found in ``AMD
  1124.   LANCE''.
  1125.  
  1126.   More technical information on LANCE based cards can be found in
  1127.   ``Notes on AMD...''
  1128.  
  1129.  
  1130.  
  1131.   3.15.  IBM / International Business Machines
  1132.  
  1133.  
  1134.  
  1135.   3.15.1.  IBM Thinkpad 300
  1136.  
  1137.  
  1138.   Status -- Supported
  1139.  
  1140.   This is compatible with the Intel based Zenith Z-note.  See ``Z-note''
  1141.   for more info.
  1142.  
  1143.   Supposedly this site has a comprehensive database of useful stuff for
  1144.   newer versions of the Thinkpad. I haven't checked it out myself yet.
  1145.  
  1146.   Thinkpad-info (http://peipa.essex.ac.uk/html/linux-thinkpad.html)
  1147.  
  1148.   For those without a WWW browser handy, try
  1149.   peipa.essex.ac.uk:/pub/tp750/
  1150.  
  1151.  
  1152.   3.15.2.  IBM Credit Card Adaptor for Ethernet
  1153.  
  1154.  
  1155.   Status -- Semi-Supported
  1156.  
  1157.   People have been using this PCMCIA card with Linux as well.  Similar
  1158.   points apply, those being that you need a supported PCMCIA chipset on
  1159.   your notebook, and that you will have to patch the PCMCIA support into
  1160.   the standard kernel.
  1161.  
  1162.   See ``PCMCIA Support'' in this document, and if you can, have a look
  1163.   at:
  1164.  
  1165.   Don's PCMCIA Stuff (http://cesdis.gsfc.nasa.gov/linux/pcmcia.html)
  1166.  
  1167.  
  1168.  
  1169.   3.16.  Intel Ethernet Cards
  1170.  
  1171.  
  1172.  
  1173.   3.16.1.  Ether Express
  1174.  
  1175.  
  1176.   Status -- Semi-Supported
  1177.  
  1178.   This card uses the intel i82586. (Surprise, huh?)  The driver is in
  1179.   the standard release of the kernel, as an alpha driver. See ``Alpha
  1180.   Drivers'' for important information on using alpha-test ethernet
  1181.   drivers with Linux.
  1182.  
  1183.   The reason is that the driver works well with slow machines, but the
  1184.   i82586 occasionally hangs from the packet buffer contention that a
  1185.   fast machine can cause.  One reported hack/fix is to change all of the
  1186.   outw() calls to outw_p(). Also, the driver is missing promiscuous and
  1187.   multicast modes. (See ``Multicast and...'')
  1188.  
  1189.   There is also the standard way of using the chip (read slower) that is
  1190.   described in the chip manual, and used in other i82586 drivers, but
  1191.   this would require a re-write of the entire driver.
  1192.  
  1193.   There is some technical information available on the i82586 in
  1194.   ``Programming the Intel Chips'' and also in the source code for the
  1195.   driver `eexpress.c'. Don't be afraid to read it. ;-)
  1196.  
  1197.   3.17.  LinkSys
  1198.  
  1199.  
  1200.  
  1201.   3.17.1.  LinkSys PCMCIA Adaptor
  1202.  
  1203.  
  1204.   Status -- Semi-Supported
  1205.  
  1206.   This is supposed to be a re-badged DE-650. See the information on the
  1207.   DE-650 in ``DE-650''.
  1208.  
  1209.  
  1210.   3.18.  Mylex
  1211.  
  1212.  
  1213.  
  1214.   3.18.1.  Mylex LNP101, LNP104
  1215.  
  1216.  
  1217.   Status -- Not Supported
  1218.  
  1219.   These are PCI cards that are based on DEC's 21040 chip. The LNP104
  1220.   uses the 21050 chip to deliver four independent 10Base-T ports. The
  1221.   standard LNP101 is selectable between 10Base-T, 10Base-2 and 10Base-5
  1222.   output.  These cards may work with a generic 21040 driver if and when
  1223.   Linux gets one. (They aren't cheap either.)
  1224.  
  1225.   Mylex can be reached at the following numbers, in case anyone wants to
  1226.   ask them about programming information and the like.
  1227.  
  1228.  
  1229.           MYLEX CORPORATION, Fremont
  1230.           Sales:  800-77-MYLEX, (510) 796-6100
  1231.           FAX:    (510) 745-8016.
  1232.  
  1233.  
  1234.  
  1235.  
  1236.   3.19.  Novell Ethernet, NExxxx and associated clones.
  1237.  
  1238.  
  1239.   The prefix `NE' came from Novell Ethernet. Novell followed the
  1240.   cheapest NatSemi databook design and sold the manufacturing rights
  1241.   (spun off?) Eagle, just to get reasonably-priced ethercards into the
  1242.   market. (The now ubiquitous NE2000 card.)
  1243.  
  1244.  
  1245.   3.19.1.  NE1000, NE2000
  1246.  
  1247.  
  1248.   Status -- Supported
  1249.  
  1250.   The now-generic name for a bare-bones design around the NatSemi 8390.
  1251.   They use programmed I/O rather than shared memory, leading to easier
  1252.   installation but slightly lower performance and a few problems. Again,
  1253.   the savings of using an 8 bit NE1000 over the NE2000 are only
  1254.   warranted if you expect light use. Some recently introduced NE2000
  1255.   clones use the National Semiconductor `AT/LANTic' 83905 chip, which
  1256.   offers a shared memory mode similar to the 8013 and EEPROM or software
  1257.   configuration. Some problems can arise with poor clones. See
  1258.   ``Problems with...'', and ``NE2000 Clones''
  1259.  
  1260.   Donald has written a NE2000 diagnostic program, but it is still
  1261.   presently in alpha test. (ne2k) You can get it from the same place as
  1262.   the rest of Donald's work, see ``Alpha Drivers'' for the how and
  1263.   where.
  1264.  
  1265.  
  1266.   3.19.2.  NE1500, NE2100
  1267.  
  1268.  
  1269.   Status -- Supported
  1270.  
  1271.   These cards use the original 7990 LANCE chip from AMD and are
  1272.   supported using the Linux lance driver.
  1273.  
  1274.   Some earlier versions of the lance driver had problems with getting
  1275.   the IRQ line via autoIRQ from the original Novell/Eagle 7990 cards.
  1276.   Hopefully this is now fixed.  If not, then specify the IRQ via LILO,
  1277.   and let us know that it still has problems.
  1278.  
  1279.   DMA selection and chip numbering information can be found in ``AMD
  1280.   LANCE''.
  1281.  
  1282.   More technical information on LANCE based cards can be found in
  1283.   ``Notes on AMD...''
  1284.  
  1285.  
  1286.   3.19.3.  NE3200
  1287.  
  1288.  
  1289.   Status -- Not Supported
  1290.  
  1291.   This card uses a lowly 8MHz 80186, and hence you are better off using
  1292.   a cheap NE2000 clone. Even if a driver was available, the NE2000 card
  1293.   would most likely be faster.
  1294.  
  1295.  
  1296.   3.20.  Pure Data
  1297.  
  1298.  
  1299.  
  1300.   3.20.1.  PDUC8028, PDI8023
  1301.  
  1302.  
  1303.   Status -- Supported
  1304.  
  1305.   The PureData PDUC8028 and PDI8023 series of cards are reported to
  1306.   work, thanks to special probe code contributed by Mike Jagdis
  1307.   jaggy@purplet.demon.co.uk. The support is integrated with the WD
  1308.   driver.
  1309.  
  1310.  
  1311.   3.21.  Racal-Interlan
  1312.  
  1313.  
  1314.  
  1315.   3.21.1.  NI52**
  1316.  
  1317.  
  1318.   Status -- Semi-Supported
  1319.  
  1320.   Michael Hipp has written a driver for this card. It is included in the
  1321.   standard kernel as an `alpha' driver. Michael would like to hear
  1322.   feedback from users that have this card. See ``Alpha Drivers'' for
  1323.   important information on using alpha-test ethernet drivers with Linux.
  1324.  
  1325.   Michael says that ``the internal sysbus seems to be slow. So we often
  1326.   lose packets because of overruns while receiving from a fast remote
  1327.   host.''
  1328.  
  1329.   This card also uses one of the Intel chips. See ``Programming the
  1330.   Intel Chips'' for more technical information.
  1331.  
  1332.  
  1333.  
  1334.   3.21.2.  NI65**
  1335.  
  1336.  
  1337.   Status -- Semi-Supported
  1338.  
  1339.   There is also a driver for the LANCE based NI6510, and it is also
  1340.   written by Michael Hipp. Again, it is also an `alpha' driver. For some
  1341.   reason, this card is not compatible with the generic LANCE driver. See
  1342.   ``Alpha Drivers'' for important information on using alpha-test
  1343.   ethernet drivers with Linux.
  1344.  
  1345.  
  1346.   3.22.  Sager
  1347.  
  1348.  
  1349.  
  1350.   3.22.1.  Sager NP943
  1351.  
  1352.  
  1353.   Status -- Semi-Supported
  1354.  
  1355.   This is just a 3c501 clone, with a different S.A. PROM prefix. I
  1356.   assume it is equally as brain dead as the original 3c501 as well.
  1357.   Kernels 1.1.53 and up check for the NP943 i.d. and then just treat it
  1358.   as a 3c501 after that. See ``3Com 3c501'' for all the reasons as to
  1359.   why you really don't want to use one of these cards.
  1360.  
  1361.  
  1362.   3.23.  Schneider & Koch
  1363.  
  1364.  
  1365.  
  1366.   3.23.1.  SK G16
  1367.  
  1368.  
  1369.   Status -- Supported
  1370.  
  1371.   This driver was included into the v1.1 kernels, and it was written by
  1372.   PJD Weichmann and SWS Bern. It appears that the SK G16 is similar to
  1373.   the NI6510, in that it is based on the first edition LANCE chip (the
  1374.   7990). Once again, I have no idea as to why this card won't work with
  1375.   the generic LANCE driver.
  1376.  
  1377.  
  1378.   3.24.  Western Digital / SMC (Standard Microsystems Corp.)
  1379.  
  1380.  
  1381.   The ethernet part of Western Digital has been bought by SMC.  One
  1382.   common mistake people make is that the relatively new SMC Elite Ultra
  1383.   is the same as the older SMC Elite16 models -- this is not the case.
  1384.  
  1385.   Here is how to contact SMC (not that you should need to.)
  1386.  
  1387.        SMC / Standard Microsystems Corp., 80 Arkay Drive, Hauppage,
  1388.        New York, 11788, USA.
  1389.  
  1390.  
  1391.   Technical Support via phone:
  1392.  
  1393.  
  1394.  
  1395.           800-992-4762 (USA)
  1396.           800-433-5345 (Canada)
  1397.           516-435-6250 (Other Countries)
  1398.  
  1399.  
  1400.  
  1401.   Literature requests:
  1402.  
  1403.           800-SMC-4-YOU (USA)
  1404.           800-833-4-SMC (Canada)
  1405.           516-435-6255  (Other Countries)
  1406.  
  1407.  
  1408.  
  1409.  
  1410.   3.24.1.  WD8003, SMC Elite
  1411.  
  1412.   Status -- Supported
  1413.  
  1414.   These are the 8-bit versions of the card. The 8 bit 8003 is slightly
  1415.   less expensive, but only worth the savings for light use. As these are
  1416.   basically the same as their 16 bit counterparts (WD8013 / SMC
  1417.   Elite16), you should see the next section for more information.
  1418.  
  1419.  
  1420.  
  1421.   3.24.2.  WD8013, SMC Elite16
  1422.  
  1423.  
  1424.   Status -- Supported
  1425.  
  1426.   Over the years the design has added more registers and an EEPROM.
  1427.   Clones usually go by the `8013' name, and usually use a non-EEPROM
  1428.   (jumpered) design. This part of WD has been sold to SMC, so you'll
  1429.   usually see something like SMC/WD8013 or SMC Elite16 Plus (WD8013).
  1430.   The shared memory makes the cards 10-20 % faster, especially with
  1431.   larger packets. More importantly (to me at least) it avoids a few bugs
  1432.   in the programmed-I/O mode of the 8390, allows safe multi-threaded
  1433.   access to the packet buffer, and doesn't have a programmed-I/O data
  1434.   register that hangs your machine during warm-boot probes.
  1435.  
  1436.   There has been a Linux program `wdsetup' floating around here and
  1437.   there, but it fails to work properly with some cards. Best to use the
  1438.   MS-DOS utility that came with your card if you have an EEPROM version.
  1439.   Besides, hopefully it is something you will only be setting once.
  1440.  
  1441.   Also see ``8013 clones'' and ``8013 problems''.
  1442.  
  1443.  
  1444.   3.24.3.  SMC Elite Ultra
  1445.  
  1446.  
  1447.   Status -- Supported
  1448.  
  1449.   This ethercard is based on a new chip from SMC, with a few new
  1450.   features. While it has a mode that is similar to the older SMC
  1451.   ethercards, it's not compatible with the old WD80*3 drivers. However,
  1452.   in this mode it shares most of its code with the other 8390 drivers,
  1453.   while operating somewhat faster than a WD8013 clone.
  1454.  
  1455.   Some of the device probe checks in pl14 were too too strict, causing
  1456.   some cards to not be detected every time. This was fixed for pl14a,
  1457.   and hence is fine for pl15. Since part of the Ultra looks like an
  1458.   8013, the Ultra probe is supposed to find an Ultra before the wd8013
  1459.   probe has a chance to mistakenly identify it.
  1460.  
  1461.   Std. as of pl14, and made possible by documentation and ethercard loan
  1462.   from Duke Kamstra. If you plan on using an Ultra with Linux send him a
  1463.   note of thanks to let him know that there are Linux users out there!
  1464.  
  1465.   I'm considering writing a separate driver for the Ultra's `Altego'
  1466.   mode which allows chaining transmits at the cost of inefficient use of
  1467.   receive buffers, but that will probably not happen right away.
  1468.   Performance re-writes of working drivers are low priority unless there
  1469.   is some particular incentive or need.
  1470.  
  1471.   Bus-Master SCSI host adaptor users take note: In the manual that ships
  1472.   with Interactive UNIX, it mentions that a bug in the SMC Ultra will
  1473.   cause data corruption with SCSI disks being run from an aha-154X host
  1474.   adaptor.  This will probably bite aha-154X compatible cards, such as
  1475.   the BusLogic boards, and the AMI-FastDisk SCSI host adaptors as well.
  1476.  
  1477.   Supposedly SMC has acknowledged the problem occurs with Interactive,
  1478.   and older Windows NT drivers. It is supposed to be a hardware conflict
  1479.   that can be worked around in the driver design. More on this as it
  1480.   develops.
  1481.  
  1482.   Some Linux users with an Ultra + aha-154X compatible cards have
  1483.   experienced data corruption, while others have not.  Donald tried this
  1484.   combination himself, and wasn't able to reproduce the problem. You
  1485.   have been warned.
  1486.  
  1487.  
  1488.   3.24.4.  SMC PCI Card
  1489.  
  1490.  
  1491.   Status -- Not Supported
  1492.  
  1493.   Supposedly SMC is offering an evaluation deal of one of these new PCI
  1494.   cards for $99 -- not a real great deal when you consider that the BOCA
  1495.   PCnet-PCI based cards are going for about $70 and they are supported
  1496.   under Linux already. If anybody knows what chipset is on these new SMC
  1497.   cards, let me know.
  1498.  
  1499.  
  1500.   3.25.  Xircom
  1501.  
  1502.  
  1503.  
  1504.   Another group that won't release documentation. No cards supported.
  1505.   Don't look for any support in the future unless they release their
  1506.   programming information. And this is highly unlikely, as they *forbid*
  1507.   you from even reverse- engineering their drivers. If you are already
  1508.   stuck with one, see if you can trade it off on some DOS (l)user.
  1509.  
  1510. ---End of part 1/2---
  1511.  
  1512.  
  1513.