Commit fef0c060 authored by Amit Kumar Salecha's avatar Amit Kumar Salecha Committed by David S. Miller

qlcnic: define error code for loopback test

o Defined error code such as fw not responding, test already running and
  cable not connected.
o Check Fw capability before performing loopback test.
Signed-off-by: default avatarAmit Kumar Salecha <amit.salecha@qlogic.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent f127f472
...@@ -822,6 +822,7 @@ struct qlcnic_mac_list_s { ...@@ -822,6 +822,7 @@ struct qlcnic_mac_list_s {
#define QLCNIC_FW_CAPABILITY_BDG BIT_8 #define QLCNIC_FW_CAPABILITY_BDG BIT_8
#define QLCNIC_FW_CAPABILITY_FVLANTX BIT_9 #define QLCNIC_FW_CAPABILITY_FVLANTX BIT_9
#define QLCNIC_FW_CAPABILITY_HW_LRO BIT_10 #define QLCNIC_FW_CAPABILITY_HW_LRO BIT_10
#define QLCNIC_FW_CAPABILITY_MULTI_LOOPBACK BIT_27
/* module types */ /* module types */
#define LINKEVENT_MODULE_NOT_PRESENT 1 #define LINKEVENT_MODULE_NOT_PRESENT 1
...@@ -936,6 +937,12 @@ struct qlcnic_ipaddr { ...@@ -936,6 +937,12 @@ struct qlcnic_ipaddr {
#define QLCNIC_READD_AGE 20 #define QLCNIC_READD_AGE 20
#define QLCNIC_LB_MAX_FILTERS 64 #define QLCNIC_LB_MAX_FILTERS 64
/* QLCNIC Driver Error Code */
#define QLCNIC_FW_NOT_RESPOND 51
#define QLCNIC_TEST_IN_PROGRESS 52
#define QLCNIC_UNDEFINED_ERROR 53
#define QLCNIC_LB_CABLE_NOT_CONN 54
struct qlcnic_filter { struct qlcnic_filter {
struct hlist_node fnode; struct hlist_node fnode;
u8 faddr[ETH_ALEN]; u8 faddr[ETH_ALEN];
...@@ -1007,7 +1014,7 @@ struct qlcnic_adapter { ...@@ -1007,7 +1014,7 @@ struct qlcnic_adapter {
u8 max_mac_filters; u8 max_mac_filters;
u8 dev_state; u8 dev_state;
u8 diag_test; u8 diag_test;
u8 diag_cnt; char diag_cnt;
u8 reset_ack_timeo; u8 reset_ack_timeo;
u8 dev_init_timeo; u8 dev_init_timeo;
u16 msg_enable; u16 msg_enable;
......
...@@ -756,6 +756,11 @@ static int qlcnic_loopback_test(struct net_device *netdev, u8 mode) ...@@ -756,6 +756,11 @@ static int qlcnic_loopback_test(struct net_device *netdev, u8 mode)
int loop = 0; int loop = 0;
int ret; int ret;
if (!(adapter->capabilities & QLCNIC_FW_CAPABILITY_MULTI_LOOPBACK)) {
netdev_info(netdev, "Firmware is not loopback test capable\n");
return -EOPNOTSUPP;
}
netdev_info(netdev, "%s loopback test in progress\n", netdev_info(netdev, "%s loopback test in progress\n",
mode == QLCNIC_ILB_MODE ? "internal" : "external"); mode == QLCNIC_ILB_MODE ? "internal" : "external");
if (adapter->op_mode == QLCNIC_NON_PRIV_FUNC) { if (adapter->op_mode == QLCNIC_NON_PRIV_FUNC) {
...@@ -765,8 +770,7 @@ static int qlcnic_loopback_test(struct net_device *netdev, u8 mode) ...@@ -765,8 +770,7 @@ static int qlcnic_loopback_test(struct net_device *netdev, u8 mode)
} }
if (test_and_set_bit(__QLCNIC_RESETTING, &adapter->state)) if (test_and_set_bit(__QLCNIC_RESETTING, &adapter->state))
return -EIO; return -EBUSY;
ret = qlcnic_diag_alloc_res(netdev, QLCNIC_LOOPBACK_TEST); ret = qlcnic_diag_alloc_res(netdev, QLCNIC_LOOPBACK_TEST);
if (ret) if (ret)
...@@ -778,19 +782,20 @@ static int qlcnic_loopback_test(struct net_device *netdev, u8 mode) ...@@ -778,19 +782,20 @@ static int qlcnic_loopback_test(struct net_device *netdev, u8 mode)
if (ret) if (ret)
goto free_res; goto free_res;
adapter->diag_cnt = 0;
do { do {
msleep(500); msleep(500);
qlcnic_process_rcv_ring_diag(sds_ring); qlcnic_process_rcv_ring_diag(sds_ring);
if (loop++ > QLCNIC_ILB_MAX_RCV_LOOP) if (loop++ > QLCNIC_ILB_MAX_RCV_LOOP) {
break; netdev_info(netdev, "firmware didnt respond to loopback"
} while (!QLCNIC_IS_LB_CONFIGURED(adapter->ahw->loopback_state)); " configure request\n");
ret = -QLCNIC_FW_NOT_RESPOND;
if (!QLCNIC_IS_LB_CONFIGURED(adapter->ahw->loopback_state)) { goto free_res;
netdev_info(netdev, "firmware didnt respond to loopback " } else if (adapter->diag_cnt) {
"configure request\n"); ret = adapter->diag_cnt;
ret = adapter->ahw->loopback_state;
goto free_res; goto free_res;
} }
} while (!QLCNIC_IS_LB_CONFIGURED(adapter->ahw->loopback_state));
ret = qlcnic_do_lb_test(adapter); ret = qlcnic_do_lb_test(adapter);
......
...@@ -1354,10 +1354,16 @@ qlcnic_handle_fw_message(int desc_cnt, int index, ...@@ -1354,10 +1354,16 @@ qlcnic_handle_fw_message(int desc_cnt, int index,
break; break;
case 1: case 1:
dev_info(dev, "loopback already in progress\n"); dev_info(dev, "loopback already in progress\n");
adapter->diag_cnt = -QLCNIC_TEST_IN_PROGRESS;
break;
case 2:
dev_info(dev, "loopback cable is not connected\n");
adapter->diag_cnt = -QLCNIC_LB_CABLE_NOT_CONN;
break; break;
default: default:
dev_info(dev, "loopback configure request failed," dev_info(dev, "loopback configure request failed,"
" ret %x\n", ret); " ret %x\n", ret);
adapter->diag_cnt = -QLCNIC_UNDEFINED_ERROR;
break; break;
} }
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment