Commit 0518c12f authored by Michal Kalderon's avatar Michal Kalderon Committed by David S. Miller

qed*: LL2 callback operations

LL2 today is interrupt driven - when tx/rx completion arrives [or any
other indication], qed needs to operate on the connection and pass
the information to the protocol-driver [or internal qed consumer].
Since we have several flavors of ll2 employeed by the driver,
each handler needs to do an if-else to determine the right functionality
to use based on the connection type.

In order to make things more scalable [given that we're going to add
additional types of ll2 flavors] move the infrastrucutre into using
a callback-based approach - the callbacks would be provided as part
of the connection's initialization parameters.
Signed-off-by: default avatarMichal Kalderon <Michal.Kalderon@cavium.com>
Signed-off-by: default avatarYuval Mintz <Yuval.Mintz@cavium.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 58de2898
...@@ -886,7 +886,7 @@ static void qedr_mac_address_change(struct qedr_dev *dev) ...@@ -886,7 +886,7 @@ static void qedr_mac_address_change(struct qedr_dev *dev)
memcpy(&sgid->raw[8], guid, sizeof(guid)); memcpy(&sgid->raw[8], guid, sizeof(guid));
/* Update LL2 */ /* Update LL2 */
rc = dev->ops->roce_ll2_set_mac_filter(dev->cdev, rc = dev->ops->ll2_set_mac_filter(dev->cdev,
dev->gsi_ll2_mac_address, dev->gsi_ll2_mac_address,
dev->ndev->dev_addr); dev->ndev->dev_addr);
......
...@@ -150,6 +150,8 @@ struct qedr_dev { ...@@ -150,6 +150,8 @@ struct qedr_dev {
u32 dp_module; u32 dp_module;
u8 dp_level; u8 dp_level;
u8 num_hwfns; u8 num_hwfns;
u8 gsi_ll2_handle;
uint wq_multiplier; uint wq_multiplier;
u8 gsi_ll2_mac_address[ETH_ALEN]; u8 gsi_ll2_mac_address[ETH_ALEN];
int gsi_qp_created; int gsi_qp_created;
......
This diff is collapsed.
...@@ -552,7 +552,6 @@ struct qed_hwfn { ...@@ -552,7 +552,6 @@ struct qed_hwfn {
#endif #endif
struct z_stream_s *stream; struct z_stream_s *stream;
struct qed_roce_ll2_info *ll2;
}; };
struct pci_params { struct pci_params {
......
This diff is collapsed.
...@@ -126,6 +126,7 @@ struct qed_ll2_info { ...@@ -126,6 +126,7 @@ struct qed_ll2_info {
u8 tx_stats_en; u8 tx_stats_en;
struct qed_ll2_rx_queue rx_queue; struct qed_ll2_rx_queue rx_queue;
struct qed_ll2_tx_queue tx_queue; struct qed_ll2_tx_queue tx_queue;
struct qed_ll2_cbs cbs;
}; };
/** /**
...@@ -134,30 +135,29 @@ struct qed_ll2_info { ...@@ -134,30 +135,29 @@ struct qed_ll2_info {
* connecion handler as output parameter. * connecion handler as output parameter.
* *
* *
* @param p_hwfn * @param cxt - pointer to the hw-function [opaque to some]
* @param data - describes connection parameters * @param data - describes connection parameters
* @return int * @return int
*/ */
int qed_ll2_acquire_connection(struct qed_hwfn *p_hwfn, int qed_ll2_acquire_connection(void *cxt, struct qed_ll2_acquire_data *data);
struct qed_ll2_acquire_data *data);
/** /**
* @brief qed_ll2_establish_connection - start previously * @brief qed_ll2_establish_connection - start previously
* allocated LL2 queues pair * allocated LL2 queues pair
* *
* @param p_hwfn * @param cxt - pointer to the hw-function [opaque to some]
* @param p_ptt * @param p_ptt
* @param connection_handle LL2 connection's handle obtained from * @param connection_handle LL2 connection's handle obtained from
* qed_ll2_require_connection * qed_ll2_require_connection
* *
* @return 0 on success, failure otherwise * @return 0 on success, failure otherwise
*/ */
int qed_ll2_establish_connection(struct qed_hwfn *p_hwfn, u8 connection_handle); int qed_ll2_establish_connection(void *cxt, u8 connection_handle);
/** /**
* @brief qed_ll2_post_rx_buffers - submit buffers to LL2 Rx queue. * @brief qed_ll2_post_rx_buffers - submit buffers to LL2 Rx queue.
* *
* @param p_hwfn * @param cxt - pointer to the hw-function [opaque to some]
* @param connection_handle LL2 connection's handle obtained from * @param connection_handle LL2 connection's handle obtained from
* qed_ll2_require_connection * qed_ll2_require_connection
* @param addr rx (physical address) buffers to submit * @param addr rx (physical address) buffers to submit
...@@ -166,7 +166,7 @@ int qed_ll2_establish_connection(struct qed_hwfn *p_hwfn, u8 connection_handle); ...@@ -166,7 +166,7 @@ int qed_ll2_establish_connection(struct qed_hwfn *p_hwfn, u8 connection_handle);
* *
* @return 0 on success, failure otherwise * @return 0 on success, failure otherwise
*/ */
int qed_ll2_post_rx_buffer(struct qed_hwfn *p_hwfn, int qed_ll2_post_rx_buffer(void *cxt,
u8 connection_handle, u8 connection_handle,
dma_addr_t addr, dma_addr_t addr,
u16 buf_len, void *cookie, u8 notify_fw); u16 buf_len, void *cookie, u8 notify_fw);
...@@ -175,14 +175,14 @@ int qed_ll2_post_rx_buffer(struct qed_hwfn *p_hwfn, ...@@ -175,14 +175,14 @@ int qed_ll2_post_rx_buffer(struct qed_hwfn *p_hwfn,
* @brief qed_ll2_prepare_tx_packet - request for start Tx BD * @brief qed_ll2_prepare_tx_packet - request for start Tx BD
* to prepare Tx packet submission to FW. * to prepare Tx packet submission to FW.
* *
* @param p_hwfn * @param cxt - pointer to the hw-function [opaque to some]
* @param connection_handle * @param connection_handle
* @param pkt - info regarding the tx packet * @param pkt - info regarding the tx packet
* @param notify_fw - issue doorbell to fw for this packet * @param notify_fw - issue doorbell to fw for this packet
* *
* @return 0 on success, failure otherwise * @return 0 on success, failure otherwise
*/ */
int qed_ll2_prepare_tx_packet(struct qed_hwfn *p_hwfn, int qed_ll2_prepare_tx_packet(void *cxt,
u8 connection_handle, u8 connection_handle,
struct qed_ll2_tx_pkt_info *pkt, struct qed_ll2_tx_pkt_info *pkt,
bool notify_fw); bool notify_fw);
...@@ -191,18 +191,18 @@ int qed_ll2_prepare_tx_packet(struct qed_hwfn *p_hwfn, ...@@ -191,18 +191,18 @@ int qed_ll2_prepare_tx_packet(struct qed_hwfn *p_hwfn,
* @brief qed_ll2_release_connection - releases resources * @brief qed_ll2_release_connection - releases resources
* allocated for LL2 connection * allocated for LL2 connection
* *
* @param p_hwfn * @param cxt - pointer to the hw-function [opaque to some]
* @param connection_handle LL2 connection's handle obtained from * @param connection_handle LL2 connection's handle obtained from
* qed_ll2_require_connection * qed_ll2_require_connection
*/ */
void qed_ll2_release_connection(struct qed_hwfn *p_hwfn, u8 connection_handle); void qed_ll2_release_connection(void *cxt, u8 connection_handle);
/** /**
* @brief qed_ll2_set_fragment_of_tx_packet - provides fragments to fill * @brief qed_ll2_set_fragment_of_tx_packet - provides fragments to fill
* Tx BD of BDs requested by * Tx BD of BDs requested by
* qed_ll2_prepare_tx_packet * qed_ll2_prepare_tx_packet
* *
* @param p_hwfn * @param cxt - pointer to the hw-function [opaque to some]
* @param connection_handle LL2 connection's handle * @param connection_handle LL2 connection's handle
* obtained from * obtained from
* qed_ll2_require_connection * qed_ll2_require_connection
...@@ -211,7 +211,7 @@ void qed_ll2_release_connection(struct qed_hwfn *p_hwfn, u8 connection_handle); ...@@ -211,7 +211,7 @@ void qed_ll2_release_connection(struct qed_hwfn *p_hwfn, u8 connection_handle);
* *
* @return 0 on success, failure otherwise * @return 0 on success, failure otherwise
*/ */
int qed_ll2_set_fragment_of_tx_packet(struct qed_hwfn *p_hwfn, int qed_ll2_set_fragment_of_tx_packet(void *cxt,
u8 connection_handle, u8 connection_handle,
dma_addr_t addr, u16 nbytes); dma_addr_t addr, u16 nbytes);
...@@ -219,27 +219,27 @@ int qed_ll2_set_fragment_of_tx_packet(struct qed_hwfn *p_hwfn, ...@@ -219,27 +219,27 @@ int qed_ll2_set_fragment_of_tx_packet(struct qed_hwfn *p_hwfn,
* @brief qed_ll2_terminate_connection - stops Tx/Rx queues * @brief qed_ll2_terminate_connection - stops Tx/Rx queues
* *
* *
* @param p_hwfn * @param cxt - pointer to the hw-function [opaque to some]
* @param connection_handle LL2 connection's handle * @param connection_handle LL2 connection's handle
* obtained from * obtained from
* qed_ll2_require_connection * qed_ll2_require_connection
* *
* @return 0 on success, failure otherwise * @return 0 on success, failure otherwise
*/ */
int qed_ll2_terminate_connection(struct qed_hwfn *p_hwfn, u8 connection_handle); int qed_ll2_terminate_connection(void *cxt, u8 connection_handle);
/** /**
* @brief qed_ll2_get_stats - get LL2 queue's statistics * @brief qed_ll2_get_stats - get LL2 queue's statistics
* *
* *
* @param p_hwfn * @param cxt - pointer to the hw-function [opaque to some]
* @param connection_handle LL2 connection's handle obtained from * @param connection_handle LL2 connection's handle obtained from
* qed_ll2_require_connection * qed_ll2_require_connection
* @param p_stats * @param p_stats
* *
* @return 0 on success, failure otherwise * @return 0 on success, failure otherwise
*/ */
int qed_ll2_get_stats(struct qed_hwfn *p_hwfn, int qed_ll2_get_stats(void *cxt,
u8 connection_handle, struct qed_ll2_stats *p_stats); u8 connection_handle, struct qed_ll2_stats *p_stats);
/** /**
......
This diff is collapsed.
...@@ -170,53 +170,10 @@ struct qed_rdma_qp { ...@@ -170,53 +170,10 @@ struct qed_rdma_qp {
void qed_rdma_dpm_bar(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt); void qed_rdma_dpm_bar(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt);
void qed_roce_async_event(struct qed_hwfn *p_hwfn, void qed_roce_async_event(struct qed_hwfn *p_hwfn,
u8 fw_event_code, union rdma_eqe_data *rdma_data); u8 fw_event_code, union rdma_eqe_data *rdma_data);
void qed_ll2b_complete_tx_gsi_packet(struct qed_hwfn *p_hwfn,
u8 connection_handle,
void *cookie,
dma_addr_t first_frag_addr,
bool b_last_fragment, bool b_last_packet);
void qed_ll2b_release_tx_gsi_packet(struct qed_hwfn *p_hwfn,
u8 connection_handle,
void *cookie,
dma_addr_t first_frag_addr,
bool b_last_fragment, bool b_last_packet);
void qed_ll2b_complete_rx_gsi_packet(struct qed_hwfn *p_hwfn,
u8 connection_handle,
void *cookie,
dma_addr_t rx_buf_addr,
u16 data_length,
u8 data_length_error,
u16 parse_flags,
u16 vlan,
u32 src_mac_addr_hi,
u16 src_mac_addr_lo, bool b_last_packet);
#else #else
static inline void qed_rdma_dpm_bar(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt) {} static inline void qed_rdma_dpm_bar(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt) {}
static inline void qed_roce_async_event(struct qed_hwfn *p_hwfn, static inline void qed_roce_async_event(struct qed_hwfn *p_hwfn,
u8 fw_event_code, u8 fw_event_code,
union rdma_eqe_data *rdma_data) {} union rdma_eqe_data *rdma_data) {}
static inline void qed_ll2b_complete_tx_gsi_packet(struct qed_hwfn *p_hwfn,
u8 connection_handle,
void *cookie,
dma_addr_t first_frag_addr,
bool b_last_fragment,
bool b_last_packet) {}
static inline void qed_ll2b_release_tx_gsi_packet(struct qed_hwfn *p_hwfn,
u8 connection_handle,
void *cookie,
dma_addr_t first_frag_addr,
bool b_last_fragment,
bool b_last_packet) {}
static inline void qed_ll2b_complete_rx_gsi_packet(struct qed_hwfn *p_hwfn,
u8 connection_handle,
void *cookie,
dma_addr_t rx_buf_addr,
u16 data_length,
u8 data_length_error,
u16 parse_flags,
u16 vlan,
u32 src_mac_addr_hi,
u16 src_mac_addr_lo,
bool b_last_packet) {}
#endif #endif
#endif #endif
...@@ -122,6 +122,40 @@ struct qed_ll2_comp_rx_data { ...@@ -122,6 +122,40 @@ struct qed_ll2_comp_rx_data {
} u; } u;
}; };
typedef
void (*qed_ll2_complete_rx_packet_cb)(void *cxt,
struct qed_ll2_comp_rx_data *data);
typedef
void (*qed_ll2_release_rx_packet_cb)(void *cxt,
u8 connection_handle,
void *cookie,
dma_addr_t rx_buf_addr,
bool b_last_packet);
typedef
void (*qed_ll2_complete_tx_packet_cb)(void *cxt,
u8 connection_handle,
void *cookie,
dma_addr_t first_frag_addr,
bool b_last_fragment,
bool b_last_packet);
typedef
void (*qed_ll2_release_tx_packet_cb)(void *cxt,
u8 connection_handle,
void *cookie,
dma_addr_t first_frag_addr,
bool b_last_fragment, bool b_last_packet);
struct qed_ll2_cbs {
qed_ll2_complete_rx_packet_cb rx_comp_cb;
qed_ll2_release_rx_packet_cb rx_release_cb;
qed_ll2_complete_tx_packet_cb tx_comp_cb;
qed_ll2_release_tx_packet_cb tx_release_cb;
void *cookie;
};
struct qed_ll2_acquire_data_inputs { struct qed_ll2_acquire_data_inputs {
enum qed_ll2_conn_type conn_type; enum qed_ll2_conn_type conn_type;
u16 mtu; u16 mtu;
...@@ -140,6 +174,8 @@ struct qed_ll2_acquire_data_inputs { ...@@ -140,6 +174,8 @@ struct qed_ll2_acquire_data_inputs {
struct qed_ll2_acquire_data { struct qed_ll2_acquire_data {
struct qed_ll2_acquire_data_inputs input; struct qed_ll2_acquire_data_inputs input;
const struct qed_ll2_cbs *cbs;
/* Output container for LL2 connection's handle */ /* Output container for LL2 connection's handle */
u8 *p_connection_handle; u8 *p_connection_handle;
}; };
......
...@@ -34,8 +34,6 @@ ...@@ -34,8 +34,6 @@
#include <linux/types.h> #include <linux/types.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/list.h> #include <linux/list.h>
#include <linux/mutex.h>
#include <linux/pci.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/qed/qed_if.h> #include <linux/qed/qed_if.h>
#include <linux/qed/qed_ll2_if.h> #include <linux/qed/qed_ll2_if.h>
...@@ -491,42 +489,6 @@ struct qed_roce_ll2_packet { ...@@ -491,42 +489,6 @@ struct qed_roce_ll2_packet {
enum qed_roce_ll2_tx_dest tx_dest; enum qed_roce_ll2_tx_dest tx_dest;
}; };
struct qed_roce_ll2_tx_params {
int reserved;
};
struct qed_roce_ll2_rx_params {
u16 vlan_id;
u8 smac[ETH_ALEN];
int rc;
};
struct qed_roce_ll2_cbs {
void (*tx_cb)(void *pdev, struct qed_roce_ll2_packet *pkt);
void (*rx_cb)(void *pdev, struct qed_roce_ll2_packet *pkt,
struct qed_roce_ll2_rx_params *params);
};
struct qed_roce_ll2_params {
u16 max_rx_buffers;
u16 max_tx_buffers;
u16 mtu;
u8 mac_address[ETH_ALEN];
struct qed_roce_ll2_cbs cbs;
void *cb_cookie;
};
struct qed_roce_ll2_info {
u8 handle;
struct qed_roce_ll2_cbs cbs;
u8 mac_address[ETH_ALEN];
void *cb_cookie;
/* Lock to protect ll2 */
struct mutex lock;
};
enum qed_rdma_type { enum qed_rdma_type {
QED_RDMA_TYPE_ROCE, QED_RDMA_TYPE_ROCE,
}; };
...@@ -579,26 +541,40 @@ struct qed_rdma_ops { ...@@ -579,26 +541,40 @@ struct qed_rdma_ops {
int (*rdma_query_qp)(void *rdma_cxt, struct qed_rdma_qp *qp, int (*rdma_query_qp)(void *rdma_cxt, struct qed_rdma_qp *qp,
struct qed_rdma_query_qp_out_params *oparams); struct qed_rdma_query_qp_out_params *oparams);
int (*rdma_destroy_qp)(void *rdma_cxt, struct qed_rdma_qp *qp); int (*rdma_destroy_qp)(void *rdma_cxt, struct qed_rdma_qp *qp);
int int
(*rdma_register_tid)(void *rdma_cxt, (*rdma_register_tid)(void *rdma_cxt,
struct qed_rdma_register_tid_in_params *iparams); struct qed_rdma_register_tid_in_params *iparams);
int (*rdma_deregister_tid)(void *rdma_cxt, u32 itid); int (*rdma_deregister_tid)(void *rdma_cxt, u32 itid);
int (*rdma_alloc_tid)(void *rdma_cxt, u32 *itid); int (*rdma_alloc_tid)(void *rdma_cxt, u32 *itid);
void (*rdma_free_tid)(void *rdma_cxt, u32 itid); void (*rdma_free_tid)(void *rdma_cxt, u32 itid);
int (*roce_ll2_start)(struct qed_dev *cdev,
struct qed_roce_ll2_params *params); int (*ll2_acquire_connection)(void *rdma_cxt,
int (*roce_ll2_stop)(struct qed_dev *cdev); struct qed_ll2_acquire_data *data);
int (*roce_ll2_tx)(struct qed_dev *cdev,
struct qed_roce_ll2_packet *packet, int (*ll2_establish_connection)(void *rdma_cxt, u8 connection_handle);
struct qed_roce_ll2_tx_params *params); int (*ll2_terminate_connection)(void *rdma_cxt, u8 connection_handle);
int (*roce_ll2_post_rx_buffer)(struct qed_dev *cdev, void (*ll2_release_connection)(void *rdma_cxt, u8 connection_handle);
struct qed_roce_ll2_buffer *buf,
u64 cookie, u8 notify_fw); int (*ll2_prepare_tx_packet)(void *rdma_cxt,
int (*roce_ll2_set_mac_filter)(struct qed_dev *cdev, u8 connection_handle,
u8 *old_mac_address, struct qed_ll2_tx_pkt_info *pkt,
u8 *new_mac_address); bool notify_fw);
int (*roce_ll2_stats)(struct qed_dev *cdev,
struct qed_ll2_stats *stats); int (*ll2_set_fragment_of_tx_packet)(void *rdma_cxt,
u8 connection_handle,
dma_addr_t addr,
u16 nbytes);
int (*ll2_post_rx_buffer)(void *rdma_cxt, u8 connection_handle,
dma_addr_t addr, u16 buf_len, void *cookie,
u8 notify_fw);
int (*ll2_get_stats)(void *rdma_cxt,
u8 connection_handle,
struct qed_ll2_stats *p_stats);
int (*ll2_set_mac_filter)(struct qed_dev *cdev,
u8 *old_mac_address, u8 *new_mac_address);
}; };
const struct qed_rdma_ops *qed_get_rdma_ops(void); const struct qed_rdma_ops *qed_get_rdma_ops(void);
......
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