mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-04 04:02:26 +00:00
Merge branch '200GbE' of git://git.kernel.org/pub/scm/linux/kernel/git/tnguy/next-queue
From: Tony Nguyen <anthony.l.nguyen@intel.com> To: davem@davemloft.net, kuba@kernel.org, pabeni@redhat.com, edumazet@google.com, netdev@vger.kernel.org Cc: Tony Nguyen <anthony.l.nguyen@intel.com>, alan.brady@intel.com Tony Nguyen says: ==================== idpf: refactor virtchnl messages Alan Brady says: The motivation for this series has two primary goals. We want to enable support of multiple simultaneous messages and make the channel more robust. The way it works right now, the driver can only send and receive a single message at a time and if something goes really wrong, it can lead to data corruption and strange bugs. To start the series, we introduce an idpf_virtchnl.h file. This reduces the burden on idpf.h which is overloaded with struct and function declarations. The conversion works by conceptualizing a send and receive as a "virtchnl transaction" (idpf_vc_xn) and introducing a "transaction manager" (idpf_vc_xn_manager). The vcxn_mngr will init a ring of transactions from which the driver will pop from a bitmap of free transactions to track in-flight messages. Instead of needing to handle a complicated send/recv for every a message, the driver now just needs to fill out a xn_params struct and hand it over to idpf_vc_xn_exec which will take care of all the messy bits. Once a message is sent and receives a reply, we leverage the completion API to signal the received buffer is ready to be used (assuming success, or an error code otherwise). At a low-level, this implements the "sw cookie" field of the virtchnl message descriptor to enable this. We have 16 bits we can put whatever we want and the recipient is required to apply the same cookie to the reply for that message. We use the first 8 bits as an index into the array of transactions to enable fast lookups and we use the second 8 bits as a salt to make sure each cookie is unique for that message. As transactions are received in arbitrary order, it's possible to reuse a transaction index and the salt guards against index conflicts to make certain the lookup is correct. As a primitive example, say index 1 is used with salt 1. The message times out without receiving a reply so index 1 is renewed to be ready for a new transaction, we report the timeout, and send the message again. Since index 1 is free to be used again now, index 1 is again sent but now salt is 2. This time we do get a reply, however it could be that the reply is _actually_ for the previous send index 1 with salt 1. Without the salt we would have no way of knowing for sure if it's the correct reply, but with we will know for certain. Through this conversion we also get several other benefits. We can now more appropriately handle asynchronously sent messages by providing space for a callback to be defined. This notably allows us to handle MAC filter failures better; previously we could potentially have stale, failed filters in our list, which shouldn't really have a major impact but is obviously not correct. I also managed to remove fairly significant more lines than I added which is a win in my book. Additionally, this converts some variables to use auto-variables where appropriate. This makes the alloc paths much cleaner and less prone to memory leaks. We also fix a few virtchnl related bugs while we're here. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
dbb0b6ca7d
@ -37,8 +37,6 @@ struct idpf_vport_max_q;
|
||||
#define IDPF_MB_MAX_ERR 20
|
||||
#define IDPF_NUM_CHUNKS_PER_MSG(struct_sz, chunk_sz) \
|
||||
((IDPF_CTLQ_MAX_BUF_LEN - (struct_sz)) / (chunk_sz))
|
||||
#define IDPF_WAIT_FOR_EVENT_TIMEO_MIN 2000
|
||||
#define IDPF_WAIT_FOR_EVENT_TIMEO 60000
|
||||
|
||||
#define IDPF_MAX_WAIT 500
|
||||
|
||||
@ -66,14 +64,12 @@ struct idpf_mac_filter {
|
||||
|
||||
/**
|
||||
* enum idpf_state - State machine to handle bring up
|
||||
* @__IDPF_STARTUP: Start the state machine
|
||||
* @__IDPF_VER_CHECK: Negotiate virtchnl version
|
||||
* @__IDPF_GET_CAPS: Negotiate capabilities
|
||||
* @__IDPF_INIT_SW: Init based on given capabilities
|
||||
* @__IDPF_STATE_LAST: Must be last, used to determine size
|
||||
*/
|
||||
enum idpf_state {
|
||||
__IDPF_STARTUP,
|
||||
__IDPF_VER_CHECK,
|
||||
__IDPF_GET_CAPS,
|
||||
__IDPF_INIT_SW,
|
||||
@ -87,6 +83,7 @@ enum idpf_state {
|
||||
* @IDPF_HR_RESET_IN_PROG: Reset in progress
|
||||
* @IDPF_REMOVE_IN_PROG: Driver remove in progress
|
||||
* @IDPF_MB_INTR_MODE: Mailbox in interrupt mode
|
||||
* @IDPF_VC_CORE_INIT: virtchnl core has been init
|
||||
* @IDPF_FLAGS_NBITS: Must be last
|
||||
*/
|
||||
enum idpf_flags {
|
||||
@ -95,6 +92,7 @@ enum idpf_flags {
|
||||
IDPF_HR_RESET_IN_PROG,
|
||||
IDPF_REMOVE_IN_PROG,
|
||||
IDPF_MB_INTR_MODE,
|
||||
IDPF_VC_CORE_INIT,
|
||||
IDPF_FLAGS_NBITS,
|
||||
};
|
||||
|
||||
@ -209,71 +207,6 @@ struct idpf_dev_ops {
|
||||
struct idpf_reg_ops reg_ops;
|
||||
};
|
||||
|
||||
/* These macros allow us to generate an enum and a matching char * array of
|
||||
* stringified enums that are always in sync. Checkpatch issues a bogus warning
|
||||
* about this being a complex macro; but it's wrong, these are never used as a
|
||||
* statement and instead only used to define the enum and array.
|
||||
*/
|
||||
#define IDPF_FOREACH_VPORT_VC_STATE(STATE) \
|
||||
STATE(IDPF_VC_CREATE_VPORT) \
|
||||
STATE(IDPF_VC_CREATE_VPORT_ERR) \
|
||||
STATE(IDPF_VC_ENA_VPORT) \
|
||||
STATE(IDPF_VC_ENA_VPORT_ERR) \
|
||||
STATE(IDPF_VC_DIS_VPORT) \
|
||||
STATE(IDPF_VC_DIS_VPORT_ERR) \
|
||||
STATE(IDPF_VC_DESTROY_VPORT) \
|
||||
STATE(IDPF_VC_DESTROY_VPORT_ERR) \
|
||||
STATE(IDPF_VC_CONFIG_TXQ) \
|
||||
STATE(IDPF_VC_CONFIG_TXQ_ERR) \
|
||||
STATE(IDPF_VC_CONFIG_RXQ) \
|
||||
STATE(IDPF_VC_CONFIG_RXQ_ERR) \
|
||||
STATE(IDPF_VC_ENA_QUEUES) \
|
||||
STATE(IDPF_VC_ENA_QUEUES_ERR) \
|
||||
STATE(IDPF_VC_DIS_QUEUES) \
|
||||
STATE(IDPF_VC_DIS_QUEUES_ERR) \
|
||||
STATE(IDPF_VC_MAP_IRQ) \
|
||||
STATE(IDPF_VC_MAP_IRQ_ERR) \
|
||||
STATE(IDPF_VC_UNMAP_IRQ) \
|
||||
STATE(IDPF_VC_UNMAP_IRQ_ERR) \
|
||||
STATE(IDPF_VC_ADD_QUEUES) \
|
||||
STATE(IDPF_VC_ADD_QUEUES_ERR) \
|
||||
STATE(IDPF_VC_DEL_QUEUES) \
|
||||
STATE(IDPF_VC_DEL_QUEUES_ERR) \
|
||||
STATE(IDPF_VC_ALLOC_VECTORS) \
|
||||
STATE(IDPF_VC_ALLOC_VECTORS_ERR) \
|
||||
STATE(IDPF_VC_DEALLOC_VECTORS) \
|
||||
STATE(IDPF_VC_DEALLOC_VECTORS_ERR) \
|
||||
STATE(IDPF_VC_SET_SRIOV_VFS) \
|
||||
STATE(IDPF_VC_SET_SRIOV_VFS_ERR) \
|
||||
STATE(IDPF_VC_GET_RSS_LUT) \
|
||||
STATE(IDPF_VC_GET_RSS_LUT_ERR) \
|
||||
STATE(IDPF_VC_SET_RSS_LUT) \
|
||||
STATE(IDPF_VC_SET_RSS_LUT_ERR) \
|
||||
STATE(IDPF_VC_GET_RSS_KEY) \
|
||||
STATE(IDPF_VC_GET_RSS_KEY_ERR) \
|
||||
STATE(IDPF_VC_SET_RSS_KEY) \
|
||||
STATE(IDPF_VC_SET_RSS_KEY_ERR) \
|
||||
STATE(IDPF_VC_GET_STATS) \
|
||||
STATE(IDPF_VC_GET_STATS_ERR) \
|
||||
STATE(IDPF_VC_ADD_MAC_ADDR) \
|
||||
STATE(IDPF_VC_ADD_MAC_ADDR_ERR) \
|
||||
STATE(IDPF_VC_DEL_MAC_ADDR) \
|
||||
STATE(IDPF_VC_DEL_MAC_ADDR_ERR) \
|
||||
STATE(IDPF_VC_GET_PTYPE_INFO) \
|
||||
STATE(IDPF_VC_GET_PTYPE_INFO_ERR) \
|
||||
STATE(IDPF_VC_LOOPBACK_STATE) \
|
||||
STATE(IDPF_VC_LOOPBACK_STATE_ERR) \
|
||||
STATE(IDPF_VC_NBITS)
|
||||
|
||||
#define IDPF_GEN_ENUM(ENUM) ENUM,
|
||||
#define IDPF_GEN_STRING(STRING) #STRING,
|
||||
|
||||
enum idpf_vport_vc_state {
|
||||
IDPF_FOREACH_VPORT_VC_STATE(IDPF_GEN_ENUM)
|
||||
};
|
||||
|
||||
extern const char * const idpf_vport_vc_state_str[];
|
||||
|
||||
/**
|
||||
* enum idpf_vport_reset_cause - Vport soft reset causes
|
||||
* @IDPF_SR_Q_CHANGE: Soft reset queue change
|
||||
@ -358,11 +291,7 @@ struct idpf_port_stats {
|
||||
* @port_stats: per port csum, header split, and other offload stats
|
||||
* @link_up: True if link is up
|
||||
* @link_speed_mbps: Link speed in mbps
|
||||
* @vc_msg: Virtchnl message buffer
|
||||
* @vc_state: Virtchnl message state
|
||||
* @vchnl_wq: Wait queue for virtchnl messages
|
||||
* @sw_marker_wq: workqueue for marker packets
|
||||
* @vc_buf_lock: Lock to protect virtchnl buffer
|
||||
*/
|
||||
struct idpf_vport {
|
||||
u16 num_txq;
|
||||
@ -408,12 +337,7 @@ struct idpf_vport {
|
||||
bool link_up;
|
||||
u32 link_speed_mbps;
|
||||
|
||||
char vc_msg[IDPF_CTLQ_MAX_BUF_LEN];
|
||||
DECLARE_BITMAP(vc_state, IDPF_VC_NBITS);
|
||||
|
||||
wait_queue_head_t vchnl_wq;
|
||||
wait_queue_head_t sw_marker_wq;
|
||||
struct mutex vc_buf_lock;
|
||||
};
|
||||
|
||||
/**
|
||||
@ -476,15 +400,11 @@ struct idpf_vport_user_config_data {
|
||||
* enum idpf_vport_config_flags - Vport config flags
|
||||
* @IDPF_VPORT_REG_NETDEV: Register netdev
|
||||
* @IDPF_VPORT_UP_REQUESTED: Set if interface up is requested on core reset
|
||||
* @IDPF_VPORT_ADD_MAC_REQ: Asynchronous add ether address in flight
|
||||
* @IDPF_VPORT_DEL_MAC_REQ: Asynchronous delete ether address in flight
|
||||
* @IDPF_VPORT_CONFIG_FLAGS_NBITS: Must be last
|
||||
*/
|
||||
enum idpf_vport_config_flags {
|
||||
IDPF_VPORT_REG_NETDEV,
|
||||
IDPF_VPORT_UP_REQUESTED,
|
||||
IDPF_VPORT_ADD_MAC_REQ,
|
||||
IDPF_VPORT_DEL_MAC_REQ,
|
||||
IDPF_VPORT_CONFIG_FLAGS_NBITS,
|
||||
};
|
||||
|
||||
@ -555,11 +475,13 @@ struct idpf_vector_lifo {
|
||||
struct idpf_vport_config {
|
||||
struct idpf_vport_user_config_data user_config;
|
||||
struct idpf_vport_max_q max_q;
|
||||
void *req_qs_chunks;
|
||||
struct virtchnl2_add_queues *req_qs_chunks;
|
||||
spinlock_t mac_filter_list_lock;
|
||||
DECLARE_BITMAP(flags, IDPF_VPORT_CONFIG_FLAGS_NBITS);
|
||||
};
|
||||
|
||||
struct idpf_vc_xn_manager;
|
||||
|
||||
/**
|
||||
* struct idpf_adapter - Device data struct generated on probe
|
||||
* @pdev: PCI device struct given on probe
|
||||
@ -601,9 +523,7 @@ struct idpf_vport_config {
|
||||
* @stats_task: Periodic statistics retrieval task
|
||||
* @stats_wq: Workqueue for statistics task
|
||||
* @caps: Negotiated capabilities with device
|
||||
* @vchnl_wq: Wait queue for virtchnl messages
|
||||
* @vc_state: Virtchnl message state
|
||||
* @vc_msg: Virtchnl message buffer
|
||||
* @vcxn_mngr: Virtchnl transaction manager
|
||||
* @dev_ops: See idpf_dev_ops
|
||||
* @num_vfs: Number of allocated VFs through sysfs. PF does not directly talk
|
||||
* to VFs but is used to initialize them
|
||||
@ -659,10 +579,8 @@ struct idpf_adapter {
|
||||
struct delayed_work stats_task;
|
||||
struct workqueue_struct *stats_wq;
|
||||
struct virtchnl2_get_capabilities caps;
|
||||
struct idpf_vc_xn_manager *vcxn_mngr;
|
||||
|
||||
wait_queue_head_t vchnl_wq;
|
||||
DECLARE_BITMAP(vc_state, IDPF_VC_NBITS);
|
||||
char vc_msg[IDPF_CTLQ_MAX_BUF_LEN];
|
||||
struct idpf_dev_ops dev_ops;
|
||||
int num_vfs;
|
||||
bool crc_enable;
|
||||
@ -903,68 +821,18 @@ void idpf_mbx_task(struct work_struct *work);
|
||||
void idpf_vc_event_task(struct work_struct *work);
|
||||
void idpf_dev_ops_init(struct idpf_adapter *adapter);
|
||||
void idpf_vf_dev_ops_init(struct idpf_adapter *adapter);
|
||||
int idpf_vport_adjust_qs(struct idpf_vport *vport);
|
||||
int idpf_init_dflt_mbx(struct idpf_adapter *adapter);
|
||||
void idpf_deinit_dflt_mbx(struct idpf_adapter *adapter);
|
||||
int idpf_vc_core_init(struct idpf_adapter *adapter);
|
||||
void idpf_vc_core_deinit(struct idpf_adapter *adapter);
|
||||
int idpf_intr_req(struct idpf_adapter *adapter);
|
||||
void idpf_intr_rel(struct idpf_adapter *adapter);
|
||||
int idpf_get_reg_intr_vecs(struct idpf_vport *vport,
|
||||
struct idpf_vec_regs *reg_vals);
|
||||
u16 idpf_get_max_tx_hdr_size(struct idpf_adapter *adapter);
|
||||
int idpf_send_delete_queues_msg(struct idpf_vport *vport);
|
||||
int idpf_send_add_queues_msg(const struct idpf_vport *vport, u16 num_tx_q,
|
||||
u16 num_complq, u16 num_rx_q, u16 num_rx_bufq);
|
||||
int idpf_initiate_soft_reset(struct idpf_vport *vport,
|
||||
enum idpf_vport_reset_cause reset_cause);
|
||||
int idpf_send_enable_vport_msg(struct idpf_vport *vport);
|
||||
int idpf_send_disable_vport_msg(struct idpf_vport *vport);
|
||||
int idpf_send_destroy_vport_msg(struct idpf_vport *vport);
|
||||
int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport);
|
||||
int idpf_send_ena_dis_loopback_msg(struct idpf_vport *vport);
|
||||
int idpf_send_get_set_rss_key_msg(struct idpf_vport *vport, bool get);
|
||||
int idpf_send_get_set_rss_lut_msg(struct idpf_vport *vport, bool get);
|
||||
int idpf_send_dealloc_vectors_msg(struct idpf_adapter *adapter);
|
||||
int idpf_send_alloc_vectors_msg(struct idpf_adapter *adapter, u16 num_vectors);
|
||||
void idpf_deinit_task(struct idpf_adapter *adapter);
|
||||
int idpf_req_rel_vector_indexes(struct idpf_adapter *adapter,
|
||||
u16 *q_vector_idxs,
|
||||
struct idpf_vector_info *vec_info);
|
||||
int idpf_vport_alloc_vec_indexes(struct idpf_vport *vport);
|
||||
int idpf_send_get_stats_msg(struct idpf_vport *vport);
|
||||
int idpf_get_vec_ids(struct idpf_adapter *adapter,
|
||||
u16 *vecids, int num_vecids,
|
||||
struct virtchnl2_vector_chunks *chunks);
|
||||
int idpf_recv_mb_msg(struct idpf_adapter *adapter, u32 op,
|
||||
void *msg, int msg_size);
|
||||
int idpf_send_mb_msg(struct idpf_adapter *adapter, u32 op,
|
||||
u16 msg_size, u8 *msg);
|
||||
void idpf_set_ethtool_ops(struct net_device *netdev);
|
||||
int idpf_vport_alloc_max_qs(struct idpf_adapter *adapter,
|
||||
struct idpf_vport_max_q *max_q);
|
||||
void idpf_vport_dealloc_max_qs(struct idpf_adapter *adapter,
|
||||
struct idpf_vport_max_q *max_q);
|
||||
int idpf_add_del_mac_filters(struct idpf_vport *vport,
|
||||
struct idpf_netdev_priv *np,
|
||||
bool add, bool async);
|
||||
int idpf_set_promiscuous(struct idpf_adapter *adapter,
|
||||
struct idpf_vport_user_config_data *config_data,
|
||||
u32 vport_id);
|
||||
int idpf_send_disable_queues_msg(struct idpf_vport *vport);
|
||||
void idpf_vport_init(struct idpf_vport *vport, struct idpf_vport_max_q *max_q);
|
||||
u32 idpf_get_vport_id(struct idpf_vport *vport);
|
||||
int idpf_vport_queue_ids_init(struct idpf_vport *vport);
|
||||
int idpf_queue_reg_init(struct idpf_vport *vport);
|
||||
int idpf_send_config_queues_msg(struct idpf_vport *vport);
|
||||
int idpf_send_enable_queues_msg(struct idpf_vport *vport);
|
||||
int idpf_send_create_vport_msg(struct idpf_adapter *adapter,
|
||||
struct idpf_vport_max_q *max_q);
|
||||
int idpf_check_supported_desc_ids(struct idpf_vport *vport);
|
||||
void idpf_vport_intr_write_itr(struct idpf_q_vector *q_vector,
|
||||
u16 itr, bool tx);
|
||||
int idpf_send_map_unmap_queue_vector_msg(struct idpf_vport *vport, bool map);
|
||||
int idpf_send_set_sriov_vfs_msg(struct idpf_adapter *adapter, u16 num_vfs);
|
||||
int idpf_sriov_configure(struct pci_dev *pdev, int num_vfs);
|
||||
|
||||
u8 idpf_vport_get_hsplit(const struct idpf_vport *vport);
|
||||
|
@ -516,6 +516,8 @@ int idpf_ctlq_post_rx_buffs(struct idpf_hw *hw, struct idpf_ctlq_info *cq,
|
||||
/* Wrap to end of end ring since current ntp is 0 */
|
||||
cq->next_to_post = cq->ring_size - 1;
|
||||
|
||||
dma_wmb();
|
||||
|
||||
wr32(hw, cq->reg.tail, cq->next_to_post);
|
||||
}
|
||||
|
||||
@ -546,11 +548,6 @@ int idpf_ctlq_recv(struct idpf_ctlq_info *cq, u16 *num_q_msg,
|
||||
int err = 0;
|
||||
u16 i;
|
||||
|
||||
if (*num_q_msg == 0)
|
||||
return 0;
|
||||
else if (*num_q_msg > cq->ring_size)
|
||||
return -EBADR;
|
||||
|
||||
/* take the lock before we start messing with the ring */
|
||||
mutex_lock(&cq->cq_lock);
|
||||
|
||||
|
@ -69,6 +69,11 @@ struct idpf_ctlq_msg {
|
||||
u8 context[IDPF_INDIRECT_CTX_SIZE];
|
||||
struct idpf_dma_mem *payload;
|
||||
} indirect;
|
||||
struct {
|
||||
u32 rsvd;
|
||||
u16 data;
|
||||
u16 flags;
|
||||
} sw_cookie;
|
||||
} ctx;
|
||||
};
|
||||
|
||||
|
@ -3,6 +3,7 @@
|
||||
|
||||
#include "idpf.h"
|
||||
#include "idpf_lan_pf_regs.h"
|
||||
#include "idpf_virtchnl.h"
|
||||
|
||||
#define IDPF_PF_ITR_IDX_SPACING 0x4
|
||||
|
||||
|
@ -2,14 +2,11 @@
|
||||
/* Copyright (C) 2023 Intel Corporation */
|
||||
|
||||
#include "idpf.h"
|
||||
#include "idpf_virtchnl.h"
|
||||
|
||||
static const struct net_device_ops idpf_netdev_ops_splitq;
|
||||
static const struct net_device_ops idpf_netdev_ops_singleq;
|
||||
|
||||
const char * const idpf_vport_vc_state_str[] = {
|
||||
IDPF_FOREACH_VPORT_VC_STATE(IDPF_GEN_STRING)
|
||||
};
|
||||
|
||||
/**
|
||||
* idpf_init_vector_stack - Fill the MSIX vector stack with vector index
|
||||
* @adapter: private data struct
|
||||
@ -82,19 +79,12 @@ static void idpf_mb_intr_rel_irq(struct idpf_adapter *adapter)
|
||||
*/
|
||||
void idpf_intr_rel(struct idpf_adapter *adapter)
|
||||
{
|
||||
int err;
|
||||
|
||||
if (!adapter->msix_entries)
|
||||
return;
|
||||
|
||||
idpf_mb_intr_rel_irq(adapter);
|
||||
pci_free_irq_vectors(adapter->pdev);
|
||||
|
||||
err = idpf_send_dealloc_vectors_msg(adapter);
|
||||
if (err)
|
||||
dev_err(&adapter->pdev->dev,
|
||||
"Failed to deallocate vectors: %d\n", err);
|
||||
|
||||
idpf_send_dealloc_vectors_msg(adapter);
|
||||
idpf_deinit_vector_stack(adapter);
|
||||
kfree(adapter->msix_entries);
|
||||
adapter->msix_entries = NULL;
|
||||
@ -975,7 +965,6 @@ static void idpf_vport_rel(struct idpf_vport *vport)
|
||||
struct idpf_rss_data *rss_data;
|
||||
struct idpf_vport_max_q max_q;
|
||||
u16 idx = vport->idx;
|
||||
int i;
|
||||
|
||||
vport_config = adapter->vport_config[vport->idx];
|
||||
idpf_deinit_rss(vport);
|
||||
@ -985,20 +974,6 @@ static void idpf_vport_rel(struct idpf_vport *vport)
|
||||
|
||||
idpf_send_destroy_vport_msg(vport);
|
||||
|
||||
/* Set all bits as we dont know on which vc_state the vport vhnl_wq
|
||||
* is waiting on and wakeup the virtchnl workqueue even if it is
|
||||
* waiting for the response as we are going down
|
||||
*/
|
||||
for (i = 0; i < IDPF_VC_NBITS; i++)
|
||||
set_bit(i, vport->vc_state);
|
||||
wake_up(&vport->vchnl_wq);
|
||||
|
||||
mutex_destroy(&vport->vc_buf_lock);
|
||||
|
||||
/* Clear all the bits */
|
||||
for (i = 0; i < IDPF_VC_NBITS; i++)
|
||||
clear_bit(i, vport->vc_state);
|
||||
|
||||
/* Release all max queues allocated to the adapter's pool */
|
||||
max_q.max_rxq = vport_config->max_q.max_rxq;
|
||||
max_q.max_txq = vport_config->max_q.max_txq;
|
||||
@ -1253,7 +1228,7 @@ void idpf_mbx_task(struct work_struct *work)
|
||||
queue_delayed_work(adapter->mbx_wq, &adapter->mbx_task,
|
||||
msecs_to_jiffies(300));
|
||||
|
||||
idpf_recv_mb_msg(adapter, VIRTCHNL2_OP_UNKNOWN, NULL, 0);
|
||||
idpf_recv_mb_msg(adapter);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -1543,9 +1518,7 @@ void idpf_init_task(struct work_struct *work)
|
||||
vport_config = adapter->vport_config[index];
|
||||
|
||||
init_waitqueue_head(&vport->sw_marker_wq);
|
||||
init_waitqueue_head(&vport->vchnl_wq);
|
||||
|
||||
mutex_init(&vport->vc_buf_lock);
|
||||
spin_lock_init(&vport_config->mac_filter_list_lock);
|
||||
|
||||
INIT_LIST_HEAD(&vport_config->user_config.mac_filter_list);
|
||||
@ -1823,6 +1796,8 @@ static int idpf_init_hard_reset(struct idpf_adapter *adapter)
|
||||
goto unlock_mutex;
|
||||
}
|
||||
|
||||
queue_delayed_work(adapter->mbx_wq, &adapter->mbx_task, 0);
|
||||
|
||||
/* Initialize the state machine, also allocate memory and request
|
||||
* resources
|
||||
*/
|
||||
@ -1902,7 +1877,7 @@ int idpf_initiate_soft_reset(struct idpf_vport *vport,
|
||||
* mess with. Nothing below should use those variables from new_vport
|
||||
* and should instead always refer to them in vport if they need to.
|
||||
*/
|
||||
memcpy(new_vport, vport, offsetof(struct idpf_vport, vc_state));
|
||||
memcpy(new_vport, vport, offsetof(struct idpf_vport, link_speed_mbps));
|
||||
|
||||
/* Adjust resource parameters prior to reallocating resources */
|
||||
switch (reset_cause) {
|
||||
@ -1951,7 +1926,7 @@ int idpf_initiate_soft_reset(struct idpf_vport *vport,
|
||||
/* Same comment as above regarding avoiding copying the wait_queues and
|
||||
* mutexes applies here. We do not want to mess with those if possible.
|
||||
*/
|
||||
memcpy(vport, new_vport, offsetof(struct idpf_vport, vc_state));
|
||||
memcpy(vport, new_vport, offsetof(struct idpf_vport, link_speed_mbps));
|
||||
|
||||
/* Since idpf_vport_queues_alloc was called with new_port, the queue
|
||||
* back pointers are currently pointing to the local new_vport. Reset
|
||||
|
@ -3,6 +3,7 @@
|
||||
|
||||
#include "idpf.h"
|
||||
#include "idpf_devids.h"
|
||||
#include "idpf_virtchnl.h"
|
||||
|
||||
#define DRV_SUMMARY "Intel(R) Infrastructure Data Path Function Linux Driver"
|
||||
|
||||
@ -30,6 +31,7 @@ static void idpf_remove(struct pci_dev *pdev)
|
||||
idpf_sriov_configure(pdev, 0);
|
||||
|
||||
idpf_vc_core_deinit(adapter);
|
||||
|
||||
/* Be a good citizen and leave the device clean on exit */
|
||||
adapter->dev_ops.reg_ops.trigger_reset(adapter, IDPF_HR_FUNC_RESET);
|
||||
idpf_deinit_dflt_mbx(adapter);
|
||||
@ -66,6 +68,8 @@ static void idpf_remove(struct pci_dev *pdev)
|
||||
adapter->vport_config = NULL;
|
||||
kfree(adapter->netdevs);
|
||||
adapter->netdevs = NULL;
|
||||
kfree(adapter->vcxn_mngr);
|
||||
adapter->vcxn_mngr = NULL;
|
||||
|
||||
mutex_destroy(&adapter->vport_ctrl_lock);
|
||||
mutex_destroy(&adapter->vector_lock);
|
||||
@ -229,8 +233,6 @@ static int idpf_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
|
||||
mutex_init(&adapter->queue_lock);
|
||||
mutex_init(&adapter->vc_buf_lock);
|
||||
|
||||
init_waitqueue_head(&adapter->vchnl_wq);
|
||||
|
||||
INIT_DELAYED_WORK(&adapter->init_task, idpf_init_task);
|
||||
INIT_DELAYED_WORK(&adapter->serv_task, idpf_service_task);
|
||||
INIT_DELAYED_WORK(&adapter->mbx_task, idpf_mbx_task);
|
||||
|
@ -2,6 +2,7 @@
|
||||
/* Copyright (C) 2023 Intel Corporation */
|
||||
|
||||
#include "idpf.h"
|
||||
#include "idpf_virtchnl.h"
|
||||
|
||||
/**
|
||||
* idpf_buf_lifo_push - push a buffer pointer onto stack
|
||||
|
@ -3,6 +3,7 @@
|
||||
|
||||
#include "idpf.h"
|
||||
#include "idpf_lan_vf_regs.h"
|
||||
#include "idpf_virtchnl.h"
|
||||
|
||||
#define IDPF_VF_ITR_IDX_SPACING 0x40
|
||||
|
||||
@ -137,7 +138,7 @@ static void idpf_vf_trigger_reset(struct idpf_adapter *adapter,
|
||||
/* Do not send VIRTCHNL2_OP_RESET_VF message on driver unload */
|
||||
if (trig_cause == IDPF_HR_FUNC_RESET &&
|
||||
!test_bit(IDPF_REMOVE_IN_PROG, adapter->flags))
|
||||
idpf_send_mb_msg(adapter, VIRTCHNL2_OP_RESET_VF, 0, NULL);
|
||||
idpf_send_mb_msg(adapter, VIRTCHNL2_OP_RESET_VF, 0, NULL, 0);
|
||||
}
|
||||
|
||||
/**
|
||||
|
File diff suppressed because it is too large
Load Diff
70
drivers/net/ethernet/intel/idpf/idpf_virtchnl.h
Normal file
70
drivers/net/ethernet/intel/idpf/idpf_virtchnl.h
Normal file
@ -0,0 +1,70 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
/* Copyright (C) 2024 Intel Corporation */
|
||||
|
||||
#ifndef _IDPF_VIRTCHNL_H_
|
||||
#define _IDPF_VIRTCHNL_H_
|
||||
|
||||
struct idpf_adapter;
|
||||
struct idpf_netdev_priv;
|
||||
struct idpf_vec_regs;
|
||||
struct idpf_vport;
|
||||
struct idpf_vport_max_q;
|
||||
struct idpf_vport_user_config_data;
|
||||
|
||||
int idpf_init_dflt_mbx(struct idpf_adapter *adapter);
|
||||
void idpf_deinit_dflt_mbx(struct idpf_adapter *adapter);
|
||||
int idpf_vc_core_init(struct idpf_adapter *adapter);
|
||||
void idpf_vc_core_deinit(struct idpf_adapter *adapter);
|
||||
|
||||
int idpf_get_reg_intr_vecs(struct idpf_vport *vport,
|
||||
struct idpf_vec_regs *reg_vals);
|
||||
int idpf_queue_reg_init(struct idpf_vport *vport);
|
||||
int idpf_vport_queue_ids_init(struct idpf_vport *vport);
|
||||
|
||||
int idpf_recv_mb_msg(struct idpf_adapter *adapter);
|
||||
int idpf_send_mb_msg(struct idpf_adapter *adapter, u32 op,
|
||||
u16 msg_size, u8 *msg, u16 cookie);
|
||||
|
||||
void idpf_vport_init(struct idpf_vport *vport, struct idpf_vport_max_q *max_q);
|
||||
u32 idpf_get_vport_id(struct idpf_vport *vport);
|
||||
int idpf_send_create_vport_msg(struct idpf_adapter *adapter,
|
||||
struct idpf_vport_max_q *max_q);
|
||||
int idpf_send_destroy_vport_msg(struct idpf_vport *vport);
|
||||
int idpf_send_enable_vport_msg(struct idpf_vport *vport);
|
||||
int idpf_send_disable_vport_msg(struct idpf_vport *vport);
|
||||
|
||||
int idpf_vport_adjust_qs(struct idpf_vport *vport);
|
||||
int idpf_vport_alloc_max_qs(struct idpf_adapter *adapter,
|
||||
struct idpf_vport_max_q *max_q);
|
||||
void idpf_vport_dealloc_max_qs(struct idpf_adapter *adapter,
|
||||
struct idpf_vport_max_q *max_q);
|
||||
int idpf_send_add_queues_msg(const struct idpf_vport *vport, u16 num_tx_q,
|
||||
u16 num_complq, u16 num_rx_q, u16 num_rx_bufq);
|
||||
int idpf_send_delete_queues_msg(struct idpf_vport *vport);
|
||||
int idpf_send_enable_queues_msg(struct idpf_vport *vport);
|
||||
int idpf_send_disable_queues_msg(struct idpf_vport *vport);
|
||||
int idpf_send_config_queues_msg(struct idpf_vport *vport);
|
||||
|
||||
int idpf_vport_alloc_vec_indexes(struct idpf_vport *vport);
|
||||
int idpf_get_vec_ids(struct idpf_adapter *adapter,
|
||||
u16 *vecids, int num_vecids,
|
||||
struct virtchnl2_vector_chunks *chunks);
|
||||
int idpf_send_alloc_vectors_msg(struct idpf_adapter *adapter, u16 num_vectors);
|
||||
int idpf_send_dealloc_vectors_msg(struct idpf_adapter *adapter);
|
||||
int idpf_send_map_unmap_queue_vector_msg(struct idpf_vport *vport, bool map);
|
||||
|
||||
int idpf_add_del_mac_filters(struct idpf_vport *vport,
|
||||
struct idpf_netdev_priv *np,
|
||||
bool add, bool async);
|
||||
int idpf_set_promiscuous(struct idpf_adapter *adapter,
|
||||
struct idpf_vport_user_config_data *config_data,
|
||||
u32 vport_id);
|
||||
int idpf_check_supported_desc_ids(struct idpf_vport *vport);
|
||||
int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport);
|
||||
int idpf_send_ena_dis_loopback_msg(struct idpf_vport *vport);
|
||||
int idpf_send_get_stats_msg(struct idpf_vport *vport);
|
||||
int idpf_send_set_sriov_vfs_msg(struct idpf_adapter *adapter, u16 num_vfs);
|
||||
int idpf_send_get_set_rss_key_msg(struct idpf_vport *vport, bool get);
|
||||
int idpf_send_get_set_rss_lut_msg(struct idpf_vport *vport, bool get);
|
||||
|
||||
#endif /* _IDPF_VIRTCHNL_H_ */
|
Loading…
Reference in New Issue
Block a user