diff options
author | Mike Christie <michaelc@cs.wisc.edu> | 2013-04-10 12:24:39 -0400 |
---|---|---|
committer | James Bottomley <JBottomley@Parallels.com> | 2013-04-11 19:55:04 -0400 |
commit | 9e45dd73234af9a59613dc2989dcc2df2dab847f (patch) | |
tree | 705342323a3cbf8de94725462407ce4ba734360a | |
parent | 1fc2b00fba55f70ab32ecc493efbca9a1a76a4e3 (diff) |
[SCSI] iscsi_tcp: support PF_MEMALLOC/__GFP_MEMALLOC
This patch has software iscsi use PF_MEMALLOC/__GFP_MEMALLOC
to be able to better support swap over iscsi disks similar to
what was added for nbd.
Signed-off-by: Mike Christie <michaelc@cs.wisc.edu>
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
-rw-r--r-- | drivers/scsi/iscsi_tcp.c | 18 |
1 files changed, 13 insertions, 5 deletions
diff --git a/drivers/scsi/iscsi_tcp.c b/drivers/scsi/iscsi_tcp.c index 1b91ca0dc1e3..9e2588a6881c 100644 --- a/drivers/scsi/iscsi_tcp.c +++ b/drivers/scsi/iscsi_tcp.c | |||
@@ -370,17 +370,24 @@ static inline int iscsi_sw_tcp_xmit_qlen(struct iscsi_conn *conn) | |||
370 | static int iscsi_sw_tcp_pdu_xmit(struct iscsi_task *task) | 370 | static int iscsi_sw_tcp_pdu_xmit(struct iscsi_task *task) |
371 | { | 371 | { |
372 | struct iscsi_conn *conn = task->conn; | 372 | struct iscsi_conn *conn = task->conn; |
373 | int rc; | 373 | unsigned long pflags = current->flags; |
374 | int rc = 0; | ||
375 | |||
376 | current->flags |= PF_MEMALLOC; | ||
374 | 377 | ||
375 | while (iscsi_sw_tcp_xmit_qlen(conn)) { | 378 | while (iscsi_sw_tcp_xmit_qlen(conn)) { |
376 | rc = iscsi_sw_tcp_xmit(conn); | 379 | rc = iscsi_sw_tcp_xmit(conn); |
377 | if (rc == 0) | 380 | if (rc == 0) { |
378 | return -EAGAIN; | 381 | rc = -EAGAIN; |
382 | break; | ||
383 | } | ||
379 | if (rc < 0) | 384 | if (rc < 0) |
380 | return rc; | 385 | break; |
386 | rc = 0; | ||
381 | } | 387 | } |
382 | 388 | ||
383 | return 0; | 389 | tsk_restore_flags(current, pflags, PF_MEMALLOC); |
390 | return rc; | ||
384 | } | 391 | } |
385 | 392 | ||
386 | /* | 393 | /* |
@@ -665,6 +672,7 @@ iscsi_sw_tcp_conn_bind(struct iscsi_cls_session *cls_session, | |||
665 | sk->sk_reuse = SK_CAN_REUSE; | 672 | sk->sk_reuse = SK_CAN_REUSE; |
666 | sk->sk_sndtimeo = 15 * HZ; /* FIXME: make it configurable */ | 673 | sk->sk_sndtimeo = 15 * HZ; /* FIXME: make it configurable */ |
667 | sk->sk_allocation = GFP_ATOMIC; | 674 | sk->sk_allocation = GFP_ATOMIC; |
675 | sk_set_memalloc(sk); | ||
668 | 676 | ||
669 | iscsi_sw_tcp_conn_set_callbacks(conn); | 677 | iscsi_sw_tcp_conn_set_callbacks(conn); |
670 | tcp_sw_conn->sendpage = tcp_sw_conn->sock->ops->sendpage; | 678 | tcp_sw_conn->sendpage = tcp_sw_conn->sock->ops->sendpage; |