README revision 4d7379630d53d9992780329b674af8c85935e858
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe#
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe# This file is provided under a CDDLv1 license. When using or
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe# redistributing this file, you may do so under this license.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe# In redistributing this file this license must be included
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe# and no other modification of this header file is permitted.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe#
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe# CDDL LICENSE SUMMARY
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe#
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe# Copyright(c) 1999 - 2008 Intel Corporation. All rights reserved.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe#
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe# The contents of this file are subject to the terms of Version
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov# 1.0 of the Common Development and Distribution License (the "License").
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe#
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov# You should have received a copy of the License with this software.
5886b388693aede815c0cf5262e123d4677cd72cGarrett D'Amore# You can obtain a copy of the License at
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov# http://www.opensolaris.org/os/licensing.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe# See the License for the specific language governing permissions
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov# and limitations under the License.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe#
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov#
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe# Copyright 2008 Sun Microsystems, Inc. All rights reserved.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov# Use is subject to license terms of the CDDLv1.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov#
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov#
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov4.0.4 code drop from Intel on 1/30/2003
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov=======================================
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov This version is used as the base for putback into both s10 and
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov s9u4.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Following changes were done to this code base before putting
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov back into solaris trees (S10 & S9U4):
5886b388693aede815c0cf5262e123d4677cd72cGarrett D'Amore
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 1) Changes to e1000_hw.c to remove build warnings
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov + diff /home/naroori/grizzly/sources/e1000g/1_4.0.4/e1000_hw.c .
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 2616c2616
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov < phy_info->downshift = hw->speed_downgraded;
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > phy_info->downshift = (int)hw->speed_downgraded;
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 2684c2684
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov < phy_info->downshift = hw->speed_downgraded;
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > phy_info->downshift = (int)hw->speed_downgraded;
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 2) Changes to e1000g_dlpi.c for ipv6 plumbing problem and
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov problem with default MTU size of 2024.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov + diff /home/naroori/grizzly/sources/e1000g/1_4.0.4/e1000g_dlpi.c .
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 313a314
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > /* the following causes problem with ipv6 plumbing...
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 314a316
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > */
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 628c630,632
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov < if (Adapter->Shared.max_frame_size == FRAME_SIZE_UPTO_16K)
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > if (Adapter->Shared.max_frame_size == ETHERMTU) {
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > }
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > else if (Adapter->Shared.max_frame_size == FRAME_SIZE_UPTO_16K) {
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 630c634,635
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov < else
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > }
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > else {
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 631a637
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > }
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 3) Changes to e1000g_main.c for version string modification,
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov removing console messages on bootup and problems with default
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov MTU size of 2024.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov + diff /home/naroori/grizzly/sources/e1000g/1_4.0.4/e1000g_main.c .
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 59c59
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov < static char e1000g_version[]="Driver Ver. 4.0.4-beta";
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > static char e1000g_version[]="Driver Ver. 4.0.4";
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 937c937
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov < e1000g_log(Adapter,CE_CONT,"\n%s, %s\n",AdapterName,e1000g_version);
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > cmn_err(CE_CONT,"!%s, %s\n",AdapterName,e1000g_version);
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 3000c3000
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov < Adapter->Shared.max_frame_size = FRAME_SIZE_UPTO_2K;
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > Adapter->Shared.max_frame_size = ETHERMTU;
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 3013c3013
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov < Adapter->Shared.max_frame_size = FRAME_SIZE_UPTO_2K;
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov > Adapter->Shared.max_frame_size = ETHERMTU;
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri PankovBug fixes to 4.0.4:
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov===================
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 1) bug#4829398 code cleanup for ethernet bootup messages
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov4.0.12 code drop from Intel on 3/18/2003
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov========================================
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov This drop had extensive changes from 4.0.4. Many changes after
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 4.0.4 were realted to new hardware (a.k.a. BayCity chipset),
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov not relevant to Grizzly.After looking at the changelog from Intel,
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov we decided not to do a putback but rather take only high priority
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov fixes from this drop and generate a new version 4.0.4.1.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Here is the changelog supplied by Intel for this drop:
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ________________________________________________________________________
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Component Name: Unix-Solaris_8254x_BayCity_Intel
86635a91ceb503bad0052c7a964ec3fd28d548dcGarrett D'Amore Description: Bay City software component for gigabit products
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ________________________________________________________________________
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---Version: 4.0.13 Date: 3/14/2003 5:00:00 PM---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Added transmit mutex locking to the 82547 workaround code.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---Version: 4.0.12 Date: 3/10/2003 8:01:00 PM---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Added new shared code with LED link speed fix
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---Version: 4.0.11 Date: 3/7/2003 5:57:00 PM---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Updated the Tanacross FIFO hang workaround to reset FIFO pointers instead of sending autonomous packets.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---Version: 4.0.10 Date: 3/4/2003 2:39:00 PM---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Removed an extra sdu adjustment that was left in by accident
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---Version: 4.0.9 Date: 3/4/2003 11:13:00 AM---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Removed the first call to adapter_stop. This was called before the HW struct was properly initialized, and could cause hangs.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Changed reported ethernet sdu from 2024 to 1500, as driver could be configured for invalid frame MTU sizes in Solaris 9.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Added Tanacross workaround for FIFO hang.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---Version: 4.0.8 Date: 2/25/2003 2:27:00 PM---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Shared code update including Phy init script.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Smartspeed workaround added. e1000g_smartspeed called from LocalTimer function every two seconds when link is down.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---Version: 4.0.7 Date: 2/18/2003 11:41:00 AM---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Updated to include bug fixes from the shared code.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov ---Version: 4.0.5 Date: 1/31/2003 10:13:00 AM---
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Support for new hardware changes
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Removed the extra ack sent at the end of the attach_req routine. This extra ack previously made IPv6 plumbing on Solaris 9 fail.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov4.0.4.1
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov=======
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov This version is not an Intel drop but 4.0.4 merged with two
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov high priority fixes from 4.0.12. We will give back the 4.0.4.1
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov driver back to Intel, per their request, so they have the exact
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov code that we are releasing through Solaris.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov The following are the two fixes selected for inclusion from
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 4.0.12 codebase:
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 1) Removing the first call to adapter_stop as discussed in
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 4.0.12 changelog.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 2) Corrections to MTU size calculations first introduced
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov in our 4.0.4 putback to bring them into sync with 4.0.12
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov MTU size calculations.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov We also added README file (current file you are reading) during
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov this putback.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov4.0.4.2
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov=======
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov This version has the following fixes:
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 1) bug#4857098: e1000g driver assumes another intel card as its own.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov The fix involved eliminating 1009, 1012, 1015, 1016, 1017
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov device-ids from e1000g nodelist so that they do not conflict
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov with iprb's subsystem-ids.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov This fix has to be reverted later once we have a proper fix for
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov bug#4859426.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 2) bug#4853683: e1000g lacks a large number of expected kstats
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov The fix involved three steps: a) Renaming some of the existing
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov kstats to comply with WDD documentation b) Computing some of
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov those which are not being tracked c) Supplying zero for the rest
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov the error stats which are not being tracked.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov This fix has to be revisited to improvise the statistics in
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov future.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 3) bug#4862529: System panics during configuring devices on a Dell 4-way
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov servers. The fix involved removing all the devic-ids from nodelist
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe except for 1010. This means that we support now only the grizzly
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov on-board gigabit chipset and "Intel Pro/1000 MT Dual Server Adapter".
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe This fix has to be reverted later once we have a proper fix for
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe bug#4859426.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe4.0.4.3
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe=======
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe This version has the following fixes:
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 1) bug#4874857: ipv6 ping fails on bootup for e1000g.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe The fix involved implementing multicast tables both at per stream
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe level and per device level.
7ffba875a0c7cf118aef7a2c9bfd00c3935e230aGarrett D'Amore
7ffba875a0c7cf118aef7a2c9bfd00c3935e230aGarrett D'Amore 2) bug#4875743: null pointer dereference in ddi_dma_addr_bind_handle.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe The fix involved adding LastTxDescriptorBuf to struct e1000g and
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe handling consequent proper calculations for LastTxDescriptor.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 3) bug#4882541: setting up ethernet address causes machine to panic.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe The fix involved removing a spurious log message which was causing
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe the panic.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 4) bug#4883302: Reinstate the removed device-ids - phase 2.
8bf58058bb64c24ccf6da9141b2f10037725b137Richard Lowe The fix involved some chip initializations to handle 1000 id.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 5) bug#4919285: device id 8086,100e needs to be added
d43e36083971394ac9c1341783ff58802c2e73efIgor Kozhukhov The fix needed for the Intel Precision 350 workstation
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe4.2.11
989f28072d20c73ae0955d6a1e3e2fc74831cb39Jerry Jelinek======
d43e36083971394ac9c1341783ff58802c2e73efIgor Kozhukhov
c10c16dec587a0662068f6e2991c29ed3a9db943Richard LoweWe need to sync up with the latest Intel code base for e1000g driver.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard LoweIntel is currently at version 4.2.11 while we are on 4.0.4 branch.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard LoweThe exact version under 4.0.4 branch is 4.0.4.3. Since we are on
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowethe branch while Intel is working on the main trunk, we have had
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowelot of friction in getting timely fixes from Intel. The current
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowesyncing up with their main trunk lets us a smooth migration path.
6d8b5bf1bbeb8c7f1357b3e5836fe664fb0fcc46Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard LoweThe new code base also would provide us with support for additional
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowecards including Quad port cards (See bugs: 4921433, 4914460).
c10c16dec587a0662068f6e2991c29ed3a9db943Richard LoweIn our old 4.0.4 branch, we had to drop support for a lot of cards
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowefor various problems; with the current syncing up, we would be able
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Loweto support so many various cards except for the cards clashing with
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Loweiprb driver.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard LoweThe new code base also has support for additional new chipsets. The code
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowebase also benefits from any fixes to the shared code base with other
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Loweoperating system drivers.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard LoweThe new codebase also has lot of cleanups in terms of various #ifdefs
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Loweand should be much simpler to maintain.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard LoweSo the list of actual ids take out are:
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe1009
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov1012
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe1013
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe1015
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe1016
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe1017
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe4.2.15
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe======
c10c16dec587a0662068f6e2991c29ed3a9db943Richard LoweThis intel code drop addresses the following bug:
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 4909863: Bad trap panic in e1000g_rtn_buf
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe4.2.16
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe======
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe This version has the following fix:
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 4932422 interconnect remains faulted after adapter disconnected and then reconnected
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri PankovNotes on packaging:
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe===================
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov Intel names the package as INTCGigaE while we chose to rename
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov it as SUNWintgige as per Sun packaging conventions.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov4.2.17
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov======
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe This version has the following fixes:
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 4971416 e1000g seems to hang system when no network connected
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 4997067 e1000gattach panicks when the going gets tough
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 4990064 e1000g leaks memory when it runs out of transmit descriptors
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov4.2.17.1
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe======
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov This version has the following fix:
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 5014625 e1000g driver panicked when snoop(1M) exited
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov4.2.17.2
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe======
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov This version has the following fix:
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 4940870 e1000g: Dependence on instance initialization order disables .conf properties
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 5033616 e1000g panicked after rem_drv while some service still binds to the driver
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 5037062 strings have crept back in e1000g/adpu320 related mutex_init()s
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 5050268 Some e1000g flag operations are not correct.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov4.2.17.3
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe======
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov This version has the following fix:
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 5067162 e1000g cannot transmit heavy UDP
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe4.2.17.4
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov======
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe This version has the following fix:
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 5010052 The stress load/unload test of Intel PWLA8494MT Quad Port NIC causes system hung
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 5050265 E1000g does not support IPV6 fast path. This will impact IPV6 performance.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 5050369 E1000g locks the system if plumb/unplumb under heavy workload and snoop.
c10c16dec587a0662068f6e2991c29ed3a9db943Richard Lowe 5050415 E1000g will accepts ethernet packets which are not addressed to it.
a9478106a12424322498e53cf7cd75bd8a4d6004Yuri Pankov 5055132 E1000g crashes when injected with Jumbo Frame packets.
4.2.17.5
======
This version has the following fix:
6175307 system crash with memory size of 11GB
6176031 the sequence of releasing resource error in e1000gattach
6180180 PktAlloc - Could not bind rbuf packet as single frag. Count - 2
6185022 Port hang when unplumb interface under heavy traffic
4.2.17.6
======
This version has the following fix:
6196426 e1000g should support NICs that use the internal serdes for external connectivity
4.2.17.7
======
This version has the following fix:
4921433 e1000g: Should not probe by using VID/DID table to identify adapters
4.2.17.8
======
This version has the following fix:
6213101 64bit DMA max address space should be supported by e1000g driver
6215261 e1000g driver 211% slower in AMD64 than 32 bit e1000g driver (S10_73, Single CPU V20z)
4.2.17.9
======
This version has the following fix:
6256212 fix for 6213101 breaks e1000g for 32-bit kernels on machines with >4GB of physical memory
4.2.17.10
======
This version has the following fix:
6203602 e1000g needs to support the Intel PCI-E card
6217046 we need to merge the Intel code (version 4.2.28) into e1000g
5.0.0
======
This version has the following fix:
PSARC/2005/470 E1000g Nemo Migration
6221079 e1000g driver interface conversion from DLPI to GLD3.0(nemo)
6224901 e1000g fails to configure VLANs on a Sun v65x
6286414 snmp: ifOperStatus for e1000g driver doesn't change when cable is unplugged.
6238486 e1000g: poor performance in web server benchmark, high CPU utilization noted
6293265 e1000g_intr doesn't use mutex at all
6304657 e1000g_PktAlloc_buffers() causes a panic when ddi_dma_addr_bind_handle() fails.
4913292 e1000g: does not support PSARC 2003/264 Extended IP cksum_offload
5071610 e1000g can't send any packets after a jumbo-packet forwarding test.
5082975 in Jumbo enable mode, netperf indicates a lower throughput, compared to Jumbo of
5085394 e1000g driver hangs system during 64byte stress testing
6174349 netlb support needed for Solaris e1000g driver
6207682 e1000g needs link up/down support
6211068 e1000g has some input error packets during stress test
6212810 e1000g caught sending unsolicited M_PROTO/M_PCPROTO messages
6219298 warnings about "inconsistent getinfo(9E) implementation"
6226217 e1000g should support trunking
6239279 Network stess test fail on 82545GM chip on IBM Blade HS40
6242612 e1000g needs to support SPARC
6247936 In e1000g transmission, ddi_dma_addr_bind_handle() returns more cookies than speficied
6273730 e1000g causes memory leaks within Freelist_alloc and PktAlloc_buffers
5073739 find some memory leaks after load_unload test
6287250 e1000g may need to use new Intel-recommended semaphore mechanism
5.0.1
======
This version has the following fix:
6313609 2-port Intel NIC (part# 370-6687) performs poorly compared to 1-port Intel NIC (part# 370-6685)
6315002 gcc and e1000g don't get along
5.0.2
======
This version has the following fix:
6319100 Tier0 Ontario machine does not boot net with sparc e1000g driver substitution for sparc ipge driver
5.0.3
======
This version has the following fix:
6327693 e1000g should use MSIs when possible
6333461 panic[cpu0]/thread=d63f4de0: assertion failed: !dma->dp_inuse, file: ../../i86pc/io/rootnex.c
5.0.4
======
This version has the following fix:
6351378 e1000g panic seen after bfu'ing latest onnv nightly
5.0.5
======
This version has the following fix:
6303973 System hard hangs when sharing interrupts (in PIC) mode
6323732 e1000g reports incorrect packet statistics
6333880 Customer is requesting driver for a newIntel 82573 NIC
6336163 netlb support needed for Solaris (sparc) e1000g driver
6339377 e1000g.conf needs to be simplified
6350407 e1000 card in Gateway E2300 does not actually send packets in S10U1
6364052 e1000g driver should provide interface to ndd utility
6367490 e1000g has problem in deliver UDP fragment with addin card
5.0.6
======
This version has the following fix:
4967732 e1000g: high mutex contention in e1000g_start
6316907 e1000g: bcopy() brings better performance in transmitting and receiving small packet
6371753 aggregation of e1000g NICs fails to provide connectivity unless snoop is running
6397163 Jumbo frame statistics always counts zero with e1000g driver
6401903 Memory leak in e1000g driver
5.0.7
======
This version has the following fix:
6337450 e1000g interfaces take much much longer to plumb than bge interfaces on the V40.
6392401 Intel Ophir (82571) e1000g driver fails to attach on sun4u Boston with snv_33
6401659 vlan header getting corrupted due to memmove in e1000g sendPacket
6407374 e1000g still uses some old ddi interrupt routines that need to be changed
6411339 BAD TRAP: e1000g_fill_tx_ring NULL pointer dereference
5.0.8
======
This version has the following fix:
6399084 ipmp doesn't work with e1000g
6412153 ndd force speed is not consistent with e1000g.conf and e1000g(7D)
6415019 system panic when plumb e1000g interface up on SPARC
6415416 netlbtest does not run on Intel(R) PRO/1000 Network controller
5.0.9
======
This version has the following fix:
6337987 Serial Over Lan issue when e1000g driver is used
5.1.0
======
This version has the following fix:
PSARC/2006/248 Nemo MAC-Type Plugin Architecture
PSARC/2006/249 Nemo Changes for Binary Compatibility
6384371 GLDv3 only supports Ethernet
6242059 nemo drivers must not know the size of the mac_t structure
6226635 MAC stats interface could cause problems with binary compatibility
5.1.1
======
This version has the following fix:
6384266 e1000g driver should provide external loopback support
6428883 NEM e1000g drive netlbtest intermittent failed when running Sunvts FUNC test with cputest,vmemtest..
6430731 e1000g.conf file removed on upgrade
6431317 add support for intel Pro/1000 PT Adapter
6433236 Update the e1000g driver with the latest shared code from Intel
6439589 e1000g: whines about checksum capability, unclear what user should do
6441386 The default value of some e1000g parameters may impact rx performance
6445239 assertion failed: cookie_count == 1, file: ../../common/io/e1000g/e1000g_alloc.c, line: 422
6447914 e1000g should support setting of multiple unicast addresses
6449595 Ophir LAA driver workaround is not working for e1000g Driver
5.1.2
======
This version has the following fix:
6450683 Boston panics with e1000g under stress
6463536 BAD TRAP panic for removing aggregation
6463756 e1000g - link_speed / kstat output
6464426 e1000g driver needs a workaround to solve an ESB2 hardware issue
5.1.3
======
This version has the following fix:
6436387 e1000g panic while using cfgadm to unconfigure the pcie slot
6460403 disconnect of pcieX that has ophir with network if plumbed crashes the system
6466962 S10u2 e1000g 5.0.9 adv_autoneg_cap is not reflected on the kstat -p
6470233 e1000g_fill_tx_ring doesn't always update TDT properly
5.1.4
======
This version has the following fix:
6462893 HCTS network test failed on thumper machine due to e1000g issue
6467860 e1000g configured/used as cluster interconnect goes up and down when connected back to back
5.1.5
======
This version has the following fix:
6479912 Interrupt throttling tunable needed
6492025 northstar MMF e1000g external loopback fail.
5.1.6
======
This version has the following fix:
6482530 Need Ethernet driver for Intel G965 chipset
6491179 link aggregation with e1000g does not work unless snoop is running
6494743 e1000g 5.1.4 driver does not work with s11_52
6502458 e1000g is open source, move the source from usr/closed to use/src
6505360 e1000g Makefile should not include "-N drv/dld" in the LDFLAGS
5.1.7
======
This version has the following fix:
6454375 e1000g link flaps at initialization, triggering failovers
6472255 e1000g can't restore to 1000M with ndd setting
6496763 e1000g should free packets when link is down
6501294 "eeprom checksum failed" with pci8086,108c device
6504688 e1000g.conf settings are inconsistent with ndd output
6505445 e1000g : when all advertised capabilities are set to 0, ndd puts all of them 1
6519690 e1000g should not print the link up/down messages to console
6531474 Fatal PCIe Fabric Error panics on T2000 when using jumbo frames on e1000g interfaces
6535712 e1000g: the processing of the checksum flags should be protected by tx_lock
5.1.8
======
This version has the following fix:
6548711 e1000g: recursive mutex_enter in e1000g_link_check() on ESB2 platforms
6550086 e1000g: detaching driver immediately after attach induces panic
5.1.9
======
This version has the following fix:
6507422 Dynamic Reconfiguration detach fails for e1000g
5.1.10
======
This version has the following fix:
6490623 Some networking problems with Solaris_b44_64 domU(using solaris_b44_64 dom0)
6510396 system panicked in e1000g_82547_timeout
6554976 e1000g driver does not support 10D5 device - Sun Pentwater PEM quad port
5.1.11
======
This version has the following fix:
6552853 system panics in e1000g_alloc_dvma_buffer during hotplug testing
5.2.0
======
This version has the following fix:
6535620 e1000g needs to support ICH9 devices
6572330 e1000g: integrate the latest Intel refactored shared code
6573381 e1000g receiving VLAN tagged frames does not do hardware checksumming
5.2.1
======
This version has the following fix:
6594676 e1000g should free private dips while no rx buffers are held by upper layer
5.2.2
======
This version has the following fix:
6480448 Sunvts netlbtest external loopback failed on 82546 chipset
6521984 Sunvts netlbtest failed on Northstar QGE cards
6531842 e1000g link goes down and up frequently on T2000 systems
6540535 Sunvts netlbtest internal loopback failed on ophir devices
6579605 Sunvts netlbtest internal loopback failed on Northstar fiber card
6595668 e1000g postinstall script missed 5 device ids which had been supported by shared code
5.2.3
======
This version has the following fix:
6335851 e1000g needs to support FMA
6605171 WARNING: pciex8086,105e - e1000g[0] : Initialize hw failed
5.2.4
======
This version has the following fix:
6619929 Sunvts test on Northstar QGC EM failed for "Not received any packets in loopback mode".
6541233 e1000g driver performs 33X Slower for Tibco RV when running Multiple RVDs
6572343 e1000g: needs to improve the ip forwarding performance
6637039 e1000g_recycle() missed a mutex_exit()
5.2.5
======
This version has the following fix:
6648775 e1000g: pci8086,10be - e1000g[0]: Identify hardware failed
5.2.6
======
This version has the following fix:
6633239 e1000g: link flaps observed on Galaxy(X4100) systems running 64-bit kernel
5.2.7
======
This version has the following fix:
6673650 e1000g needs to support Brussels
5.2.8
======
This version has the following fix:
6674179 SunFire X4150 panics at e1000g_receive
6679136 E1000g with patch 128028-03 will not allow pause frames to be set
6687947 e1000g needs to integrate the latest Intel shared code to support ICH9m
6699622 e1000g: add support for network device in new development machine
5.2.9
======
6665738 e1000g issues with some Ethernet controllers
6713685 e1000g:one device id macro should be renamed
5.2.10
======
This version has the following fixes:
6335837 e1000g needs to support LSO
6637659 e1000g has problem on transmit hardware checksum support
5.2.11
======
This version has the following fixes:
6698039 e1000g tx doesn't work on the specific chipset since snv_88
6597545 e1000g ESB2 serdes device pciex8086,1098 hangs in network testing
6693205 running sunvts7.0 on Generic s10u5build10 causes unix:cmi_mca_panic on thumper
6694279 e1000g driver: internal loopback mode support needed for nic ESB-2
6721574 max number of segments in e1000g_tx_dma_attr need to be updated when LSO is supported
5.2.12
======
This version has the following fix:
6634746 e1000g is missing lint target in Makefile
6705005 e1000g LINK/ACT LED behaviour is not consistent with the EEPROM default
6738552 e1000g rx_lock is not initialized and destroyed in the code
5.2.13
======
This version has the following fix:
6666998 Add support for ICH10 in e1000g driver
6709230 Requesting driver support in e1000g for new Intel(R) single port MAC/PHY NIC