1 /* CoreChip-sz SR9800 one chip USB 2.0 Ethernet Devices
3 * Author : Liu Junliang <liujunliang_ljl@163.com>
5 * Based on asix_common.c, asix_devices.c
7 * This file is licensed under the terms of the GNU General Public License
8 * version 2. This program is licensed "as is" without any warranty of any
9 * kind, whether express or implied.*
12 #include <linux/module.h>
13 #include <linux/kmod.h>
14 #include <linux/init.h>
15 #include <linux/netdevice.h>
16 #include <linux/etherdevice.h>
17 #include <linux/ethtool.h>
18 #include <linux/workqueue.h>
19 #include <linux/mii.h>
20 #include <linux/usb.h>
21 #include <linux/crc32.h>
22 #include <linux/usb/usbnet.h>
23 #include <linux/slab.h>
24 #include <linux/if_vlan.h>
28 static int sr_read_cmd(struct usbnet
*dev
, u8 cmd
, u16 value
, u16 index
,
33 err
= usbnet_read_cmd(dev
, cmd
, SR_REQ_RD_REG
, value
, index
,
35 if ((err
!= size
) && (err
>= 0))
41 static int sr_write_cmd(struct usbnet
*dev
, u8 cmd
, u16 value
, u16 index
,
46 err
= usbnet_write_cmd(dev
, cmd
, SR_REQ_WR_REG
, value
, index
,
48 if ((err
!= size
) && (err
>= 0))
55 sr_write_cmd_async(struct usbnet
*dev
, u8 cmd
, u16 value
, u16 index
,
58 usbnet_write_cmd_async(dev
, cmd
, SR_REQ_WR_REG
, value
, index
, data
,
62 static int sr_rx_fixup(struct usbnet
*dev
, struct sk_buff
*skb
)
66 while (offset
+ sizeof(u32
) < skb
->len
) {
67 struct sk_buff
*sr_skb
;
69 u32 header
= get_unaligned_le32(skb
->data
+ offset
);
71 offset
+= sizeof(u32
);
72 /* get the packet length */
73 size
= (u16
) (header
& 0x7ff);
74 if (size
!= ((~header
>> 16) & 0x07ff)) {
75 netdev_err(dev
->net
, "%s : Bad Header Length\n",
80 if ((size
> dev
->net
->mtu
+ ETH_HLEN
+ VLAN_HLEN
) ||
81 (size
+ offset
> skb
->len
)) {
82 netdev_err(dev
->net
, "%s : Bad RX Length %d\n",
86 sr_skb
= netdev_alloc_skb_ip_align(dev
->net
, size
);
90 skb_put(sr_skb
, size
);
91 memcpy(sr_skb
->data
, skb
->data
+ offset
, size
);
92 usbnet_skb_return(dev
, sr_skb
);
94 offset
+= (size
+ 1) & 0xfffe;
97 if (skb
->len
!= offset
) {
98 netdev_err(dev
->net
, "%s : Bad SKB Length %d\n", __func__
,
106 static struct sk_buff
*sr_tx_fixup(struct usbnet
*dev
, struct sk_buff
*skb
,
109 int headroom
= skb_headroom(skb
);
110 int tailroom
= skb_tailroom(skb
);
111 u32 padbytes
= 0xffff0000;
115 padlen
= ((skb
->len
+ 4) % (dev
->maxpacket
- 1)) ? 0 : 4;
117 if ((!skb_cloned(skb
)) && ((headroom
+ tailroom
) >= (4 + padlen
))) {
118 if ((headroom
< 4) || (tailroom
< padlen
)) {
119 skb
->data
= memmove(skb
->head
+ 4, skb
->data
,
121 skb_set_tail_pointer(skb
, skb
->len
);
124 struct sk_buff
*skb2
;
125 skb2
= skb_copy_expand(skb
, 4, padlen
, flags
);
126 dev_kfree_skb_any(skb
);
133 packet_len
= (((skb
->len
- 4) ^ 0x0000ffff) << 16) + (skb
->len
- 4);
134 cpu_to_le32s(&packet_len
);
135 skb_copy_to_linear_data(skb
, &packet_len
, sizeof(packet_len
));
138 cpu_to_le32s(&padbytes
);
139 memcpy(skb_tail_pointer(skb
), &padbytes
, sizeof(padbytes
));
140 skb_put(skb
, sizeof(padbytes
));
146 static void sr_status(struct usbnet
*dev
, struct urb
*urb
)
148 struct sr9800_int_data
*event
;
151 if (urb
->actual_length
< 8)
154 event
= urb
->transfer_buffer
;
155 link
= event
->link
& 0x01;
156 if (netif_carrier_ok(dev
->net
) != link
) {
157 usbnet_link_change(dev
, link
, 1);
158 netdev_dbg(dev
->net
, "Link Status is: %d\n", link
);
164 static inline int sr_set_sw_mii(struct usbnet
*dev
)
168 ret
= sr_write_cmd(dev
, SR_CMD_SET_SW_MII
, 0x0000, 0, 0, NULL
);
170 netdev_err(dev
->net
, "Failed to enable software MII access\n");
174 static inline int sr_set_hw_mii(struct usbnet
*dev
)
178 ret
= sr_write_cmd(dev
, SR_CMD_SET_HW_MII
, 0x0000, 0, 0, NULL
);
180 netdev_err(dev
->net
, "Failed to enable hardware MII access\n");
184 static inline int sr_get_phy_addr(struct usbnet
*dev
)
189 ret
= sr_read_cmd(dev
, SR_CMD_READ_PHY_ID
, 0, 0, 2, buf
);
191 netdev_err(dev
->net
, "%s : Error reading PHYID register:%02x\n",
195 netdev_dbg(dev
->net
, "%s : returning 0x%04x\n", __func__
,
204 static int sr_sw_reset(struct usbnet
*dev
, u8 flags
)
208 ret
= sr_write_cmd(dev
, SR_CMD_SW_RESET
, flags
, 0, 0, NULL
);
210 netdev_err(dev
->net
, "Failed to send software reset:%02x\n",
216 static u16
sr_read_rx_ctl(struct usbnet
*dev
)
221 ret
= sr_read_cmd(dev
, SR_CMD_READ_RX_CTL
, 0, 0, 2, &v
);
223 netdev_err(dev
->net
, "Error reading RX_CTL register:%02x\n",
228 ret
= le16_to_cpu(v
);
233 static int sr_write_rx_ctl(struct usbnet
*dev
, u16 mode
)
237 netdev_dbg(dev
->net
, "%s : mode = 0x%04x\n", __func__
, mode
);
238 ret
= sr_write_cmd(dev
, SR_CMD_WRITE_RX_CTL
, mode
, 0, 0, NULL
);
241 "Failed to write RX_CTL mode to 0x%04x:%02x\n",
247 static u16
sr_read_medium_status(struct usbnet
*dev
)
252 ret
= sr_read_cmd(dev
, SR_CMD_READ_MEDIUM_STATUS
, 0, 0, 2, &v
);
255 "Error reading Medium Status register:%02x\n", ret
);
256 return ret
; /* TODO: callers not checking for error ret */
259 return le16_to_cpu(v
);
262 static int sr_write_medium_mode(struct usbnet
*dev
, u16 mode
)
266 netdev_dbg(dev
->net
, "%s : mode = 0x%04x\n", __func__
, mode
);
267 ret
= sr_write_cmd(dev
, SR_CMD_WRITE_MEDIUM_MODE
, mode
, 0, 0, NULL
);
270 "Failed to write Medium Mode mode to 0x%04x:%02x\n",
275 static int sr_write_gpio(struct usbnet
*dev
, u16 value
, int sleep
)
279 netdev_dbg(dev
->net
, "%s : value = 0x%04x\n", __func__
, value
);
280 ret
= sr_write_cmd(dev
, SR_CMD_WRITE_GPIOS
, value
, 0, 0, NULL
);
282 netdev_err(dev
->net
, "Failed to write GPIO value 0x%04x:%02x\n",
290 /* SR9800 have a 16-bit RX_CTL value */
291 static void sr_set_multicast(struct net_device
*net
)
293 struct usbnet
*dev
= netdev_priv(net
);
294 struct sr_data
*data
= (struct sr_data
*)&dev
->data
;
295 u16 rx_ctl
= SR_DEFAULT_RX_CTL
;
297 if (net
->flags
& IFF_PROMISC
) {
298 rx_ctl
|= SR_RX_CTL_PRO
;
299 } else if (net
->flags
& IFF_ALLMULTI
||
300 netdev_mc_count(net
) > SR_MAX_MCAST
) {
301 rx_ctl
|= SR_RX_CTL_AMALL
;
302 } else if (netdev_mc_empty(net
)) {
303 /* just broadcast and directed */
305 /* We use the 20 byte dev->data
306 * for our 8 byte filter buffer
307 * to avoid allocating memory that
308 * is tricky to free later
310 struct netdev_hw_addr
*ha
;
313 memset(data
->multi_filter
, 0, SR_MCAST_FILTER_SIZE
);
315 /* Build the multicast hash filter. */
316 netdev_for_each_mc_addr(ha
, net
) {
317 crc_bits
= ether_crc(ETH_ALEN
, ha
->addr
) >> 26;
318 data
->multi_filter
[crc_bits
>> 3] |=
322 sr_write_cmd_async(dev
, SR_CMD_WRITE_MULTI_FILTER
, 0, 0,
323 SR_MCAST_FILTER_SIZE
, data
->multi_filter
);
325 rx_ctl
|= SR_RX_CTL_AM
;
328 sr_write_cmd_async(dev
, SR_CMD_WRITE_RX_CTL
, rx_ctl
, 0, 0, NULL
);
331 static int sr_mdio_read(struct net_device
*net
, int phy_id
, int loc
)
333 struct usbnet
*dev
= netdev_priv(net
);
336 mutex_lock(&dev
->phy_mutex
);
338 sr_read_cmd(dev
, SR_CMD_READ_MII_REG
, phy_id
, (__u16
)loc
, 2, &res
);
340 mutex_unlock(&dev
->phy_mutex
);
343 "%s : phy_id=0x%02x, loc=0x%02x, returns=0x%04x\n", __func__
,
344 phy_id
, loc
, le16_to_cpu(res
));
346 return le16_to_cpu(res
);
350 sr_mdio_write(struct net_device
*net
, int phy_id
, int loc
, int val
)
352 struct usbnet
*dev
= netdev_priv(net
);
353 __le16 res
= cpu_to_le16(val
);
356 "%s : phy_id=0x%02x, loc=0x%02x, val=0x%04x\n", __func__
,
358 mutex_lock(&dev
->phy_mutex
);
360 sr_write_cmd(dev
, SR_CMD_WRITE_MII_REG
, phy_id
, (__u16
)loc
, 2, &res
);
362 mutex_unlock(&dev
->phy_mutex
);
365 /* Get the PHY Identifier from the PHYSID1 & PHYSID2 MII registers */
366 static u32
sr_get_phyid(struct usbnet
*dev
)
372 /* Poll for the rare case the FW or phy isn't ready yet. */
373 for (i
= 0; i
< 100; i
++) {
374 phy_reg
= sr_mdio_read(dev
->net
, dev
->mii
.phy_id
, MII_PHYSID1
);
375 if (phy_reg
!= 0 && phy_reg
!= 0xFFFF)
380 if (phy_reg
<= 0 || phy_reg
== 0xFFFF)
383 phy_id
= (phy_reg
& 0xffff) << 16;
385 phy_reg
= sr_mdio_read(dev
->net
, dev
->mii
.phy_id
, MII_PHYSID2
);
389 phy_id
|= (phy_reg
& 0xffff);
395 sr_get_wol(struct net_device
*net
, struct ethtool_wolinfo
*wolinfo
)
397 struct usbnet
*dev
= netdev_priv(net
);
400 if (sr_read_cmd(dev
, SR_CMD_READ_MONITOR_MODE
, 0, 0, 1, &opt
) < 0) {
401 wolinfo
->supported
= 0;
402 wolinfo
->wolopts
= 0;
405 wolinfo
->supported
= WAKE_PHY
| WAKE_MAGIC
;
406 wolinfo
->wolopts
= 0;
407 if (opt
& SR_MONITOR_LINK
)
408 wolinfo
->wolopts
|= WAKE_PHY
;
409 if (opt
& SR_MONITOR_MAGIC
)
410 wolinfo
->wolopts
|= WAKE_MAGIC
;
414 sr_set_wol(struct net_device
*net
, struct ethtool_wolinfo
*wolinfo
)
416 struct usbnet
*dev
= netdev_priv(net
);
419 if (wolinfo
->wolopts
& WAKE_PHY
)
420 opt
|= SR_MONITOR_LINK
;
421 if (wolinfo
->wolopts
& WAKE_MAGIC
)
422 opt
|= SR_MONITOR_MAGIC
;
424 if (sr_write_cmd(dev
, SR_CMD_WRITE_MONITOR_MODE
,
425 opt
, 0, 0, NULL
) < 0)
431 static int sr_get_eeprom_len(struct net_device
*net
)
433 struct usbnet
*dev
= netdev_priv(net
);
434 struct sr_data
*data
= (struct sr_data
*)&dev
->data
;
436 return data
->eeprom_len
;
439 static int sr_get_eeprom(struct net_device
*net
,
440 struct ethtool_eeprom
*eeprom
, u8
*data
)
442 struct usbnet
*dev
= netdev_priv(net
);
443 __le16
*ebuf
= (__le16
*)data
;
447 /* Crude hack to ensure that we don't overwrite memory
448 * if an odd length is supplied
453 eeprom
->magic
= SR_EEPROM_MAGIC
;
455 /* sr9800 returns 2 bytes from eeprom on read */
456 for (i
= 0; i
< eeprom
->len
/ 2; i
++) {
457 ret
= sr_read_cmd(dev
, SR_CMD_READ_EEPROM
, eeprom
->offset
+ i
,
465 static void sr_get_drvinfo(struct net_device
*net
,
466 struct ethtool_drvinfo
*info
)
468 struct usbnet
*dev
= netdev_priv(net
);
469 struct sr_data
*data
= (struct sr_data
*)&dev
->data
;
471 /* Inherit standard device info */
472 usbnet_get_drvinfo(net
, info
);
473 strncpy(info
->driver
, DRIVER_NAME
, sizeof(info
->driver
));
474 strncpy(info
->version
, DRIVER_VERSION
, sizeof(info
->version
));
475 info
->eedump_len
= data
->eeprom_len
;
478 static u32
sr_get_link(struct net_device
*net
)
480 struct usbnet
*dev
= netdev_priv(net
);
482 return mii_link_ok(&dev
->mii
);
485 static int sr_ioctl(struct net_device
*net
, struct ifreq
*rq
, int cmd
)
487 struct usbnet
*dev
= netdev_priv(net
);
489 return generic_mii_ioctl(&dev
->mii
, if_mii(rq
), cmd
, NULL
);
492 static int sr_set_mac_address(struct net_device
*net
, void *p
)
494 struct usbnet
*dev
= netdev_priv(net
);
495 struct sr_data
*data
= (struct sr_data
*)&dev
->data
;
496 struct sockaddr
*addr
= p
;
498 if (netif_running(net
))
500 if (!is_valid_ether_addr(addr
->sa_data
))
501 return -EADDRNOTAVAIL
;
503 memcpy(net
->dev_addr
, addr
->sa_data
, ETH_ALEN
);
505 /* We use the 20 byte dev->data
506 * for our 6 byte mac buffer
507 * to avoid allocating memory that
508 * is tricky to free later
510 memcpy(data
->mac_addr
, addr
->sa_data
, ETH_ALEN
);
511 sr_write_cmd_async(dev
, SR_CMD_WRITE_NODE_ID
, 0, 0, ETH_ALEN
,
517 static const struct ethtool_ops sr9800_ethtool_ops
= {
518 .get_drvinfo
= sr_get_drvinfo
,
519 .get_link
= sr_get_link
,
520 .get_msglevel
= usbnet_get_msglevel
,
521 .set_msglevel
= usbnet_set_msglevel
,
522 .get_wol
= sr_get_wol
,
523 .set_wol
= sr_set_wol
,
524 .get_eeprom_len
= sr_get_eeprom_len
,
525 .get_eeprom
= sr_get_eeprom
,
526 .get_settings
= usbnet_get_settings
,
527 .set_settings
= usbnet_set_settings
,
528 .nway_reset
= usbnet_nway_reset
,
531 static int sr9800_link_reset(struct usbnet
*dev
)
533 struct ethtool_cmd ecmd
= { .cmd
= ETHTOOL_GSET
};
536 mii_check_media(&dev
->mii
, 1, 1);
537 mii_ethtool_gset(&dev
->mii
, &ecmd
);
538 mode
= SR9800_MEDIUM_DEFAULT
;
540 if (ethtool_cmd_speed(&ecmd
) != SPEED_100
)
541 mode
&= ~SR_MEDIUM_PS
;
543 if (ecmd
.duplex
!= DUPLEX_FULL
)
544 mode
&= ~SR_MEDIUM_FD
;
546 netdev_dbg(dev
->net
, "%s : speed: %u duplex: %d mode: 0x%04x\n",
547 __func__
, ethtool_cmd_speed(&ecmd
), ecmd
.duplex
, mode
);
549 sr_write_medium_mode(dev
, mode
);
555 static int sr9800_set_default_mode(struct usbnet
*dev
)
560 sr_mdio_write(dev
->net
, dev
->mii
.phy_id
, MII_BMCR
, BMCR_RESET
);
561 sr_mdio_write(dev
->net
, dev
->mii
.phy_id
, MII_ADVERTISE
,
562 ADVERTISE_ALL
| ADVERTISE_CSMA
);
563 mii_nway_restart(&dev
->mii
);
565 ret
= sr_write_medium_mode(dev
, SR9800_MEDIUM_DEFAULT
);
569 ret
= sr_write_cmd(dev
, SR_CMD_WRITE_IPG012
,
570 SR9800_IPG0_DEFAULT
| SR9800_IPG1_DEFAULT
,
571 SR9800_IPG2_DEFAULT
, 0, NULL
);
573 netdev_dbg(dev
->net
, "Write IPG,IPG1,IPG2 failed: %d\n", ret
);
577 /* Set RX_CTL to default values with 2k buffer, and enable cactus */
578 ret
= sr_write_rx_ctl(dev
, SR_DEFAULT_RX_CTL
);
582 rx_ctl
= sr_read_rx_ctl(dev
);
583 netdev_dbg(dev
->net
, "RX_CTL is 0x%04x after all initializations\n",
586 rx_ctl
= sr_read_medium_status(dev
);
587 netdev_dbg(dev
->net
, "Medium Status:0x%04x after all initializations\n",
595 static int sr9800_reset(struct usbnet
*dev
)
597 struct sr_data
*data
= (struct sr_data
*)&dev
->data
;
601 ret
= sr_write_gpio(dev
,
602 SR_GPIO_RSE
| SR_GPIO_GPO_2
| SR_GPIO_GPO2EN
, 5);
606 embd_phy
= ((sr_get_phy_addr(dev
) & 0x1f) == 0x10 ? 1 : 0);
608 ret
= sr_write_cmd(dev
, SR_CMD_SW_PHY_SELECT
, embd_phy
, 0, 0, NULL
);
610 netdev_dbg(dev
->net
, "Select PHY #1 failed: %d\n", ret
);
614 ret
= sr_sw_reset(dev
, SR_SWRESET_IPPD
| SR_SWRESET_PRL
);
620 ret
= sr_sw_reset(dev
, SR_SWRESET_CLEAR
);
627 ret
= sr_sw_reset(dev
, SR_SWRESET_IPRL
);
631 ret
= sr_sw_reset(dev
, SR_SWRESET_PRTE
);
637 rx_ctl
= sr_read_rx_ctl(dev
);
638 netdev_dbg(dev
->net
, "RX_CTL is 0x%04x after software reset\n", rx_ctl
);
639 ret
= sr_write_rx_ctl(dev
, 0x0000);
643 rx_ctl
= sr_read_rx_ctl(dev
);
644 netdev_dbg(dev
->net
, "RX_CTL is 0x%04x setting to 0x0000\n", rx_ctl
);
646 ret
= sr_sw_reset(dev
, SR_SWRESET_PRL
);
652 ret
= sr_sw_reset(dev
, SR_SWRESET_IPRL
| SR_SWRESET_PRL
);
658 ret
= sr9800_set_default_mode(dev
);
662 /* Rewrite MAC address */
663 memcpy(data
->mac_addr
, dev
->net
->dev_addr
, ETH_ALEN
);
664 ret
= sr_write_cmd(dev
, SR_CMD_WRITE_NODE_ID
, 0, 0, ETH_ALEN
,
675 static const struct net_device_ops sr9800_netdev_ops
= {
676 .ndo_open
= usbnet_open
,
677 .ndo_stop
= usbnet_stop
,
678 .ndo_start_xmit
= usbnet_start_xmit
,
679 .ndo_tx_timeout
= usbnet_tx_timeout
,
680 .ndo_change_mtu
= usbnet_change_mtu
,
681 .ndo_set_mac_address
= sr_set_mac_address
,
682 .ndo_validate_addr
= eth_validate_addr
,
683 .ndo_do_ioctl
= sr_ioctl
,
684 .ndo_set_rx_mode
= sr_set_multicast
,
687 static int sr9800_phy_powerup(struct usbnet
*dev
)
691 /* set the embedded Ethernet PHY in power-down state */
692 ret
= sr_sw_reset(dev
, SR_SWRESET_IPPD
| SR_SWRESET_IPRL
);
694 netdev_err(dev
->net
, "Failed to power down PHY : %d\n", ret
);
699 /* set the embedded Ethernet PHY in power-up state */
700 ret
= sr_sw_reset(dev
, SR_SWRESET_IPRL
);
702 netdev_err(dev
->net
, "Failed to reset PHY: %d\n", ret
);
707 /* set the embedded Ethernet PHY in reset state */
708 ret
= sr_sw_reset(dev
, SR_SWRESET_CLEAR
);
710 netdev_err(dev
->net
, "Failed to power up PHY: %d\n", ret
);
715 /* set the embedded Ethernet PHY in power-up state */
716 ret
= sr_sw_reset(dev
, SR_SWRESET_IPRL
);
718 netdev_err(dev
->net
, "Failed to reset PHY: %d\n", ret
);
725 static int sr9800_bind(struct usbnet
*dev
, struct usb_interface
*intf
)
727 struct sr_data
*data
= (struct sr_data
*)&dev
->data
;
728 u16 led01_mux
, led23_mux
;
733 data
->eeprom_len
= SR9800_EEPROM_LEN
;
735 usbnet_get_endpoints(dev
, intf
);
737 /* LED Setting Rule :
741 * CC : MFA2(LED2), Reserved for SR9800
742 * DD : MFA3(LED3), Reserved for SR9800
744 led01_mux
= (SR_LED_MUX_LINK_ACTIVE
<< 8) | SR_LED_MUX_LINK
;
745 led23_mux
= (SR_LED_MUX_LINK_ACTIVE
<< 8) | SR_LED_MUX_TX_ACTIVE
;
746 ret
= sr_write_cmd(dev
, SR_CMD_LED_MUX
, led01_mux
, led23_mux
, 0, NULL
);
748 netdev_err(dev
->net
, "set LINK LED failed : %d\n", ret
);
752 /* Get the MAC address */
753 ret
= sr_read_cmd(dev
, SR_CMD_READ_NODE_ID
, 0, 0, ETH_ALEN
,
756 netdev_dbg(dev
->net
, "Failed to read MAC address: %d\n", ret
);
759 netdev_dbg(dev
->net
, "mac addr : %pM\n", dev
->net
->dev_addr
);
761 /* Initialize MII structure */
762 dev
->mii
.dev
= dev
->net
;
763 dev
->mii
.mdio_read
= sr_mdio_read
;
764 dev
->mii
.mdio_write
= sr_mdio_write
;
765 dev
->mii
.phy_id_mask
= 0x1f;
766 dev
->mii
.reg_num_mask
= 0x1f;
767 dev
->mii
.phy_id
= sr_get_phy_addr(dev
);
769 dev
->net
->netdev_ops
= &sr9800_netdev_ops
;
770 dev
->net
->ethtool_ops
= &sr9800_ethtool_ops
;
772 embd_phy
= ((dev
->mii
.phy_id
& 0x1f) == 0x10 ? 1 : 0);
773 /* Reset the PHY to normal operation mode */
774 ret
= sr_write_cmd(dev
, SR_CMD_SW_PHY_SELECT
, embd_phy
, 0, 0, NULL
);
776 netdev_dbg(dev
->net
, "Select PHY #1 failed: %d\n", ret
);
780 /* Init PHY routine */
781 ret
= sr9800_phy_powerup(dev
);
785 rx_ctl
= sr_read_rx_ctl(dev
);
786 netdev_dbg(dev
->net
, "RX_CTL is 0x%04x after software reset\n", rx_ctl
);
787 ret
= sr_write_rx_ctl(dev
, 0x0000);
791 rx_ctl
= sr_read_rx_ctl(dev
);
792 netdev_dbg(dev
->net
, "RX_CTL is 0x%04x setting to 0x0000\n", rx_ctl
);
794 /* Read PHYID register *AFTER* the PHY was reset properly */
795 phyid
= sr_get_phyid(dev
);
796 netdev_dbg(dev
->net
, "PHYID=0x%08x\n", phyid
);
798 /* medium mode setting */
799 ret
= sr9800_set_default_mode(dev
);
803 if (dev
->udev
->speed
== USB_SPEED_HIGH
) {
804 ret
= sr_write_cmd(dev
, SR_CMD_BULKIN_SIZE
,
805 SR9800_BULKIN_SIZE
[SR9800_MAX_BULKIN_4K
].byte_cnt
,
806 SR9800_BULKIN_SIZE
[SR9800_MAX_BULKIN_4K
].threshold
,
809 netdev_err(dev
->net
, "Reset RX_CTL failed: %d\n", ret
);
813 SR9800_BULKIN_SIZE
[SR9800_MAX_BULKIN_4K
].size
;
815 ret
= sr_write_cmd(dev
, SR_CMD_BULKIN_SIZE
,
816 SR9800_BULKIN_SIZE
[SR9800_MAX_BULKIN_2K
].byte_cnt
,
817 SR9800_BULKIN_SIZE
[SR9800_MAX_BULKIN_2K
].threshold
,
820 netdev_err(dev
->net
, "Reset RX_CTL failed: %d\n", ret
);
824 SR9800_BULKIN_SIZE
[SR9800_MAX_BULKIN_2K
].size
;
826 netdev_dbg(dev
->net
, "%s : setting rx_urb_size with : %ld\n", __func__
,
834 static const struct driver_info sr9800_driver_info
= {
835 .description
= "CoreChip SR9800 USB 2.0 Ethernet",
838 .link_reset
= sr9800_link_reset
,
839 .reset
= sr9800_reset
,
840 .flags
= DRIVER_FLAG
,
841 .rx_fixup
= sr_rx_fixup
,
842 .tx_fixup
= sr_tx_fixup
,
845 static const struct usb_device_id products
[] = {
847 USB_DEVICE(0x0fe6, 0x9800), /* SR9800 Device */
848 .driver_info
= (unsigned long) &sr9800_driver_info
,
853 MODULE_DEVICE_TABLE(usb
, products
);
855 static struct usb_driver sr_driver
= {
857 .id_table
= products
,
858 .probe
= usbnet_probe
,
859 .suspend
= usbnet_suspend
,
860 .resume
= usbnet_resume
,
861 .disconnect
= usbnet_disconnect
,
862 .supports_autosuspend
= 1,
865 module_usb_driver(sr_driver
);
867 MODULE_AUTHOR("Liu Junliang <liujunliang_ljl@163.com");
868 MODULE_VERSION(DRIVER_VERSION
);
869 MODULE_DESCRIPTION("SR9800 USB 2.0 USB2NET Dev : http://www.corechip-sz.com");
870 MODULE_LICENSE("GPL");