diff options
author | Amit Kumar Salecha <amit.salecha@qlogic.com> | 2010-07-24 14:32:17 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-07-25 19:32:40 -0400 |
commit | 36a1898ddfde3e36a6813ac72540e011a3de57ae (patch) | |
tree | 5fd6aea58575421fb5ff9d0e94e65d47617ca35b /drivers/net/qlcnic | |
parent | fed66381d65a35198639f564365e61a7f256bf79 (diff) |
qlcnic: fix loopback test
o Loopback not supported for virtual function.
Signed-off-by: Amit Kumar Salecha <amit.salecha@qlogic.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/qlcnic')
-rw-r--r-- | drivers/net/qlcnic/qlcnic.h | 2 | ||||
-rw-r--r-- | drivers/net/qlcnic/qlcnic_ethtool.c | 10 | ||||
-rw-r--r-- | drivers/net/qlcnic/qlcnic_main.c | 18 |
3 files changed, 8 insertions, 22 deletions
diff --git a/drivers/net/qlcnic/qlcnic.h b/drivers/net/qlcnic/qlcnic.h index fad8e9a51a54..970389331bbc 100644 --- a/drivers/net/qlcnic/qlcnic.h +++ b/drivers/net/qlcnic/qlcnic.h | |||
@@ -1301,8 +1301,6 @@ struct qlcnic_nic_template { | |||
1301 | int (*get_mac_addr) (struct qlcnic_adapter *, u8*); | 1301 | int (*get_mac_addr) (struct qlcnic_adapter *, u8*); |
1302 | int (*config_bridged_mode) (struct qlcnic_adapter *, u32); | 1302 | int (*config_bridged_mode) (struct qlcnic_adapter *, u32); |
1303 | int (*config_led) (struct qlcnic_adapter *, u32, u32); | 1303 | int (*config_led) (struct qlcnic_adapter *, u32, u32); |
1304 | int (*set_ilb_mode) (struct qlcnic_adapter *); | ||
1305 | void (*clear_ilb_mode) (struct qlcnic_adapter *); | ||
1306 | int (*start_firmware) (struct qlcnic_adapter *); | 1304 | int (*start_firmware) (struct qlcnic_adapter *); |
1307 | }; | 1305 | }; |
1308 | 1306 | ||
diff --git a/drivers/net/qlcnic/qlcnic_ethtool.c b/drivers/net/qlcnic/qlcnic_ethtool.c index 7d6558e33dca..9328d59e21e0 100644 --- a/drivers/net/qlcnic/qlcnic_ethtool.c +++ b/drivers/net/qlcnic/qlcnic_ethtool.c | |||
@@ -678,6 +678,12 @@ static int qlcnic_loopback_test(struct net_device *netdev) | |||
678 | int max_sds_rings = adapter->max_sds_rings; | 678 | int max_sds_rings = adapter->max_sds_rings; |
679 | int ret; | 679 | int ret; |
680 | 680 | ||
681 | if (adapter->op_mode == QLCNIC_NON_PRIV_FUNC) { | ||
682 | dev_warn(&adapter->pdev->dev, "Loopback test not supported" | ||
683 | "for non privilege function\n"); | ||
684 | return 0; | ||
685 | } | ||
686 | |||
681 | if (test_and_set_bit(__QLCNIC_RESETTING, &adapter->state)) | 687 | if (test_and_set_bit(__QLCNIC_RESETTING, &adapter->state)) |
682 | return -EIO; | 688 | return -EIO; |
683 | 689 | ||
@@ -685,13 +691,13 @@ static int qlcnic_loopback_test(struct net_device *netdev) | |||
685 | if (ret) | 691 | if (ret) |
686 | goto clear_it; | 692 | goto clear_it; |
687 | 693 | ||
688 | ret = adapter->nic_ops->set_ilb_mode(adapter); | 694 | ret = qlcnic_set_ilb_mode(adapter); |
689 | if (ret) | 695 | if (ret) |
690 | goto done; | 696 | goto done; |
691 | 697 | ||
692 | ret = qlcnic_do_ilb_test(adapter); | 698 | ret = qlcnic_do_ilb_test(adapter); |
693 | 699 | ||
694 | adapter->nic_ops->clear_ilb_mode(adapter); | 700 | qlcnic_clear_ilb_mode(adapter); |
695 | 701 | ||
696 | done: | 702 | done: |
697 | qlcnic_diag_free_res(netdev, max_sds_rings); | 703 | qlcnic_diag_free_res(netdev, max_sds_rings); |
diff --git a/drivers/net/qlcnic/qlcnic_main.c b/drivers/net/qlcnic/qlcnic_main.c index f1f7acfbf412..f147958e05a1 100644 --- a/drivers/net/qlcnic/qlcnic_main.c +++ b/drivers/net/qlcnic/qlcnic_main.c | |||
@@ -107,8 +107,6 @@ static void qlcnic_config_indev_addr(struct net_device *dev, unsigned long); | |||
107 | static int qlcnic_start_firmware(struct qlcnic_adapter *); | 107 | static int qlcnic_start_firmware(struct qlcnic_adapter *); |
108 | 108 | ||
109 | static void qlcnic_dev_set_npar_ready(struct qlcnic_adapter *); | 109 | static void qlcnic_dev_set_npar_ready(struct qlcnic_adapter *); |
110 | static void qlcnicvf_clear_ilb_mode(struct qlcnic_adapter *); | ||
111 | static int qlcnicvf_set_ilb_mode(struct qlcnic_adapter *); | ||
112 | static int qlcnicvf_config_led(struct qlcnic_adapter *, u32, u32); | 110 | static int qlcnicvf_config_led(struct qlcnic_adapter *, u32, u32); |
113 | static int qlcnicvf_config_bridged_mode(struct qlcnic_adapter *, u32); | 111 | static int qlcnicvf_config_bridged_mode(struct qlcnic_adapter *, u32); |
114 | static int qlcnicvf_start_firmware(struct qlcnic_adapter *); | 112 | static int qlcnicvf_start_firmware(struct qlcnic_adapter *); |
@@ -381,8 +379,6 @@ static struct qlcnic_nic_template qlcnic_ops = { | |||
381 | .get_mac_addr = qlcnic_get_mac_address, | 379 | .get_mac_addr = qlcnic_get_mac_address, |
382 | .config_bridged_mode = qlcnic_config_bridged_mode, | 380 | .config_bridged_mode = qlcnic_config_bridged_mode, |
383 | .config_led = qlcnic_config_led, | 381 | .config_led = qlcnic_config_led, |
384 | .set_ilb_mode = qlcnic_set_ilb_mode, | ||
385 | .clear_ilb_mode = qlcnic_clear_ilb_mode, | ||
386 | .start_firmware = qlcnic_start_firmware | 382 | .start_firmware = qlcnic_start_firmware |
387 | }; | 383 | }; |
388 | 384 | ||
@@ -390,8 +386,6 @@ static struct qlcnic_nic_template qlcnic_vf_ops = { | |||
390 | .get_mac_addr = qlcnic_get_mac_address, | 386 | .get_mac_addr = qlcnic_get_mac_address, |
391 | .config_bridged_mode = qlcnicvf_config_bridged_mode, | 387 | .config_bridged_mode = qlcnicvf_config_bridged_mode, |
392 | .config_led = qlcnicvf_config_led, | 388 | .config_led = qlcnicvf_config_led, |
393 | .set_ilb_mode = qlcnicvf_set_ilb_mode, | ||
394 | .clear_ilb_mode = qlcnicvf_clear_ilb_mode, | ||
395 | .start_firmware = qlcnicvf_start_firmware | 389 | .start_firmware = qlcnicvf_start_firmware |
396 | }; | 390 | }; |
397 | 391 | ||
@@ -2841,18 +2835,6 @@ qlcnicvf_config_led(struct qlcnic_adapter *adapter, u32 state, u32 rate) | |||
2841 | return -EOPNOTSUPP; | 2835 | return -EOPNOTSUPP; |
2842 | } | 2836 | } |
2843 | 2837 | ||
2844 | static int | ||
2845 | qlcnicvf_set_ilb_mode(struct qlcnic_adapter *adapter) | ||
2846 | { | ||
2847 | return -EOPNOTSUPP; | ||
2848 | } | ||
2849 | |||
2850 | static void | ||
2851 | qlcnicvf_clear_ilb_mode(struct qlcnic_adapter *adapter) | ||
2852 | { | ||
2853 | return; | ||
2854 | } | ||
2855 | |||
2856 | static ssize_t | 2838 | static ssize_t |
2857 | qlcnic_store_bridged_mode(struct device *dev, | 2839 | qlcnic_store_bridged_mode(struct device *dev, |
2858 | struct device_attribute *attr, const char *buf, size_t len) | 2840 | struct device_attribute *attr, const char *buf, size_t len) |