devices/e1000/e1000_param-2.6.20-ethercat.c
author Knud Baastrup <kba@deif.com>
Tue, 14 Apr 2015 10:12:55 -0400
changeset 2625 e25af8bd3957
parent 680 48c2dbc12bde
permissions -rw-r--r--
Eoe mac address now derived from unique mac.
The EoE MAC address is now derived from the NIC part of the first global
unique MAC address of the linked list of available network interfaces or
otherwise the MAC address used by the EtherCAT master. The EoE MAC address
will get the format 02:NIC:NIC:NIC:RP:RP where NIC comes from the unique MAC
address (if available) and RP is the ring position of the EoE slave.
680
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     1
/*******************************************************************************
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     2
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     3
  Intel PRO/1000 Linux driver
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     4
  Copyright(c) 1999 - 2006 Intel Corporation.
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     5
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     6
  This program is free software; you can redistribute it and/or modify it
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     7
  under the terms and conditions of the GNU General Public License,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     8
  version 2, as published by the Free Software Foundation.
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     9
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    10
  This program is distributed in the hope it will be useful, but WITHOUT
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    11
  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    12
  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    13
  more details.
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    14
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    15
  You should have received a copy of the GNU General Public License along with
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    16
  this program; if not, write to the Free Software Foundation, Inc.,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    17
  51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    18
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    19
  The full GNU General Public License is included in this distribution in
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    20
  the file called "COPYING".
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    21
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    22
  Contact Information:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    23
  Linux NICS <linux.nics@intel.com>
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    24
  e1000-devel Mailing List <e1000-devel@lists.sourceforge.net>
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    25
  Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    26
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    27
*******************************************************************************/
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    28
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    29
#include "e1000-2.6.20-ethercat.h"
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    30
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    31
/* This is the only thing that needs to be changed to adjust the
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    32
 * maximum number of ports that the driver can manage.
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    33
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    34
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    35
#define E1000_MAX_NIC 32
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    36
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    37
#define OPTION_UNSET   -1
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    38
#define OPTION_DISABLED 0
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    39
#define OPTION_ENABLED  1
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    40
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    41
/* All parameters are treated the same, as an integer array of values.
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    42
 * This macro just reduces the need to repeat the same declaration code
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    43
 * over and over (plus this helps to avoid typo bugs).
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    44
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    45
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    46
#define E1000_PARAM_INIT { [0 ... E1000_MAX_NIC] = OPTION_UNSET }
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    47
#define E1000_PARAM(X, desc) \
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    48
	static int __devinitdata X[E1000_MAX_NIC+1] = E1000_PARAM_INIT; \
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    49
	static int num_##X = 0; \
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    50
	module_param_array_named(X, X, int, &num_##X, 0); \
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    51
	MODULE_PARM_DESC(X, desc);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    52
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    53
/* Transmit Descriptor Count
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    54
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    55
 * Valid Range: 80-256 for 82542 and 82543 gigabit ethernet controllers
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    56
 * Valid Range: 80-4096 for 82544 and newer
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    57
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    58
 * Default Value: 256
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    59
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    60
E1000_PARAM(TxDescriptors, "Number of transmit descriptors");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    61
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    62
/* Receive Descriptor Count
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    63
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    64
 * Valid Range: 80-256 for 82542 and 82543 gigabit ethernet controllers
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    65
 * Valid Range: 80-4096 for 82544 and newer
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    66
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    67
 * Default Value: 256
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    68
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    69
E1000_PARAM(RxDescriptors, "Number of receive descriptors");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    70
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    71
/* User Specified Speed Override
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    72
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    73
 * Valid Range: 0, 10, 100, 1000
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    74
 *  - 0    - auto-negotiate at all supported speeds
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    75
 *  - 10   - only link at 10 Mbps
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    76
 *  - 100  - only link at 100 Mbps
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    77
 *  - 1000 - only link at 1000 Mbps
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    78
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    79
 * Default Value: 0
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    80
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    81
E1000_PARAM(Speed, "Speed setting");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    82
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    83
/* User Specified Duplex Override
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    84
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    85
 * Valid Range: 0-2
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    86
 *  - 0 - auto-negotiate for duplex
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    87
 *  - 1 - only link at half duplex
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    88
 *  - 2 - only link at full duplex
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    89
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    90
 * Default Value: 0
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    91
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    92
E1000_PARAM(Duplex, "Duplex setting");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    93
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    94
/* Auto-negotiation Advertisement Override
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    95
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    96
 * Valid Range: 0x01-0x0F, 0x20-0x2F (copper); 0x20 (fiber)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    97
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    98
 * The AutoNeg value is a bit mask describing which speed and duplex
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    99
 * combinations should be advertised during auto-negotiation.
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   100
 * The supported speed and duplex modes are listed below
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   101
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   102
 * Bit           7     6     5      4      3     2     1      0
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   103
 * Speed (Mbps)  N/A   N/A   1000   N/A    100   100   10     10
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   104
 * Duplex                    Full          Full  Half  Full   Half
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   105
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   106
 * Default Value: 0x2F (copper); 0x20 (fiber)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   107
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   108
E1000_PARAM(AutoNeg, "Advertised auto-negotiation setting");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   109
#define AUTONEG_ADV_DEFAULT  0x2F
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   110
#define AUTONEG_ADV_MASK     0x2F
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   111
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   112
/* User Specified Flow Control Override
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   113
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   114
 * Valid Range: 0-3
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   115
 *  - 0 - No Flow Control
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   116
 *  - 1 - Rx only, respond to PAUSE frames but do not generate them
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   117
 *  - 2 - Tx only, generate PAUSE frames but ignore them on receive
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   118
 *  - 3 - Full Flow Control Support
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   119
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   120
 * Default Value: Read flow control settings from the EEPROM
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   121
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   122
E1000_PARAM(FlowControl, "Flow Control setting");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   123
#define FLOW_CONTROL_DEFAULT FLOW_CONTROL_FULL
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   124
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   125
/* XsumRX - Receive Checksum Offload Enable/Disable
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   126
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   127
 * Valid Range: 0, 1
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   128
 *  - 0 - disables all checksum offload
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   129
 *  - 1 - enables receive IP/TCP/UDP checksum offload
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   130
 *        on 82543 and newer -based NICs
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   131
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   132
 * Default Value: 1
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   133
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   134
E1000_PARAM(XsumRX, "Disable or enable Receive Checksum offload");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   135
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   136
/* Transmit Interrupt Delay in units of 1.024 microseconds
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   137
 *  Tx interrupt delay needs to typically be set to something non zero
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   138
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   139
 * Valid Range: 0-65535
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   140
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   141
E1000_PARAM(TxIntDelay, "Transmit Interrupt Delay");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   142
#define DEFAULT_TIDV                   8
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   143
#define MAX_TXDELAY               0xFFFF
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   144
#define MIN_TXDELAY                    0
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   145
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   146
/* Transmit Absolute Interrupt Delay in units of 1.024 microseconds
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   147
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   148
 * Valid Range: 0-65535
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   149
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   150
E1000_PARAM(TxAbsIntDelay, "Transmit Absolute Interrupt Delay");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   151
#define DEFAULT_TADV                  32
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   152
#define MAX_TXABSDELAY            0xFFFF
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   153
#define MIN_TXABSDELAY                 0
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   154
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   155
/* Receive Interrupt Delay in units of 1.024 microseconds
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   156
 *   hardware will likely hang if you set this to anything but zero.
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   157
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   158
 * Valid Range: 0-65535
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   159
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   160
E1000_PARAM(RxIntDelay, "Receive Interrupt Delay");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   161
#define DEFAULT_RDTR                   0
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   162
#define MAX_RXDELAY               0xFFFF
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   163
#define MIN_RXDELAY                    0
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   164
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   165
/* Receive Absolute Interrupt Delay in units of 1.024 microseconds
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   166
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   167
 * Valid Range: 0-65535
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   168
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   169
E1000_PARAM(RxAbsIntDelay, "Receive Absolute Interrupt Delay");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   170
#define DEFAULT_RADV                   8
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   171
#define MAX_RXABSDELAY            0xFFFF
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   172
#define MIN_RXABSDELAY                 0
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   173
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   174
/* Interrupt Throttle Rate (interrupts/sec)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   175
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   176
 * Valid Range: 100-100000 (0=off, 1=dynamic, 3=dynamic conservative)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   177
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   178
E1000_PARAM(InterruptThrottleRate, "Interrupt Throttling Rate");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   179
#define DEFAULT_ITR                    3
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   180
#define MAX_ITR                   100000
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   181
#define MIN_ITR                      100
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   182
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   183
/* Enable Smart Power Down of the PHY
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   184
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   185
 * Valid Range: 0, 1
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   186
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   187
 * Default Value: 0 (disabled)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   188
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   189
E1000_PARAM(SmartPowerDownEnable, "Enable PHY smart power down");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   190
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   191
/* Enable Kumeran Lock Loss workaround
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   192
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   193
 * Valid Range: 0, 1
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   194
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   195
 * Default Value: 1 (enabled)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   196
 */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   197
E1000_PARAM(KumeranLockLoss, "Enable Kumeran lock loss workaround");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   198
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   199
struct e1000_option {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   200
	enum { enable_option, range_option, list_option } type;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   201
	char *name;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   202
	char *err;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   203
	int  def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   204
	union {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   205
		struct { /* range_option info */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   206
			int min;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   207
			int max;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   208
		} r;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   209
		struct { /* list_option info */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   210
			int nr;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   211
			struct e1000_opt_list { int i; char *str; } *p;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   212
		} l;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   213
	} arg;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   214
};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   215
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   216
static int __devinit
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   217
e1000_validate_option(int *value, struct e1000_option *opt,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   218
		struct e1000_adapter *adapter)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   219
{
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   220
	if (*value == OPTION_UNSET) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   221
		*value = opt->def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   222
		return 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   223
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   224
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   225
	switch (opt->type) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   226
	case enable_option:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   227
		switch (*value) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   228
		case OPTION_ENABLED:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   229
			DPRINTK(PROBE, INFO, "%s Enabled\n", opt->name);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   230
			return 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   231
		case OPTION_DISABLED:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   232
			DPRINTK(PROBE, INFO, "%s Disabled\n", opt->name);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   233
			return 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   234
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   235
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   236
	case range_option:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   237
		if (*value >= opt->arg.r.min && *value <= opt->arg.r.max) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   238
			DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   239
					"%s set to %i\n", opt->name, *value);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   240
			return 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   241
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   242
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   243
	case list_option: {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   244
		int i;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   245
		struct e1000_opt_list *ent;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   246
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   247
		for (i = 0; i < opt->arg.l.nr; i++) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   248
			ent = &opt->arg.l.p[i];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   249
			if (*value == ent->i) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   250
				if (ent->str[0] != '\0')
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   251
					DPRINTK(PROBE, INFO, "%s\n", ent->str);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   252
				return 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   253
			}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   254
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   255
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   256
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   257
	default:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   258
		BUG();
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   259
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   260
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   261
	DPRINTK(PROBE, INFO, "Invalid %s value specified (%i) %s\n",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   262
	       opt->name, *value, opt->err);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   263
	*value = opt->def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   264
	return -1;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   265
}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   266
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   267
static void e1000_check_fiber_options(struct e1000_adapter *adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   268
static void e1000_check_copper_options(struct e1000_adapter *adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   269
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   270
/**
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   271
 * e1000_check_options - Range Checking for Command Line Parameters
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   272
 * @adapter: board private structure
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   273
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   274
 * This routine checks all command line parameters for valid user
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   275
 * input.  If an invalid value is given, or if no user specified
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   276
 * value exists, a default value is used.  The final value is stored
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   277
 * in a variable in the adapter structure.
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   278
 **/
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   279
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   280
void __devinit
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   281
e1000_check_options(struct e1000_adapter *adapter)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   282
{
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   283
	int bd = adapter->bd_number;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   284
	if (bd >= E1000_MAX_NIC) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   285
		DPRINTK(PROBE, NOTICE,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   286
		       "Warning: no configuration for board #%i\n", bd);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   287
		DPRINTK(PROBE, NOTICE, "Using defaults for all values\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   288
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   289
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   290
	{ /* Transmit Descriptor Count */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   291
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   292
			.type = range_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   293
			.name = "Transmit Descriptors",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   294
			.err  = "using default of "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   295
				__MODULE_STRING(E1000_DEFAULT_TXD),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   296
			.def  = E1000_DEFAULT_TXD,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   297
			.arg  = { .r = { .min = E1000_MIN_TXD }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   298
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   299
		struct e1000_tx_ring *tx_ring = adapter->tx_ring;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   300
		int i;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   301
		e1000_mac_type mac_type = adapter->hw.mac_type;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   302
		opt.arg.r.max = mac_type < e1000_82544 ?
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   303
			E1000_MAX_TXD : E1000_MAX_82544_TXD;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   304
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   305
		if (num_TxDescriptors > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   306
			tx_ring->count = TxDescriptors[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   307
			e1000_validate_option(&tx_ring->count, &opt, adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   308
			E1000_ROUNDUP(tx_ring->count,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   309
						REQ_TX_DESCRIPTOR_MULTIPLE);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   310
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   311
			tx_ring->count = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   312
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   313
		for (i = 0; i < adapter->num_tx_queues; i++)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   314
			tx_ring[i].count = tx_ring->count;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   315
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   316
	{ /* Receive Descriptor Count */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   317
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   318
			.type = range_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   319
			.name = "Receive Descriptors",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   320
			.err  = "using default of "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   321
				__MODULE_STRING(E1000_DEFAULT_RXD),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   322
			.def  = E1000_DEFAULT_RXD,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   323
			.arg  = { .r = { .min = E1000_MIN_RXD }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   324
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   325
		struct e1000_rx_ring *rx_ring = adapter->rx_ring;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   326
		int i;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   327
		e1000_mac_type mac_type = adapter->hw.mac_type;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   328
		opt.arg.r.max = mac_type < e1000_82544 ? E1000_MAX_RXD :
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   329
			E1000_MAX_82544_RXD;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   330
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   331
		if (num_RxDescriptors > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   332
			rx_ring->count = RxDescriptors[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   333
			e1000_validate_option(&rx_ring->count, &opt, adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   334
			E1000_ROUNDUP(rx_ring->count,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   335
						REQ_RX_DESCRIPTOR_MULTIPLE);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   336
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   337
			rx_ring->count = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   338
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   339
		for (i = 0; i < adapter->num_rx_queues; i++)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   340
			rx_ring[i].count = rx_ring->count;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   341
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   342
	{ /* Checksum Offload Enable/Disable */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   343
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   344
			.type = enable_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   345
			.name = "Checksum Offload",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   346
			.err  = "defaulting to Enabled",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   347
			.def  = OPTION_ENABLED
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   348
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   349
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   350
		if (num_XsumRX > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   351
			int rx_csum = XsumRX[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   352
			e1000_validate_option(&rx_csum, &opt, adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   353
			adapter->rx_csum = rx_csum;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   354
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   355
			adapter->rx_csum = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   356
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   357
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   358
	{ /* Flow Control */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   359
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   360
		struct e1000_opt_list fc_list[] =
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   361
			{{ E1000_FC_NONE,    "Flow Control Disabled" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   362
			 { E1000_FC_RX_PAUSE,"Flow Control Receive Only" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   363
			 { E1000_FC_TX_PAUSE,"Flow Control Transmit Only" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   364
			 { E1000_FC_FULL,    "Flow Control Enabled" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   365
			 { E1000_FC_DEFAULT, "Flow Control Hardware Default" }};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   366
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   367
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   368
			.type = list_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   369
			.name = "Flow Control",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   370
			.err  = "reading default settings from EEPROM",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   371
			.def  = E1000_FC_DEFAULT,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   372
			.arg  = { .l = { .nr = ARRAY_SIZE(fc_list),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   373
					 .p = fc_list }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   374
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   375
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   376
		if (num_FlowControl > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   377
			int fc = FlowControl[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   378
			e1000_validate_option(&fc, &opt, adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   379
			adapter->hw.fc = adapter->hw.original_fc = fc;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   380
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   381
			adapter->hw.fc = adapter->hw.original_fc = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   382
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   383
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   384
	{ /* Transmit Interrupt Delay */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   385
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   386
			.type = range_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   387
			.name = "Transmit Interrupt Delay",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   388
			.err  = "using default of " __MODULE_STRING(DEFAULT_TIDV),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   389
			.def  = DEFAULT_TIDV,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   390
			.arg  = { .r = { .min = MIN_TXDELAY,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   391
					 .max = MAX_TXDELAY }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   392
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   393
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   394
		if (num_TxIntDelay > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   395
			adapter->tx_int_delay = TxIntDelay[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   396
			e1000_validate_option(&adapter->tx_int_delay, &opt,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   397
			                      adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   398
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   399
			adapter->tx_int_delay = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   400
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   401
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   402
	{ /* Transmit Absolute Interrupt Delay */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   403
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   404
			.type = range_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   405
			.name = "Transmit Absolute Interrupt Delay",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   406
			.err  = "using default of " __MODULE_STRING(DEFAULT_TADV),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   407
			.def  = DEFAULT_TADV,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   408
			.arg  = { .r = { .min = MIN_TXABSDELAY,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   409
					 .max = MAX_TXABSDELAY }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   410
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   411
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   412
		if (num_TxAbsIntDelay > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   413
			adapter->tx_abs_int_delay = TxAbsIntDelay[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   414
			e1000_validate_option(&adapter->tx_abs_int_delay, &opt,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   415
			                      adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   416
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   417
			adapter->tx_abs_int_delay = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   418
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   419
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   420
	{ /* Receive Interrupt Delay */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   421
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   422
			.type = range_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   423
			.name = "Receive Interrupt Delay",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   424
			.err  = "using default of " __MODULE_STRING(DEFAULT_RDTR),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   425
			.def  = DEFAULT_RDTR,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   426
			.arg  = { .r = { .min = MIN_RXDELAY,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   427
					 .max = MAX_RXDELAY }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   428
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   429
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   430
		if (num_RxIntDelay > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   431
			adapter->rx_int_delay = RxIntDelay[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   432
			e1000_validate_option(&adapter->rx_int_delay, &opt,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   433
			                      adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   434
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   435
			adapter->rx_int_delay = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   436
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   437
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   438
	{ /* Receive Absolute Interrupt Delay */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   439
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   440
			.type = range_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   441
			.name = "Receive Absolute Interrupt Delay",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   442
			.err  = "using default of " __MODULE_STRING(DEFAULT_RADV),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   443
			.def  = DEFAULT_RADV,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   444
			.arg  = { .r = { .min = MIN_RXABSDELAY,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   445
					 .max = MAX_RXABSDELAY }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   446
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   447
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   448
		if (num_RxAbsIntDelay > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   449
			adapter->rx_abs_int_delay = RxAbsIntDelay[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   450
			e1000_validate_option(&adapter->rx_abs_int_delay, &opt,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   451
			                      adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   452
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   453
			adapter->rx_abs_int_delay = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   454
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   455
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   456
	{ /* Interrupt Throttling Rate */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   457
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   458
			.type = range_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   459
			.name = "Interrupt Throttling Rate (ints/sec)",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   460
			.err  = "using default of " __MODULE_STRING(DEFAULT_ITR),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   461
			.def  = DEFAULT_ITR,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   462
			.arg  = { .r = { .min = MIN_ITR,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   463
					 .max = MAX_ITR }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   464
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   465
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   466
		if (num_InterruptThrottleRate > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   467
			adapter->itr = InterruptThrottleRate[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   468
			switch (adapter->itr) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   469
			case 0:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   470
				DPRINTK(PROBE, INFO, "%s turned off\n",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   471
				        opt.name);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   472
				break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   473
			case 1:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   474
				DPRINTK(PROBE, INFO, "%s set to dynamic mode\n",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   475
					opt.name);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   476
				adapter->itr_setting = adapter->itr;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   477
				adapter->itr = 20000;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   478
				break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   479
			case 3:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   480
				DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   481
				        "%s set to dynamic conservative mode\n",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   482
					opt.name);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   483
				adapter->itr_setting = adapter->itr;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   484
				adapter->itr = 20000;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   485
				break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   486
			default:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   487
				e1000_validate_option(&adapter->itr, &opt,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   488
				        adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   489
				/* save the setting, because the dynamic bits change itr */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   490
				/* clear the lower two bits because they are
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   491
				 * used as control */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   492
				adapter->itr_setting = adapter->itr & ~3;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   493
				break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   494
			}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   495
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   496
			adapter->itr_setting = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   497
			adapter->itr = 20000;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   498
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   499
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   500
	{ /* Smart Power Down */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   501
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   502
			.type = enable_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   503
			.name = "PHY Smart Power Down",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   504
			.err  = "defaulting to Disabled",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   505
			.def  = OPTION_DISABLED
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   506
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   507
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   508
		if (num_SmartPowerDownEnable > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   509
			int spd = SmartPowerDownEnable[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   510
			e1000_validate_option(&spd, &opt, adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   511
			adapter->smart_power_down = spd;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   512
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   513
			adapter->smart_power_down = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   514
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   515
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   516
	{ /* Kumeran Lock Loss Workaround */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   517
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   518
			.type = enable_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   519
			.name = "Kumeran Lock Loss Workaround",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   520
			.err  = "defaulting to Enabled",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   521
			.def  = OPTION_ENABLED
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   522
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   523
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   524
		if (num_KumeranLockLoss > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   525
			int kmrn_lock_loss = KumeranLockLoss[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   526
			e1000_validate_option(&kmrn_lock_loss, &opt, adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   527
			adapter->hw.kmrn_lock_loss_workaround_disabled = !kmrn_lock_loss;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   528
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   529
			adapter->hw.kmrn_lock_loss_workaround_disabled = !opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   530
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   531
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   532
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   533
	switch (adapter->hw.media_type) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   534
	case e1000_media_type_fiber:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   535
	case e1000_media_type_internal_serdes:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   536
		e1000_check_fiber_options(adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   537
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   538
	case e1000_media_type_copper:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   539
		e1000_check_copper_options(adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   540
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   541
	default:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   542
		BUG();
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   543
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   544
}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   545
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   546
/**
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   547
 * e1000_check_fiber_options - Range Checking for Link Options, Fiber Version
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   548
 * @adapter: board private structure
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   549
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   550
 * Handles speed and duplex options on fiber adapters
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   551
 **/
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   552
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   553
static void __devinit
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   554
e1000_check_fiber_options(struct e1000_adapter *adapter)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   555
{
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   556
	int bd = adapter->bd_number;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   557
	if (num_Speed > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   558
		DPRINTK(PROBE, INFO, "Speed not valid for fiber adapters, "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   559
		       "parameter ignored\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   560
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   561
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   562
	if (num_Duplex > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   563
		DPRINTK(PROBE, INFO, "Duplex not valid for fiber adapters, "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   564
		       "parameter ignored\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   565
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   566
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   567
	if ((num_AutoNeg > bd) && (AutoNeg[bd] != 0x20)) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   568
		DPRINTK(PROBE, INFO, "AutoNeg other than 1000/Full is "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   569
				 "not valid for fiber adapters, "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   570
				 "parameter ignored\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   571
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   572
}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   573
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   574
/**
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   575
 * e1000_check_copper_options - Range Checking for Link Options, Copper Version
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   576
 * @adapter: board private structure
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   577
 *
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   578
 * Handles speed and duplex options on copper adapters
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   579
 **/
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   580
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   581
static void __devinit
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   582
e1000_check_copper_options(struct e1000_adapter *adapter)
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   583
{
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   584
	int speed, dplx, an;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   585
	int bd = adapter->bd_number;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   586
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   587
	{ /* Speed */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   588
		struct e1000_opt_list speed_list[] = {{          0, "" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   589
						      {   SPEED_10, "" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   590
						      {  SPEED_100, "" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   591
						      { SPEED_1000, "" }};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   592
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   593
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   594
			.type = list_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   595
			.name = "Speed",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   596
			.err  = "parameter ignored",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   597
			.def  = 0,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   598
			.arg  = { .l = { .nr = ARRAY_SIZE(speed_list),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   599
					 .p = speed_list }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   600
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   601
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   602
		if (num_Speed > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   603
			speed = Speed[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   604
			e1000_validate_option(&speed, &opt, adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   605
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   606
			speed = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   607
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   608
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   609
	{ /* Duplex */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   610
		struct e1000_opt_list dplx_list[] = {{           0, "" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   611
						     { HALF_DUPLEX, "" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   612
						     { FULL_DUPLEX, "" }};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   613
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   614
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   615
			.type = list_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   616
			.name = "Duplex",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   617
			.err  = "parameter ignored",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   618
			.def  = 0,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   619
			.arg  = { .l = { .nr = ARRAY_SIZE(dplx_list),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   620
					 .p = dplx_list }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   621
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   622
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   623
		if (e1000_check_phy_reset_block(&adapter->hw)) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   624
			DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   625
				"Link active due to SoL/IDER Session. "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   626
			        "Speed/Duplex/AutoNeg parameter ignored.\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   627
			return;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   628
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   629
		if (num_Duplex > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   630
			dplx = Duplex[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   631
			e1000_validate_option(&dplx, &opt, adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   632
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   633
			dplx = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   634
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   635
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   636
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   637
	if ((num_AutoNeg > bd) && (speed != 0 || dplx != 0)) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   638
		DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   639
		       "AutoNeg specified along with Speed or Duplex, "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   640
		       "parameter ignored\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   641
		adapter->hw.autoneg_advertised = AUTONEG_ADV_DEFAULT;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   642
	} else { /* Autoneg */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   643
		struct e1000_opt_list an_list[] =
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   644
			#define AA "AutoNeg advertising "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   645
			{{ 0x01, AA "10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   646
			 { 0x02, AA "10/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   647
			 { 0x03, AA "10/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   648
			 { 0x04, AA "100/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   649
			 { 0x05, AA "100/HD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   650
			 { 0x06, AA "100/HD, 10/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   651
			 { 0x07, AA "100/HD, 10/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   652
			 { 0x08, AA "100/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   653
			 { 0x09, AA "100/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   654
			 { 0x0a, AA "100/FD, 10/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   655
			 { 0x0b, AA "100/FD, 10/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   656
			 { 0x0c, AA "100/FD, 100/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   657
			 { 0x0d, AA "100/FD, 100/HD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   658
			 { 0x0e, AA "100/FD, 100/HD, 10/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   659
			 { 0x0f, AA "100/FD, 100/HD, 10/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   660
			 { 0x20, AA "1000/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   661
			 { 0x21, AA "1000/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   662
			 { 0x22, AA "1000/FD, 10/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   663
			 { 0x23, AA "1000/FD, 10/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   664
			 { 0x24, AA "1000/FD, 100/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   665
			 { 0x25, AA "1000/FD, 100/HD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   666
			 { 0x26, AA "1000/FD, 100/HD, 10/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   667
			 { 0x27, AA "1000/FD, 100/HD, 10/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   668
			 { 0x28, AA "1000/FD, 100/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   669
			 { 0x29, AA "1000/FD, 100/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   670
			 { 0x2a, AA "1000/FD, 100/FD, 10/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   671
			 { 0x2b, AA "1000/FD, 100/FD, 10/FD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   672
			 { 0x2c, AA "1000/FD, 100/FD, 100/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   673
			 { 0x2d, AA "1000/FD, 100/FD, 100/HD, 10/HD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   674
			 { 0x2e, AA "1000/FD, 100/FD, 100/HD, 10/FD" },
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   675
			 { 0x2f, AA "1000/FD, 100/FD, 100/HD, 10/FD, 10/HD" }};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   676
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   677
		struct e1000_option opt = {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   678
			.type = list_option,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   679
			.name = "AutoNeg",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   680
			.err  = "parameter ignored",
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   681
			.def  = AUTONEG_ADV_DEFAULT,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   682
			.arg  = { .l = { .nr = ARRAY_SIZE(an_list),
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   683
					 .p = an_list }}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   684
		};
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   685
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   686
		if (num_AutoNeg > bd) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   687
			an = AutoNeg[bd];
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   688
			e1000_validate_option(&an, &opt, adapter);
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   689
		} else {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   690
			an = opt.def;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   691
		}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   692
		adapter->hw.autoneg_advertised = an;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   693
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   694
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   695
	switch (speed + dplx) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   696
	case 0:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   697
		adapter->hw.autoneg = adapter->fc_autoneg = 1;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   698
		if ((num_Speed > bd) && (speed != 0 || dplx != 0))
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   699
			DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   700
			       "Speed and duplex autonegotiation enabled\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   701
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   702
	case HALF_DUPLEX:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   703
		DPRINTK(PROBE, INFO, "Half Duplex specified without Speed\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   704
		DPRINTK(PROBE, INFO, "Using Autonegotiation at "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   705
			"Half Duplex only\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   706
		adapter->hw.autoneg = adapter->fc_autoneg = 1;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   707
		adapter->hw.autoneg_advertised = ADVERTISE_10_HALF |
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   708
		                                 ADVERTISE_100_HALF;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   709
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   710
	case FULL_DUPLEX:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   711
		DPRINTK(PROBE, INFO, "Full Duplex specified without Speed\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   712
		DPRINTK(PROBE, INFO, "Using Autonegotiation at "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   713
			"Full Duplex only\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   714
		adapter->hw.autoneg = adapter->fc_autoneg = 1;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   715
		adapter->hw.autoneg_advertised = ADVERTISE_10_FULL |
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   716
		                                 ADVERTISE_100_FULL |
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   717
		                                 ADVERTISE_1000_FULL;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   718
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   719
	case SPEED_10:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   720
		DPRINTK(PROBE, INFO, "10 Mbps Speed specified "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   721
			"without Duplex\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   722
		DPRINTK(PROBE, INFO, "Using Autonegotiation at 10 Mbps only\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   723
		adapter->hw.autoneg = adapter->fc_autoneg = 1;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   724
		adapter->hw.autoneg_advertised = ADVERTISE_10_HALF |
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   725
		                                 ADVERTISE_10_FULL;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   726
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   727
	case SPEED_10 + HALF_DUPLEX:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   728
		DPRINTK(PROBE, INFO, "Forcing to 10 Mbps Half Duplex\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   729
		adapter->hw.autoneg = adapter->fc_autoneg = 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   730
		adapter->hw.forced_speed_duplex = e1000_10_half;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   731
		adapter->hw.autoneg_advertised = 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   732
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   733
	case SPEED_10 + FULL_DUPLEX:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   734
		DPRINTK(PROBE, INFO, "Forcing to 10 Mbps Full Duplex\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   735
		adapter->hw.autoneg = adapter->fc_autoneg = 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   736
		adapter->hw.forced_speed_duplex = e1000_10_full;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   737
		adapter->hw.autoneg_advertised = 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   738
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   739
	case SPEED_100:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   740
		DPRINTK(PROBE, INFO, "100 Mbps Speed specified "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   741
			"without Duplex\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   742
		DPRINTK(PROBE, INFO, "Using Autonegotiation at "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   743
			"100 Mbps only\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   744
		adapter->hw.autoneg = adapter->fc_autoneg = 1;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   745
		adapter->hw.autoneg_advertised = ADVERTISE_100_HALF |
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   746
		                                 ADVERTISE_100_FULL;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   747
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   748
	case SPEED_100 + HALF_DUPLEX:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   749
		DPRINTK(PROBE, INFO, "Forcing to 100 Mbps Half Duplex\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   750
		adapter->hw.autoneg = adapter->fc_autoneg = 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   751
		adapter->hw.forced_speed_duplex = e1000_100_half;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   752
		adapter->hw.autoneg_advertised = 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   753
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   754
	case SPEED_100 + FULL_DUPLEX:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   755
		DPRINTK(PROBE, INFO, "Forcing to 100 Mbps Full Duplex\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   756
		adapter->hw.autoneg = adapter->fc_autoneg = 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   757
		adapter->hw.forced_speed_duplex = e1000_100_full;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   758
		adapter->hw.autoneg_advertised = 0;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   759
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   760
	case SPEED_1000:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   761
		DPRINTK(PROBE, INFO, "1000 Mbps Speed specified without "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   762
			"Duplex\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   763
		DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   764
			"Using Autonegotiation at 1000 Mbps "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   765
			"Full Duplex only\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   766
		adapter->hw.autoneg = adapter->fc_autoneg = 1;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   767
		adapter->hw.autoneg_advertised = ADVERTISE_1000_FULL;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   768
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   769
	case SPEED_1000 + HALF_DUPLEX:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   770
		DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   771
			"Half Duplex is not supported at 1000 Mbps\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   772
		DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   773
			"Using Autonegotiation at 1000 Mbps "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   774
			"Full Duplex only\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   775
		adapter->hw.autoneg = adapter->fc_autoneg = 1;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   776
		adapter->hw.autoneg_advertised = ADVERTISE_1000_FULL;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   777
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   778
	case SPEED_1000 + FULL_DUPLEX:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   779
		DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   780
		       "Using Autonegotiation at 1000 Mbps Full Duplex only\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   781
		adapter->hw.autoneg = adapter->fc_autoneg = 1;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   782
		adapter->hw.autoneg_advertised = ADVERTISE_1000_FULL;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   783
		break;
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   784
	default:
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   785
		BUG();
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   786
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   787
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   788
	/* Speed, AutoNeg and MDI/MDI-X must all play nice */
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   789
	if (e1000_validate_mdi_setting(&(adapter->hw)) < 0) {
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   790
		DPRINTK(PROBE, INFO,
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   791
			"Speed, AutoNeg and MDI-X specifications are "
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   792
			"incompatible. Setting MDI-X to a compatible value.\n");
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   793
	}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   794
}
48c2dbc12bde Added e1000 driver for 2.6.20.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   795