Skip to content

Commit 4a4caa2

Browse files
author
Nicholas Bellinger
committed
iscsi-target: Pre-allocate more tags to avoid ack starvation
This patch addresses an traditional iscsi-target fabric ack starvation issue where iscsit_allocate_cmd() -> percpu_ida_alloc_state() ends up hitting slow path percpu-ida code, because iscsit_ack_from_expstatsn() is expected to free ack'ed tags after tag allocation. This is done to take into account the tags waiting to be acknowledged and released in iscsit_ack_from_expstatsn(), but who's number are not directly limited by the CmdSN Window queue_depth being enforced by the target. So that said, this patch bumps up the pre-allocated number of per session tags to: (max(queue_depth, ISCSIT_MIN_TAGS) * 2) + ISCSIT_EXTRA_TAGS for good measure to avoid the percpu_ida_alloc_state() slow path. Cc: <stable@vger.kernel.org> #3.12+ Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
1 parent 49a47f2 commit 4a4caa2

File tree

1 file changed

+1
-1
lines changed

1 file changed

+1
-1
lines changed

drivers/target/iscsi/iscsi_target_nego.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1192,7 +1192,7 @@ int iscsi_target_locate_portal(
11921192
*/
11931193
alloc_tags:
11941194
tag_num = max_t(u32, ISCSIT_MIN_TAGS, queue_depth);
1195-
tag_num += (tag_num / 2) + ISCSIT_EXTRA_TAGS;
1195+
tag_num = (tag_num * 2) + ISCSIT_EXTRA_TAGS;
11961196
tag_size = sizeof(struct iscsi_cmd) + conn->conn_transport->priv_size;
11971197

11981198
ret = transport_alloc_session_tags(sess->se_sess, tag_num, tag_size);

0 commit comments

Comments
 (0)