mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	qed: iWARP CM add passive side connect
This patch implements the passive side connect. It addresses pre-allocating resources, creating a connection element upon valid SYN packet received. Calling upper layer and implementation of the accept/reject calls. Error handling is not part of this patch. Signed-off-by: Michal Kalderon <Michal.Kalderon@cavium.com> Signed-off-by: Yuval Mintz <Yuval.Mintz@cavium.com> Signed-off-by: Ariel Elior <Ariel.Elior@cavium.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									65a91a6cdb
								
							
						
					
					
						commit
						456a584947
					
				| @ -789,6 +789,8 @@ void qed_configure_vp_wfq_on_link_change(struct qed_dev *cdev, | |||||||
| void qed_clean_wfq_db(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt); | void qed_clean_wfq_db(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt); | ||||||
| int qed_device_num_engines(struct qed_dev *cdev); | int qed_device_num_engines(struct qed_dev *cdev); | ||||||
| int qed_device_get_port_id(struct qed_dev *cdev); | int qed_device_get_port_id(struct qed_dev *cdev); | ||||||
|  | void qed_set_fw_mac_addr(__le16 *fw_msb, | ||||||
|  | 			 __le16 *fw_mid, __le16 *fw_lsb, u8 *mac); | ||||||
| 
 | 
 | ||||||
| #define QED_LEADING_HWFN(dev)   (&dev->hwfns[0]) | #define QED_LEADING_HWFN(dev)   (&dev->hwfns[0]) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -4127,3 +4127,14 @@ int qed_device_get_port_id(struct qed_dev *cdev) | |||||||
| { | { | ||||||
| 	return (QED_LEADING_HWFN(cdev)->abs_pf_id) % qed_device_num_ports(cdev); | 	return (QED_LEADING_HWFN(cdev)->abs_pf_id) % qed_device_num_ports(cdev); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | void qed_set_fw_mac_addr(__le16 *fw_msb, | ||||||
|  | 			 __le16 *fw_mid, __le16 *fw_lsb, u8 *mac) | ||||||
|  | { | ||||||
|  | 	((u8 *)fw_msb)[0] = mac[1]; | ||||||
|  | 	((u8 *)fw_msb)[1] = mac[0]; | ||||||
|  | 	((u8 *)fw_mid)[0] = mac[3]; | ||||||
|  | 	((u8 *)fw_mid)[1] = mac[2]; | ||||||
|  | 	((u8 *)fw_lsb)[0] = mac[5]; | ||||||
|  | 	((u8 *)fw_lsb)[1] = mac[4]; | ||||||
|  | } | ||||||
|  | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -42,6 +42,8 @@ enum qed_iwarp_qp_state { | |||||||
| 
 | 
 | ||||||
| enum qed_iwarp_qp_state qed_roce2iwarp_state(enum qed_roce_qp_state state); | enum qed_iwarp_qp_state qed_roce2iwarp_state(enum qed_roce_qp_state state); | ||||||
| 
 | 
 | ||||||
|  | #define QED_IWARP_PREALLOC_CNT  (256) | ||||||
|  | 
 | ||||||
| #define QED_IWARP_LL2_SYN_TX_SIZE       (128) | #define QED_IWARP_LL2_SYN_TX_SIZE       (128) | ||||||
| #define QED_IWARP_LL2_SYN_RX_SIZE       (256) | #define QED_IWARP_LL2_SYN_RX_SIZE       (256) | ||||||
| #define QED_IWARP_MAX_SYN_PKT_SIZE      (128) | #define QED_IWARP_MAX_SYN_PKT_SIZE      (128) | ||||||
| @ -55,6 +57,8 @@ struct qed_iwarp_ll2_buff { | |||||||
| 
 | 
 | ||||||
| struct qed_iwarp_info { | struct qed_iwarp_info { | ||||||
| 	struct list_head listen_list;	/* qed_iwarp_listener */ | 	struct list_head listen_list;	/* qed_iwarp_listener */ | ||||||
|  | 	struct list_head ep_list;	/* qed_iwarp_ep */ | ||||||
|  | 	struct list_head ep_free_list;	/* pre-allocated ep's */ | ||||||
| 	spinlock_t iw_lock;	/* for iwarp resources */ | 	spinlock_t iw_lock;	/* for iwarp resources */ | ||||||
| 	spinlock_t qp_lock;	/* for teardown races */ | 	spinlock_t qp_lock;	/* for teardown races */ | ||||||
| 	u32 rcv_wnd_scale; | 	u32 rcv_wnd_scale; | ||||||
| @ -68,6 +72,61 @@ struct qed_iwarp_info { | |||||||
| 	enum mpa_rtr_type rtr_type; | 	enum mpa_rtr_type rtr_type; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | enum qed_iwarp_ep_state { | ||||||
|  | 	QED_IWARP_EP_INIT, | ||||||
|  | 	QED_IWARP_EP_MPA_REQ_RCVD, | ||||||
|  | 	QED_IWARP_EP_MPA_OFFLOADED, | ||||||
|  | 	QED_IWARP_EP_ESTABLISHED, | ||||||
|  | 	QED_IWARP_EP_CLOSED | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | union async_output { | ||||||
|  | 	struct iwarp_eqe_data_mpa_async_completion mpa_response; | ||||||
|  | 	struct iwarp_eqe_data_tcp_async_completion mpa_request; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | #define QED_MAX_PRIV_DATA_LEN (512) | ||||||
|  | struct qed_iwarp_ep_memory { | ||||||
|  | 	u8 in_pdata[QED_MAX_PRIV_DATA_LEN]; | ||||||
|  | 	u8 out_pdata[QED_MAX_PRIV_DATA_LEN]; | ||||||
|  | 	union async_output async_output; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | /* Endpoint structure represents a TCP connection. This connection can be
 | ||||||
|  |  * associated with a QP or not (in which case QP==NULL) | ||||||
|  |  */ | ||||||
|  | struct qed_iwarp_ep { | ||||||
|  | 	struct list_head list_entry; | ||||||
|  | 	struct qed_rdma_qp *qp; | ||||||
|  | 	struct qed_iwarp_ep_memory *ep_buffer_virt; | ||||||
|  | 	dma_addr_t ep_buffer_phys; | ||||||
|  | 	enum qed_iwarp_ep_state state; | ||||||
|  | 	int sig; | ||||||
|  | 	struct qed_iwarp_cm_info cm_info; | ||||||
|  | 	enum tcp_connect_mode connect_mode; | ||||||
|  | 	enum mpa_rtr_type rtr_type; | ||||||
|  | 	enum mpa_negotiation_mode mpa_rev; | ||||||
|  | 	u32 tcp_cid; | ||||||
|  | 	u32 cid; | ||||||
|  | 	u16 mss; | ||||||
|  | 	u8 remote_mac_addr[6]; | ||||||
|  | 	u8 local_mac_addr[6]; | ||||||
|  | 	bool mpa_reply_processed; | ||||||
|  | 
 | ||||||
|  | 	/* For Passive side - syn packet related data */ | ||||||
|  | 	u16 syn_ip_payload_length; | ||||||
|  | 	struct qed_iwarp_ll2_buff *syn; | ||||||
|  | 	dma_addr_t syn_phy_addr; | ||||||
|  | 
 | ||||||
|  | 	/* The event_cb function is called for asynchrounous events associated
 | ||||||
|  | 	 * with the ep. It is initialized at different entry points depending | ||||||
|  | 	 * on whether the ep is the tcp connection active side or passive side | ||||||
|  | 	 * The cb_context is passed to the event_cb function. | ||||||
|  | 	 */ | ||||||
|  | 	iwarp_event_handler event_cb; | ||||||
|  | 	void *cb_context; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| struct qed_iwarp_listener { | struct qed_iwarp_listener { | ||||||
| 	struct list_head list_entry; | 	struct list_head list_entry; | ||||||
| 
 | 
 | ||||||
| @ -115,6 +174,9 @@ qed_iwarp_create_listen(void *rdma_cxt, | |||||||
| 			struct qed_iwarp_listen_in *iparams, | 			struct qed_iwarp_listen_in *iparams, | ||||||
| 			struct qed_iwarp_listen_out *oparams); | 			struct qed_iwarp_listen_out *oparams); | ||||||
| 
 | 
 | ||||||
|  | int qed_iwarp_accept(void *rdma_cxt, struct qed_iwarp_accept_in *iparams); | ||||||
|  | 
 | ||||||
|  | int qed_iwarp_reject(void *rdma_cxt, struct qed_iwarp_reject_in *iparams); | ||||||
| int qed_iwarp_destroy_listen(void *rdma_cxt, void *handle); | int qed_iwarp_destroy_listen(void *rdma_cxt, void *handle); | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -1227,19 +1227,6 @@ static enum eth_filter_action qed_filter_action(enum qed_filter_opcode opcode) | |||||||
| 	return action; | 	return action; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void qed_set_fw_mac_addr(__le16 *fw_msb, |  | ||||||
| 				__le16 *fw_mid, |  | ||||||
| 				__le16 *fw_lsb, |  | ||||||
| 				u8 *mac) |  | ||||||
| { |  | ||||||
| 	((u8 *)fw_msb)[0] = mac[1]; |  | ||||||
| 	((u8 *)fw_msb)[1] = mac[0]; |  | ||||||
| 	((u8 *)fw_mid)[0] = mac[3]; |  | ||||||
| 	((u8 *)fw_mid)[1] = mac[2]; |  | ||||||
| 	((u8 *)fw_lsb)[0] = mac[5]; |  | ||||||
| 	((u8 *)fw_lsb)[1] = mac[4]; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static int | static int | ||||||
| qed_filter_ucast_common(struct qed_hwfn *p_hwfn, | qed_filter_ucast_common(struct qed_hwfn *p_hwfn, | ||||||
| 			u16 opaque_fid, | 			u16 opaque_fid, | ||||||
|  | |||||||
| @ -85,6 +85,7 @@ struct qed_rdma_info { | |||||||
| 	struct qed_bmap qp_map; | 	struct qed_bmap qp_map; | ||||||
| 	struct qed_bmap srq_map; | 	struct qed_bmap srq_map; | ||||||
| 	struct qed_bmap cid_map; | 	struct qed_bmap cid_map; | ||||||
|  | 	struct qed_bmap tcp_cid_map; | ||||||
| 	struct qed_bmap real_cid_map; | 	struct qed_bmap real_cid_map; | ||||||
| 	struct qed_bmap dpi_map; | 	struct qed_bmap dpi_map; | ||||||
| 	struct qed_bmap toggle_bits; | 	struct qed_bmap toggle_bits; | ||||||
| @ -167,6 +168,7 @@ struct qed_rdma_qp { | |||||||
| 
 | 
 | ||||||
| 	void *shared_queue; | 	void *shared_queue; | ||||||
| 	dma_addr_t shared_queue_phys_addr; | 	dma_addr_t shared_queue_phys_addr; | ||||||
|  | 	struct qed_iwarp_ep *ep; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| #if IS_ENABLED(CONFIG_QED_RDMA) | #if IS_ENABLED(CONFIG_QED_RDMA) | ||||||
|  | |||||||
| @ -111,6 +111,8 @@ union ramrod_data { | |||||||
| 	struct rdma_srq_destroy_ramrod_data rdma_destroy_srq; | 	struct rdma_srq_destroy_ramrod_data rdma_destroy_srq; | ||||||
| 	struct rdma_srq_modify_ramrod_data rdma_modify_srq; | 	struct rdma_srq_modify_ramrod_data rdma_modify_srq; | ||||||
| 	struct iwarp_create_qp_ramrod_data iwarp_create_qp; | 	struct iwarp_create_qp_ramrod_data iwarp_create_qp; | ||||||
|  | 	struct iwarp_tcp_offload_ramrod_data iwarp_tcp_offload; | ||||||
|  | 	struct iwarp_mpa_offload_ramrod_data iwarp_mpa_offload; | ||||||
| 	struct iwarp_modify_qp_ramrod_data iwarp_modify_qp; | 	struct iwarp_modify_qp_ramrod_data iwarp_modify_qp; | ||||||
| 	struct iwarp_init_func_ramrod_data iwarp_init_func; | 	struct iwarp_init_func_ramrod_data iwarp_init_func; | ||||||
| 	struct fcoe_init_ramrod_params fcoe_init; | 	struct fcoe_init_ramrod_params fcoe_init; | ||||||
|  | |||||||
| @ -38,6 +38,8 @@ | |||||||
| #include <linux/slab.h> | #include <linux/slab.h> | ||||||
| 
 | 
 | ||||||
| /* dma_addr_t manip */ | /* dma_addr_t manip */ | ||||||
|  | #define PTR_LO(x)               ((u32)(((uintptr_t)(x)) & 0xffffffff)) | ||||||
|  | #define PTR_HI(x)               ((u32)((((uintptr_t)(x)) >> 16) >> 16)) | ||||||
| #define DMA_LO_LE(x)		cpu_to_le32(lower_32_bits(x)) | #define DMA_LO_LE(x)		cpu_to_le32(lower_32_bits(x)) | ||||||
| #define DMA_HI_LE(x)		cpu_to_le32(upper_32_bits(x)) | #define DMA_HI_LE(x)		cpu_to_le32(upper_32_bits(x)) | ||||||
| #define DMA_REGPAIR_LE(x, val)	do { \ | #define DMA_REGPAIR_LE(x, val)	do { \ | ||||||
|  | |||||||
| @ -472,6 +472,7 @@ struct qed_rdma_counters_out_params { | |||||||
| 
 | 
 | ||||||
| enum qed_iwarp_event_type { | enum qed_iwarp_event_type { | ||||||
| 	QED_IWARP_EVENT_MPA_REQUEST,	  /* Passive side request received */ | 	QED_IWARP_EVENT_MPA_REQUEST,	  /* Passive side request received */ | ||||||
|  | 	QED_IWARP_EVENT_PASSIVE_COMPLETE, /* ack on mpa response */ | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| enum qed_tcp_ip_version { | enum qed_tcp_ip_version { | ||||||
| @ -516,6 +517,23 @@ struct qed_iwarp_listen_out { | |||||||
| 	void *handle; | 	void *handle; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | struct qed_iwarp_accept_in { | ||||||
|  | 	void *ep_context; | ||||||
|  | 	void *cb_context; | ||||||
|  | 	struct qed_rdma_qp *qp; | ||||||
|  | 	const void *private_data; | ||||||
|  | 	u16 private_data_len; | ||||||
|  | 	u8 ord; | ||||||
|  | 	u8 ird; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | struct qed_iwarp_reject_in { | ||||||
|  | 	void *ep_context; | ||||||
|  | 	void *cb_context; | ||||||
|  | 	const void *private_data; | ||||||
|  | 	u16 private_data_len; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| struct qed_roce_ll2_header { | struct qed_roce_ll2_header { | ||||||
| 	void *vaddr; | 	void *vaddr; | ||||||
| 	dma_addr_t baddr; | 	dma_addr_t baddr; | ||||||
| @ -626,6 +644,12 @@ struct qed_rdma_ops { | |||||||
| 				   struct qed_iwarp_listen_in *iparams, | 				   struct qed_iwarp_listen_in *iparams, | ||||||
| 				   struct qed_iwarp_listen_out *oparams); | 				   struct qed_iwarp_listen_out *oparams); | ||||||
| 
 | 
 | ||||||
|  | 	int (*iwarp_accept)(void *rdma_cxt, | ||||||
|  | 			    struct qed_iwarp_accept_in *iparams); | ||||||
|  | 
 | ||||||
|  | 	int (*iwarp_reject)(void *rdma_cxt, | ||||||
|  | 			    struct qed_iwarp_reject_in *iparams); | ||||||
|  | 
 | ||||||
| 	int (*iwarp_destroy_listen)(void *rdma_cxt, void *handle); | 	int (*iwarp_destroy_listen)(void *rdma_cxt, void *handle); | ||||||
| 
 | 
 | ||||||
| }; | }; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Kalderon, Michal
						Kalderon, Michal