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: Amit Kumar Salecha <amit.salecha@qlogic.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f127f4727f
commit
fef0c0600b
|
@ -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 {
|
||||||
#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 {
|
||||||
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)
|
||||||
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)
|
||||||
}
|
}
|
||||||
|
|
||||||
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)
|
||||||
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,
|
||||||
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;
|
||||||
|
|
Loading…
Reference in New Issue