xref: /titanic_52/usr/src/uts/common/io/e1000g/README (revision 4e5fbfeda6c7dee3dd62538723087263e6de8e18)
1#
2# This file is provided under a CDDLv1 license.  When using or
3# redistributing this file, you may do so under this license.
4# In redistributing this file this license must be included
5# and no other modification of this header file is permitted.
6#
7# CDDL LICENSE SUMMARY
8#
9# Copyright(c) 1999 - 2007 Intel Corporation. All rights reserved.
10#
11# The contents of this file are subject to the terms of Version
12# 1.0 of the Common Development and Distribution License (the "License").
13#
14# You should have received a copy of the License with this software.
15# You can obtain a copy of the License at
16#	http://www.opensolaris.org/os/licensing.
17# See the License for the specific language governing permissions
18# and limitations under the License.
19#
20#
21# Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
22# Use is subject to license terms of the CDDLv1.
23#
24#
25# ident	"%Z%%M%	%I%	%E% SMI"
26#
27
284.0.4 code drop from Intel on 1/30/2003
29=======================================
30  This version is used as the base for putback into both s10 and
31  s9u4.
32
33  Following changes were done to this code base before putting
34  back into solaris trees (S10 & S9U4):
35
36  1) Changes to e1000_hw.c to remove build warnings
37
38     + diff /home/naroori/grizzly/sources/e1000g/1_4.0.4/e1000_hw.c .
39     2616c2616
40     <  phy_info->downshift = hw->speed_downgraded;
41     ---
42     >  phy_info->downshift = (int)hw->speed_downgraded;
43     2684c2684
44     <  phy_info->downshift = hw->speed_downgraded;
45     ---
46     >  phy_info->downshift = (int)hw->speed_downgraded;
47
48  2) Changes to e1000g_dlpi.c for ipv6 plumbing problem and
49     problem with default MTU size of 2024.
50
51     + diff /home/naroori/grizzly/sources/e1000g/1_4.0.4/e1000g_dlpi.c .
52     313a314
53     >  /* the following causes problem with ipv6 plumbing...
54     314a316
55     >  */
56     628c630,632
57     <    if (Adapter->Shared.max_frame_size == FRAME_SIZE_UPTO_16K)
58     ---
59     >    if (Adapter->Shared.max_frame_size == ETHERMTU) {
60     >    }
61     >    else if (Adapter->Shared.max_frame_size == FRAME_SIZE_UPTO_16K) {
62     630c634,635
63     <    else
64     ---
65     >    }
66     >    else  {
67     631a637
68     >    }
69
70  3) Changes to e1000g_main.c for version string modification,
71     removing console messages on bootup and problems with default
72     MTU size of 2024.
73
74     + diff /home/naroori/grizzly/sources/e1000g/1_4.0.4/e1000g_main.c .
75     59c59
76     < static char e1000g_version[]="Driver Ver. 4.0.4-beta";
77     ---
78     > static char e1000g_version[]="Driver Ver. 4.0.4";
79     937c937
80     <        e1000g_log(Adapter,CE_CONT,"\n%s, %s\n",AdapterName,e1000g_version);
81     ---
82     >        cmn_err(CE_CONT,"!%s, %s\n",AdapterName,e1000g_version);
83     3000c3000
84     <        Adapter->Shared.max_frame_size = FRAME_SIZE_UPTO_2K;
85     ---
86     >        Adapter->Shared.max_frame_size = ETHERMTU;
87     3013c3013
88     <        Adapter->Shared.max_frame_size = FRAME_SIZE_UPTO_2K;
89     ---
90     >        Adapter->Shared.max_frame_size = ETHERMTU;
91
92
93
94Bug fixes to 4.0.4:
95===================
96   1) bug#4829398 code cleanup for ethernet bootup messages
97
98
994.0.12 code drop from Intel on 3/18/2003
100========================================
101
102  This drop had extensive changes from 4.0.4. Many changes after
103  4.0.4 were realted to new hardware (a.k.a. BayCity chipset),
104  not relevant to Grizzly.After looking at the changelog from Intel,
105  we decided not to do a putback but rather take only high priority
106  fixes from this drop and generate a new version 4.0.4.1.
107
108  Here is the changelog supplied by Intel for this drop:
109
110    ________________________________________________________________________
111    Component Name: Unix-Solaris_8254x_BayCity_Intel
112    Description: Bay City software component for gigabit products
113    ________________________________________________________________________
114
115
116    ---Version: 4.0.13  Date: 3/14/2003 5:00:00 PM---
117    Added transmit mutex locking to the 82547 workaround code.
118
119    ---Version: 4.0.12  Date: 3/10/2003 8:01:00 PM---
120    Added new shared code with LED link speed fix
121
122    ---Version: 4.0.11  Date: 3/7/2003 5:57:00 PM---
123    Updated the Tanacross FIFO hang workaround to reset FIFO pointers instead of sending autonomous packets.
124
125    ---Version: 4.0.10  Date: 3/4/2003 2:39:00 PM---
126    Removed an extra sdu adjustment that was left in by accident
127
128    ---Version: 4.0.9   Date: 3/4/2003 11:13:00 AM---
129    Removed the first call to adapter_stop.  This was called before the HW struct was properly initialized, and could cause hangs.
130
131    Changed reported ethernet sdu from 2024 to 1500, as driver could be configured for invalid frame MTU sizes in Solaris 9.
132
133    Added Tanacross workaround for FIFO hang.
134
135    ---Version: 4.0.8   Date: 2/25/2003 2:27:00 PM---
136    Shared code update including Phy init script.
137    Smartspeed workaround added.  e1000g_smartspeed called from LocalTimer function every two seconds when link is down.
138
139    ---Version: 4.0.7   Date: 2/18/2003 11:41:00 AM---
140    Updated to include bug fixes from the shared code.
141
142    ---Version: 4.0.5   Date: 1/31/2003 10:13:00 AM---
143    Support for new hardware changes
144    Removed the extra ack sent at the end of the attach_req routine.  This extra ack previously made IPv6 plumbing on Solaris 9 fail.
145
146
1474.0.4.1
148=======
149   This version is not an Intel drop but 4.0.4 merged with two
150   high priority fixes from 4.0.12. We will give back the 4.0.4.1
151   driver back to Intel, per their request, so they have the exact
152   code that we are releasing through Solaris.
153
154   The following are the two fixes selected for inclusion from
155   4.0.12 codebase:
156
157   1) Removing the first call to adapter_stop as discussed in
158      4.0.12 changelog.
159
160   2) Corrections to MTU size calculations first introduced
161      in our 4.0.4 putback to bring them into sync with 4.0.12
162      MTU size calculations.
163
164   We also added README file (current file you are reading) during
165   this putback.
166
1674.0.4.2
168=======
169  This version has the following fixes:
170
171  1) bug#4857098: e1000g driver assumes another intel card as its own.
172     The fix involved eliminating 1009, 1012, 1015, 1016, 1017
173     device-ids from e1000g nodelist so that they do not conflict
174     with iprb's subsystem-ids.
175
176     This fix has to be reverted later once we have a proper fix for
177     bug#4859426.
178
179   2) bug#4853683: e1000g lacks a large number of expected kstats
180      The fix involved three steps: a) Renaming some of the existing
181      kstats to comply with WDD documentation b) Computing some of
182      those which are not being tracked c) Supplying zero for the rest
183      the error stats which are not being tracked.
184
185      This fix has to be revisited to improvise the statistics in
186      future.
187
188   3) bug#4862529: System panics during configuring devices on a Dell 4-way
189      servers. The fix involved removing all the devic-ids from nodelist
190      except for 1010. This means that we support now only the grizzly
191      on-board gigabit chipset and "Intel Pro/1000 MT Dual Server Adapter".
192
193      This fix has to be reverted later once we have a proper fix for
194      bug#4859426.
195
1964.0.4.3
197=======
198  This version has the following fixes:
199
200  1) bug#4874857: ipv6 ping fails on bootup for e1000g.
201	 The fix involved implementing multicast tables both at per stream
202	 level and per device level.
203
204  2) bug#4875743: null pointer dereference in ddi_dma_addr_bind_handle.
205	 The fix involved adding LastTxDescriptorBuf to struct e1000g and
206	 handling consequent proper calculations for LastTxDescriptor.
207
208  3) bug#4882541: setting up ethernet address causes machine to panic.
209     The fix involved removing a spurious log message which was causing
210	 the panic.
211
212  4) bug#4883302: Reinstate the removed device-ids - phase 2.
213	 The fix involved some chip initializations to handle 1000 id.
214
215  5) bug#4919285: device id 8086,100e needs to be added
216	 The fix needed for the Intel Precision 350 workstation
217
2184.2.11
219======
220
221We need to sync up with the latest Intel code base for e1000g driver.
222
223Intel is currently at version 4.2.11 while we are on 4.0.4 branch.
224The exact version under 4.0.4 branch is 4.0.4.3. Since we are on
225the branch while Intel is working on the main trunk, we have had
226lot of friction in getting timely fixes from Intel. The current
227syncing up with their main trunk lets us a smooth migration path.
228
229The new code base  also would provide us with support for additional
230cards including Quad port cards (See bugs: 4921433, 4914460).
231In our old 4.0.4 branch, we had to drop support for a lot of cards
232for various problems; with the current syncing up, we would be able
233to support so many various cards except for the cards clashing with
234iprb driver.
235
236The new code base also has support for additional new chipsets. The code
237base also benefits from any fixes to the shared code base with other
238operating system drivers.
239
240The new codebase also has lot of cleanups in terms of various #ifdefs
241and should be much simpler to maintain.
242
243So the list of actual ids take out are:
2441009
2451012
2461013
2471015
2481016
2491017
250
2514.2.15
252======
253This intel code drop addresses the following bug:
254
255    4909863: Bad trap panic in e1000g_rtn_buf
256
2574.2.16
258======
259  This version has the following fix:
260   4932422 interconnect remains faulted after adapter disconnected and then reconnected
261
262Notes on packaging:
263===================
264   Intel names the package as INTCGigaE while we chose to rename
265   it as SUNWintgige as per Sun packaging conventions.
266
2674.2.17
268======
269  This version has the following fixes:
270   4971416 e1000g seems to hang system when no network connected
271   4997067 e1000gattach panicks when the going gets tough
272   4990064 e1000g leaks memory when it runs out of transmit descriptors
273
2744.2.17.1
275======
276  This version has the following fix:
277   5014625 e1000g driver panicked when snoop(1M) exited
278
2794.2.17.2
280======
281  This version has the following fix:
282   4940870 e1000g: Dependence on instance initialization order disables .conf properties
283   5033616 e1000g panicked after rem_drv while some service still binds to the driver
284   5037062 strings have crept back in e1000g/adpu320 related mutex_init()s
285   5050268 Some e1000g flag operations are not correct.
286
2874.2.17.3
288======
289  This version has the following fix:
290   5067162 e1000g cannot transmit heavy UDP
291
2924.2.17.4
293======
294  This version has the following fix:
295   5010052 The stress load/unload test of Intel PWLA8494MT Quad Port NIC causes system hung
296   5050265 E1000g does not support IPV6 fast path. This will impact IPV6 performance.
297   5050369 E1000g locks the system if plumb/unplumb under heavy workload and snoop.
298   5050415 E1000g will accepts ethernet packets which are not addressed to it.
299   5055132 E1000g crashes when injected with Jumbo Frame packets.
300
3014.2.17.5
302======
303  This version has the following fix:
304   6175307 system crash with memory size of 11GB
305   6176031 the sequence of releasing resource error in e1000gattach
306   6180180 PktAlloc - Could not bind rbuf packet as single frag. Count - 2
307   6185022 Port hang when unplumb interface under heavy traffic
308
3094.2.17.6
310======
311  This version has the following fix:
312   6196426 e1000g should support NICs that use the internal serdes for external connectivity
313
3144.2.17.7
315======
316  This version has the following fix:
317   4921433 e1000g: Should not probe by using VID/DID table to identify adapters
318
3194.2.17.8
320======
321  This version has the following fix:
322   6213101 64bit DMA max address space should be supported by e1000g driver
323   6215261 e1000g driver 211% slower in AMD64 than 32 bit e1000g driver (S10_73, Single CPU V20z)
324
3254.2.17.9
326======
327  This version has the following fix:
328   6256212 fix for 6213101 breaks e1000g for 32-bit kernels on machines with >4GB of physical memory
329
3304.2.17.10
331======
332  This version has the following fix:
333   6203602 e1000g needs to support the Intel PCI-E card
334   6217046 we need to merge the Intel code (version 4.2.28) into e1000g
335
3365.0.0
337======
338  This version has the following fix:
339   PSARC/2005/470 E1000g Nemo Migration
340   6221079 e1000g driver interface conversion from DLPI to GLD3.0(nemo)
341   6224901 e1000g fails to configure VLANs on a Sun v65x
342   6286414 snmp: ifOperStatus for e1000g driver doesn't change when cable is unplugged.
343   6238486 e1000g: poor performance in web server benchmark, high CPU utilization noted
344   6293265 e1000g_intr doesn't use mutex at all
345   6304657 e1000g_PktAlloc_buffers() causes a panic when ddi_dma_addr_bind_handle() fails.
346   4913292 e1000g: does not support PSARC 2003/264 Extended IP cksum_offload
347   5071610 e1000g can't send any packets after a jumbo-packet forwarding test.
348   5082975 in Jumbo enable mode, netperf indicates a lower throughput, compared to Jumbo of
349   5085394 e1000g driver hangs system during 64byte stress testing
350   6174349 netlb support needed for Solaris e1000g driver
351   6207682 e1000g needs link up/down support
352   6211068 e1000g has some input error packets during stress test
353   6212810 e1000g caught sending unsolicited M_PROTO/M_PCPROTO messages
354   6219298 warnings about "inconsistent getinfo(9E) implementation"
355   6226217 e1000g should support trunking
356   6239279 Network stess test fail on 82545GM chip on IBM Blade HS40
357   6242612 e1000g needs to support SPARC
358   6247936 In e1000g transmission, ddi_dma_addr_bind_handle() returns more cookies than speficied
359   6273730 e1000g causes memory leaks within Freelist_alloc and PktAlloc_buffers
360   5073739 find some memory leaks after load_unload test
361   6287250 e1000g may need to use new Intel-recommended semaphore mechanism
362
3635.0.1
364======
365  This version has the following fix:
366   6313609 2-port Intel NIC (part# 370-6687) performs poorly compared to 1-port Intel NIC (part# 370-6685)
367   6315002 gcc and e1000g don't get along
368
3695.0.2
370======
371  This version has the following fix:
372   6319100 Tier0 Ontario machine does not boot net with sparc e1000g driver substitution for sparc ipge driver
373
3745.0.3
375======
376  This version has the following fix:
377   6327693 e1000g should use MSIs when possible
378   6333461 panic[cpu0]/thread=d63f4de0: assertion failed: !dma->dp_inuse, file: ../../i86pc/io/rootnex.c
379
3805.0.4
381======
382  This version has the following fix:
383   6351378 e1000g panic seen after bfu'ing latest onnv nightly
384
3855.0.5
386======
387  This version has the following fix:
388   6303973 System hard hangs when sharing interrupts (in PIC) mode
389   6323732 e1000g reports incorrect packet statistics
390   6333880 Customer is requesting driver for a newIntel 82573 NIC
391   6336163 netlb support needed for Solaris (sparc) e1000g driver
392   6339377 e1000g.conf needs to be simplified
393   6350407 e1000 card in Gateway E2300 does not actually send packets in S10U1
394   6364052 e1000g driver should provide interface to ndd utility
395   6367490 e1000g has problem in deliver UDP fragment with addin card
396
3975.0.6
398======
399  This version has the following fix:
400   4967732 e1000g: high mutex contention in e1000g_start
401   6316907 e1000g: bcopy() brings better performance in transmitting and receiving small packet
402   6371753 aggregation of e1000g NICs fails to provide connectivity unless snoop is running
403   6397163 Jumbo frame statistics always counts zero with e1000g driver
404   6401903 Memory leak in e1000g driver
405
4065.0.7
407======
408  This version has the following fix:
409   6337450 e1000g interfaces take much much longer to plumb than bge interfaces on the V40.
410   6392401 Intel Ophir (82571) e1000g driver fails to attach on sun4u Boston with snv_33
411   6401659 vlan header getting corrupted due to memmove in e1000g sendPacket
412   6407374 e1000g still uses some old ddi interrupt routines that need to be changed
413   6411339 BAD TRAP: e1000g_fill_tx_ring NULL pointer dereference
414
4155.0.8
416======
417  This version has the following fix:
418   6399084 ipmp doesn't work with e1000g
419   6412153 ndd force speed is not consistent with e1000g.conf and e1000g(7D)
420   6415019 system panic when plumb e1000g interface up on SPARC
421   6415416 netlbtest does not run on Intel(R) PRO/1000 Network controller
422
4235.0.9
424======
425  This version has the following fix:
426  6337987 Serial Over Lan issue when e1000g driver is used
427
4285.1.0
429======
430  This version has the following fix:
431  PSARC/2006/248 Nemo MAC-Type Plugin Architecture
432  PSARC/2006/249 Nemo Changes for Binary Compatibility
433  6384371 GLDv3 only supports Ethernet
434  6242059 nemo drivers must not know the size of the mac_t structure
435  6226635 MAC stats interface could cause problems with binary compatibility
436
4375.1.1
438======
439  This version has the following fix:
440   6384266 e1000g driver should provide external loopback support
441   6428883 NEM e1000g drive netlbtest intermittent failed when running Sunvts FUNC test with cputest,vmemtest..
442   6430731 e1000g.conf file removed on upgrade
443   6431317 add support for intel Pro/1000 PT Adapter
444   6433236 Update the e1000g driver with the latest shared code from Intel
445   6439589 e1000g: whines about checksum capability, unclear what user should do
446   6441386 The default value of some e1000g parameters may impact rx performance
447   6445239 assertion failed: cookie_count == 1, file: ../../common/io/e1000g/e1000g_alloc.c, line: 422
448   6447914 e1000g should support setting of multiple unicast addresses
449   6449595 Ophir LAA driver workaround is not working for e1000g Driver
450
4515.1.2
452======
453  This version has the following fix:
454   6450683 Boston panics with e1000g under stress
455   6463536 BAD TRAP panic for removing aggregation
456   6463756 e1000g - link_speed / kstat output
457   6464426 e1000g driver needs a workaround to solve an ESB2 hardware issue
458
4595.1.3
460======
461  This version has the following fix:
462   6436387 e1000g panic while using cfgadm to unconfigure the pcie slot
463   6460403 disconnect of pcieX that has ophir with network if plumbed crashes the system
464   6466962 S10u2 e1000g 5.0.9 adv_autoneg_cap is not reflected on the kstat -p
465   6470233 e1000g_fill_tx_ring doesn't always update TDT properly
466
4675.1.4
468======
469  This version has the following fix:
470   6462893 HCTS network test failed on thumper machine due to e1000g issue
471   6467860 e1000g configured/used as cluster interconnect goes up and down when connected back to back
472
4735.1.5
474======
475  This version has the following fix:
476   6479912 Interrupt throttling tunable needed
477   6492025 northstar MMF e1000g external loopback fail.
478
4795.1.6
480======
481  This version has the following fix:
482   6482530 Need Ethernet driver for Intel G965 chipset
483   6491179 link aggregation with e1000g does not work unless snoop is running
484   6494743 e1000g 5.1.4 driver does not work with s11_52
485   6502458 e1000g is open source, move the source from usr/closed to use/src
486   6505360 e1000g Makefile should not include "-N drv/dld" in the LDFLAGS
487
488