idpf: add idpf_virtchnl.h
idpf.h is quite heavy. We can reduce the burden a fair bit by introducing an idpf_virtchnl.h file. This mostly just moves function declarations but there are many of them. This also makes an attempt to group those declarations in a way that makes some sense instead of mishmashed. Suggested-by: Alexander Lobakin <aleksander.lobakin@intel.com> Signed-off-by: Alan Brady <alan.brady@intel.com> Tested-by: Krishneil Singh <krishneil.k.singh@intel.com> Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
This commit is contained in:
@@ -903,68 +903,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);
|
||||
|
||||
@@ -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,6 +2,7 @@
|
||||
/* 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;
|
||||
|
||||
@@ -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"
|
||||
|
||||
|
||||
@@ -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
|
||||
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
/* Copyright (C) 2023 Intel Corporation */
|
||||
|
||||
#include "idpf.h"
|
||||
#include "idpf_virtchnl.h"
|
||||
|
||||
/**
|
||||
* idpf_recv_event_msg - Receive virtchnl event message
|
||||
|
||||
@@ -0,0 +1,71 @@
|
||||
/* 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, 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_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_ */
|
||||
Reference in New Issue
Block a user