| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 |  | 
|  | 2 | NOTE | 
|  | 3 | ---- | 
|  | 4 |  | 
|  | 5 | This document was contributed by Cirrus Logic for kernel 2.2.5.  This version | 
| Francois Cami | e1f8e87 | 2008-10-15 22:01:59 -0700 | [diff] [blame] | 6 | has been updated for 2.3.48 by Andrew Morton. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 |  | 
|  | 8 | Cirrus make a copy of this driver available at their website, as | 
|  | 9 | described below.  In general, you should use the driver version which | 
|  | 10 | comes with your Linux distribution. | 
|  | 11 |  | 
|  | 12 |  | 
|  | 13 |  | 
|  | 14 | CIRRUS LOGIC LAN CS8900/CS8920 ETHERNET ADAPTERS | 
|  | 15 | Linux Network Interface Driver ver. 2.00 <kernel 2.3.48> | 
|  | 16 | =============================================================================== | 
|  | 17 |  | 
|  | 18 |  | 
|  | 19 | TABLE OF CONTENTS | 
|  | 20 |  | 
|  | 21 | 1.0 CIRRUS LOGIC LAN CS8900/CS8920 ETHERNET ADAPTERS | 
|  | 22 | 1.1 Product Overview | 
|  | 23 | 1.2 Driver Description | 
|  | 24 | 1.2.1 Driver Name | 
|  | 25 | 1.2.2 File in the Driver Package | 
|  | 26 | 1.3 System Requirements | 
|  | 27 | 1.4 Licensing Information | 
|  | 28 |  | 
|  | 29 | 2.0 ADAPTER INSTALLATION and CONFIGURATION | 
|  | 30 | 2.1 CS8900-based Adapter Configuration | 
|  | 31 | 2.2 CS8920-based Adapter Configuration | 
|  | 32 |  | 
|  | 33 | 3.0 LOADING THE DRIVER AS A MODULE | 
|  | 34 |  | 
|  | 35 | 4.0 COMPILING THE DRIVER | 
|  | 36 | 4.1 Compiling the Driver as a Loadable Module | 
|  | 37 | 4.2 Compiling the driver to support memory mode | 
|  | 38 | 4.3 Compiling the driver to support Rx DMA | 
|  | 39 | 4.4 Compiling the Driver into the Kernel | 
|  | 40 |  | 
|  | 41 | 5.0 TESTING AND TROUBLESHOOTING | 
|  | 42 | 5.1 Known Defects and Limitations | 
|  | 43 | 5.2 Testing the Adapter | 
|  | 44 | 5.2.1 Diagnostic Self-Test | 
|  | 45 | 5.2.2 Diagnostic Network Test | 
|  | 46 | 5.3 Using the Adapter's LEDs | 
|  | 47 | 5.4 Resolving I/O Conflicts | 
|  | 48 |  | 
|  | 49 | 6.0 TECHNICAL SUPPORT | 
|  | 50 | 6.1 Contacting Cirrus Logic's Technical Support | 
|  | 51 | 6.2 Information Required Before Contacting Technical Support | 
|  | 52 | 6.3 Obtaining the Latest Driver Version | 
|  | 53 | 6.4 Current maintainer | 
|  | 54 | 6.5 Kernel boot parameters | 
|  | 55 |  | 
|  | 56 |  | 
|  | 57 | 1.0 CIRRUS LOGIC LAN CS8900/CS8920 ETHERNET ADAPTERS | 
|  | 58 | =============================================================================== | 
|  | 59 |  | 
|  | 60 |  | 
|  | 61 | 1.1 PRODUCT OVERVIEW | 
|  | 62 |  | 
|  | 63 | The CS8900-based ISA Ethernet Adapters from Cirrus Logic follow | 
|  | 64 | IEEE 802.3 standards and support half or full-duplex operation in ISA bus | 
|  | 65 | computers on 10 Mbps Ethernet networks.  The adapters are designed for operation | 
|  | 66 | in 16-bit ISA or EISA bus expansion slots and are available in | 
|  | 67 | 10BaseT-only or 3-media configurations (10BaseT, 10Base2, and AUI for 10Base-5 | 
|  | 68 | or fiber networks). | 
|  | 69 |  | 
|  | 70 | CS8920-based adapters are similar to the CS8900-based adapter with additional | 
|  | 71 | features for Plug and Play (PnP) support and Wakeup Frame recognition.  As | 
|  | 72 | such, the configuration procedures differ somewhat between the two types of | 
|  | 73 | adapters.  Refer to the "Adapter Configuration" section for details on | 
|  | 74 | configuring both types of adapters. | 
|  | 75 |  | 
|  | 76 |  | 
|  | 77 | 1.2 DRIVER DESCRIPTION | 
|  | 78 |  | 
|  | 79 | The CS8900/CS8920 Ethernet Adapter driver for Linux supports the Linux | 
|  | 80 | v2.3.48 or greater kernel.  It can be compiled directly into the kernel | 
|  | 81 | or loaded at run-time as a device driver module. | 
|  | 82 |  | 
|  | 83 | 1.2.1 Driver Name: cs89x0 | 
|  | 84 |  | 
|  | 85 | 1.2.2 Files in the Driver Archive: | 
|  | 86 |  | 
|  | 87 | The files in the driver at Cirrus' website include: | 
|  | 88 |  | 
|  | 89 | readme.txt         - this file | 
|  | 90 | build              - batch file to compile cs89x0.c. | 
|  | 91 | cs89x0.c           - driver C code | 
|  | 92 | cs89x0.h           - driver header file | 
|  | 93 | cs89x0.o           - pre-compiled module (for v2.2.5 kernel) | 
|  | 94 | config/Config.in   - sample file to include cs89x0 driver in the kernel. | 
|  | 95 | config/Makefile    - sample file to include cs89x0 driver in the kernel. | 
|  | 96 | config/Space.c     - sample file to include cs89x0 driver in the kernel. | 
|  | 97 |  | 
|  | 98 |  | 
|  | 99 |  | 
|  | 100 | 1.3 SYSTEM REQUIREMENTS | 
|  | 101 |  | 
|  | 102 | The following hardware is required: | 
|  | 103 |  | 
|  | 104 | * Cirrus Logic LAN (CS8900/20-based) Ethernet ISA Adapter | 
|  | 105 |  | 
|  | 106 | * IBM or IBM-compatible PC with: | 
|  | 107 | * An 80386 or higher processor | 
|  | 108 | * 16 bytes of contiguous IO space available between 210h - 370h | 
|  | 109 | * One available IRQ (5,10,11,or 12 for the CS8900, 3-7,9-15 for CS8920). | 
|  | 110 |  | 
|  | 111 | * Appropriate cable (and connector for AUI, 10BASE-2) for your network | 
|  | 112 | topology. | 
|  | 113 |  | 
|  | 114 | The following software is required: | 
|  | 115 |  | 
|  | 116 | * LINUX kernel version 2.3.48 or higher | 
|  | 117 |  | 
|  | 118 | * CS8900/20 Setup Utility (DOS-based) | 
|  | 119 |  | 
|  | 120 | * LINUX kernel sources for your kernel (if compiling into kernel) | 
|  | 121 |  | 
|  | 122 | * GNU Toolkit (gcc and make) v2.6 or above (if compiling into kernel | 
|  | 123 | or a module) | 
|  | 124 |  | 
|  | 125 |  | 
|  | 126 |  | 
|  | 127 | 1.4 LICENSING INFORMATION | 
|  | 128 |  | 
|  | 129 | This program is free software; you can redistribute it and/or modify it under | 
|  | 130 | the terms of the GNU General Public License as published by the Free Software | 
|  | 131 | Foundation, version 1. | 
|  | 132 |  | 
|  | 133 | This program is distributed in the hope that it will be useful, but WITHOUT | 
|  | 134 | ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | 
|  | 135 | FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for | 
|  | 136 | more details. | 
|  | 137 |  | 
|  | 138 | For a full copy of the GNU General Public License, write to the Free Software | 
|  | 139 | Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 
|  | 140 |  | 
|  | 141 |  | 
|  | 142 |  | 
|  | 143 | 2.0 ADAPTER INSTALLATION and CONFIGURATION | 
|  | 144 | =============================================================================== | 
|  | 145 |  | 
|  | 146 | Both the CS8900 and CS8920-based adapters can be configured using parameters | 
|  | 147 | stored in an on-board EEPROM. You must use the DOS-based CS8900/20 Setup | 
|  | 148 | Utility if you want to change the adapter's configuration in EEPROM. | 
|  | 149 |  | 
|  | 150 | When loading the driver as a module, you can specify many of the adapter's | 
|  | 151 | configuration parameters on the command-line to override the EEPROM's settings | 
|  | 152 | or for interface configuration when an EEPROM is not used. (CS8920-based | 
|  | 153 | adapters must use an EEPROM.) See Section 3.0 LOADING THE DRIVER AS A MODULE. | 
|  | 154 |  | 
|  | 155 | Since the CS8900/20 Setup Utility is a DOS-based application, you must install | 
|  | 156 | and configure the adapter in a DOS-based system using the CS8900/20 Setup | 
|  | 157 | Utility before installation in the target LINUX system.  (Not required if | 
|  | 158 | installing a CS8900-based adapter and the default configuration is acceptable.) | 
|  | 159 |  | 
|  | 160 |  | 
|  | 161 | 2.1 CS8900-BASED ADAPTER CONFIGURATION | 
|  | 162 |  | 
|  | 163 | CS8900-based adapters shipped from Cirrus Logic have been configured | 
|  | 164 | with the following "default" settings: | 
|  | 165 |  | 
|  | 166 | Operation Mode:      Memory Mode | 
|  | 167 | IRQ:                 10 | 
|  | 168 | Base I/O Address:    300 | 
|  | 169 | Memory Base Address: D0000 | 
|  | 170 | Optimization:	       DOS Client | 
|  | 171 | Transmission Mode:   Half-duplex | 
|  | 172 | BootProm:            None | 
|  | 173 | Media Type:	       Autodetect (3-media cards) or | 
|  | 174 | 10BASE-T (10BASE-T only adapter) | 
|  | 175 |  | 
|  | 176 | You should only change the default configuration settings if conflicts with | 
|  | 177 | another adapter exists. To change the adapter's configuration, run the | 
|  | 178 | CS8900/20 Setup Utility. | 
|  | 179 |  | 
|  | 180 |  | 
|  | 181 | 2.2 CS8920-BASED ADAPTER CONFIGURATION | 
|  | 182 |  | 
|  | 183 | CS8920-based adapters are shipped from Cirrus Logic configured as Plug | 
|  | 184 | and Play (PnP) enabled.  However, since the cs89x0 driver does NOT | 
|  | 185 | support PnP, you must install the CS8920 adapter in a DOS-based PC and | 
|  | 186 | run the CS8900/20 Setup Utility to disable PnP and configure the | 
|  | 187 | adapter before installation in the target Linux system.  Failure to do | 
|  | 188 | this will leave the adapter inactive and the driver will be unable to | 
|  | 189 | communicate with the adapter. | 
|  | 190 |  | 
|  | 191 |  | 
|  | 192 | **************************************************************** | 
|  | 193 | *                    CS8920-BASED ADAPTERS:                    * | 
|  | 194 | *                                                              * | 
|  | 195 | * CS8920-BASED ADAPTERS ARE PLUG and PLAY ENABLED BY DEFAULT.  * | 
|  | 196 | * THE CS89X0 DRIVER DOES NOT SUPPORT PnP. THEREFORE, YOU MUST  * | 
|  | 197 | * RUN THE CS8900/20 SETUP UTILITY TO DISABLE PnP SUPPORT AND   * | 
|  | 198 | * TO ACTIVATE THE ADAPTER.                                     * | 
|  | 199 | **************************************************************** | 
|  | 200 |  | 
|  | 201 |  | 
|  | 202 |  | 
|  | 203 |  | 
|  | 204 | 3.0 LOADING THE DRIVER AS A MODULE | 
|  | 205 | =============================================================================== | 
|  | 206 |  | 
|  | 207 | If the driver is compiled as a loadable module, you can load the driver module | 
|  | 208 | with the 'modprobe' command.  Many of the adapter's configuration parameters can | 
|  | 209 | be specified as command-line arguments to the load command.  This facility | 
|  | 210 | provides a means to override the EEPROM's settings or for interface | 
|  | 211 | configuration when an EEPROM is not used. | 
|  | 212 |  | 
|  | 213 | Example: | 
|  | 214 |  | 
|  | 215 | insmod cs89x0.o io=0x200 irq=0xA media=aui | 
|  | 216 |  | 
|  | 217 | This example loads the module and configures the adapter to use an IO port base | 
|  | 218 | address of 200h, interrupt 10, and use the AUI media connection.  The following | 
|  | 219 | configuration options are available on the command line: | 
|  | 220 |  | 
|  | 221 | * io=###               - specify IO address (200h-360h) | 
|  | 222 | * irq=##               - specify interrupt level | 
|  | 223 | * use_dma=1            - Enable DMA | 
|  | 224 | * dma=#                - specify dma channel (Driver is compiled to support | 
|  | 225 | Rx DMA only) | 
|  | 226 | * dmasize=# (16 or 64) - DMA size 16K or 64K.  Default value is set to 16. | 
|  | 227 | * media=rj45           - specify media type | 
|  | 228 | or media=bnc | 
|  | 229 | or media=aui | 
| Matt LaPlante | 2fe0ae7 | 2006-10-03 22:50:39 +0200 | [diff] [blame] | 230 | or media=auto | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 231 | * duplex=full          - specify forced half/full/autonegotiate duplex | 
|  | 232 | or duplex=half | 
|  | 233 | or duplex=auto | 
|  | 234 | * debug=#              - debug level (only available if the driver was compiled | 
|  | 235 | for debugging) | 
|  | 236 |  | 
|  | 237 | NOTES: | 
|  | 238 |  | 
|  | 239 | a) If an EEPROM is present, any specified command-line parameter | 
|  | 240 | will override the corresponding configuration value stored in | 
|  | 241 | EEPROM. | 
|  | 242 |  | 
|  | 243 | b) The "io" parameter must be specified on the command-line. | 
|  | 244 |  | 
|  | 245 | c) The driver's hardware probe routine is designed to avoid | 
|  | 246 | writing to I/O space until it knows that there is a cs89x0 | 
|  | 247 | card at the written addresses.  This could cause problems | 
|  | 248 | with device probing.  To avoid this behaviour, add one | 
|  | 249 | to the `io=' module parameter.  This doesn't actually change | 
|  | 250 | the I/O address, but it is a flag to tell the driver | 
| Matt LaPlante | fa00e7e | 2006-11-30 04:55:36 +0100 | [diff] [blame] | 251 | to partially initialise the hardware before trying to | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 252 | identify the card.  This could be dangerous if you are | 
|  | 253 | not sure that there is a cs89x0 card at the provided address. | 
|  | 254 |  | 
|  | 255 | For example, to scan for an adapter located at IO base 0x300, | 
|  | 256 | specify an IO address of 0x301. | 
|  | 257 |  | 
|  | 258 | d) The "duplex=auto" parameter is only supported for the CS8920. | 
|  | 259 |  | 
|  | 260 | e) The minimum command-line configuration required if an EEPROM is | 
|  | 261 | not present is: | 
|  | 262 |  | 
|  | 263 | io | 
|  | 264 | irq | 
|  | 265 | media type (no autodetect) | 
|  | 266 |  | 
|  | 267 | f) The following additional parameters are CS89XX defaults (values | 
|  | 268 | used with no EEPROM or command-line argument). | 
|  | 269 |  | 
|  | 270 | * DMA Burst = enabled | 
|  | 271 | * IOCHRDY Enabled = enabled | 
|  | 272 | * UseSA = enabled | 
|  | 273 | * CS8900 defaults to half-duplex if not specified on command-line | 
|  | 274 | * CS8920 defaults to autoneg if not specified on command-line | 
|  | 275 | * Use reset defaults for other config parameters | 
|  | 276 | * dma_mode = 0 | 
|  | 277 |  | 
|  | 278 | g) You can use ifconfig to set the adapter's Ethernet address. | 
|  | 279 |  | 
|  | 280 | h) Many Linux distributions use the 'modprobe' command to load | 
|  | 281 | modules.  This program uses the '/etc/conf.modules' file to | 
|  | 282 | determine configuration information which is passed to a driver | 
|  | 283 | module when it is loaded.  All the configuration options which are | 
|  | 284 | described above may be placed within /etc/conf.modules. | 
|  | 285 |  | 
|  | 286 | For example: | 
|  | 287 |  | 
|  | 288 | > cat /etc/conf.modules | 
|  | 289 | ... | 
|  | 290 | alias eth0 cs89x0 | 
|  | 291 | options cs89x0 io=0x0200 dma=5 use_dma=1 | 
|  | 292 | ... | 
|  | 293 |  | 
|  | 294 | In this example we are telling the module system that the | 
|  | 295 | ethernet driver for this machine should use the cs89x0 driver.  We | 
|  | 296 | are asking 'modprobe' to pass the 'io', 'dma' and 'use_dma' | 
|  | 297 | arguments to the driver when it is loaded. | 
|  | 298 |  | 
|  | 299 | i) Cirrus recommend that the cs89x0 use the ISA DMA channels 5, 6 or | 
|  | 300 | 7.  You will probably find that other DMA channels will not work. | 
|  | 301 |  | 
|  | 302 | j) The cs89x0 supports DMA for receiving only.  DMA mode is | 
|  | 303 | significantly more efficient.  Flooding a 400 MHz Celeron machine | 
|  | 304 | with large ping packets consumes 82% of its CPU capacity in non-DMA | 
|  | 305 | mode.  With DMA this is reduced to 45%. | 
|  | 306 |  | 
|  | 307 | k) If your Linux kernel was compiled with inbuilt plug-and-play | 
|  | 308 | support you will be able to find information about the cs89x0 card | 
|  | 309 | with the command | 
|  | 310 |  | 
|  | 311 | cat /proc/isapnp | 
|  | 312 |  | 
|  | 313 | l) If during DMA operation you find erratic behavior or network data | 
|  | 314 | corruption you should use your PC's BIOS to slow the EISA bus clock. | 
|  | 315 |  | 
|  | 316 | m) If the cs89x0 driver is compiled directly into the kernel | 
|  | 317 | (non-modular) then its I/O address is automatically determined by | 
|  | 318 | ISA bus probing.  The IRQ number, media options, etc are determined | 
|  | 319 | from the card's EEPROM. | 
|  | 320 |  | 
|  | 321 | n) If the cs89x0 driver is compiled directly into the kernel, DMA | 
|  | 322 | mode may be selected by providing the kernel with a boot option | 
|  | 323 | 'cs89x0_dma=N' where 'N' is the desired DMA channel number (5, 6 or 7). | 
|  | 324 |  | 
|  | 325 | Kernel boot options may be provided on the LILO command line: | 
|  | 326 |  | 
|  | 327 | LILO boot: linux cs89x0_dma=5 | 
|  | 328 |  | 
|  | 329 | or they may be placed in /etc/lilo.conf: | 
|  | 330 |  | 
|  | 331 | image=/boot/bzImage-2.3.48 | 
|  | 332 | append="cs89x0_dma=5" | 
|  | 333 | label=linux | 
|  | 334 | root=/dev/hda5 | 
|  | 335 | read-only | 
|  | 336 |  | 
|  | 337 | The DMA Rx buffer size is hardwired to 16 kbytes in this mode. | 
|  | 338 | (64k mode is not available). | 
|  | 339 |  | 
|  | 340 |  | 
|  | 341 | 4.0 COMPILING THE DRIVER | 
|  | 342 | =============================================================================== | 
|  | 343 |  | 
|  | 344 | The cs89x0 driver can be compiled directly into the kernel or compiled into | 
|  | 345 | a loadable device driver module. | 
|  | 346 |  | 
|  | 347 |  | 
|  | 348 | 4.1 COMPILING THE DRIVER AS A LOADABLE MODULE | 
|  | 349 |  | 
|  | 350 | To compile the driver into a loadable module, use the following command | 
|  | 351 | (single command line, without quotes): | 
|  | 352 |  | 
|  | 353 | "gcc -D__KERNEL__ -I/usr/src/linux/include -I/usr/src/linux/net/inet -Wall | 
|  | 354 | -Wstrict-prototypes -O2 -fomit-frame-pointer -DMODULE -DCONFIG_MODVERSIONS | 
|  | 355 | -c cs89x0.c" | 
|  | 356 |  | 
|  | 357 | 4.2 COMPILING THE DRIVER TO SUPPORT MEMORY MODE | 
|  | 358 |  | 
|  | 359 | Support for memory mode was not carried over into the 2.3 series kernels. | 
|  | 360 |  | 
|  | 361 | 4.3 COMPILING THE DRIVER TO SUPPORT Rx DMA | 
|  | 362 |  | 
|  | 363 | The compile-time optionality for DMA was removed in the 2.3 kernel | 
|  | 364 | series.  DMA support is now unconditionally part of the driver.  It is | 
|  | 365 | enabled by the 'use_dma=1' module option. | 
|  | 366 |  | 
|  | 367 | 4.4 COMPILING THE DRIVER INTO THE KERNEL | 
|  | 368 |  | 
|  | 369 | If your Linux distribution already has support for the cs89x0 driver | 
|  | 370 | then simply copy the source file to the /usr/src/linux/drivers/net | 
|  | 371 | directory to replace the original ones and run the make utility to | 
|  | 372 | rebuild the kernel.  See Step 3 for rebuilding the kernel. | 
|  | 373 |  | 
|  | 374 | If your Linux does not include the cs89x0 driver, you need to edit three | 
|  | 375 | configuration files, copy the source file to the /usr/src/linux/drivers/net | 
|  | 376 | directory, and then run the make utility to rebuild the kernel. | 
|  | 377 |  | 
|  | 378 | 1. Edit the following configuration files by adding the statements as | 
|  | 379 | indicated.  (When possible, try to locate the added text to the section of the | 
|  | 380 | file containing similar statements). | 
|  | 381 |  | 
|  | 382 |  | 
|  | 383 | a.) In /usr/src/linux/drivers/net/Config.in, add: | 
|  | 384 |  | 
|  | 385 | tristate 'CS89x0 support' CONFIG_CS89x0 | 
|  | 386 |  | 
|  | 387 | Example: | 
|  | 388 |  | 
|  | 389 | if [ "$CONFIG_EXPERIMENTAL" = "y" ]; then | 
|  | 390 | tristate 'ICL EtherTeam 16i/32 support' CONFIG_ETH16I | 
|  | 391 | fi | 
|  | 392 |  | 
|  | 393 | tristate 'CS89x0 support' CONFIG_CS89x0 | 
|  | 394 |  | 
|  | 395 | tristate 'NE2000/NE1000 support' CONFIG_NE2000 | 
|  | 396 | if [ "$CONFIG_EXPERIMENTAL" = "y" ]; then | 
|  | 397 | tristate 'NI5210 support' CONFIG_NI52 | 
|  | 398 |  | 
|  | 399 |  | 
|  | 400 | b.) In /usr/src/linux/drivers/net/Makefile, add the following lines: | 
|  | 401 |  | 
|  | 402 | ifeq ($(CONFIG_CS89x0),y) | 
|  | 403 | L_OBJS += cs89x0.o | 
|  | 404 | else | 
|  | 405 | ifeq ($(CONFIG_CS89x0),m) | 
|  | 406 | M_OBJS += cs89x0.o | 
|  | 407 | endif | 
|  | 408 | endif | 
|  | 409 |  | 
|  | 410 |  | 
|  | 411 | c.) In /linux/drivers/net/Space.c file, add the line: | 
|  | 412 |  | 
|  | 413 | extern int cs89x0_probe(struct device *dev); | 
|  | 414 |  | 
|  | 415 |  | 
|  | 416 | Example: | 
|  | 417 |  | 
|  | 418 | extern int ultra_probe(struct device *dev); | 
|  | 419 | extern int wd_probe(struct device *dev); | 
|  | 420 | extern int el2_probe(struct device *dev); | 
|  | 421 |  | 
|  | 422 | extern int cs89x0_probe(struct device *dev); | 
|  | 423 |  | 
|  | 424 | extern int ne_probe(struct device *dev); | 
|  | 425 | extern int hp_probe(struct device *dev); | 
|  | 426 | extern int hp_plus_probe(struct device *dev); | 
|  | 427 |  | 
|  | 428 |  | 
|  | 429 | Also add: | 
|  | 430 |  | 
|  | 431 | #ifdef CONFIG_CS89x0 | 
|  | 432 | { cs89x0_probe,0 }, | 
|  | 433 | #endif | 
|  | 434 |  | 
|  | 435 |  | 
|  | 436 | 2.) Copy the driver source files (cs89x0.c and cs89x0.h) | 
|  | 437 | into the /usr/src/linux/drivers/net directory. | 
|  | 438 |  | 
|  | 439 |  | 
|  | 440 | 3.) Go to /usr/src/linux directory and run 'make config' followed by 'make' | 
|  | 441 | (or make bzImage) to rebuild the kernel. | 
|  | 442 |  | 
|  | 443 | 4.) Use the DOS 'setup' utility to disable plug and play on the NIC. | 
|  | 444 |  | 
|  | 445 |  | 
|  | 446 | 5.0 TESTING AND TROUBLESHOOTING | 
|  | 447 | =============================================================================== | 
|  | 448 |  | 
|  | 449 | 5.1 KNOWN DEFECTS and LIMITATIONS | 
|  | 450 |  | 
|  | 451 | Refer to the RELEASE.TXT file distributed as part of this archive for a list of | 
|  | 452 | known defects, driver limitations, and work arounds. | 
|  | 453 |  | 
|  | 454 |  | 
|  | 455 | 5.2 TESTING THE ADAPTER | 
|  | 456 |  | 
|  | 457 | Once the adapter has been installed and configured, the diagnostic option of | 
|  | 458 | the CS8900/20 Setup Utility can be used to test the functionality of the | 
|  | 459 | adapter and its network connection.  Use the diagnostics 'Self Test' option to | 
|  | 460 | test the functionality of the adapter with the hardware configuration you have | 
|  | 461 | assigned. You can use the diagnostics 'Network Test' to test the ability of the | 
|  | 462 | adapter to communicate across the Ethernet with another PC equipped with a | 
|  | 463 | CS8900/20-based adapter card (it must also be running the CS8900/20 Setup | 
|  | 464 | Utility). | 
|  | 465 |  | 
|  | 466 | NOTE: The Setup Utility's diagnostics are designed to run in a | 
|  | 467 | DOS-only operating system environment.  DO NOT run the diagnostics | 
|  | 468 | from a DOS or command prompt session under Windows 95, Windows NT, | 
|  | 469 | OS/2, or other operating system. | 
|  | 470 |  | 
|  | 471 | To run the diagnostics tests on the CS8900/20 adapter: | 
|  | 472 |  | 
|  | 473 | 1.) Boot DOS on the PC and start the CS8900/20 Setup Utility. | 
|  | 474 |  | 
|  | 475 | 2.) The adapter's current configuration is displayed.  Hit the ENTER key to | 
|  | 476 | get to the main menu. | 
|  | 477 |  | 
|  | 478 | 4.) Select 'Diagnostics' (ALT-G) from the main menu. | 
|  | 479 | * Select 'Self-Test' to test the adapter's basic functionality. | 
|  | 480 | * Select 'Network Test' to test the network connection and cabling. | 
|  | 481 |  | 
|  | 482 |  | 
|  | 483 | 5.2.1 DIAGNOSTIC SELF-TEST | 
|  | 484 |  | 
|  | 485 | The diagnostic self-test checks the adapter's basic functionality as well as | 
|  | 486 | its ability to communicate across the ISA bus based on the system resources | 
|  | 487 | assigned during hardware configuration.  The following tests are performed: | 
|  | 488 |  | 
|  | 489 | * IO Register Read/Write Test | 
|  | 490 | The IO Register Read/Write test insures that the CS8900/20 can be | 
|  | 491 | accessed in IO mode, and that the IO base address is correct. | 
|  | 492 |  | 
|  | 493 | * Shared Memory Test | 
|  | 494 | The Shared Memory test insures the CS8900/20 can be accessed in memory | 
|  | 495 | mode and that the range of memory addresses assigned does not conflict | 
|  | 496 | with other devices in the system. | 
|  | 497 |  | 
|  | 498 | * Interrupt Test | 
|  | 499 | The Interrupt test insures there are no conflicts with the assigned IRQ | 
|  | 500 | signal. | 
|  | 501 |  | 
|  | 502 | * EEPROM Test | 
|  | 503 | The EEPROM test insures the EEPROM can be read. | 
|  | 504 |  | 
|  | 505 | * Chip RAM Test | 
|  | 506 | The Chip RAM test insures the 4K of memory internal to the CS8900/20 is | 
|  | 507 | working properly. | 
|  | 508 |  | 
|  | 509 | * Internal Loop-back Test | 
|  | 510 | The Internal Loop Back test insures the adapter's transmitter and | 
|  | 511 | receiver are operating properly.  If this test fails, make sure the | 
|  | 512 | adapter's cable is connected to the network (check for LED activity for | 
|  | 513 | example). | 
|  | 514 |  | 
|  | 515 | * Boot PROM Test | 
|  | 516 | The Boot PROM  test insures the Boot PROM is present, and can be read. | 
|  | 517 | Failure indicates the Boot PROM  was not successfully read due to a | 
|  | 518 | hardware problem or due to a conflicts on the Boot PROM address | 
|  | 519 | assignment. (Test only applies if the adapter is configured to use the | 
|  | 520 | Boot PROM option.) | 
|  | 521 |  | 
|  | 522 | Failure of a test item indicates a possible system resource conflict with | 
|  | 523 | another device on the ISA bus.  In this case, you should use the Manual Setup | 
|  | 524 | option to reconfigure the adapter by selecting a different value for the system | 
|  | 525 | resource that failed. | 
|  | 526 |  | 
|  | 527 |  | 
|  | 528 | 5.2.2 DIAGNOSTIC NETWORK TEST | 
|  | 529 |  | 
|  | 530 | The Diagnostic Network Test verifies a working network connection by | 
|  | 531 | transferring data between two CS8900/20 adapters installed in different PCs | 
|  | 532 | on the same network. (Note: the diagnostic network test should not be run | 
|  | 533 | between two nodes across a router.) | 
|  | 534 |  | 
|  | 535 | This test requires that each of the two PCs have a CS8900/20-based adapter | 
|  | 536 | installed and have the CS8900/20 Setup Utility running.  The first PC is | 
|  | 537 | configured as a Responder and the other PC is configured as an Initiator. | 
|  | 538 | Once the Initiator is started, it sends data frames to the Responder which | 
|  | 539 | returns the frames to the Initiator. | 
|  | 540 |  | 
|  | 541 | The total number of frames received and transmitted are displayed on the | 
|  | 542 | Initiator's display, along with a count of the number of frames received and | 
|  | 543 | transmitted OK or in error.  The test can be terminated anytime by the user at | 
|  | 544 | either PC. | 
|  | 545 |  | 
|  | 546 | To setup the Diagnostic Network Test: | 
|  | 547 |  | 
|  | 548 | 1.) Select a PC with a CS8900/20-based adapter and a known working network | 
|  | 549 | connection to act as the Responder.  Run the CS8900/20 Setup Utility | 
|  | 550 | and select 'Diagnostics -> Network Test -> Responder' from the main | 
|  | 551 | menu.  Hit ENTER to start the Responder. | 
|  | 552 |  | 
|  | 553 | 2.) Return to the PC with the CS8900/20-based adapter you want to test and | 
|  | 554 | start the CS8900/20 Setup Utility. | 
|  | 555 |  | 
|  | 556 | 3.) From the main menu, Select 'Diagnostic -> Network Test -> Initiator'. | 
|  | 557 | Hit ENTER to start the test. | 
|  | 558 |  | 
|  | 559 | You may stop the test on the Initiator at any time while allowing the Responder | 
|  | 560 | to continue running.  In this manner, you can move to additional PCs and test | 
|  | 561 | them by starting the Initiator on another PC without having to stop/start the | 
|  | 562 | Responder. | 
|  | 563 |  | 
|  | 564 |  | 
|  | 565 |  | 
|  | 566 | 5.3 USING THE ADAPTER'S LEDs | 
|  | 567 |  | 
|  | 568 | The 2 and 3-media adapters have two LEDs visible on the back end of the board | 
|  | 569 | located near the 10Base-T connector. | 
|  | 570 |  | 
|  | 571 | Link Integrity LED: A "steady" ON of the green LED indicates a valid 10Base-T | 
|  | 572 | connection.  (Only applies to 10Base-T.  The green LED has no significance for | 
|  | 573 | a 10Base-2 or AUI connection.) | 
|  | 574 |  | 
|  | 575 | TX/RX LED: The yellow LED lights briefly each time the adapter transmits or | 
|  | 576 | receives data. (The yellow LED will appear to "flicker" on a typical network.) | 
|  | 577 |  | 
|  | 578 |  | 
|  | 579 | 5.4 RESOLVING I/O CONFLICTS | 
|  | 580 |  | 
|  | 581 | An IO conflict occurs when two or more adapter use the same ISA resource (IO | 
|  | 582 | address, memory address or IRQ).  You can usually detect an IO conflict in one | 
|  | 583 | of four ways after installing and or configuring the CS8900/20-based adapter: | 
|  | 584 |  | 
|  | 585 | 1.) The system does not boot properly (or at all). | 
|  | 586 |  | 
| Matt LaPlante | 84eb8d0 | 2006-10-03 22:53:09 +0200 | [diff] [blame] | 587 | 2.) The driver cannot communicate with the adapter, reporting an "Adapter | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 588 | not found" error message. | 
|  | 589 |  | 
|  | 590 | 3.) You cannot connect to the network or the driver will not load. | 
|  | 591 |  | 
|  | 592 | 4.) If you have configured the adapter to run in memory mode but the driver | 
|  | 593 | reports it is using IO mode when loading, this is an indication of a | 
|  | 594 | memory address conflict. | 
|  | 595 |  | 
|  | 596 | If an IO conflict occurs, run the CS8900/20 Setup Utility and perform a | 
|  | 597 | diagnostic self-test.  Normally, the ISA resource in conflict will fail the | 
|  | 598 | self-test.  If so, reconfigure the adapter selecting another choice for the | 
|  | 599 | resource in conflict.  Run the diagnostics again to check for further IO | 
|  | 600 | conflicts. | 
|  | 601 |  | 
|  | 602 | In some cases, such as when the PC will not boot, it may be necessary to remove | 
|  | 603 | the adapter and reconfigure it by installing it in another PC to run the | 
|  | 604 | CS8900/20 Setup Utility.  Once reinstalled in the target system, run the | 
|  | 605 | diagnostics self-test to ensure the new configuration is free of conflicts | 
|  | 606 | before loading the driver again. | 
|  | 607 |  | 
|  | 608 | When manually configuring the adapter, keep in mind the typical ISA system | 
|  | 609 | resource usage as indicated in the tables below. | 
|  | 610 |  | 
|  | 611 | I/O Address    	Device                        IRQ      Device | 
|  | 612 | -----------    	--------                      ---      -------- | 
|  | 613 | 200-20F       	Game I/O adapter               3       COM2, Bus Mouse | 
|  | 614 | 230-23F       	Bus Mouse                      4       COM1 | 
|  | 615 | 270-27F       	LPT3: third parallel port      5       LPT2 | 
|  | 616 | 2F0-2FF       	COM2: second serial port       6       Floppy Disk controller | 
|  | 617 | 320-32F       	Fixed disk controller          7       LPT1 | 
|  | 618 | 8       Real-time Clock | 
|  | 619 | 9       EGA/VGA display adapter | 
|  | 620 | 12       Mouse (PS/2) | 
|  | 621 | Memory Address  Device                          13       Math Coprocessor | 
|  | 622 | --------------  ---------------------           14       Hard Disk controller | 
| Matt LaPlante | 5d3f083 | 2006-11-30 05:21:10 +0100 | [diff] [blame] | 623 | A000-BFFF	EGA Graphics Adapter | 
|  | 624 | A000-C7FF	VGA Graphics Adapter | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 625 | B000-BFFF	Mono Graphics Adapter | 
|  | 626 | B800-BFFF	Color Graphics Adapter | 
|  | 627 | E000-FFFF	AT BIOS | 
|  | 628 |  | 
|  | 629 |  | 
|  | 630 |  | 
|  | 631 |  | 
|  | 632 | 6.0 TECHNICAL SUPPORT | 
|  | 633 | =============================================================================== | 
|  | 634 |  | 
|  | 635 | 6.1 CONTACTING CIRRUS LOGIC'S TECHNICAL SUPPORT | 
|  | 636 |  | 
|  | 637 | Cirrus Logic's CS89XX Technical Application Support can be reached at: | 
|  | 638 |  | 
|  | 639 | Telephone  :(800) 888-5016 (from inside U.S. and Canada) | 
|  | 640 | :(512) 442-7555 (from outside the U.S. and Canada) | 
|  | 641 | Fax        :(512) 912-3871 | 
|  | 642 | Email      :ethernet@crystal.cirrus.com | 
|  | 643 | WWW        :http://www.cirrus.com | 
|  | 644 |  | 
|  | 645 |  | 
|  | 646 | 6.2 INFORMATION REQUIRED BEFORE CONTACTING TECHNICAL SUPPORT | 
|  | 647 |  | 
|  | 648 | Before contacting Cirrus Logic for technical support, be prepared to provide as | 
|  | 649 | Much of the following information as possible. | 
|  | 650 |  | 
|  | 651 | 1.) Adapter type (CRD8900, CDB8900, CDB8920, etc.) | 
|  | 652 |  | 
|  | 653 | 2.) Adapter configuration | 
|  | 654 |  | 
|  | 655 | * IO Base, Memory Base, IO or memory mode enabled, IRQ, DMA channel | 
|  | 656 | * Plug and Play enabled/disabled (CS8920-based adapters only) | 
|  | 657 | * Configured for media auto-detect or specific media type (which type). | 
|  | 658 |  | 
|  | 659 | 3.) PC System's Configuration | 
|  | 660 |  | 
|  | 661 | * Plug and Play system (yes/no) | 
|  | 662 | * BIOS (make and version) | 
|  | 663 | * System make and model | 
|  | 664 | * CPU (type and speed) | 
|  | 665 | * System RAM | 
|  | 666 | * SCSI Adapter | 
|  | 667 |  | 
|  | 668 | 4.) Software | 
|  | 669 |  | 
|  | 670 | * CS89XX driver and version | 
|  | 671 | * Your network operating system and version | 
|  | 672 | * Your system's OS version | 
|  | 673 | * Version of all protocol support files | 
|  | 674 |  | 
|  | 675 | 5.) Any Error Message displayed. | 
|  | 676 |  | 
|  | 677 |  | 
|  | 678 |  | 
|  | 679 | 6.3 OBTAINING THE LATEST DRIVER VERSION | 
|  | 680 |  | 
|  | 681 | You can obtain the latest CS89XX drivers and support software from Cirrus Logic's | 
|  | 682 | Web site.  You can also contact Cirrus Logic's Technical Support (email: | 
|  | 683 | ethernet@crystal.cirrus.com) and request that you be registered for automatic | 
|  | 684 | software-update notification. | 
|  | 685 |  | 
|  | 686 | Cirrus Logic maintains a web page at http://www.cirrus.com with the | 
| Paolo Ornati | 670e9f3 | 2006-10-03 22:57:56 +0200 | [diff] [blame] | 687 | latest drivers and technical publications. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 688 |  | 
|  | 689 |  | 
|  | 690 | 6.4 Current maintainer | 
|  | 691 |  | 
|  | 692 | In February 2000 the maintenance of this driver was assumed by Andrew | 
| Francois Cami | e1f8e87 | 2008-10-15 22:01:59 -0700 | [diff] [blame] | 693 | Morton. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 694 |  | 
|  | 695 | 6.5 Kernel module parameters | 
|  | 696 |  | 
|  | 697 | For use in embedded environments with no cs89x0 EEPROM, the kernel boot | 
|  | 698 | parameter `cs89x0_media=' has been implemented.  Usage is: | 
|  | 699 |  | 
|  | 700 | cs89x0_media=rj45    or | 
|  | 701 | cs89x0_media=aui     or | 
|  | 702 | cs89x0_media=bnc | 
|  | 703 |  |