diff options
-rw-r--r-- | net/rds/ib.h | 24 | ||||
-rw-r--r-- | net/rds/ib_recv.c | 22 | ||||
-rw-r--r-- | net/rds/ib_send.c | 32 |
3 files changed, 23 insertions, 55 deletions
diff --git a/net/rds/ib.h b/net/rds/ib.h index 426035ac54a1..dbf8d6e31493 100644 --- a/net/rds/ib.h +++ b/net/rds/ib.h | |||
@@ -356,28 +356,4 @@ extern unsigned long rds_ib_sysctl_max_recv_allocation; | |||
356 | extern unsigned int rds_ib_sysctl_flow_control; | 356 | extern unsigned int rds_ib_sysctl_flow_control; |
357 | extern ctl_table rds_ib_sysctl_table[]; | 357 | extern ctl_table rds_ib_sysctl_table[]; |
358 | 358 | ||
359 | /* | ||
360 | * Helper functions for getting/setting the header and data SGEs in | ||
361 | * RDS packets (not RDMA) | ||
362 | * | ||
363 | * From version 3.1 onwards, header is in front of data in the sge. | ||
364 | */ | ||
365 | static inline struct ib_sge * | ||
366 | rds_ib_header_sge(struct rds_ib_connection *ic, struct ib_sge *sge) | ||
367 | { | ||
368 | if (ic->conn->c_version > RDS_PROTOCOL_3_0) | ||
369 | return &sge[0]; | ||
370 | else | ||
371 | return &sge[1]; | ||
372 | } | ||
373 | |||
374 | static inline struct ib_sge * | ||
375 | rds_ib_data_sge(struct rds_ib_connection *ic, struct ib_sge *sge) | ||
376 | { | ||
377 | if (ic->conn->c_version > RDS_PROTOCOL_3_0) | ||
378 | return &sge[1]; | ||
379 | else | ||
380 | return &sge[0]; | ||
381 | } | ||
382 | |||
383 | #endif | 359 | #endif |
diff --git a/net/rds/ib_recv.c b/net/rds/ib_recv.c index a68a3a721c6c..e9fe08a86c40 100644 --- a/net/rds/ib_recv.c +++ b/net/rds/ib_recv.c | |||
@@ -95,15 +95,15 @@ void rds_ib_recv_init_ring(struct rds_ib_connection *ic) | |||
95 | recv->r_wr.sg_list = recv->r_sge; | 95 | recv->r_wr.sg_list = recv->r_sge; |
96 | recv->r_wr.num_sge = RDS_IB_RECV_SGE; | 96 | recv->r_wr.num_sge = RDS_IB_RECV_SGE; |
97 | 97 | ||
98 | sge = rds_ib_data_sge(ic, recv->r_sge); | 98 | sge = &recv->r_sge[0]; |
99 | sge->addr = 0; | ||
100 | sge->length = RDS_FRAG_SIZE; | ||
101 | sge->lkey = ic->i_mr->lkey; | ||
102 | |||
103 | sge = rds_ib_header_sge(ic, recv->r_sge); | ||
104 | sge->addr = ic->i_recv_hdrs_dma + (i * sizeof(struct rds_header)); | 99 | sge->addr = ic->i_recv_hdrs_dma + (i * sizeof(struct rds_header)); |
105 | sge->length = sizeof(struct rds_header); | 100 | sge->length = sizeof(struct rds_header); |
106 | sge->lkey = ic->i_mr->lkey; | 101 | sge->lkey = ic->i_mr->lkey; |
102 | |||
103 | sge = &recv->r_sge[1]; | ||
104 | sge->addr = 0; | ||
105 | sge->length = RDS_FRAG_SIZE; | ||
106 | sge->lkey = ic->i_mr->lkey; | ||
107 | } | 107 | } |
108 | } | 108 | } |
109 | 109 | ||
@@ -190,14 +190,14 @@ static int rds_ib_recv_refill_one(struct rds_connection *conn, | |||
190 | recv->r_frag->f_offset = ic->i_frag.f_offset; | 190 | recv->r_frag->f_offset = ic->i_frag.f_offset; |
191 | recv->r_frag->f_mapped = dma_addr; | 191 | recv->r_frag->f_mapped = dma_addr; |
192 | 192 | ||
193 | sge = rds_ib_data_sge(ic, recv->r_sge); | 193 | sge = &recv->r_sge[0]; |
194 | sge->addr = dma_addr; | ||
195 | sge->length = RDS_FRAG_SIZE; | ||
196 | |||
197 | sge = rds_ib_header_sge(ic, recv->r_sge); | ||
198 | sge->addr = ic->i_recv_hdrs_dma + (recv - ic->i_recvs) * sizeof(struct rds_header); | 194 | sge->addr = ic->i_recv_hdrs_dma + (recv - ic->i_recvs) * sizeof(struct rds_header); |
199 | sge->length = sizeof(struct rds_header); | 195 | sge->length = sizeof(struct rds_header); |
200 | 196 | ||
197 | sge = &recv->r_sge[1]; | ||
198 | sge->addr = dma_addr; | ||
199 | sge->length = RDS_FRAG_SIZE; | ||
200 | |||
201 | get_page(recv->r_frag->f_page); | 201 | get_page(recv->r_frag->f_page); |
202 | 202 | ||
203 | if (ic->i_frag.f_offset < RDS_PAGE_LAST_OFF) { | 203 | if (ic->i_frag.f_offset < RDS_PAGE_LAST_OFF) { |
diff --git a/net/rds/ib_send.c b/net/rds/ib_send.c index e86908497fcf..46026d9091f1 100644 --- a/net/rds/ib_send.c +++ b/net/rds/ib_send.c | |||
@@ -156,18 +156,14 @@ void rds_ib_send_init_ring(struct rds_ib_connection *ic) | |||
156 | 156 | ||
157 | send->s_wr.wr_id = i; | 157 | send->s_wr.wr_id = i; |
158 | send->s_wr.sg_list = send->s_sge; | 158 | send->s_wr.sg_list = send->s_sge; |
159 | send->s_wr.num_sge = 1; | ||
160 | send->s_wr.opcode = IB_WR_SEND; | ||
161 | send->s_wr.send_flags = 0; | ||
162 | send->s_wr.ex.imm_data = 0; | 159 | send->s_wr.ex.imm_data = 0; |
163 | 160 | ||
164 | sge = rds_ib_data_sge(ic, send->s_sge); | 161 | sge = &send->s_sge[0]; |
165 | sge->lkey = ic->i_mr->lkey; | ||
166 | |||
167 | sge = rds_ib_header_sge(ic, send->s_sge); | ||
168 | sge->addr = ic->i_send_hdrs_dma + (i * sizeof(struct rds_header)); | 162 | sge->addr = ic->i_send_hdrs_dma + (i * sizeof(struct rds_header)); |
169 | sge->length = sizeof(struct rds_header); | 163 | sge->length = sizeof(struct rds_header); |
170 | sge->lkey = ic->i_mr->lkey; | 164 | sge->lkey = ic->i_mr->lkey; |
165 | |||
166 | send->s_sge[1].lkey = ic->i_mr->lkey; | ||
171 | } | 167 | } |
172 | } | 168 | } |
173 | 169 | ||
@@ -441,28 +437,24 @@ rds_ib_xmit_populate_wr(struct rds_ib_connection *ic, | |||
441 | 437 | ||
442 | send->s_wr.send_flags = send_flags; | 438 | send->s_wr.send_flags = send_flags; |
443 | send->s_wr.opcode = IB_WR_SEND; | 439 | send->s_wr.opcode = IB_WR_SEND; |
444 | send->s_wr.num_sge = 2; | 440 | send->s_wr.num_sge = 1; |
445 | send->s_wr.next = NULL; | 441 | send->s_wr.next = NULL; |
446 | send->s_queued = jiffies; | 442 | send->s_queued = jiffies; |
447 | send->s_op = NULL; | 443 | send->s_op = NULL; |
448 | 444 | ||
445 | sge = &send->s_sge[0]; | ||
446 | sge->addr = ic->i_send_hdrs_dma + (pos * sizeof(struct rds_header)); | ||
447 | sge->length = sizeof(struct rds_header); | ||
448 | sge->lkey = ic->i_mr->lkey; | ||
449 | |||
449 | if (length != 0) { | 450 | if (length != 0) { |
450 | sge = rds_ib_data_sge(ic, send->s_sge); | 451 | send->s_wr.num_sge = 2; |
452 | |||
453 | sge = &send->s_sge[1]; | ||
451 | sge->addr = buffer; | 454 | sge->addr = buffer; |
452 | sge->length = length; | 455 | sge->length = length; |
453 | sge->lkey = ic->i_mr->lkey; | 456 | sge->lkey = ic->i_mr->lkey; |
454 | |||
455 | sge = rds_ib_header_sge(ic, send->s_sge); | ||
456 | } else { | ||
457 | /* We're sending a packet with no payload. There is only | ||
458 | * one SGE */ | ||
459 | send->s_wr.num_sge = 1; | ||
460 | sge = &send->s_sge[0]; | ||
461 | } | 457 | } |
462 | |||
463 | sge->addr = ic->i_send_hdrs_dma + (pos * sizeof(struct rds_header)); | ||
464 | sge->length = sizeof(struct rds_header); | ||
465 | sge->lkey = ic->i_mr->lkey; | ||
466 | } | 458 | } |
467 | 459 | ||
468 | /* | 460 | /* |