aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/qlcnic
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/qlcnic')
-rw-r--r--drivers/net/qlcnic/qlcnic_hdr.h6
-rw-r--r--drivers/net/qlcnic/qlcnic_main.c22
2 files changed, 17 insertions, 11 deletions
diff --git a/drivers/net/qlcnic/qlcnic_hdr.h b/drivers/net/qlcnic/qlcnic_hdr.h
index 8285a06eecdb..a984cd227582 100644
--- a/drivers/net/qlcnic/qlcnic_hdr.h
+++ b/drivers/net/qlcnic/qlcnic_hdr.h
@@ -707,6 +707,12 @@ enum {
707#define QLCNIC_DEV_FAILED 0x6 707#define QLCNIC_DEV_FAILED 0x6
708#define QLCNIC_DEV_QUISCENT 0x7 708#define QLCNIC_DEV_QUISCENT 0x7
709 709
710#define QLC_DEV_SET_REF_CNT(VAL, FN) ((VAL) |= (1 << (FN * 4)))
711#define QLC_DEV_CLR_REF_CNT(VAL, FN) ((VAL) &= ~(1 << (FN * 4)))
712#define QLC_DEV_SET_RST_RDY(VAL, FN) ((VAL) |= (1 << (FN * 4)))
713#define QLC_DEV_SET_QSCNT_RDY(VAL, FN) ((VAL) |= (2 << (FN * 4)))
714#define QLC_DEV_CLR_RST_QSCNT(VAL, FN) ((VAL) &= ~(3 << (FN * 4)))
715
710#define QLCNIC_RCODE_DRIVER_INFO 0x20000000 716#define QLCNIC_RCODE_DRIVER_INFO 0x20000000
711#define QLCNIC_RCODE_DRIVER_CAN_RELOAD 0x40000000 717#define QLCNIC_RCODE_DRIVER_CAN_RELOAD 0x40000000
712#define QLCNIC_RCODE_FATAL_ERROR 0x80000000 718#define QLCNIC_RCODE_FATAL_ERROR 0x80000000
diff --git a/drivers/net/qlcnic/qlcnic_main.c b/drivers/net/qlcnic/qlcnic_main.c
index 06349908092f..3c8a963f68a9 100644
--- a/drivers/net/qlcnic/qlcnic_main.c
+++ b/drivers/net/qlcnic/qlcnic_main.c
@@ -1963,9 +1963,9 @@ qlcnic_set_drv_state(struct qlcnic_adapter *adapter, int state)
1963 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE); 1963 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE);
1964 1964
1965 if (state == QLCNIC_DEV_NEED_RESET) 1965 if (state == QLCNIC_DEV_NEED_RESET)
1966 val |= ((u32)0x1 << (adapter->portnum * 4)); 1966 QLC_DEV_SET_RST_RDY(val, adapter->portnum);
1967 else if (state == QLCNIC_DEV_NEED_QUISCENT) 1967 else if (state == QLCNIC_DEV_NEED_QUISCENT)
1968 val |= ((u32)0x1 << ((adapter->portnum * 4) + 1)); 1968 QLC_DEV_SET_QSCNT_RDY(val, adapter->portnum);
1969 1969
1970 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val); 1970 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val);
1971 1971
@@ -1981,7 +1981,7 @@ qlcnic_clr_drv_state(struct qlcnic_adapter *adapter)
1981 return -EBUSY; 1981 return -EBUSY;
1982 1982
1983 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE); 1983 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE);
1984 val &= ~((u32)0x3 << (adapter->portnum * 4)); 1984 QLC_DEV_CLR_RST_QSCNT(val, adapter->portnum);
1985 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val); 1985 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val);
1986 1986
1987 qlcnic_api_unlock(adapter); 1987 qlcnic_api_unlock(adapter);
@@ -1998,14 +1998,14 @@ qlcnic_clr_all_drv_state(struct qlcnic_adapter *adapter)
1998 goto err; 1998 goto err;
1999 1999
2000 val = QLCRD32(adapter, QLCNIC_CRB_DEV_REF_COUNT); 2000 val = QLCRD32(adapter, QLCNIC_CRB_DEV_REF_COUNT);
2001 val &= ~((u32)0x1 << (adapter->portnum * 4)); 2001 QLC_DEV_CLR_REF_CNT(val, adapter->portnum);
2002 QLCWR32(adapter, QLCNIC_CRB_DEV_REF_COUNT, val); 2002 QLCWR32(adapter, QLCNIC_CRB_DEV_REF_COUNT, val);
2003 2003
2004 if (!(val & 0x11111111)) 2004 if (!(val & 0x11111111))
2005 QLCWR32(adapter, QLCNIC_CRB_DEV_STATE, QLCNIC_DEV_COLD); 2005 QLCWR32(adapter, QLCNIC_CRB_DEV_STATE, QLCNIC_DEV_COLD);
2006 2006
2007 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE); 2007 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE);
2008 val &= ~((u32)0x3 << (adapter->portnum * 4)); 2008 QLC_DEV_CLR_RST_QSCNT(val, adapter->portnum);
2009 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val); 2009 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val);
2010 2010
2011 qlcnic_api_unlock(adapter); 2011 qlcnic_api_unlock(adapter);
@@ -2036,7 +2036,7 @@ qlcnic_can_start_firmware(struct qlcnic_adapter *adapter)
2036{ 2036{
2037 u32 val, prev_state; 2037 u32 val, prev_state;
2038 u8 dev_init_timeo = adapter->dev_init_timeo; 2038 u8 dev_init_timeo = adapter->dev_init_timeo;
2039 int portnum = adapter->portnum; 2039 u8 portnum = adapter->portnum;
2040 2040
2041 if (test_and_clear_bit(__QLCNIC_START_FW, &adapter->state)) 2041 if (test_and_clear_bit(__QLCNIC_START_FW, &adapter->state))
2042 return 1; 2042 return 1;
@@ -2045,8 +2045,8 @@ qlcnic_can_start_firmware(struct qlcnic_adapter *adapter)
2045 return -1; 2045 return -1;
2046 2046
2047 val = QLCRD32(adapter, QLCNIC_CRB_DEV_REF_COUNT); 2047 val = QLCRD32(adapter, QLCNIC_CRB_DEV_REF_COUNT);
2048 if (!(val & ((int)0x1 << (portnum * 4)))) { 2048 if (!(val & (1 << (portnum * 4)))) {
2049 val |= ((u32)0x1 << (portnum * 4)); 2049 QLC_DEV_SET_REF_CNT(val, portnum);
2050 QLCWR32(adapter, QLCNIC_CRB_DEV_REF_COUNT, val); 2050 QLCWR32(adapter, QLCNIC_CRB_DEV_REF_COUNT, val);
2051 } 2051 }
2052 2052
@@ -2065,13 +2065,13 @@ qlcnic_can_start_firmware(struct qlcnic_adapter *adapter)
2065 2065
2066 case QLCNIC_DEV_NEED_RESET: 2066 case QLCNIC_DEV_NEED_RESET:
2067 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE); 2067 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE);
2068 val |= ((u32)0x1 << (portnum * 4)); 2068 QLC_DEV_SET_RST_RDY(val, portnum);
2069 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val); 2069 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val);
2070 break; 2070 break;
2071 2071
2072 case QLCNIC_DEV_NEED_QUISCENT: 2072 case QLCNIC_DEV_NEED_QUISCENT:
2073 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE); 2073 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE);
2074 val |= ((u32)0x1 << ((portnum * 4) + 1)); 2074 QLC_DEV_SET_QSCNT_RDY(val, portnum);
2075 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val); 2075 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val);
2076 break; 2076 break;
2077 2077
@@ -2101,7 +2101,7 @@ qlcnic_can_start_firmware(struct qlcnic_adapter *adapter)
2101 return -1; 2101 return -1;
2102 2102
2103 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE); 2103 val = QLCRD32(adapter, QLCNIC_CRB_DRV_STATE);
2104 val &= ~((u32)0x3 << (portnum * 4)); 2104 QLC_DEV_CLR_RST_QSCNT(val, portnum);
2105 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val); 2105 QLCWR32(adapter, QLCNIC_CRB_DRV_STATE, val);
2106 2106
2107 qlcnic_api_unlock(adapter); 2107 qlcnic_api_unlock(adapter);