diff options
author | Simon Derr <simon.derr@bull.net> | 2014-03-10 11:38:50 -0400 |
---|---|---|
committer | Eric Van Hensbergen <ericvh@gmail.com> | 2014-03-25 17:38:12 -0400 |
commit | 3f9d5b8dfdc7b013287caaa847b378912b013f77 (patch) | |
tree | bd10ade4064b26ded527730fd6de195faedb2968 /net/9p | |
parent | afd8d65411551839b7ab14a539d00075b2793451 (diff) |
9pnet_rdma: update request status during send
This will be needed by the flush logic.
Signed-off-by: Simon Derr <simon.derr@bull.net>
Signed-off-by: Eric Van Hensbergen <ericvh@gmail.com>
Diffstat (limited to 'net/9p')
-rw-r--r-- | net/9p/trans_rdma.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/net/9p/trans_rdma.c b/net/9p/trans_rdma.c index f127ae504911..b374c578ddb8 100644 --- a/net/9p/trans_rdma.c +++ b/net/9p/trans_rdma.c | |||
@@ -510,6 +510,11 @@ dont_need_post_recv: | |||
510 | goto send_error; | 510 | goto send_error; |
511 | } | 511 | } |
512 | 512 | ||
513 | /* Mark request as `sent' *before* we actually send it, | ||
514 | * because doing if after could erase the REQ_STATUS_RCVD | ||
515 | * status in case of a very fast reply. | ||
516 | */ | ||
517 | req->status = REQ_STATUS_SENT; | ||
513 | err = ib_post_send(rdma->qp, &wr, &bad_wr); | 518 | err = ib_post_send(rdma->qp, &wr, &bad_wr); |
514 | if (err) | 519 | if (err) |
515 | goto send_error; | 520 | goto send_error; |
@@ -519,6 +524,7 @@ dont_need_post_recv: | |||
519 | 524 | ||
520 | /* Handle errors that happened during or while preparing the send: */ | 525 | /* Handle errors that happened during or while preparing the send: */ |
521 | send_error: | 526 | send_error: |
527 | req->status = REQ_STATUS_ERROR; | ||
522 | kfree(c); | 528 | kfree(c); |
523 | p9_debug(P9_DEBUG_ERROR, "Error %d in rdma_request()\n", err); | 529 | p9_debug(P9_DEBUG_ERROR, "Error %d in rdma_request()\n", err); |
524 | 530 | ||