]>
Commit | Line | Data |
---|---|---|
61ee496e GKH |
1 | From e9162ab1610531d6ea6c1833daeb2613e44275e8 Mon Sep 17 00:00:00 2001 |
2 | From: Peter Korsgaard <jacmet@sunsite.dk> | |
3 | Date: Mon, 3 May 2010 10:01:26 +0000 | |
4 | Subject: dm9601: fix phy/eeprom write routine | |
5 | ||
6 | From: Peter Korsgaard <jacmet@sunsite.dk> | |
7 | ||
8 | commit e9162ab1610531d6ea6c1833daeb2613e44275e8 upstream. | |
9 | ||
10 | Use correct bit positions in DM_SHARED_CTRL register for writes. | |
11 | ||
12 | Michael Planes recently encountered a 'KY-RS9600 USB-LAN converter', which | |
13 | came with a driver CD containing a Linux driver. This driver turns out to | |
14 | be a copy of dm9601.c with symbols renamed and my copyright stripped. | |
15 | That aside, it did contain 1 functional change in dm_write_shared_word(), | |
16 | and after checking the datasheet the original value was indeed wrong | |
17 | (read versus write bits). | |
18 | ||
19 | On Michaels HW, this change bumps receive speed from ~30KB/s to ~900KB/s. | |
20 | On other devices the difference is less spectacular, but still significant | |
21 | (~30%). | |
22 | ||
23 | Reported-by: Michael Planes <michael.planes@free.fr> | |
24 | Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk> | |
25 | Signed-off-by: David S. Miller <davem@davemloft.net> | |
26 | Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de> | |
27 | ||
28 | --- | |
29 | drivers/net/usb/dm9601.c | 2 +- | |
30 | 1 file changed, 1 insertion(+), 1 deletion(-) | |
31 | ||
32 | --- a/drivers/net/usb/dm9601.c | |
33 | +++ b/drivers/net/usb/dm9601.c | |
34 | @@ -238,7 +238,7 @@ static int dm_write_shared_word(struct u | |
35 | goto out; | |
36 | ||
37 | dm_write_reg(dev, DM_SHARED_ADDR, phy ? (reg | 0x40) : reg); | |
38 | - dm_write_reg(dev, DM_SHARED_CTRL, phy ? 0x1c : 0x14); | |
39 | + dm_write_reg(dev, DM_SHARED_CTRL, phy ? 0x1a : 0x12); | |
40 | ||
41 | for (i = 0; i < DM_TIMEOUT; i++) { | |
42 | u8 tmp; |