diff options
Diffstat (limited to 'net/smc/smc_tx.c')
| -rw-r--r-- | net/smc/smc_tx.c | 28 | 
1 files changed, 17 insertions, 11 deletions
| diff --git a/net/smc/smc_tx.c b/net/smc/smc_tx.c index 21ec1832ab51..c48dc2d5fd3a 100644 --- a/net/smc/smc_tx.c +++ b/net/smc/smc_tx.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * Shared Memory Communications over RDMA (SMC-R) and RoCE   * @@ -24,6 +25,8 @@  #include "smc_cdc.h"  #include "smc_tx.h" +#define SMC_TX_WORK_DELAY	HZ +  /***************************** sndbuf producer *******************************/  /* callback implementation for sk.sk_write_space() @@ -174,10 +177,12 @@ int smc_tx_sendmsg(struct smc_sock *smc, struct msghdr *msg, size_t len)  				  copylen, conn->sndbuf_size - tx_cnt_prep);  		chunk_len_sum = chunk_len;  		chunk_off = tx_cnt_prep; +		smc_sndbuf_sync_sg_for_cpu(conn);  		for (chunk = 0; chunk < 2; chunk++) {  			rc = memcpy_from_msg(sndbuf_base + chunk_off,  					     msg, chunk_len);  			if (rc) { +				smc_sndbuf_sync_sg_for_device(conn);  				if (send_done)  					return send_done;  				goto out_err; @@ -192,6 +197,7 @@ int smc_tx_sendmsg(struct smc_sock *smc, struct msghdr *msg, size_t len)  			chunk_len_sum += chunk_len;  			chunk_off = 0; /* modulo offset in send ring buffer */  		} +		smc_sndbuf_sync_sg_for_device(conn);  		/* update cursors */  		smc_curs_add(conn->sndbuf_size, &prep, copylen);  		smc_curs_write(&conn->tx_curs_prep, @@ -277,6 +283,7 @@ static int smc_tx_rdma_writes(struct smc_connection *conn)  	struct smc_link_group *lgr = conn->lgr;  	int to_send, rmbespace;  	struct smc_link *link; +	dma_addr_t dma_addr;  	int num_sges;  	int rc; @@ -334,12 +341,11 @@ static int smc_tx_rdma_writes(struct smc_connection *conn)  		src_len = conn->sndbuf_size - sent.count;  	}  	src_len_sum = src_len; +	dma_addr = sg_dma_address(conn->sndbuf_desc->sgt[SMC_SINGLE_LINK].sgl);  	for (dstchunk = 0; dstchunk < 2; dstchunk++) {  		num_sges = 0;  		for (srcchunk = 0; srcchunk < 2; srcchunk++) { -			sges[srcchunk].addr = -				conn->sndbuf_desc->dma_addr[SMC_SINGLE_LINK] + -				src_off; +			sges[srcchunk].addr = dma_addr + src_off;  			sges[srcchunk].length = src_len;  			sges[srcchunk].lkey = link->roce_pd->local_dma_lkey;  			num_sges++; @@ -391,8 +397,7 @@ int smc_tx_sndbuf_nonempty(struct smc_connection *conn)  	int rc;  	spin_lock_bh(&conn->send_lock); -	rc = smc_cdc_get_free_slot(&conn->lgr->lnk[SMC_SINGLE_LINK], &wr_buf, -				   &pend); +	rc = smc_cdc_get_free_slot(conn, &wr_buf, &pend);  	if (rc < 0) {  		if (rc == -EBUSY) {  			struct smc_sock *smc = @@ -403,7 +408,8 @@ int smc_tx_sndbuf_nonempty(struct smc_connection *conn)  				goto out_unlock;  			}  			rc = 0; -			schedule_work(&conn->tx_work); +			schedule_delayed_work(&conn->tx_work, +					      SMC_TX_WORK_DELAY);  		}  		goto out_unlock;  	} @@ -427,7 +433,7 @@ out_unlock:   */  static void smc_tx_work(struct work_struct *work)  { -	struct smc_connection *conn = container_of(work, +	struct smc_connection *conn = container_of(to_delayed_work(work),  						   struct smc_connection,  						   tx_work);  	struct smc_sock *smc = container_of(conn, struct smc_sock, conn); @@ -460,12 +466,12 @@ void smc_tx_consumer_update(struct smc_connection *conn)  	    ((to_confirm > conn->rmbe_update_limit) &&  	     ((to_confirm > (conn->rmbe_size / 2)) ||  	      conn->local_rx_ctrl.prod_flags.write_blocked))) { -		rc = smc_cdc_get_free_slot(&conn->lgr->lnk[SMC_SINGLE_LINK], -					   &wr_buf, &pend); +		rc = smc_cdc_get_free_slot(conn, &wr_buf, &pend);  		if (!rc)  			rc = smc_cdc_msg_send(conn, wr_buf, pend);  		if (rc < 0) { -			schedule_work(&conn->tx_work); +			schedule_delayed_work(&conn->tx_work, +					      SMC_TX_WORK_DELAY);  			return;  		}  		smc_curs_write(&conn->rx_curs_confirmed, @@ -484,6 +490,6 @@ void smc_tx_consumer_update(struct smc_connection *conn)  void smc_tx_init(struct smc_sock *smc)  {  	smc->sk.sk_write_space = smc_tx_write_space; -	INIT_WORK(&smc->conn.tx_work, smc_tx_work); +	INIT_DELAYED_WORK(&smc->conn.tx_work, smc_tx_work);  	spin_lock_init(&smc->conn.send_lock);  } | 
