diff options
author | Or Gerlitz <ogerlitz@voltaire.com> | 2010-02-08 08:18:39 -0500 |
---|---|---|
committer | Roland Dreier <rolandd@cisco.com> | 2010-02-24 12:41:11 -0500 |
commit | 704315f082d473b34047817f0a6a01924f38501e (patch) | |
tree | c32c2a8e5470679b42d8aa3fae86c56bc9bc8f4c | |
parent | bcc60c381d857ced653e912cbe6121294773e147 (diff) |
IB/iser: Remove atomic counter for posted receive buffers
Now that both the posting and reaping of receive buffers is done in
the completion path, the counter of outstanding buffers not be atomic.
Signed-off-by: Or Gerlitz <ogerlitz@voltaire.com>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
-rw-r--r-- | drivers/infiniband/ulp/iser/iscsi_iser.h | 2 | ||||
-rw-r--r-- | drivers/infiniband/ulp/iser/iser_initiator.c | 6 | ||||
-rw-r--r-- | drivers/infiniband/ulp/iser/iser_verbs.c | 16 |
3 files changed, 12 insertions, 12 deletions
diff --git a/drivers/infiniband/ulp/iser/iscsi_iser.h b/drivers/infiniband/ulp/iser/iscsi_iser.h index 83effb61059..4491235340d 100644 --- a/drivers/infiniband/ulp/iser/iscsi_iser.h +++ b/drivers/infiniband/ulp/iser/iscsi_iser.h | |||
@@ -266,7 +266,7 @@ struct iser_conn { | |||
266 | struct ib_fmr_pool *fmr_pool; /* pool of IB FMRs */ | 266 | struct ib_fmr_pool *fmr_pool; /* pool of IB FMRs */ |
267 | int disc_evt_flag; /* disconn event delivered */ | 267 | int disc_evt_flag; /* disconn event delivered */ |
268 | wait_queue_head_t wait; /* waitq for conn/disconn */ | 268 | wait_queue_head_t wait; /* waitq for conn/disconn */ |
269 | atomic_t post_recv_buf_count; /* posted rx count */ | 269 | int post_recv_buf_count; /* posted rx count */ |
270 | atomic_t post_send_buf_count; /* posted tx count */ | 270 | atomic_t post_send_buf_count; /* posted tx count */ |
271 | char name[ISER_OBJECT_NAME_SIZE]; | 271 | char name[ISER_OBJECT_NAME_SIZE]; |
272 | struct iser_page_vec *page_vec; /* represents SG to fmr maps* | 272 | struct iser_page_vec *page_vec; /* represents SG to fmr maps* |
diff --git a/drivers/infiniband/ulp/iser/iser_initiator.c b/drivers/infiniband/ulp/iser/iser_initiator.c index 6d9bbe6363e..3e65a43d215 100644 --- a/drivers/infiniband/ulp/iser/iser_initiator.c +++ b/drivers/infiniband/ulp/iser/iser_initiator.c | |||
@@ -268,7 +268,7 @@ int iser_conn_set_full_featured_mode(struct iscsi_conn *conn) | |||
268 | 268 | ||
269 | /* Check that there is no posted recv or send buffers left - */ | 269 | /* Check that there is no posted recv or send buffers left - */ |
270 | /* they must be consumed during the login phase */ | 270 | /* they must be consumed during the login phase */ |
271 | BUG_ON(atomic_read(&iser_conn->ib_conn->post_recv_buf_count) != 0); | 271 | BUG_ON(iser_conn->ib_conn->post_recv_buf_count != 0); |
272 | BUG_ON(atomic_read(&iser_conn->ib_conn->post_send_buf_count) != 0); | 272 | BUG_ON(atomic_read(&iser_conn->ib_conn->post_send_buf_count) != 0); |
273 | 273 | ||
274 | if (iser_alloc_rx_descriptors(iser_conn->ib_conn)) | 274 | if (iser_alloc_rx_descriptors(iser_conn->ib_conn)) |
@@ -569,12 +569,12 @@ void iser_rcv_completion(struct iser_rx_desc *rx_desc, | |||
569 | * task eliminates the need to worry on tasks which are completed in * | 569 | * task eliminates the need to worry on tasks which are completed in * |
570 | * parallel to the execution of iser_conn_term. So the code that waits * | 570 | * parallel to the execution of iser_conn_term. So the code that waits * |
571 | * for the posted rx bufs refcount to become zero handles everything */ | 571 | * for the posted rx bufs refcount to become zero handles everything */ |
572 | atomic_dec(&conn->ib_conn->post_recv_buf_count); | 572 | conn->ib_conn->post_recv_buf_count--; |
573 | 573 | ||
574 | if (rx_dma == ib_conn->login_dma) | 574 | if (rx_dma == ib_conn->login_dma) |
575 | return; | 575 | return; |
576 | 576 | ||
577 | outstanding = atomic_read(&ib_conn->post_recv_buf_count); | 577 | outstanding = ib_conn->post_recv_buf_count; |
578 | if (outstanding + ISER_MIN_POSTED_RX <= ISER_QP_MAX_RECV_DTOS) { | 578 | if (outstanding + ISER_MIN_POSTED_RX <= ISER_QP_MAX_RECV_DTOS) { |
579 | count = min(ISER_QP_MAX_RECV_DTOS - outstanding, | 579 | count = min(ISER_QP_MAX_RECV_DTOS - outstanding, |
580 | ISER_MIN_POSTED_RX); | 580 | ISER_MIN_POSTED_RX); |
diff --git a/drivers/infiniband/ulp/iser/iser_verbs.c b/drivers/infiniband/ulp/iser/iser_verbs.c index 89b95604406..202c00dc6a7 100644 --- a/drivers/infiniband/ulp/iser/iser_verbs.c +++ b/drivers/infiniband/ulp/iser/iser_verbs.c | |||
@@ -453,7 +453,7 @@ static void iser_disconnected_handler(struct rdma_cm_id *cma_id) | |||
453 | ISCSI_ERR_CONN_FAILED); | 453 | ISCSI_ERR_CONN_FAILED); |
454 | 454 | ||
455 | /* Complete the termination process if no posts are pending */ | 455 | /* Complete the termination process if no posts are pending */ |
456 | if ((atomic_read(&ib_conn->post_recv_buf_count) == 0) && | 456 | if (ib_conn->post_recv_buf_count == 0 && |
457 | (atomic_read(&ib_conn->post_send_buf_count) == 0)) { | 457 | (atomic_read(&ib_conn->post_send_buf_count) == 0)) { |
458 | ib_conn->state = ISER_CONN_DOWN; | 458 | ib_conn->state = ISER_CONN_DOWN; |
459 | wake_up_interruptible(&ib_conn->wait); | 459 | wake_up_interruptible(&ib_conn->wait); |
@@ -500,7 +500,7 @@ void iser_conn_init(struct iser_conn *ib_conn) | |||
500 | { | 500 | { |
501 | ib_conn->state = ISER_CONN_INIT; | 501 | ib_conn->state = ISER_CONN_INIT; |
502 | init_waitqueue_head(&ib_conn->wait); | 502 | init_waitqueue_head(&ib_conn->wait); |
503 | atomic_set(&ib_conn->post_recv_buf_count, 0); | 503 | ib_conn->post_recv_buf_count = 0; |
504 | atomic_set(&ib_conn->post_send_buf_count, 0); | 504 | atomic_set(&ib_conn->post_send_buf_count, 0); |
505 | atomic_set(&ib_conn->refcount, 1); | 505 | atomic_set(&ib_conn->refcount, 1); |
506 | INIT_LIST_HEAD(&ib_conn->conn_list); | 506 | INIT_LIST_HEAD(&ib_conn->conn_list); |
@@ -651,11 +651,11 @@ int iser_post_recvl(struct iser_conn *ib_conn) | |||
651 | rx_wr.num_sge = 1; | 651 | rx_wr.num_sge = 1; |
652 | rx_wr.next = NULL; | 652 | rx_wr.next = NULL; |
653 | 653 | ||
654 | atomic_inc(&ib_conn->post_recv_buf_count); | 654 | ib_conn->post_recv_buf_count++; |
655 | ib_ret = ib_post_recv(ib_conn->qp, &rx_wr, &rx_wr_failed); | 655 | ib_ret = ib_post_recv(ib_conn->qp, &rx_wr, &rx_wr_failed); |
656 | if (ib_ret) { | 656 | if (ib_ret) { |
657 | iser_err("ib_post_recv failed ret=%d\n", ib_ret); | 657 | iser_err("ib_post_recv failed ret=%d\n", ib_ret); |
658 | atomic_dec(&ib_conn->post_recv_buf_count); | 658 | ib_conn->post_recv_buf_count--; |
659 | } | 659 | } |
660 | return ib_ret; | 660 | return ib_ret; |
661 | } | 661 | } |
@@ -679,11 +679,11 @@ int iser_post_recvm(struct iser_conn *ib_conn, int count) | |||
679 | rx_wr--; | 679 | rx_wr--; |
680 | rx_wr->next = NULL; /* mark end of work requests list */ | 680 | rx_wr->next = NULL; /* mark end of work requests list */ |
681 | 681 | ||
682 | atomic_add(count, &ib_conn->post_recv_buf_count); | 682 | ib_conn->post_recv_buf_count += count; |
683 | ib_ret = ib_post_recv(ib_conn->qp, ib_conn->rx_wr, &rx_wr_failed); | 683 | ib_ret = ib_post_recv(ib_conn->qp, ib_conn->rx_wr, &rx_wr_failed); |
684 | if (ib_ret) { | 684 | if (ib_ret) { |
685 | iser_err("ib_post_recv failed ret=%d\n", ib_ret); | 685 | iser_err("ib_post_recv failed ret=%d\n", ib_ret); |
686 | atomic_sub(count, &ib_conn->post_recv_buf_count); | 686 | ib_conn->post_recv_buf_count -= count; |
687 | } else | 687 | } else |
688 | ib_conn->rx_desc_head = my_rx_head; | 688 | ib_conn->rx_desc_head = my_rx_head; |
689 | return ib_ret; | 689 | return ib_ret; |
@@ -778,14 +778,14 @@ static void iser_handle_comp_error(struct iser_desc *desc, | |||
778 | 778 | ||
779 | if ((char *)desc == ib_conn->login_buf || | 779 | if ((char *)desc == ib_conn->login_buf || |
780 | (rx_first <= rx && rx <= rx_last)) | 780 | (rx_first <= rx && rx <= rx_last)) |
781 | atomic_dec(&ib_conn->post_recv_buf_count); | 781 | ib_conn->post_recv_buf_count--; |
782 | else { /* type is TX control/command/dataout */ | 782 | else { /* type is TX control/command/dataout */ |
783 | if (desc->type == ISCSI_TX_DATAOUT) | 783 | if (desc->type == ISCSI_TX_DATAOUT) |
784 | kmem_cache_free(ig.desc_cache, desc); | 784 | kmem_cache_free(ig.desc_cache, desc); |
785 | atomic_dec(&ib_conn->post_send_buf_count); | 785 | atomic_dec(&ib_conn->post_send_buf_count); |
786 | } | 786 | } |
787 | 787 | ||
788 | if (atomic_read(&ib_conn->post_recv_buf_count) == 0 && | 788 | if (ib_conn->post_recv_buf_count == 0 && |
789 | atomic_read(&ib_conn->post_send_buf_count) == 0) { | 789 | atomic_read(&ib_conn->post_send_buf_count) == 0) { |
790 | /* getting here when the state is UP means that the conn is * | 790 | /* getting here when the state is UP means that the conn is * |
791 | * being terminated asynchronously from the iSCSI layer's * | 791 | * being terminated asynchronously from the iSCSI layer's * |