]> bbs.cooldavid.org Git - jme.git/blob - CHANGELOG
net: drivers: use bool type instead of double negation
[jme.git] / CHANGELOG
1 Version 1.0.7 -- 10/19/2010
2         Source migrated to git, stop maintaining CHANGELOG.
3         The detail of changes can be found with "git log -p VERSION..VERSION"
4         example: git log -p jme-1.0.6..jme-1.0.7
5
6 Version 1.0.6 -- 03/19/2010
7         * Fix memory leak while receiving packets from unregistered VLAN.
8         * Protect vlgrp structure by pause RX actions. Instead of adding
9           lock in the hot zone.
10         * Merge new updates from mainline kernel.
11
12 Version 1.0.5 -- 06/20/2009
13         * Fixed unmatched tasklet_disable and tasklet_enable pair.
14         * Allocate ring buffer information data while module initialize,
15           instead of using global space.
16         * Drop shadow register support, due to buggy hardware.
17
18 Version 1.0.4 -- ??/??/2008
19         * remove unused #include <version.h>
20                 By: Huang Weiyi <weiyi.huang@gmail.com>
21         * fix build error at csum_ipv6_magic()
22                 By: Kamalesh Babulal <kamalesh@linux.vnet.ibm.com>
23
24 Version 1.0.3 -- 10/09/2008
25         * Fixing shared IRQ problem, fixed by akeem.
26         * Add RSS_PATCH, HALF_MODE_PATCH bit setting for JMC250_rev 0x11.
27         * Added ifdef CONFIG_PM for prevent warnings with CONFIG_PM disabled.
28
29 Version 1.0.2 -- 09/15/2008
30         * Modify version check for rev 11 buggy hardware.
31
32 Version 1.0.1 -- 09/05/2008
33         * Removed SPI access to flash device through ioctl.
34           Will be implement with MTD block device and SPI Master in the future.
35
36 Version 1.0 -- 08/29/2008
37         * Passed checkpatch.pl
38         * Passed sparse cleanly.
39         * Tested on various check that mentioned in SubmitChecklist.
40         * Supporting message level controlled by ethtool.
41         * Remove backward compatible codes.
42           (But still kept in non-mainline driver)
43         * Add pseudo hot-plug support.
44         * Fixed fragmented IP packet's TCP/UDP checksum error.
45         * Fine tune some locks, and use atomic bit operations.
46         * Add SPI interface through ioctl for flash re-programing.
47         * Fix high-loading link-down hardware reset unclean problem.
48         * Link-Change tasklet is modified to process all link-change interrupt.
49         * Fix potential racy atomic locks.
50         * Add work-arround for rev 11
51         * Add register debug human readable facilities.
52
53 Version 0.9e -- 08/13/2008
54         * Fix PCC ISR handling bug.
55         * Allow PCCMTUCLR
56         * Wait phylink if PHY WoL is enabled, preventing
57           immediate resume.
58         * Default to turn on Magic Frame WoL only.
59         * Add pci_enable_wake on S1.
60         * Don't release/request IRQ on suspend/resume.
61
62
63 Version 0.9d-msix -- 08/14/2008
64         * Add MSIX support.
65         * Since I still have no idea how to explicitly balance
66           the load to CPUs, the 1.0 version won't include this
67           feature.
68
69
70 Version 0.9d -- 08/13/2008
71         * Fix watchdog bug.
72         * Add jmc260 support.
73
74
75 Version 0.9c -- 08/11/2008
76         * Fix change mac address bug.
77         * Fix PHY Addr polling bug.
78         * Add eeprom read/write support for ethtool
79         * Add PHY Register dump for ethtool
80
81
82 Version 0.9b -- 08/08/2008
83         * Add FPGA Support.
84         * Fix NAPI <-> Adaptive PCC mode switching bug.
85         * Default use Adaptive PCC mode.
86         * Modified watchdog.
87         * Support NAPI for 2.6.22 kernel
88
89
90 Version 0.9a -- 08/07/2008
91         * Implement NAPI, use ethtool -C ethX adaptive-rx [on|off] to switch
92           between NAPI or Dynamic PCC mode at runtime.
93         * Fix Dynamic PCC switch bug.
94         * Pass packets with error checksum to host instead of drop.
95
96
97 Version 0.9 -- 08/04/2008
98         * Implement Scatter-Gather offloading.
99         * Implement TCP Segment offloading.
100         * Pause TX queue until TX queue have sufficient space.
101         *       (Saved a lot CPU)
102         * Turn on WOL by default.
103         * Setup Wakeup Frame to not possible matched pattern.
104         * Tested TCP/UDP csum over IPv4/IPv6 over VLAN all working fine! ^^
105         * Tested TSO over IPv4/IPv6 over VLAN all working fine! ^^
106
107
108 Version 0.8 -- 08/02/2008
109         * Remember last link status for interface up/down.
110         * When driver loaded/unloaded and interface down, change
111         *       link to 10/half force for power saving.
112         * Check MTU setting when setting tx csum.
113         * Implement VLAN offloading.
114
115
116 Version 0.7 -- 08/01/2008
117         * Added Suspend/Resume support.
118         * Added Wake on LAN support.
119
120
121 Version 0.6 -- 07/30/2008
122         * Use NIC Timer for dynamic PCC.
123         * Add another PCC rule for heavy error packet load.
124         * Report and set GHC when change duplex at 10/100 force mode.
125         * Implement Jumboframe.
126         * Implement MSI.
127         * Backdoor for changing "FIFO Threshold for processing next packet"
128         *       Using:
129         *               ethtool -C eth1 adaptive-rx on adaptive-tx on \
130         *               rx-usecs 250 rx-frames-low N
131         *               N := 16 | 32 | 64 | 128
132
133
134 Version 0.5 -- 07/25/2008
135         * Add tx timeout watchdog.
136         * Handle PHY Force mode correctly.
137                 If AN is off, mmaped PHY Status will not update, need to
138                 get information using SMI.
139                 Our NIC does not support 1000M Force Mode, return invalid
140                 if user try to set that.
141         * Should work fine when hot-[un]pluged with pcie-hotplug driver.
142         * Record TX Collision error count on half-duplex mode.
143         * Implement tx ipv6/ip/tcp/udp checksum offloading
144         * Implement rx ipv6/ip/tcp/udp checksum offloading
145         * Add restart-AN support for ethtool.
146         * Add pause control for ethtool.
147         * Add register dump support for ethtool.
148         * Add PCC information for ethtool.
149         * Set Transmit Timer/Retry at Half Duplex Mode.
150         * Change "FIFO Threshold for processing next packet" of RXCS
151                 default to 32QW (Originally 128QW)
152
153
154 Version 0.4 -- 07/24/2008
155         * Support runtime change link speed.
156
157
158 Version 0.3 -- 07/22/2008
159         * Clean up some code, try making it more fit to CodingStyle
160         * Add prepad cache-line optimize support.
161         * Basic RX PCC structure added.
162         * Basic TX PCC structure added.
163         * Reset PHY Processor and turn on ALL advertise by default.
164         * Rewrite TX related functions.
165         * Added 64bit address for PCI DMA support.
166         * Dynamic PCC Adjustment.
167
168
169 Version 0.2 -- 07/17/2008
170         * Handle multiple RX descriptor per packet (Received a LONG packet.)
171         * Drop error RX packets, and update the counter.
172         * Using interrupt shadow register.
173         * Using sk_buff as receive buffer, NIC directly DMA to sk_buff->data.
174         * Use sk_buff kernel provided for NIC directly DMA to send packet.
175         * Use tasklet for tx desc cleanup. (Reduce ISR latency)
176         * Rearange ring data structure for CPU caching efficiency.
177         * Setup RXCS with correct values.
178         * Older(tested to 2.6.18) linux kernel support.
179         * Added a tasklet for link status change.
180         * Added a tasklet for processing incoming packets.
181         * Check DMA MRRS from pci config space, and fill TXCS.
182         * Save TXCS value in local memory, reduce register read time.
183
184
185 Version 0.1 -- 07/11/2008
186         * Basic function completed.
187         * Interrupt handler and xmit function are implemented with
188           care of multiple CPU enviroment.
189         * All offload engine are not used.
190         * PCC/MSI are not used.
191         * Redudent memory copy are used. (Will be removed in the future)
192         * Acceptible performance.
193
194                 Testing platform: Intel(R) Pentium(R) 4 CPU 3.00GHz
195                                   JMicron JMC250
196
197                 Peer platforman:  AMD Athlon(tm) 64 Processor 3000+
198                                   D-Link DGE-530T (Marvell 88E8001)
199
200                         Speed           CPU Usage
201                 TCP tx: 7xMB            40%
202                 TCP rx: 3xMB            30%
203
204                 Note: These speed could be limited by peer, since CPU
205                       load is not much, and queue is not full.
206
207