Commit 4a6c396e authored by David S. Miller's avatar David S. Miller

Merge branch '40GbE' of git://git.kernel.org/pub/scm/linux/kernel/git/tnguy/next-queue

Mateusz Palczewski says:

====================
40GbE Intel Wired LAN Driver Updates 2021-10-18

Use single state machine for driver initialization
and for service initialized driver. The init state
machine implemented in init_task() is merged
into the watchdog_task(). The init_task() function
is removed.
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents 939a6567 898ef1cb
...@@ -177,6 +177,7 @@ enum iavf_state_t { ...@@ -177,6 +177,7 @@ enum iavf_state_t {
__IAVF_INIT_VERSION_CHECK, /* aq msg sent, awaiting reply */ __IAVF_INIT_VERSION_CHECK, /* aq msg sent, awaiting reply */
__IAVF_INIT_GET_RESOURCES, /* aq msg sent, awaiting reply */ __IAVF_INIT_GET_RESOURCES, /* aq msg sent, awaiting reply */
__IAVF_INIT_SW, /* got resources, setting up structs */ __IAVF_INIT_SW, /* got resources, setting up structs */
__IAVF_INIT_FAILED, /* init failed, restarting procedure */
__IAVF_RESETTING, /* in reset */ __IAVF_RESETTING, /* in reset */
__IAVF_COMM_FAILED, /* communication with PF failed */ __IAVF_COMM_FAILED, /* communication with PF failed */
/* Below here, watchdog is running */ /* Below here, watchdog is running */
...@@ -225,7 +226,6 @@ struct iavf_adapter { ...@@ -225,7 +226,6 @@ struct iavf_adapter {
struct work_struct reset_task; struct work_struct reset_task;
struct work_struct adminq_task; struct work_struct adminq_task;
struct delayed_work client_task; struct delayed_work client_task;
struct delayed_work init_task;
wait_queue_head_t down_waitqueue; wait_queue_head_t down_waitqueue;
struct iavf_q_vector *q_vectors; struct iavf_q_vector *q_vectors;
struct list_head vlan_filter_list; struct list_head vlan_filter_list;
...@@ -312,6 +312,7 @@ struct iavf_adapter { ...@@ -312,6 +312,7 @@ struct iavf_adapter {
struct iavf_hw hw; /* defined in iavf_type.h */ struct iavf_hw hw; /* defined in iavf_type.h */
enum iavf_state_t state; enum iavf_state_t state;
enum iavf_state_t last_state;
unsigned long crit_section; unsigned long crit_section;
struct delayed_work watchdog_task; struct delayed_work watchdog_task;
...@@ -393,6 +394,15 @@ struct iavf_device { ...@@ -393,6 +394,15 @@ struct iavf_device {
extern char iavf_driver_name[]; extern char iavf_driver_name[];
extern struct workqueue_struct *iavf_wq; extern struct workqueue_struct *iavf_wq;
static inline void iavf_change_state(struct iavf_adapter *adapter,
enum iavf_state_t state)
{
if (adapter->state != state) {
adapter->last_state = adapter->state;
adapter->state = state;
}
}
int iavf_up(struct iavf_adapter *adapter); int iavf_up(struct iavf_adapter *adapter);
void iavf_down(struct iavf_adapter *adapter); void iavf_down(struct iavf_adapter *adapter);
int iavf_process_config(struct iavf_adapter *adapter); int iavf_process_config(struct iavf_adapter *adapter);
......
This diff is collapsed.
...@@ -1735,7 +1735,7 @@ void iavf_virtchnl_completion(struct iavf_adapter *adapter, ...@@ -1735,7 +1735,7 @@ void iavf_virtchnl_completion(struct iavf_adapter *adapter,
iavf_free_all_tx_resources(adapter); iavf_free_all_tx_resources(adapter);
iavf_free_all_rx_resources(adapter); iavf_free_all_rx_resources(adapter);
if (adapter->state == __IAVF_DOWN_PENDING) { if (adapter->state == __IAVF_DOWN_PENDING) {
adapter->state = __IAVF_DOWN; iavf_change_state(adapter, __IAVF_DOWN);
wake_up(&adapter->down_waitqueue); wake_up(&adapter->down_waitqueue);
} }
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