|
@@ -40,7 +40,6 @@
|
|
|
#include <linux/export.h>
|
|
|
#include <linux/sizes.h>
|
|
|
|
|
|
-#include "rds_single_path.h"
|
|
|
#include "rds.h"
|
|
|
|
|
|
/* When transmitting messages in rds_send_xmit, we need to emerge from
|
|
@@ -1153,7 +1152,7 @@ out:
|
|
|
* Reply to a ping packet.
|
|
|
*/
|
|
|
int
|
|
|
-rds_send_pong(struct rds_connection *conn, __be16 dport)
|
|
|
+rds_send_pong(struct rds_conn_path *cp, __be16 dport)
|
|
|
{
|
|
|
struct rds_message *rm;
|
|
|
unsigned long flags;
|
|
@@ -1165,31 +1164,32 @@ rds_send_pong(struct rds_connection *conn, __be16 dport)
|
|
|
goto out;
|
|
|
}
|
|
|
|
|
|
- rm->m_daddr = conn->c_faddr;
|
|
|
+ rm->m_daddr = cp->cp_conn->c_faddr;
|
|
|
rm->data.op_active = 1;
|
|
|
|
|
|
- rds_conn_connect_if_down(conn);
|
|
|
+ rds_conn_connect_if_down(cp->cp_conn);
|
|
|
|
|
|
- ret = rds_cong_wait(conn->c_fcong, dport, 1, NULL);
|
|
|
+ ret = rds_cong_wait(cp->cp_conn->c_fcong, dport, 1, NULL);
|
|
|
if (ret)
|
|
|
goto out;
|
|
|
|
|
|
- spin_lock_irqsave(&conn->c_lock, flags);
|
|
|
- list_add_tail(&rm->m_conn_item, &conn->c_send_queue);
|
|
|
+ spin_lock_irqsave(&cp->cp_lock, flags);
|
|
|
+ list_add_tail(&rm->m_conn_item, &cp->cp_send_queue);
|
|
|
set_bit(RDS_MSG_ON_CONN, &rm->m_flags);
|
|
|
rds_message_addref(rm);
|
|
|
- rm->m_inc.i_conn = conn;
|
|
|
+ rm->m_inc.i_conn = cp->cp_conn;
|
|
|
+ rm->m_inc.i_conn_path = cp;
|
|
|
|
|
|
rds_message_populate_header(&rm->m_inc.i_hdr, 0, dport,
|
|
|
- conn->c_next_tx_seq);
|
|
|
- conn->c_next_tx_seq++;
|
|
|
- spin_unlock_irqrestore(&conn->c_lock, flags);
|
|
|
+ cp->cp_next_tx_seq);
|
|
|
+ cp->cp_next_tx_seq++;
|
|
|
+ spin_unlock_irqrestore(&cp->cp_lock, flags);
|
|
|
|
|
|
rds_stats_inc(s_send_queued);
|
|
|
rds_stats_inc(s_send_pong);
|
|
|
|
|
|
/* schedule the send work on rds_wq */
|
|
|
- queue_delayed_work(rds_wq, &conn->c_send_w, 1);
|
|
|
+ queue_delayed_work(rds_wq, &cp->cp_send_w, 1);
|
|
|
|
|
|
rds_message_put(rm);
|
|
|
return 0;
|